一种语音编码选择性加密方法

文档序号:2837086阅读:998来源:国知局

专利名称::一种语音编码选择性加密方法
技术领域
:本发明涉及语音编码
技术领域
。尤其是涉及一种语音编码选择性加密方法,特别是涉及G.729语音编码的选择性加密方法。
背景技术
:随着通信业务需求的飞速增长,为了保证通信业务数据的传输,人们大力开展各种数据压縮技术的研究工作。而语音信号的压縮数字化传输,是多年以来人们一直努力的方向。现有技术一般采用低速率语音编码技术进行语音传输。低速率语音编码是在尽量减少失真的情况下,降低编码速率,以便减小传输时所占用的带宽。其相比较于模拟传输,—可以节省带宽,便于实现与互联网(InternetProtocol,IP)的融合。G.729是国际电信联盟(InternationalTelecommunicationUnion,ITU)为低码率多媒体通信制定的语音编码标准。该语音编码方案是ITU-TH.324标准系列的组成部分,能够以非常低的码率压縮语音或多媒体设备的其它音频信号分量,G.729语音信号的采样频率为8kHz,帧长10ms。G.729采用了共轭结构代数码激励线性预测(Conjugate-SstructureAlgebraic-Code-ExcitedLinear-Prediction,CS-ACELP)算法,它是基于码激励线性预测(Code-ExcitedLinear-Predictive,CELP)的编码技术,每80个样点为一个语音帧,根据语音信号的数学模型,综合利用线性预测编码(LinearPredictiveCoding,LPC)、合成分丰斤》去(Analysis-By-Synthesis,ABS)、矢量量化(VectorQuantizer,VQ)以及感知加权(PerceptualWeighting)等技术,对语音信号分析并提取各种参数(线性预测滤波器系数、自适应码本(Adaptivecodebook)和固定码本(Fixedcodebook)中的码本索引、自适应码本矢量增益和固定码本矢量增益),把这些参数编码发送。解码端把收到的比特流恢复成参数编码,解码得到各个参数,用自适应码本索引从自适应码本中得到自适应码矢量,用固定码本索引从固定码本中得到固定码矢量,分别乘以它们的增益,按点相加后构成激励序列。用线性预测滤波器系数构成合成滤波器,用自适应码本方法实现长时或基音合成滤波,计算出合成语音后,用后置滤波器进一步增强音质。如图1所示,为G.729编码原理图。输入信号先经过高通滤波预处理,处理之后形成的语音信号作为后续分析的"输入信号"。信号预测分析每帧进行一次线性预测(LinearPredictive,LP)分析,计算LP滤波器系数,这些参数转换为线谱对(LineSpectrumPairs,LSP),由于它是频域参数,所以和语音信号谱包络的峰有更紧密地联系,同时用LSP参数构成合成滤波器容易保证稳定性,且LSP具有误差相对性,即某个频率点上的LSP偏差只对该频率附近的语音产生影响。对LSP参数的量化,采用两级预测分裂式矢量量化,用一个4阶滑动平均(MovingAverage,MA)预测器预测当前帧的LSP系数计算值和预测值差值,用两级VQ量化。第一级LSP矢量维数为10维,用7比特编码;第二级的量化输入,是第一级量化器的量化输出与其输入的差,其输出分裂为两个5维码本L2,L3,每个码本用5比特编码。激励信号用合成分析法(ABS)搜索,以原始语音与合成语音的误差感知加权最小为测度进行搜索。该过程是将误差信号通过一个感觉加权滤波器,感知加权滤波器用未量化的LP系数构造而成。激励参数,包括固定码本(Fixedcodebook)和自适应码本(Adaptivecodebook),每子帧(5ms,40个样点)计算一次。量化的和未量化的LP滤波器系数用于第二子帧,而在第一子帧使用内插(Interpolated)的LP系数,根据感知加权语音信号每帧(10ms,80个样点)估计一次开环基音延时。每个子帧都重复进行操作。目标信号通过加权合成滤波器滤过的LP残差计算得到。由LP残差和激励之间误差滤波修改这些滤波器的初始状态,这等效于从加权语音信号中减去加权合成滤波器的零输入响应。计算加权合成滤波器的脉冲响应,然后用目标信号和脉冲响应搜索开环基音延时附近的值作闭环基音分析(即寻找自适应码本延时和增益),分数基音延时(FractionalPitchDelay,FPD)分辨率1/3样点间隔,在第一子帧用8bits基音时延编码,在第二子帧用5bits编码,从目标信号中减去自适应码本的贡献。新的目标信号用于固定码本搜索寻找最佳激励,17bitS的代数码本用于固定码本编码。自适应码本和固定码本的增益用7bitS组合矢量量化。自适应码本和固定码本增益用两级共轭结构的码本来进行矢量量化。固定码本增益可以表示为gC:YgC',其中gC'是基于以前的固定码本能量的预测增益,Y是校正系数。自适应码本增益gp和校正系数Y,是使用两级共轭结构码本量化的矢量。"共轭"是指每一个输入矢量被量化为两个码本的线性合成。第一级包含一个3比特的二维码本GA,第二级包含一个4比特的二维码本GB。每个码本的第一个元素,代表量化自适应码本增益的一部分,第二个元素代表固定码本增益校正系数的一部分。如图2所示,为G.729解码原理图,首先,从接收到的比特流中提取出参数索引,解码这些参数索引得到10ms语音帧对应的编码参数,包括LSP系数、2个分数基音时延、2个固定码本矢量、2个自适应和固定码本增益。每一子帧的LSP系数被插值,并变换为LP滤波器系数。然后对每一个5ms子帧,进行以下操作1、重建激励信号将自适应码本和固定码本矢量(分别和各自的增益相乘)相加。2、重建语音信号将激励信号通过LP合成滤波器滤波。3、后处理重建语音信号依次通过自适应后置滤波器(包括长时和短时合成滤波器)、高通滤波器,最后定标。由以上过程可知,被编码器处理后的一帧信号需传输的参数有声道参数LSP参数,用以在解码端构造LPC合成滤波器;激励参数——基音周期与长时预测增益,随机码本的脉冲位置和增益。传统的语音编码加密方法都是对G.729压縮语音流整体进行加密。然而与文本消息相比,语音流数据量大,实时性要求高,直接用传统加密算法如AES(AdvancedEncryptionStandard)、3DES(3DataEncryptionStandard)算法等对其进行整体加密,会引起明显的时延,降低其实时性性能。不仅如此,它还会显著增加系统的运算负荷,占用更多资源,消耗更多能源。这在许多场合,诸如移动通信等对低能耗十分苛求的情况下,是无法忍受的。另外,对语音数据流进行整体加密,不方便满足不同等级的业务需求。
发明内容本发明所要解决的问题在于提供一种语音编码选择性加密方法,其按安全等级选择需要加密的G.729语音编码帧的比特位。为实现本发明而提供的一种语音编码选择性加密方法,包括下列歩骤步骤A,首先进行初始化,选择加密所需安全等级,确定流加密方法的初始值和调节参数;步骤B,按照安全等级确定选用的比特位置表,即确定要加密的具体的比特位,利用所述流加密方法执行加密操作。所述的语音编码选择性加密方法,还可以包括下列步骤歩骤C,解密方接到加密数据后,首先进行初始化,然后执行解密操作。所述步骤A包括下列步骤步骤A1,用户选择加密所需的安全等级;步骤A2,确定混沌流加密方法的初始值和调节参数;步骤A3,取调节参数中的初始值的有效二进制位,转换字节型数据,将转换的数据存入一数组作为密钥流表,此密钥流表将用以和语音数据流明文要加密的位进行异或运算,以获得密文。所述歩骤B包括下列步骤步骤B1,按照安全等级确定选用的比特位置表;步骤B2,在按照安全等级确定选用的比特位置表后,执行当前帧的加密操作;歩骤B3,完成当前帧的加密操作后,如果密钥流使用完,利用所述混沌流加密方法中的调节参数对当前混沌序列值进行迭代,得到新的密钥流,更新密钥流表;如果还有语音帧,则转回步骤B2,转而处理下一帧,如果没有语音帧,加密结束。所述步骤C包括下列步骤步骤C1,接收控制参数得到加密安全等级,并得到混沌流加密方法的初始值和调节参数;步骤C2,取初始值的有效二进制位,转换为字节型数据,将转换的数据存入字节型数组作为密钥流表,此密钥流表将用以和语音数据流密文加密的位进行异或运算,以获得明文;步骤C3,按照安全等级确定选用的比特位置表;步骤C4,执行当前帧的解密操作;歩骤C5,完成当前帧的解密操作后,如果密钥流使用完,利用调节参数对当前混沌序列值进行迭代,得到新的密钥流,更新密钥流表;如果还有语音帧,则转回步骤C4,转而处理下一帧,如果没有语音帧,解密结束。所述的流加密方法为混沌流加密方法。所述混沌流加密方法为改进的Logistics映射的一维非线性迭代方法表征的混沌流加密方法,所述迭代方法如下式所示G(x)=((3+l)(l+l/(3)px(l-x)p其中,pe(1,4),x。e(0,1),x的初始值为x。,通过此式迭代可以得到X',X2,X3,...Xn...o所述步骤B中,按加密所需的安全等级确定选用的比特位置表,为按照G.729标准语音帧中各参数对重建语音的作用以及重要性的不同,将比特位分为不同类别,加密不同类别的比特位获得不同安全等级或效果。所述语音帧中参数的比特位的分类有以下两种模式第一,以保密性以及效率为首要目标,以加密尽可能少的位获得尽可能好的保密性,旨在降低话音可懂度。划分为六个安全等级。安全等级一,加密语音帧中的20比特位;安全等级二,加密语音帧中的21比特位;安全等级三,加密语音帧中的22比特位;安全等级四,加密语音帧中的23比特位;安全等级五,加密语音帧中的24比特位;安全等级六,加密语音帧中的36比特位;第二,以可能出现的业务需求为目标进行考虑。提出以下方案安全等级七,模糊语音性别(即通过听语音无法准确判断原说话人的性别,可以听懂语义,但听不出是男声还是女声)选择需加密的比特位;安全等级八,减小通话/非通话期的区别选择需加密的比特位;实际应用中,可根据具体需要对以上安全等级进行组合使用。本发明的有益效果是本发明的语音编码选择性加密方法,一方面能够提高语音通话的实时性。其对语音帧进行选择性加密,在帧内,按安全等级的需要,对那些敏感性高(即对重建语音影响大)的比特位进行加密,与传统的对语音媒体内容进行整体加密相比,这无疑加快加密速度,提高效率;另一方面,其能够降低系统能耗,减少对资源的占用。降低能耗在一些能源资源十分紧张的应用环境中,如无线通信领域中其移动设备携带能量有限,是非常关键的问题,减少对资源的占用,也可减轻网络处理节点的负荷。进一步地,其能够便于满足不同等级的业务需求。选择性加密不仅仅可以从技术上满足更好的需求,它在许多互联网的业务中,也有实际的应用价值。比如,提供各类音频服务的网站,其语音材料可以以不同的加密强度提供给用户,如果是免费提供给用户试听,可以对语音采取某种低强度的加密,以进行模糊处理,再如,在可以理解语音内容的情况下,使语音性别无法辨认。诸如此类的许多应用,总之,选择性加密为不同等级的业务需求提供了可行性与良好的技术支持。图1为现有技术G.729标准语音帧的语音编码原理图2为现有技术G.729标准语音帧的语音解码原理图3为本发明安全等级一中语音帧中需要加密的20比特位;图4为本发明安全等级二中语音帧中需要加密的21比特位;图5为本发明安全等级三中语音帧中需要加密的22比特位;图6为本发明安全等级四中语音帧中需要加密的23比特位;图7为本发明安全等级五中语音帧中需要加密的24比特位;图8为本发明安全等级六中语音帧中需要加密的36比特位;图9为本发明安全等级七中模糊语音性别需要加密的比特位;图10为本发明安全等级八中减小通话/非通话期的区别需要加密的比特位;图11为本发明语音编码选择性加解密方法流程图12为本发明语音编码选择性加密中步骤S100初始化方法流程图;图13为本发明语音编码选择性加密中步骤S200具体加密操作方法流程图14为本发明语音编码选择性加密中步骤S300解密方法流程图;图15为安全等级7时G.729标准语音帧第1字节加密过程示意图;图16为安全等级7时G.729标准语音帧第8字节加密过程示意图;图17为安全等级7时G.729标准语音帧第9字节加密过程示意图;图18为安全等级7时G.729标准语音帧第10字节加密过程示意图。具体实施例方式为了使本发明的目的、技术方案及优点更加清楚明白,以下结合附图及实施例,对本发明的一种语音编码选择性加密方法进行进一步详细说明。应当理解,此处所描述的具体实施例仅仅用以解释本发明,并不用于限定本发明。一般地,在对语音加密效果的衡量标准中,包括客观和主观评测两方面,但对于低速率的窄带压縮语音信号,客观评测的参数如信噪比等,很难真正反映其表现性能,而主观评测更贴近实际情况,所以通常更注重主观评测。主观评测上的几个主要衡量标准即包括以下几点1、语音可理解性(语义)2、语音的性别判断3、明文攻击4、静音/非静音的区分这也就是在语音的主观评测上希望达到的标准,也就是说,本发明实施例中,应当通过加密,使人在听过语音后不可再做出关于以上几点的有效的分辨行为。需要说明的是,以上四个标准相当于加密安全强度最高的要求。本发明实施例中不同的安全等级得到的加密效果不一样,并不是都可以满足以上四个标准,并且本发明中的方法是对加密的效率和安全强度的一种折中,在两者间寻求一个平衡点。以上标准仅仅是一个我们希望达到的总的标准与原则,与本发明的安全等级等等没有直接关联联系,也没有先后排序。数字语音、图像以及视频压縮数据流都有一个特性,即感官上的不均衡重要性(nonuniformperceptualimportance),也就是说,数据流中一部分位上发生的错误比在其他位上发生的错误所带来的影响要显著的多。因此,不同于加密整个多媒体流,本发明语音编码选择性加密方法,采用一种选择性加密方法,与传统加密方法中加密所有数据的做法不一样,选择性加密方法仅对一部分对感知影响更为重大的比特位进行加密,而剩余的部分则直接不加保护的在信道中传输,即通过保持加密后数据格式信息和控制信息不变,只加密部分实际数据,从而保持加密后数据流的相容性,其在确保所需安全强度的情况下,降低运算负荷,也就节省了更多的资源、能耗,传输速度得到了很大的提高,在实时性方面也就有了更好的表现,能够满足实时性要求。选择性加密方法要求与具体的数据格式相结合,根据安全性水平要求的不同,选择加密不同的敏感数据,从而满足不同的需求,本发明实施例以G.729语音编码的选择性加密来说明本发明的语音编码选择性加密方法,但是本发明并不限定于只适用于G.729语音编码,其同样可以适用于其它标准的语音编码。如图11所示,其中,图11为本发明语音编码选择性加解密方法流程图。下面详细说明本发明的一种语音编码选择性加密方法步骤S100,首先进行初始化,选择加密所需安全等级,确定加密迭代方法的初始值和调节参数;如图12所示,其具体包括如下步骤步骤S110,用户选择加密所需的安全等级;步骤S120,确定改进的Logistics映射的一维非线性迭代方法表征混沌流加密方法的初始值xo和调节参数(3;用户选择这两个参数xo和p,此两个参数即相当于密钥。x。在01之间取值,(3在1..,4之间取值,对小数点后的位数没有要求,较佳地,鉴于计算机可处理的位数,两个参数在小数点后取不超过10位。本发明实施例举例说明,所述两个参数为取值X(r0.31234567,P=2.5。同时,需要说明的是,可以在操作系统为WindowsXp、VC编程环境中,将此两个参数存储为双精度浮点数类型,以便于选取64位有效二进制位。步骤S130,取初始值x。的小数点后的64位有效二进制位,转换为8个字节型(byte)数据,将转换的数组存入一数组作为密钥流表,此密钥流表将用以和语音数据流明文要加密的位进行异或运算,以获得密文。所述转换为现有技术,其将64个二进制位分为8组,每一组8个比特位刚好形成一个字节型数据;所述密钥流表为将转换的数据存入一长度为8的字节型(byte)型数组keyList[]得到,其用以和语音数据流明文要加密的位进行异或运算,以获得密文。步骤S200,按照安全等级确定选用的加密比特位置表,执行加密操作。在语音编码加密的过程中,用户在选择加密所需安全等级后,就要根据具体的加密对象G.729的语音编码的格式特点,选择确定需要加密的语音编码的比特位。如图13所示,具体包括如下步骤步骤S210,首先按照安全等级确定选用的加密比特位置表。步骤S220,在按照安全等级确定选用的比特位置表后,执行当前帧的具体加密操作。步骤230,完成当前帧的加密操作后,如果密钥流使用完,利用所述混沌流加密方法中的调节参数对当前混沌序列值进行迭代,得到新的密钥流,更新密钥流表;如果还有语音帧,则转回歩骤220,转而处理下一帧,如果没有语音帧,加密结束。进一步地,还可以包括下列步骤步骤S300,解密方接到加密数据后,首先进行初始化,然后执行解密操作。如图14所示,具体包括如下步骤歩骤S310,接收控制参数,得到加密安全等级,并得到混沌流加密方法的初始值x。和调节参数(3;步骤S320,取x。的小数点后的64位有效二进制位,转换为8个byte型数据,将转换的数据存入一长度为8的byte型数组keyList[]作为密钥流表,用以和语音数据流密文中加密的位进行异或运算,以获得明文;歩骤S330,按照安全等级确定选用的加密比特位置表。步骤S340,在按照安全等级确定选用的比特位置表后,执行当前帧的具体解密操作;步骤S350,完成当前帧的解密操作后,如果密钥流使用完,利用调节参数对当前混沌序列值进行迭代,得到新的密钥流,更新密钥流表;如果还有语音帧,则转回步骤S340,转而处理下一帧,如果没有语音帧,解密结束。执行本发明选择性加密方法的具体解密流程,与执行加密操作流程相对应,本领域的技术人员可以根据本发明具体实施例所描述的加密过程而完成解密过程,因此,在本发明实施例中,不再一一进行详细描述。下面详细说明步骤S120中确定改进的Logistics映射的一维非线性迭代方法表征的混沌流加密方法的调节参数xo和(3的具体方法过程较佳地,综合考虑选择性加密的特点、效率以及安全性,本发明实施例中采用混沌流加密算法,但异或操作不以比特位为单位,而是以字节为单位,且对混沌密钥流的使用进行改进,结合对G.729帧结构所选择的需要加密部分位置的特点,可以适当地对混沌密钥流进行重复使用,而不十分影响其安全性能,从而提高效率。流加密的优点是错误扩展小、实时性高,其保密度取决于密钥发生器产生的密钥序列的随机性,当密钥序列非常接近随机序列时,其安全性很高。但是,传统的流加密方法中,采用的伪随机序列发生器为线性同余发生器或线性反馈移位寄存器,它们的安全性都较差,易被破解。因此,本发明实施例采用改进的LogisticsMap混沌流加密方法。作为一种可实施的方式,一种简单且被广泛研究的自治一维离散动态系统是Logistics映射方法,它用一维非线性迭代方法来表征的混沌流加密方法,如下式所示。F(xn)=bcn(1-xn)其中,n二0,1,2,……,xo和人为调节参数,当x0e(0,l),XG(3.5699456...,4)时,Logistics映射工作于混沌态,即由初始条件xo在Logistics映射方法的作用下所产生的序列(Xk,k=0,l,2,3...}是非周期的、不收敛的,且对初始值和参数非常敏感。该混沌流加密方法有两个问题,一个是流加密方法的固定点,即多次迭代趋近于某一个固定值,另一个是"稳定窗",即在某个区间的点聚集,窗中产生的迭代序列不能提供作为密钥流所必须的安全性。本发明实施例采用改进的Logistics地图(Logisticsmap)—维非线性迭代方法以避免现有技术的问题。本发明实施例的迭代方法如下式所示G(x)=(p+I)(l+1/P)px(l-x)p其中,pe(l,4),XoE(O,l),x的初始值为xo,通过此式迭代可以得到X!,X2,X3,…Xn…。理论上,上式产生的序列是非周期的,但是由于受到计算机字长的限制,实际由计算机仿真得到的混沌序列都只是对客观混沌的逼近,因此有一个"循环窗"问题,就是经过若干次迭代,迭代值出现周期性。根据测试的结果,在采用双精度的浮点运算时,可用的迭代平均次数>=2*107。下面详细说明步骤S200中按加密所需的安全等级确定选用的比特位置表的具体方法过程为了说明本发明的加密所需的安全等级确定选用的比特位置表,首先说明G.729标准帧结构,并根据其编码原理分析其参数作用和重要性,然后根据其参数作用按安全等级或实际需求选择要加密的比特位,将比特位分为不同类别,加密不同类别的比特位获得不同安全等级或效果。如表1所示为G.729语音编码帧的比特位分配表。表1G.729语音编码帧的比特位分配表<table>tableseeoriginaldocumentpage15</column></row><table><table>tableseeoriginaldocumentpage16</column></row><table>通过对G.729的编码过程的分析,对照帧结构,可以确定帧中各个参数的作用1)G.729帧中的LSP参数L0,Ll,L2,L3是线性预测滤波器(短时合成滤波器)的参数,用以在解码端构成LPC合成滤波器,十分关键,LPC系数和最后的语音的可理解性(即语义)有着密切关联;2)G.729帧中的自适应码本延时(基因延时)参数P1、P2是解码端总激励中的长时基音成分,也即周期脉冲成分,这个成分影响着人耳对语音的性别判断;3)G.729帧中的码本增益GA、GB是自适应码本和固定码本的增益的联合编码,增益参数影响着人耳对语音的通话与静音期的分辨能力;4)G.729帧中的固定码本索引和固定码本符号分别代表固定码本(语音激励中的非周期脉冲成分)的编码脉冲的符号和位置。固定码本是在对激励信号的编码过程中,对目标矢量和长时基音贡献的差值的逼近,是总激励的余量信号,也是对目标矢量和长时基音贡献的差值的逼近,它是总激励中的非周期脉冲成分。因此,通过对语音加密效果的衡量标准和G.729各参数作用的联合考虑,明确LSP参数、码本增益和自适应码本延时三个参数非常重要,在选择加密参数时需要首先考虑,固定码本参数的加密可以置后考虑。本发明以K.Swaninathan等人提出的G.729语音帧重要比特位36bit(即本发明中的安全等级六的加密,见图8)的最小集合为基础,主要考虑上述分析中已选择的三个参数,结合其内部各自更为详尽的编码过程,进一步在三个参数内部进行比特位的选择,以在36位比特位中再次筛选出更少的比特位。1、LSP系数(LPC系数)内部的进一步选择。由图8可以看到,36比特位中仅包含了Ll、L2两个参数,没有包含L0、L3,这是因为G.729对LSP系数编码时,首先用4阶滑动平均(MA,MovingAverage)预测器来预测当前帧的线谱频率,计算的和预测的线谱频率的差值采用的两级分裂式预测矢量量化的方法进行量化。第一级是10维矢量量化,Ll表示码本索引,用7bit编码;第二级是将10维分裂为两个5维的码本,L2表示较低的5维码本索引,L3表示较高的5维码本索引,分别用5bits编码。L0仅用于选择G.729提供的两种4阶MA预测器其中的一个。通过研究LSP系数的量化编码过程知道,Ll是第一级矢量量化的索引,最为重要,它会影响到解码端处对L2、L3的解码,因此在L1、L2、L3中应优先加密;L2是第二级矢量量化时先编码的部分,会影响在其后编、解码的L3,因此优先于L3对它加密。另外,因为L1、L2、L3都是码本索引,并不是码本本身,对其部分位变换,会极大影响通过它们搜索出来的码本,因此在上述对L1、L2两个参数加密的基础上,进一步的,仅对这L1、L2部分位进行加密;2、自适应码本时延参数内部的进一步选择。自适应码本搜索每一子帧(5ms)进行一次。用闭环分析最小化加权均方误差来决定每一子帧的最佳时延,闭环基音搜索的准则是使原始语音和重构语音之间均方感知加权误差最小。确定基音时延以后,进行自适应码本时延的码字计算。第一子帧基音时延Tl用8bits编码,第二子帧基音时延T2用5bits编码。基音时延T2的值编码与T1的值有关,相当于差分编码。因此,在解码端,Pl的重要性高于P2,因为它对T2的解码亦有影响。所以,在对P1、P2进行加密时,对Pl加密的比特位应多于P2。我们对P1、P2加密部分位;3、码本增益参数内部的进一歩选择。自适应码本增益和固定码本增益是用7bits的矢量量化,用原始语音和重构语音之间的误差加权均方最小来搜索增益码本。同样的,因为GA、GB都是码本索引,并不是码本本身,对其部分位变换,会极大影响通过它们搜索出来的码本,因此在上述对GA、GB两个参数加密的基础上,进一步的,仅对这GA、GB进行部分位加密;在以上分析的基础上,对G.729语音帧进行不同比特位的加密后,对加密语音进行反复试听和分析比较,根据试听结果最后把G.729语音帧选择性加密分为8个安全等级,前六个安全等级旨在以最少的加密位获得尽可能高的保密性,后两个安全等级旨在为各类业务需求提供可能性与技术支持。8个安全等级是按照以下两种目标分别提出的第一,以保密性为首要目标,以加密尽可能少的位获得尽可能好的保密性,旨在降低话音可懂度。划分为六个安全等级安全等级一,加密语音帧中的20比特位,如图3;安全等级二,加密语音帧中的21比特位,如图4;安全等级三,加密语音帧中的22比特位,如图5;安全等级四,加密语音帧中的23比特位,如图6;安全等级五,加密语音帧中的24比特位,如图7;安全等级六,加密语音帧中的36比特位,如图8;第二,以可能出现的业务需求为目标进行考虑,提出以下方法安全等级七,模糊语音性别(即通过听语音无法准确判断原说话人的性别,可以听懂,但听不出是男声还是女声)选择需加密的比特位,如图9;安全等级八,减小通话/非通话期的区别选择需加密的比特位,如图10;在本发明实施例中,给出了8类安全等级的选择性加密,没有限制某种具体的应用背景以及安全需求。如果某种实际应用中,对比特位进行加密安全效果没有达到具体环境的应用要求的话,可以在本发明的8种安全等级间进行自由组合,直到获得所需效果。作为一种可实施的方式,所述安全等级和选择性加密一帧中各字节需加密的比特位置表的数据结构可以表示如下/*安全等级*/#defmeSECURITY—LEVEL1#defmeSECURITY—LEVEL2#defineSEC而TY一LEVEL3#defineSECURITY—LEVEL4#defmeSECURITYLEVEL41//安全等级一2//安全等级二3//安全等级三4//安全等级四5//安全等级五#defineSECURITY—LEVEL46〃安全等级六#defmeSECURITY—LEVEL47〃安全等级七#defmeSECURITY—LEVEL48〃安全等级八/*选择性加密一帧中各字节需加密的比特位置表*/bytelevel1—Bitpos一List[]={0xle,0x07,0x7c,0x00,0x00,0x90,0xl9,0x00,0x00,0x32};〃安全等级1时,选用的比特位置表bytelevel2Bitpos—List[]={0xle,0x07,0x7c,0x00,0x00,0x^,0x39,0x00,0x00,0x32};〃安全等级2时,选用的比特位置表bytelevel3—Bitpos—List[]={0xle,0x07,0x7c,0x00,0x00,0xb0,0xl9,0x00,0x00,0x36};〃安全等级3时,选用的比特位置表bytelevel4—Bitpos—List[]={0xle,0x07,0x7c,0x00,0x00,0xb0,0x39,0x00,0x00,0x36};〃安全等级4时,选用的比特位置表bytelevel5—Bitpos—List[]={0x3e,0x07,0x7c,0x00,0x00,0xb0,0x39,0x00,0x00,0x36};〃安全等级5时,选用的比特位置表bytelevel6_Bitpos—List[]={0xfe,0xlf,0xfc,0x01,0x00,0xfD,0x3f,0x00,0x00,0xfe};〃安全等级6时,选用的比特位置表bytelevel7—Bitpos一List[]={0x00,0x00,0xfc,0x7f,0x00,0x00,0xf8,0x0f,0x00,0x00};〃安全等级7时,选用的比特位置表bytelevel8—Bitpos—List[]={0xOO,OxO0,OxO0,0x00,Ox00,OxfD,0x07,OxO0,0xOO,0xfe};〃安全等级8时,选用的比特位置表下面详细说明本发明歩骤S220执行加密操作的具体方法过程在本发明实施例中,以安全等级为7的情况为例进行分析说明,此时加密的比特位置表选用level7—Bitpos—List[]。数组keyList[8]存放混沌密钥流。Xi小数点后取64位二进制位,生成8字节的字节型(byte)型数据,存入数组keyList[8]中。本方法中设置标志量times,以记录同一密钥使用的次数。其初始值设置为0。具体包括如下步骤步骤S221,首先收到语音帧的第一帧,数组level7一Bitpos一List[]的第1项记录语音帧的第1字节需要加密的比特位,取出其值00011110,比特位为1说明相应语音帧字节的相应比特位需要加密,否则不用;步骤S222,将00011110与数组keyList[](存放生成的64位密钥流)的第((l+times)%8)项相与,得到的结果与语音帧的第1字节进行异或,结果送回语音帧第1字节,如图15所示,图示以times=0时为例,因此此时图15中数组keyList[]即是使用第1项;步骤S223,再查找数组leve17—Bitpos—List[]的第2项,它记录语音帧的第2字节需要加密的比特位,取出其值000001111;步骤S224,将00011110与数组keyList[]的第((2+times)%8)项相与,得到的结果与语音帧的第2字节进行异或,结果送回语音帧第2字节;以此类推,直到将语音帧的第8字节加密完成,如图16所示。步骤S225,当语音帧的第9个字节需要加密时,査找数组level7—Bitpos—List[]的第9项,与keyList[]表的第((9+times)%8)项相与,用此结果与语音帧第9字节进行异或加密。如图17所示,当进行到步骤S225时,keyList[]的8个字节全部用过一轮,当语音帧的第9个字节需要加密时,keyList[]表回到表头第((9+times)%8)项,图示以times^时为例,因此此时图17中即是回到表头第1项。查找数组level7—Bitpos—List[]的第9项,将此字节与数组keyList[]的第((9+times)%8)项相与,得到的结果与语音帧第9字节进行异或加密。因为语音帧每一字节要加密的比特位并不相同,即使keyList[]重复使用,其中每一次真正使用到的比特位也不尽相同。步骤S226,向后滑动继续加密第10字节,同时,keyList[]表也向后滑动,level7—BitposJList[]也向后移动一项;如图18所示,语音帧第9字节加密完后,向后滑动继续加密第10字节,同时,keyList[]表也向后滑动到第((10+times)%8)项,level7—Bitpos—List[]也向后移动一项,査找数组数组leve17—Bitpos—List[]的第10项,将此字节与数组keyList[]的第((10+times)%8)项相与,得到的结果与语音帧第10字节进行异或加密,图示以times^0时为例,因此此时图18中数组keyList[]使用的是第2项。到此,此语音帧加密完成,标志量times增l。下面详细说明本发明步骤S230执行更新密钥的具体方法过程步骤S231,在当前语音帧加密完成后,判断标志量times是否为8,如果不是8则不更新密钥流,转至歩骤S234;如果是8,密钥流已用过8次,需要更新密钥流,继续下一步骤;步骤S232,标志量times重新赋值为0;歩骤S233,keyList[]表作废,需要更新。利用下式G(x)=((3+"(1+1/(3)px(1-x)p,对Xi(x的当前值)进行迭代,得到xw,取xw的小数点后的64位有效二进制位,转换为8个byte型数据,将转换的数据存入数组keyList[],实现了keyList[]的更新。步骤S234,如果还有要加密的语音帧,则继续取下一帧,转回步骤S220;如果没有,加密结束。本发明的语音编码选择性加密方法,使用选择性加密对G.729编码语音进行混沌流加密,具有如下优点1)提高语音通话的实时性语音编码选择性加密方法从以下几方面提高加密效率Al)对语音帧进行选择性加密,在帧内,按安全等级的需要,对那些敏感性高的比特位(即对重建语音影响大)进行加密。与传统的对语音媒体内容进行整体加密相比,这无疑加快加密速度。A2)使用流加密算法,将明文直接和密钥流进行异或,相比分组算法,此法速度更快。A3)为了增强安全性,流加密算法中使用的密钥流为混沌序列,由改进的Logisticsmap映射得到。此法在迭代过程中,计算复杂度较大,为了减少密钥流的计算量,结合G.729帧结构所选择的需要加密部分位置的特点,适当地对混沌密钥流进行重复使用,而不显著影响其安全性能。2)降低系统能耗,减少对资源的占用对语音帧进行选择性加密,使用流加密算法,对混沌密钥流进行适当的重复利用,这些措施在提高效率的同时,也可以降低系统能耗,减少占用的资源数量。降低能耗在一些能源资源十分紧张的应用环境中,如无线通信领域中其移动设备携带能量有限,是非常关键的问题。减少对资源的占用,也可减轻网络处理节点的负荷。3)便于满足不同等级的业务需求选择性加密不仅仅可以从技术上满足更好的需求,它在许多互联网的业务中,也有实际的应用价值。在语音帧内,按实际业务的需要,对特定的部分比特位进行加密,可以获得各种效果,如模糊语音的性别,使人无法辨识男女,再如,提供各类音频服务的网站,其语音材料可以以不同的加密强度提供给用户,如果是免费提供给用户试听,可以对语音采取某种低的加密强度,以进行模糊处理,降低音质。诸如此类的许多应用,总之,选择性加密为不同等级的业务需求提供了可行性与良好的技术支持。以上对本发明的具体实施例进行了描述和说明,这些实施例应被认为其只是示例性的,并不用于对本发明进行限制,本发明应根据所附的权利要求进行解释。权利要求1、一种语音编码选择性加密方法,其特征在于,包括下列步骤步骤A,进行初始化,选择所需安全等级,确定流加密方法的初始值和调节参数;步骤B,按照安全等级确定选用的比特位置表,利用所述流加密方法执行加密操作。2、根据权利要求1所述的语音编码选择性加密方法,其特征在于,还包括下列步骤步骤C,解密方接到加密数据后,首先进行初始化,然后执行解密操作。3、根据权利要求1或2所述的语音编码选择性加密方法,其特征在于,所述步骤A包括下列步骤步骤A1,用户选择加密所需的安全等级;步骤A2,确定流加密方法的初始值和调节参数;歩骤A3,取调节参数中的初始值的有效二进制位,转换字节型数据,将转换的数据存入一数组作为密钥流表,此密钥流表将用以和语音数据流明文要加密的位进行异或运算,以获得密文。4、根据权利要求1或2所述的语音编码选择性加密方法,其特征在于,所述步骤B包括下列步骤步骤B1,按照安全等级确定选用的比特位置表;步骤B2,在按照安全等级确定选用的比特位置表后,执行当前帧的加密操作;步骤B3,完成当前帧的加密操作后,如果密钥流使用完,利用所述混沌流加密方法中的调节参数对当前混沌序列值进行迭代,得到新的密钥流,更新密钥流表;如果还有语音帧,则转回步骤B2,转而处理下一帧,如果没有语音帧,加密结束。5、根据权利要求1或2所述的所述的语音编码选择性加密方法,其特征在于,所述歩骤C包括下列步骤歩骤Cl,接收控制参数,得到加密安全等级,并得到混沌流加密方法的初始值和调节参数;步骤C2,取调节参数的有效二进制位,转换为字节型数据,将转换的数据存入字节型数组作为密钥流表,此密钥流表将用以和语音数据流密文中加密的位进行异或运算,以获得明文;歩骤C3,按照安全等级确定选用的比特位置表;步骤C4,执行当前帧的解密操作;歩骤C5,完成当前帧的解密操作后,如果密钥流使用完,利用调节参数对当前混沌序列值进行迭代,得到新的密钥流,更新密钥流表;如果还有语音帧,则转回步骤C4,转而处理下一帧,如果没有语音帧,解密结束。6、根据权利要求1或2所述的语音编码选择性加密方法,其特征在于,所述的流加密方法为混沌流加密方法。7、根据权利要求6所述的语音编码选择性加密方法,其特征在于,所述混沌流加密方法为改进的Logistics映射的一维非线性迭代方法表征的混沌流加密方法。8、根据权利要求7所述的语音编码选择性加密方法,其特征在于,所述迭代方法如下式所示G(x)=((3+l)(l+l/p)px(l-x)e其中,|3G(1,4),x。e(0,1),x的初始值为xo,通过此式迭代可以得到x,,X2,X3,…Xn…。9、根据权利要求1或2所述的语音编码选择性加密方法,其特征在于,所述语音编码为G.729标准语音编码。10、根据权利要求9所述的语音编码选择性加密方法,其特征在于,所述所述步骤B中,按加密所需的安全等级确定选用的比特位置表,为按照G.729标准语音帧中各参数对重建语音的作用以及重要性的不同,将比特位分为不同类别,加密不同类别的比特位获得不同安全等级或效果。11、根据权利要求10所述的语音编码选择性加密方法,其特征在于,所述语音帧中参数的比特位的分类包括下列等级之一或者其组合安全等级一,加密语音帧中的20比特位;安全等级二,加密语音帧中的21比特位;安全等级三,加密语音帧中的22比特位;安全等级四,加密语音帧中的23比特位;安全等级五,加密语音帧中的24比特位;安全等级六,加密语音帧中的36比特位。12、根据权利要求11所述的语音编码选择性加密方法,其特征在于,所述语音帧中参数的比特位的分类还包括下列等级之一或者其组合安全等级七,模糊语音性别选择需加密的比特位;安全等级八,减小通话/非通话期的区别选择需加密的比特位。全文摘要本发明公开了一种语音编码选择性加密方法,其包括步骤A,首先进行初始化,选择加密所需安全等级,确定混沌流加密方法的调节参数和初始值;步骤B,按照安全等级选用加密的比特位置表,以加密部分比特位,利用混沌流加密方法执行加密操作。还可以包括步骤C,解密方接到加密数据后,首先进行初始化,然后执行解密操作。其按安全等级选择需要加密的语音编码帧的比特位,提高语音通话的实时性,降低系统能耗,满足不同等级的业务需求。文档编号G10L19/12GK101114450SQ200710052799公开日2008年1月30日申请日期2007年7月20日优先权日2007年7月20日发明者娟何,王芙蓉,莫益军申请人:华中科技大学
网友询问留言 已有0条留言
  • 还没有人留言评论。精彩留言会获得点赞!
1