zoukankan      html  css  js  c++  java
  • 很好的一篇讲LTP在编解码中的作用的文章

    原文链接
     
    LONG-TERM PREDICTION

    by: Adit Aviv 
          Kfir Grichman

    introduction:

    The speech signal has been studied for various reasons and applications by many researchers for many years. Some studies broke down the speech signal into its smallest portions, called phonemes. However, here we will describe the speech signal in terms of its general characteristics. The traditional vocoders which have been in use for many years classify the input speech signal either as voiced or unvoiced. A voiced speech segment is known by its relatively high energy content, but more importantly it contains periodicity which is called the pitch of voiced speech. The unvoiced part of speech, on the other hand, looks more like random noise with no periodicity. However, there are some parts of speech that.are neither voiced nor unvoiced, but a mixture of the two. These are usually called the transition regions, where there is a change either from voiced to unvoiced or unvoiced to voiced.

    One of the most powerful speech analysis methods is that of Linear Predictive Coding, or LPC analysis as it is commonly referred to. In LPC analysis the short-term correlations between speech samples (formants) are modelled and removed by a very efficient short order filter. Another equally powerful and related method is pitch prediction. In pitch prediction, the long-term correlation of speech samples are modelled. In the following report, these linear prediction techniques will be examined and discussed.

     
    LINEAR PREDICTIVE CODING (LPC) OF SPEECH
    The linear predictive coding (LPC) method for speech analysis and synthesis is based on modeling the vocal tract as a linear all-pole (IIR) filter having the system function:

    When p is the number of poles, G is the filter gain, and { ap (k) } are the parameters that determine the poles. There are two mutually exclusive excitation function to model voiced and unvoiced speech sounds. On a short time basis, voiced speech is periodic with a fundamental frequency F0, or a pitch period 1/F0, which depend on the speaker. 
    Thus voiced speech is generated by exciting the all-pole filter model by a periodic 
    impulse train with a period equal to the desired pitch period. 
    Unvoiced speech sounds are generated by exciting the all pole filter model by the

    Block diagram model for the generation of a speech signal

    Given a short-time segment of a speech signal, usually about 20ms or 160 samples at an 8 kHz sampling rate, the speech encoder at the transmitter must determine the proper excitation function, the pitch period for voiced speech, the gain parameter G, and the coefficients a(k). 
    A block diagram that illustrates the speech encoding system is given in the next figure : 
     

    Encoder and decoder for LPC

    At the  receiver the speech signal is synthesized from the model and the excitation signal.

    The parameter of the all pole filter model are easily determined from the speech samples by mans of linear prediction.

    To be specific, the output of the fir linear prediction filter is: 
      
     

                     1.1

    and the corresponding error between the observed sample s(n) and the predicted value is, 
      
     

              1.2

      
      
      
      
     

    By minimizing the sum of squared errors, that is, 
      
     

                       1.3

      
      
      
      
     

    We can determine the pole parameters {ap(k)} of the model. The result of differentiating with respect to each of the parameters and equating the result to zero, is a set of p linear equations, 
      
     

                      1.4

      
      
      
      
     

    Where rss(m) is the autocorrelation of the sequence s(n) defined as,

                                            1.5

    The linear equation (1.4) can be expressed in matrix form as 
      
     

                                                             1.6

    When Rss is a p*p autocorrelation matrix, rss is a p*1 autocorrelation vector, and a p*1 vector of model parameters. Hence

     1.7

      
      
     

    LONG - TERM  PREDICTION (LTP)

    In the residual LPC we can see the  ability of LPC analysis to remove the adjacent or neighbouring sample correlations present in speech . As observed, this was equivalent to removing the spectral envelope in the signal spectrum. However, as can be seen from the Figure pitch prediction, after LPC analysis there are still considerable variations in the spectrum, i.e. it is far from white. 
      
      
      
    Spectra of (a) original speech envelope, (b) original speech spectrum, and (c) LPC residual spectrum .

     
     

    Looking at the residual signal in the Figures above, it is clear that long-term correlations, especially during voiced regions, still exist between samples.

    To hear the original signal click here... 
    To hear the residual LPC click here...

    The most evident of these are the sharp periodic pulses which, being the excitation signal, is hardly surprising, as our original source-filter model assumes this type of input signal. This also explains why the LPC analysis, which models our vocal tract, cannot adequately remove them. Consequently, to remove the periodic structure of the residual or excitation signal, a second stage of prediction is required. The objective of this second stage is again to spectrally flatten our signal, i.e. to remove the fine structure. But unlike the LPC analysis, it exploits correlation between the speech samples that are one 'pitch' or multiple 'pitch' period away. For this reason, the pitch prediction (filter) is usually called the long-term prediction (LTP) and the filter delay is called the lag. In the following report, these long-term or distant sample based predictors will be described. 
     

     Pitch predictor (filter) formulation

    Before discussing methods of pitch or long-term prediction, it is perhaps worth considering what our objectives are. Our aim is to model the long-term correlation left in the speech residual signal after LPC inverse filtering (or in the original speech signal) such that when the model parameters are used in a filter, it will remove the long-term correlation as much as possible, or spectrally flatten our signal. There are no obvious reasons why we must use the residual and not the original signal to model the long-term correlation in the speech signal, as long as the effects of the formants are taken into account during determination of the long-term delay (pitch) in our model.

    The order of the LTP is not too critical if the combination is carefully optimised, e.g. block edge effects must be carefully compensated to avoid 'clicking' type distortions. It is worth noting that the prediction gain of the combined system will always be less than the sum of the gains in systems employing the LTP  in isolation. This is because in reality the vocal tract and excitation are not completely separable, as assumed in our model, but are interconnected. The LTP can be interpreted as 
      
      
     1.8           
      
    where T is the 'pitch period', and bj are the 'pitch gain' coefficients which reflect the amount of correlation between the distant samples. The combined analysis model can be represented by a time domain difference equation: 
    1.9 

    where r(n) is the past excitation signal. Following a similar procedure to that of the LPC analysis, our goal is to determine estimates (Bj, T, aj) of the model parameter (bj, T, ai). Then, the prediction error is given by: 
      
      2.0

    The mean squared error solution to equation (2.0) is not as straightforward as for the LPC analysis due to the presence of the delay factor T. To overcome this hurdle, two sub-optimal approaches can be taken:

    (1) One-Shot Optimisation: if one assumes that the pitch spectrum information of the residual r(n) is 
         close to the pitch spectrum information of the input speech s(n), then we can solve for ai as before 
         and then use the residual from the LPC inverse filter to determine (B,T).Thus during the first iteration, 
         the STP coefficients are estimated to minimise the intermediate residual energy. The LTP coefficients 
         are then found using this intermediate residual signal. This procedure can be considered to be near 
         optimal provided the long-term lag, T, is greater than the analysis frame size, i.e. T > N. 
    (2) Iterative Sequential Approach: an analysis similar to the one-shot method described above is first 
         performed. During subsequent iterations, the STP is re- opfimised given the previously determined 
         LTP coefficients . Also, the LTP is recalculated based on the newly formed intermediate 
         residual. This iteration process can then be continued until a certain threshold, or a fixed number of 
         iterations, is reached.

    For practical reasons, the one-shot method is usually preferred as it only requires one iteration. In the iterative sequential method the main difficulty is to set a suitable threshold for the termination of the iteration run. Overall, it is substantially more complicated. However, the iterative method has been reported to give a better prediction gain and better perceptual performance . This is usually achieved with a shifting of the STP prediction gain to the LTP prediction gain. Here, only the one- shot method is considered as follows. 
    By removing the STP effect in equation (2.0), we obtain 
     2.1

    The estimates can now be determined by mean squared error, i.e. 
     2.2 

    Replacing the expectation with finite summations, we get 
    2.3  
     

    By setting 
     
    to zero, we obtain

    2.4  
      
    which can be written in matrix form as 
      
    2.5  
      
    where

    2.6  
    2.7 

    The Bj coefficients can now be solved by inverting V(i,j), e.g. using Cholesky's decomposition. In the above formulation, a 'fix-up' may be used to ensure that the filter so formed is stable, e.g. by adding a small noise source into the formulation, the matrix inversion to obtain [V(i,j)]-l can be made more reliably. However, a stable LTP is not a pre-condition on the LTP analysis as rapid transitions are sometimes desired.

    In the above formulation it is assumed that the pitch lag, T, has already been found and that 
    Bj =Bj,T To determine T, various pitch measurement algorithms can be used (in our project we took the 3-tap LTP, I = 1, which forms the pitch prediction based on three past samples at T - 1, TT + 1) . These include the auto-correlation , average magnitude difference function (AMDF) , Cepstrum  and Maximum Likelihood . These methods perform with different characteristics, especially with a noisy input signal. For simplicity, the auto-correlation algorithm is used for the general description below. 
    As the preceding analysis to determine Bj has shown, pitch analysis is performed on a block containing N samples. However, the size of our window in which the block is taken is required to be considerably longer than the analysis frame length, N. This is because our pitch value, T, can vary between a minimum, Tmin, of around 16 samples to a maximum, Tmax, of around 150 samples. Therefore, our ideal analysis window is much greater (N +Tmax) in length (200-256 samples) such that it contains more than one complete pitch period. For simplicity, consider a 1-tap LTP, i.e. (I = 0)

    2.8  
     

    Thus 
     

    2.9  
     

    3.0  
     

    Substituting this into equation (2.3), 
     

    3.1  
     

    The main problem

    To determine the optimum T, values of the lags are tested between Tmin, and Tmax, and the lag which minimises the error E is the optimum. Having found T, the gain B can be found. A plot of the LPC residual and the signal (secondary excitation) after LTP inverse filtering is shown in the next Figures .

    To hear the residual LPC click here...

    To hear the residual LTP click here...

    Time domain plots of  LPC and pitch residuals

    Time domain plots of both LPC and pitch residuals.

    It is clear that the secondary excitation no longer possesses the sharp pulse-like characteristics of the residual, i.e. it looks much whiter than the LPC residual. Similar formulation can also be given for multiple tap LTPS.

    Multiple tap LTPs tend to provide better performance than the single-tap LTP, in general, but with increased complexity and larger capacity requirement for the extra two filter taps B-1 and B1. 
     

    Final conclution: 
    After we found the "white residual" we can comprees the error to minimum and by that get a clear signal with low-bit rate. 
      
    To hear the final signal after the Resiver click here...

      
     

  • 相关阅读:
    Day5下午解题报告1
    Linux 命令整理
    [置顶] 正则表达式应用:匹配email地址
    IE浏览器下web调试工具之--IE WebDeveloper介绍
    ORACLE客户端乱码
    冒泡排序
    【C++】第二章:Hello World!
    hdu4710
    (SQL SERVER) (ORACLE) (ACCESS)(POSTGRE SQL)四种数据库操作C#代码
    How to calculate the undo_retention time
  • 原文地址:https://www.cnblogs.com/gaozehua/p/3243437.html
Copyright © 2011-2022 走看看