WebRTC实现VoiceAgent智能体

今天给大家介绍使用RTCPilot实现基于WebRTC的voice agent。

RTCpilot是基于c++17开发的,跨平台,支持服务集群的WebRTC服务。

什么是voice agent?

一句话定义:实时语音对话AI大模型,跑在 WebRTC 低延迟实时音视频通道上,让用户直接在浏览器 / APP 里,像打电话一样和 AI 自然对话。

Voice Agent主要功能,Voice Agent==语音智能体,

主要功能和特点是:

  • 能听

  • 能想

  • 能说

  • 能实时、全双工、可打断地跟人聊天

也就是在它的回答过程中,你可以打断它的回答,提出新的问题。

它基于WebRTC体系,整个流程:

语音采集 → WebRTC 传输 → 云端实时 ASR → LLM 流式推理 → 流式 TTS → WebRTC 回传 → 播放

RTC Voice Agent在国内云厂商已经非常普及,声网,火山引擎,科大讯飞。他们宣传:

实时语音交互基础设施 + 大模型语音化引擎,

把任意文本大模型快速变成可实时对话的 Voice Agent。

我们使用基于开源的RTC pilot来实现一个完整的voice agent,完全开源实现,可以本地部署,不依赖任何云平台。

在视频连接中,有演示效果:

RTC实现VoiceAgent

RTC Pilot的Voice Agent实现,原来的RTC Pilot是一个WebRTC音视频会议SFU服务,支持跨平台,支持集群部署,本质是一个支持网络高并发的SFU。

但是支持voice agent后,加入音频编解码,加入ASR,文字转语音服务,加入TTS语音转文字服务,一下子系统变成CPU密集型的服务,也就是变成WebRTC MCU服务。

其实ASR,TTS和编解码服务,应该放在单独的MCU服务中,这么实现主要是广大初级网友不知道怎么部署,被迫无奈的实现。

当前的RTCPilot支持voice agent的代码,独立放在voiceagent分支,我还在犹豫是否合入主线,或者如何合入主线。

因为涉及编解码,voiceagent还未支持win11平台,后续也需要改进。

RTCPilot服务端地址:

复制代码
https://github.com/runner365/RTCPilotbranch:voiceagent

RTCPilot客户端地址:

复制代码
https://github.com/runner365/webrtc_js_client

如果你有好的建议,可以在评论区告诉我。

如果觉得对你有帮助,请一键三连,谢谢大家。

相关推荐
metaRTC13 小时前
metaRTC8 成功适配 RTOS:开启 MCU/嵌入式实时音视频新时代
单片机·嵌入式硬件·webrtc·实时音视频·rtos
Fisher3Star19 小时前
mediasoup中ip与announceAddress配置要点
webrtc·sdp
小柯博客2 天前
Amazon Kinesis Video Streams C WebRTC SDK 开发实战
c语言·开发语言·网络·stm32·嵌入式硬件·webrtc·yocto
RTC老炮3 天前
WebRTC下FlexFEC算法架构及原理
网络·算法·音视频·webrtc
换个昵称都难4 天前
webrtc源码下载(2026年4月)
webrtc
牛奶4 天前
不经过服务器,两个人怎么直接通话?
前端·websocket·webrtc
RTC老炮5 天前
音视频FEC前向纠错算法Reed-Solomon原理分析
网络·算法·架构·音视频·webrtc
dualven_in_csdn5 天前
【webrtc】ubuntu 编译中遇到的问题
webrtc
RTC老炮11 天前
RaptorQ前向纠错算法架构分析
网络·算法·架构·webrtc
许彰午12 天前
# 政务远程帮办:WebRTC视频通话+录屏录音+手工拼WAV实录
音视频·webrtc·政务