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

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

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

相关推荐
runner365.git5 小时前
RTCPilot的信令流程
webrtc·音视频开发
runner365.git5 小时前
如何使用RTCPilot配置一个集群RTC服务
webrtc·实时音视频·音视频开发
深念Y1 天前
从WebSocket到WebRTC,豆包级实时语音交互背后的技术演进
websocket·网络协议·实时互动·webrtc·语音识别·实时音视频
AI视觉网奇3 天前
webrtc 硬编码
ffmpeg·webrtc
REDcker3 天前
WebRTC 接收端音频流畅低延迟播放:原理与源码对照(NetEQ / Opus)
音视频·webrtc
SUNNY_SHUN3 天前
LiveKit Agents:基于WebRTC的实时语音视频AI Agent框架(9.9k Star)
人工智能·github·webrtc
Pending4 天前
从 400 行到 40 行:一个 WebRTC 播放器的简洁实现之道
开源·webrtc·前端工程化
CrystalShaw5 天前
WebRTC原生PLC VS SILK之PLC
webrtc
乐鑫科技 Espressif6 天前
亚马逊 KVS WebRTC SDK 适配乐鑫芯片及 ESP RainMaker Camera
人工智能·webrtc·乐鑫科技