`
xujinquan19
  • 浏览: 145506 次
  • 性别: Icon_minigender_1
  • 来自: 广州
社区版块
存档分类
最新评论

浅谈网络语音技术

 
阅读更多

浅谈网络语音技术

      当我们使用像Skype、QQ这样的工具和朋友流畅地进行语音视频聊天时,我们可曾想过其背后有哪些强大的技术在支撑?本文将对网络语音通话所使用到的技术做一些简单的介绍,算是管中窥豹吧。

一.概念模型

      网络语音通话通常是双向的,就模型层面来说,这个双向是对称的。为了简单起见,我们讨论一个方向的通道就可以了。一方说话,另一方则听到声音。看似简单而迅捷,但是其背后的流程却是相当复杂的。我们将其经过的各个主要环节简化成下图所示的概念模型:

    

      这是一个最基础的模型,由五个重要的环节构成:采集、编码、传送、解码、播放。

1.语音采集

      语音采集指的是从麦克风采集音频数据,即声音样本转换成数字信号。其涉及到几个重要的参数:采样频率、采样位数、声道数。

      简单的来说:采样频率,就是在1秒内进行采集动作的次数;采样位数,就是每次采集动作得到的数据长度。

      而一个音频帧的大小就等于:(采样频率×采样位数×声道数×时间)/8。     

      通常一个采样帧的时长为10ms,即每10ms的数据构成一个音频帧。假设:采样率16k、采样位数16bit、声道数1,那么一个10ms的音频帧的大小为:(16000*16*1*0.01)/8 = 320 字节。计算式中的0.01为秒,即10ms。

2.编码

      假设我们将采集到的音频帧不经过编码,而直接发送,那么我们可以计算其所需要的带宽要求,仍以上例:320*100 =32KBytes/s,如果换算为bits/s,则为256kb/s。这是个很大的带宽占用。而通过网络流量监控工具,我们可以发现采用类似QQ等IM软件进行语音通话时,流量为3-5KB/s,这比原始流量小了一个数量级。而这主要得益于音频编码技术。

      所以,在实际的语音通话应用中,编码这个环节是不可缺少的。目前有很多常用的语音编码技术,像G.729、iLBC、AAC、SPEEX等等。

3.网络传送

      当一个音频帧完成编码后,即可通过网络发送给通话的对方。对于语音对话这样Realtime应用,低延迟和平稳是非常重要的,这就要求我们的网络传送非常顺畅。

4.解码

      当对方接收到编码帧后,会对其进行解码,以恢复成为可供声卡直接播放的数据。    

5.语音播放

      完成解码后,即可将得到的音频帧提交给声卡进行播放。

二.实际应用中的难点及解决方案

      如果仅仅依靠上述的技术就能实现一个效果良好的应用于广域网上的语音对话系统,那就没什么太大的必要来撰写此文了。正是有很多现实的因素为上述的概念模型引入了众多挑战,使得网络语音系统的实现不是那么简单,其涉及到很多专业技术。当然,这些挑战大多已经有了成熟的解决方案。首先,我们要为“效果良好”的语音对话系统下个定义,我觉得应该达到如下几点:

(1)低延迟。只有低延迟,才能让通话的双方有很强的Realtime的感觉。当然,这个主要取决于网络的速度和通话双方的物理位置的距离,就单纯软件的角度,优化的可能性很小。

(2)背景噪音小。

(3)声音流畅、没有卡、停顿的感觉。

(4)没有回音。

      下面我们就逐个说说实际网络语音对话系统中额外用到的技术。

 1.回音消除 AEC

      现在大家几乎都已经都习惯了在语音聊天时,直接用PC或笔记本的声音外放功能。殊不知,这个小小的习惯曾为语音技术提出了多大的挑战。当使用外放功能时,扬声器播放的声音会被麦克风再次采集,传回给对方,这样对方就听到了自己的回音。所以,实际应用中,回音消除的功能是必需的。

      在得到采集的音频帧后,在编码之前的这个间隙,是回音消除模块工作的时机。     

    

      其原理简单地来说就是,回音消除模块依据刚播放的音频帧,在采集的音频帧中做一些类似抵消的运算,从而将回声从采集帧中清除掉。这个过程是相当复杂的,而且其还与你聊天时所处的房间的大小、以及你在房间中的位置有关,因为这些信息决定了声波反射的时长。 智能的回音消除模块,能动态调整内部参数,以最佳适应当前的环境。

2.噪声抑制 DENOISE

      噪声抑制又称为降噪处理,是根据语音数据的特点,将属于背景噪音的部分识别出来,并从音频帧中过滤掉。有很多编码器都内置了该功能。

3.抖动缓冲区 JitterBuffer

      抖动缓冲区用于解决网络抖动的问题。所谓网络抖动,就是网络延迟一会大一会小,在这种情况下,即使发送方是定时发送数据包的(比如每100ms发送一个包),而接收方的接收就无法同样定时了,有时一个周期内一个包都接收不到,有时一个周期内接收到好几个包。如此,导致接收方听到的声音就是一卡一卡的。

      JitterBuffer工作于解码器之后,语音播放之前的环节。即语音解码完成后,将解码帧放入JitterBuffer,声卡的播放回调到来时,从JitterBuffer中取出最老的一帧进行播放。     

    

      JitterBuffer的缓冲深度取决于网络抖动的程度,网络抖动越大,缓冲深度越大,播放音频的延迟就越大。所以,JitterBuffer是利用了较高的延迟来换取声音的流畅播放的,因为相比声音一卡一卡来说,稍大一点的延迟但更流畅的效果,其主观体验要更好。

      当然,JitterBuffer的缓冲深度不是一直不变的,而是根据网络抖动程度的变化而动态调整的。当网络恢复到非常平稳通畅时,缓冲深度会非常小,这样因为JitterBuffer而增加的播放延迟就可以忽略不计了。

4.静音检测 VAD

      在语音对话中,要是当一方没有说话时,就不会产生流量就好了。静音检测就是用于这个目的的。静音检测通常也集成在编码模块中。静音检测算法结合前面的噪声抑制算法,可以识别出当前是否有语音输入,如果没有语音输入,就可以编码输出一个特殊的的编码帧(比如长度为0)。

      特别是在多人视频会议中,通常只有一个人在发言,这种情况下,利用静音检测技术而节省带宽还是非常可观的。

5.混音算法

      在多人语音聊天时,我们需要同时播放来自于多个人的语音数据,而声卡播放的缓冲区只有一个,所以,需要将多路语音混合成一路,这就是混音算法要做的事情。即使,你可以想办法绕开混音而让多路声音同时播放,那么对于回音消除的目的而言,也必需混音成一路播放,否则,回音消除最多就只能消除多路声音中的某一路。

      混音可以在客户端进行,也可以在服务端进行(可节省下行的带宽)。如果使用了P2P通道,那么混音就只能在客户端进行了。如果是在客户端混音,通常,混音是播放之前的最后一个环节。

 

      综合上面的概念模型以及现实中用到的网络语音技术,下面我们给出一个完整的模型图:

    

        本文是我们在实现OMCS语音部分功能的一个粗略的经验总结。在这里,我们只是对图中各个环节做了一个最简单的说明,而任何一块深入下去,都可以写成一篇长篇论文甚至是一本书。所以,本文就算是为那些刚刚接触网络语音系统开发的人提供一个入门的地图,给出一些线索。

至此,在网络语音技术基础上再引出视频技术,可以借鉴一些SDK资料,

商用或学习都可以使用的,下载SDK可到CSDN上:

http://dldx.csdn.net/fd.php?i=447645132231776&s=ef991809163c5ef73ba9560d77bc6294

QQ:839788402
分享到:
评论

相关推荐

    浅谈多媒体技术对幼儿语言能力的影响

    浅谈多媒体技术对幼儿语言能力的影响

    浅谈如何实现信息技术类课程的网络教学——以《Python语言》课程为例.zip

    浅谈如何实现信息技术类课程的网络教学——以《Python语言》课程为例

    浅谈如何实现信息技术类课程的网络教学——以《Python语言》课程为例.pdf

    浅谈如何实现信息技术类课程的网络教学——以《Python语言》课程为例.pdf

    浅谈人工智能技术的发展.docx

    浅谈人工智能技术的发展全文共10页,当前为第1页。浅谈人工智能技术的发展全文共10页,当前为第1页。浅谈人工智能技术的发展 浅谈人工智能技术的发展全文共10页,当前为第1页。 浅谈人工智能技术的发展全文共10页,...

    模拟技术中的浅谈网络硬仿真系统的技术的运用

    所谓无线网络,既包括允许用户建立远距离无线连接的全球语音和数据网络,也包括为近距离无线连接进行优化的红外线技术及射频技术,与有线网络的用途十分类似,最大的不同在于传输媒介的不同,利用无线电技术取代网线...

    浅谈网络硬仿真系统的技术的运用

    所谓无线网络,既包括允许用户建立远距离无线连接的语音和数据网络,也包括为近距离无线连接进行优化的红外线技术及射频技术,与有线网络的用途十分类似,的不同在于传输媒介的不同,利用无线电技术取代网线,可以和...

    通信与网络中的浅谈无线网络基础的重要性

    所谓无线网络,既包括允许用户建立远距离无线连接的全球语音和数据网络,也包括为近距离无线连接进行优化的红外线技术及射频技术,与有线网络的用途十分类似,最大的不同在于传输媒介的不同,利用无线电技术取代网线...

    通信与网络中的浅谈基于软交换的下一代广电网络技术

    从发展的角度来看,NGN是从传统的以电路交换为主的PSTN网络中逐渐迈向以分组交换为主,它承载了原有PSTN网络的所有业务,把大量的数据传输卸载到IP网络中以减轻PSTN网络的重荷,又以IP技术的新特性增加和增强了许多...

    浅谈软交换在3G核心网中的应用和引入

    下一代网络泛指一个以IP为中心,可以支持语音、数据和多媒体业务融合全新的网络。3G不是现有移动网和IP网的简单叠加,也不是单项节点技术和网络技术的结合,而是整个网络框架的变革,是一种整体方案。软交换 ...

    浅谈无线网络基础的重要性

    所谓无线网络,既包括允许用户建立远距离无线连接的语音和数据网络,也包括为近距离无线连接进行优化的红外线技术及射频技术,与有线网络的用途十分类似,的不同在于传输媒介的不同,利用无线电技术取代网线,可以和...

    通信与网络中的浅谈提高网络视频会议质量的QoS技术

    随着IP网络与Internet在当今使用得越来越广泛,基于IP网络的视频会议系统也越来越为广大的消费者所接受,在现有企业网内融合语音、视频和数据通信,能为公司缩减大笔商务开支,其中尤以VoIP和视频会议最为重要。...

    浅谈人工智能的现状与未来.txt

    浅谈人工智能的现状与未来 本文对人工智能的发展历程,现状以及发展趋势作一个初步的解读,人工智能应用于工程是是目前工程技术研究的热点之一,本文也将就人工智能中的专家系统、模拟逻辑、神经网络控制在机电一体...

    GSM+GPRS+GPS技术应用论文资料合集80篇.zip

    浅谈GSM网络优化存在问题及解决方法.pdf 简述GSM系统逻辑信道及SDCCH信道.pdf 论述GSM移动网络优化方案探讨.pdf 诺基亚西门子通信帮助GSM运营商突破频谱瓶颈.pdf 远程故障诊断报警系统的设计.pdf

    浅谈NGN网络安全问题

     为了强调IP技术的重要性,业界的主要公司之一思科公司(Cisco Systems)主张称为IP-NGN从意义上讲,NGN是基于TDM的PSTN语音网络和基于IP/ATM的分组网络融合的产物,它使得在新一代网络上语音、视频、数据等综合...

    通信与网络中的浅谈DVR网络化随安防技术发展现状

    它是一套进行图像存储处理的计算机系统,具有对图像/语音进行长时间录像、录音、远程监视和控制的功能,DVR集合了录像机、画面分割器、云台镜头控制、报警控制、网络传输等五种功能于一身,用一台设备就能取代模拟...

    通信与网络中的浅谈PTN技术与IP化移动回传网

     当今电信业务全面IP化的趋势同样体现在移动通信领域,移动通信业务正由以时分复用(TDM)为内核的语音业务向IP化业务为内核的语音、数据等多样业务类型转变。随着3G网络IP化的不断推进、移动数据业务的深入开展,...

    通信与网络中的浅谈NGN网络安全问题

     为了强调IP技术的重要性,业界的主要公司之一思科公司(Cisco Systems)主张称为IP-NGN从意义上讲,NGN是基于TDM的PSTN语音网络和基于IP/ATM的分组网络融合的产物,它使得在新一代网络上语音、视频、数据等综合...

    浅谈提高网络视频会议质量的QoS技术

    随着IP网络与Internet在当今使用得越来越广泛,基于IP网络的视频会议系统也越来越为广大的消费者所接受,在现有企业网内融合语音、视频和数据通信,能为公司缩减大笔商务开支,其中尤以VoIP和视频会议为重要。...

    浅谈AirWisdom网络优化发展现状

     所谓无线网络,既包括允许用户建立远距离无线连接的全球语音和数据网络,也包括为近距离无线连接进行优化的红外线技术及射频技术,与有线网络的用途十分类似,最大的不同在于传输媒介的不同,利用无线电技术取代...

    嵌入式系统/ARM技术中的浅谈视频监控车载化技术方案

     所谓无线网络,既包括允许用户建立远距离无线连接的全球语音和数据网络,也包括为近距离无线连接进行优化的红外线技术及射频技术,与有线网络的用途十分类似,最大的不同在于传输媒介的不同,利用无线电技术取代...

Global site tag (gtag.js) - Google Analytics