Opus低延迟音频编解码器API手册中文翻译.doc
《Opus低延迟音频编解码器API手册中文翻译.doc》由会员分享,可在线阅读,更多相关《Opus低延迟音频编解码器API手册中文翻译.doc(104页珍藏版)》请在咨信网上搜索。
1、H:精品资料建筑精品网原稿ok(删除公文)建筑精品网5未上传百度Opus: IETF低延迟音频编解码器:API和操作手册Opus简介Opus编解码器是专门设计用于互联网的交互式语音和音频传输。它是由IETF的编解码器工作组设计的, 合并了Skype的SILK和Xiph. Org的CELT技术。Opus编解码器的设计目的是处理广泛的交互式音频应用程序,包括IP语音,视频,游戏内聊天,甚至远程现场音乐表演。它能够适用于从低码率窄带语音到非常高质量的立体声音乐。它的主要特点是: 采样率从8至48 kHz 比特率从6kb/s到510kb/s 对固定码率(CBR)和可变码率(VBR)都能支持 从窄带到宽
2、带的音频带宽 支持语音和音乐 支持单声道和立体声 支持多通道(最多255通道) 帧规格从2.5毫秒到60毫秒 良好的损失鲁棒性和包丢失隐藏性(PLC)( 注: 应是指丢包也不容易被发现) 浮点和定点执行文档包括: Opus Encoder Opus Decoder Repacketizer Opus Multistream API Opus library information functions Opus Custom Opus Encoder 本节描述了Opus编码器OpusEncoder的过程和函数类型定义typedef struct OpusEncoderOpusEncoderOpu
3、s encoder 状态. 函数intopus_encoder_get_size (int channels)获得 OpusEncoder结构的大小OpusEncoder *opus_encoder_create (opus_int32 Fs, int channels, int application, int *error)分配和初始化 encoder状态. intopus_encoder_init (OpusEncoder *st, opus_int32 Fs, int channels, int application)初始化一个以前分配的编码器状态。所指向的内存圣必须至少是opus_
4、encoder_get_size()返回的大小. opus_int32opus_encode (OpusEncoder *st, const opus_int16 *pcm, int frame_size, unsigned char *data, opus_int32 max_data_bytes)对一个 Opus帧进行编码. opus_int32opus_encode_float (OpusEncoder *st, const float *pcm, int frame_size, unsigned char *data, opus_int32 max_data_bytes)根据浮点输入对
5、一个 Opus帧进行编码. voidopus_encoder_destroy (OpusEncoder *st)释放一个根据opus_encoder_create()已分配的OpusEncoder 对象。 intopus_encoder_ctl (OpusEncoder *st, int request,.)向一个Opus编码器执行一个 CTL 函数. 详细描述本节描述了用于编码Opus的过程和函数。既然Opus是一个有状态的编解码器, 编码过程始于创立一个编码器状态, 用以下方法做到: int error;OpusEncoder *enc;enc = opus_encoder_create(
6、Fs, channels, application, &error);从这一点上, enc能够用于编码音频流。一个编码器状态在同一时间不得用于多于一个音频流。同样,编码器状态不能对于每帧重新初始化。当opus_encoder_create()为状态分配内存时, 它也能够初始化预分配的内存: int size;int error;OpusEncoder *enc;size = opus_encoder_get_size(channels);enc = malloc(size);error = opus_encoder_init(enc, Fs, channels, application);op
7、us_encoder_get_size()返回编码器状态要求的大小。注意,这段代码的未来版本可能改变大小,因此没有assuptions应该对它做出。编码器状态在内存中总是连续,复制它只要一个浅拷贝就足够了。使用opus_encoder_ctl()接口能够改变一些编码器的参数设置。所有这些参数都已有缺省值, 因此只在必要的情况下改变它们。最常见的参数设置修改是: opus_encoder_ctl(enc, OPUS_SET_BITRATE(bitrate);opus_encoder_ctl(enc, OPUS_SET_COMPLEXITY(complexity);opus_encoder_ctl
8、(enc, OPUS_SET_SIGNAL(signal_type);在这里: bitrate( 比特率) 的单位是比特/秒(b / s) complexity( 复杂性) 是一个值从1到10,1最低, 10最高, 值越大越复杂 signal_type( 信号的类型) 包括OPUS_AUTO (缺省), OPUS_SIGNAL_VOICE, or OPUS_SIGNAL_MUSIC。看Encoder related CTLs 和 Generic CTLs能够获得可设置和查询的参数详细清单。在一个音频流处理过程中, 大多数参数能够设置或修改。为了对一个帧进行编码, 必须正确地用音频数据的帧(2.
9、5, 5, 10, 20, 40 或60 毫秒)来调用opus_encode() 或opus_encode_float()函数。len = opus_encode(enc, audio_frame, frame_size, packet, max_packet);在这里: l audio_frame( 音频帧) 是opus_int16(或用于opus_encode_float()的浮点)格式的音频数据l frame_size( 帧大小) 是样本中帧的最大数(每个通道)l packet( 包) 是写成压缩数据的字节数组, l max_packet是能够写入包的字节数的最大值推荐(4000字节)。
10、不要使用max_packet控制VBR的目标比特率,而应该用OPUS_SET_BITRATE CTL。opus_encode() 和opus_encode_float()返回实际写入包的字节数。返回值能够是负数,这表明一个错误已经发生。如果返回值是1个字节,那么包不需要传播(DTX)。一旦一个编码器状态已不再需要, 能够用以下方式解构: opus_encoder_destroy(enc);如果编码器是用opus_encoder_init() 创立的, 而不是使用opus_encoder_create()函数, 那么不需要采取行动, 要求从潜在的释放为它手动分配的内存(上述例子是调用 free(
11、enc)中分离。类型定义文档typedef struct OpusEncoder OpusEncoderOpus编码器状态。这包含了一个Opus编码器的完整状态。它是位置独立的, 而且能够自由复制。函数文档opus_int32 opus_encode ( OpusEncoder * st,const opus_int16 * pcm,int frame_size,unsigned char * data,opus_int32 max_data_bytes ) 对一个Opus帧进行编码。参数: instOpusEncoder*:编码器状态inpcmopus_int16*: 输入信号(如果是2 通
12、道有交叉). 长度是 frame_size*channels*sizeof(opus_int16)inframe_sizeint:输入信号的每通道样本数. 这必须是编码器采样率的Opus帧大小。比如, 48 kHz 下允许值有120, 240, 480, 960, 1920, 和 2880。少于10毫秒的采样( 48 kHz 有480个样本) , 将阻止编码器使用LPC或混合模式。outdataunsigned char*: 输出负载。必须包含至少max_data_bytes 的容量。inmax_data_bytesopus_int32: 为输出负载所分配的内存大小。能够用于限制固定比特率的最
13、大上限, 但不能用作唯一的比特率限制, 能够用OPUS_SET_BITRATE来控制比特率。返回值: 成功, 是被编码包的长度( 字节数) , 失败, 一个负的错误代码opus_int32 opus_encode_float ( OpusEncoder * st,const float * pcm,int frame_size,unsigned char * data,opus_int32 max_data_bytes ) 根据浮点输入对一个 Opus帧进行编码.参数: instOpusEncoder*:编码器状态inpcmfloat*:浮点格式的输入(如果是2 通道有交叉), 正常范围在+/
14、-1.0之间. 超过该范围的采样也是支持的, 但它将被解码器用整型API截取, 而且只能在知道远端支持扩展的动态范围的情况下使用。长度是 frame_size*channels*sizeof(float) inframe_sizeint: 输入信号的每通道样本数. 这必须是编码器采样率的Opus帧大小。比如, 48 kHz 下允许值有120, 240, 480, 960, 1920, 和 2880。少于10毫秒的采样( 48 kHz 有480个样本) , 将阻止编码器使用LPC或混合模式。outdataunsigned char*:输出负载。必须包含至少max_data_bytes 的容量。i
15、nmax_data_bytesopus_int32: 为输出负载所分配的内存大小。能够用于限制固定比特率的最大上限, 但不能用作唯一的比特率限制, 能够用OPUS_SET_BITRATE来控制比特率。.返回值: 成功, 是被编码包的长度( 字节数) , 失败, 一个负的错误代码。OpusEncoder* opus_encoder_create ( opus_int32 Fs,int channels,int application,int * error ) 分配和初始化一个编码器状态。包括三种编码模式: OPUS_APPLICATION_VOIP: 在给定比特率条件下为声音信号提供最高质量,
16、 它经过高通滤波和强调共振峰和谐波增强了输入信号。它包括带内前向错误检查以预防包丢失。典型的VOIP应用程序使用这种模式。由于进行了增强, 即使是高比特率的情况下, 输出的声音与输入相比, 听起来可能不一样。OPUS_APPLICATION_AUDIO: 对大多数非语音信号, 如音乐, 在给定比特率条件下提供了最高的质量。使用这种模式的场合包括音乐、 混音(音乐/声音),广播,和需要不到15 毫秒的信号延迟的其它应用。OPUS_APPLICATION_RESTRICTED_LOWDELAY: 配置低延迟模式将为减少延迟禁用语音优化模式。这种模式只能在刚初始化或刚重设编码器的情况下使用, 因为在
17、这些情况下编解码器的延迟被修改了。( 当心! ) 当调用者知道语音优化模式不再需要时, 配置低延迟模式是有用的。参数: inFsopus_int32: 输入信号的采样率 (Hz), 必须是8000、 1 、 16000、 24000、 或48000。inchannelsint:输入信号的通道数 (1 or 2) 。inapplicationint:编码模式(OPUS_APPLICATION_VOIP/OPUS_APPLICATION_AUDIO/OPUS_APPLICATION_RESTRICTED_LOWDELAY)outerrorint*: 错误代码注意: 无论选择什么样的采样率和通道数,
18、 如果选择的比特率太低, Opus编码器能够切换到一个较低的音频带宽或通道数。这也意味着总是使用48 kHz立体声输入和让编码器优化编码是安全的。int opus_encoder_ctl ( OpusEncoder * st,int request, . ) 向一个Opus编码器执行一个 CTL 函数.一般其请求和后续的参数是由一个提供便利的宏来产生的。参数: stOpusEncoder*: 编码器状态 request int: 这个及所有其它参数应被1个在Generic CTLs 或Encoder related CTLs所提供便利的宏来替代参见: Generic CTLs Encoder
19、related CTLsvoid opus_encoder_destroy ( OpusEncoder * st) Frees an OpusEncoder allocated by opus_encoder_create().释放一个根据opus_encoder_create()已分配的OpusEncoder 对象。参数: instOpusEncoder*: 用于释放的编码器状态。int opus_encoder_get_size ( int channels) 获得 OpusEncoder结构的大小。参数: inchannelsint: 通道数, 必须是1或2.返回: 字节数的大小.int
20、 opus_encoder_init ( OpusEncoder * st,opus_int32 Fs,int channels,int application ) 初始化一个以前分配的编码器状态。状态所指向的内存必须至少是opus_encoder_get_size()返回的大小.在这里, 应用程序不要用系统自动分配内存, 而要准备用自己的分配器。参见: opus_encoder_create(),opus_encoder_get_size()。为重设一个以前初始化的状态, 使用OPUS_RESET_STATE CTL.参数: instOpusEncoder*: 编码器状态 inFsopus_
21、int32: 输入信号的采样率 (Hz), 必须是8000、 1 、 16000、 24000、 或48000。 inchannelsint: 输入信号的通道数 (1 or 2) inapplicationint: 编码模式(OPUS_APPLICATION_VOIP/OPUS_APPLICATION_AUDIO/OPUS_APPLICATION_RESTRICTED_LOWDELAY)返回值: 成功, OPUS_OK, 失败, 错误代码。Opus Decoder 本节描述了Opus解码器OpusDecoder的过程和函数类型定义typedef struct OpusDecoderOpusDe
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- Opus 延迟 音频 编解码器 API 手册 中文翻译
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【天****】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【天****】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。