The present invention relates to the processing of data by switching between different sub-band domains, in particular, but not in any way exclusively, for the transcoding between two types of compression coding/decoding.
Recent developments in digital coding formats for multimedia signals today allow significant compression rates. Furthermore, the increase in the capacities of transport and access networks is now ensuring everyday use by the public at large of digital multimedia contents (speech, audio, image, video and the like). The consumption of this content is done on various types of terminals (computers, mobile terminals, personal assistants (PDA), television decoder terminals (“Set-Top-Box”) or the like) and via various types of network (IP, ADSL, DVB, UMTS, or the like). This access to multimedia content by the user must be done in a transparent manner on these various terminals and across these various networks. One then speaks of “universal access to multimedia content” or “UMA” standing for “Universal Multimedia Access”, a diagrammatic illustration of which is represented in
One of the main problems due to the heterogeneity of terminals relates to the diversity of the coding formats that they are capable of interpreting. One possible solution would be to recover the capacities of the terminal before delivering the content in a compatible format. This solution may turn out to be more or less effective according to the scenario of delivery of the multimedia content considered (downloading, streaming or broadcasting). It becomes inapplicable in certain cases, such as for broadcasting or for streaming in multicast mode. The concept of transcoding (or of changing coding format) therefore turns out to be important. This operation may intervene at various levels of the transmission chain. It may intervene at the server level for changing the format of the content previously stored for example in a database, or else intervene in a gateway in the network, or the like.
A direct and customary method of transcoding consists in decoding the content and in recoding it to obtain a representation in the new coding format. This method generally has the drawbacks of using significant computational power, of increasing the algorithmic delay due to the processing and sometimes of adding a supplementary degradation of the perceptual quality of the multimedia signal. These parameters are very significant in multimedia applications. Their improvement (reduction in complexity and in delay and maintaining of quality) is a significant factor for the success of these applications. This factor sometimes becomes an essential condition of implementation.
With the aim of improving these parameters, the principle of so-called “intelligent” transcoding has come into being. This type of transcoding consists in performing a partial decoding, the most minimal possible, of the initial coding format to extract the parameters allowing the reconstruction of the new coding format. The success of this method is therefore measured by its capacity to reduce algorithmic complexity and algorithmic delay and of maintaining, or even increasing, perceptual quality.
In image and video coding, much work on transcoding has been carried out. We cite for example the changing of image size from CIF to QCIF, or else MPEG-2 to MPEG-4 formats. For the transcoding of speech signals, typically in telephony, work is under way for solving problems related to the coding formats. On the other hand, very little or almost no work has tackled the processing of audio signals. The existing work remains restricted to cases of reducing bit rate within one and the same format or when switching between certain coding formats of very similar structures. The main reason lies in the fact that the most widely used audio coders are of transform (or sub-band) type and, generally, these coders use transforms or filter banks that differ. Thus, it will be understood that the embodying of a system for converting between the representations of the signal in the domains of these transforms or filter banks is therefore the first difficulty to be overcome before being able to attack any other problem related to intelligent transcoding in the field of audio.
Given below is a definition of audio transcoding and the principal problems which arise, after a brief reminder of the principles of perceptual audio sub-band coding.
There exists a great diversity of audio coders which have been designed for various types of applications and for a wide range of bit rates and qualities. These coders may be specific to the constructor (or “proprietary”), or else standardized by decisions of international bodies. Additionally, they all possess a common basic structure and rely on like principles.
The basic principle of perceptual frequency audio coding consists in reducing the bit rate of information by utilizing the properties of the hearing system of the human being. The nonrelevant components of the audio signal are eliminated. This operation uses the phenomenon of so-called “masking”. As the description of this masking effect is done principally in the frequency domain, the representation of the signal is carried out in the frequency domain.
More specifically, the basic schemes of a coding and decoding system are presented in
With reference to
Finally, the temporal audio signal is reconstituted by the bank of synthesis filters 25.
The first stage of any perceptual audio coding system therefore consists of a bank of analysis filters 20, used for the time/frequency transformation. A wide, variety of filter banks and transforms have been developed and utilized in audio coders. Mention may be made by way of example of pseudo-QMF filter banks, hybrid filter banks, MDCT transform banks. The MDCT transform is currently turning out to be the most effective in this context. It is the basis of the most recent and efficacious audio coding algorithms such as those used for the MPEG-4 AAC, TwinVQ and BSAC, Dolby AC-3 standard, in the TDAC coder/decoder (standing for “Time Domain Aliasing Cancellation”) from France Telecom, in UIT-T standard G.722.1.
Although these various transformations have been developed separately, they may be described by a similar general mathematical approach and from various points of view: modulated cosine filter banks, lapped orthogonal transforms (or “LOT”) and more generally for filter banks with maximal decimation, that is to say with critical sampling. It is recalled that the property of critical sampling for a filter bank consists in the subsampling/oversampling factor being equal to the number of sub-bands.
a and 3b respectively illustrate the conventional transcoding and intelligent transcoding schemes in a communication chain, between a coder CO1 according to a first coding format and a decoder DEC2 according to a second coding format. In the case of conventional transcoding, a complete decoding operation is performed by the decoder module DEC1 according to the first format (
In the case of
Represented in
The use by the coders of various types of filter banks (of different sizes, in particular in terms of number of sub-bands, and of different structures) is the first and principal problem to be overcome. This therefore involves transposing the whole set of samples of a frame from the domain of an initial filter bank to that of a destination filter bank. This transposition is the first operation to be done in any intelligent audio transcoding system.
Table 1 below gives a summary regarding the types of filter banks used in the best known transform-based audio coders, as well as their characteristics. As may be noted, in addition to the MDCT transform which is the one most widely used, there are the pseudo-QMF banks. Additionally, they all form part of the family of maximal decimation and modulated cosine banks that exactly or almost satisfy the property of perfect reconstruction.
It is indicated that the switch between the AAC and AC-3 formats is currently arousing much interest.
Table 2 below restates certain types of sub-band coding of table 1 while detailing a few of their applications.
In the known prior art in audio transcoding, document U.S. Pat. No. 6,134,523 presents a process for reducing bit rate in the coded domain for audio signals coded by MPEG-1 Layer I or II. Even though this process is akin to audio transcoding processes, it does not carry out any change between coding formats and the signals of the sub-bands remain in the representation of one and the same transformed domain, namely the representation of the pseudo-QMF filter bank. Here, the signals are quite simply requantized according to a new allocation of bits.
Additionally, in document US-2003/0149559, is proposed a process for reducing the complexity of the psycho-acoustic model during a transcoding operation. Thus, so as not to have to resort to an operation for calculating masking thresholds during transcoding, the new system uses values stored in a database of distortion templates. Even though this process deals with the problems of transcoding, it remains far from the objectives, relating to switching between filter bank domains.
In document. US-2003/014241 is proposed a system for transcoding between the MPEG-1 Layer II and MPEG-1 Layer III audio coding formats. Specifically, the MPEG-1 Layer II format uses a pseudo-QMF analysis filter bank and the MPEG-1. Layer III format uses the same filter bank followed by an MDCT transform of size 18 applied to the output sub-band signals of said bank. One speaks of a “hybrid filter bank”. The conversion system proposed in this document consists in applying this transform after inverse quantization of the samples of the sub-bands of an MPEG-1 Layer II frame. The system therefore profits from the similarity between the two coding formats.
With respect to the sought-after aim within the sense of the present invention, the following remarks may be noted:
Multirate processing and filtering in the transformed domain are already known in another context of image and/or video data processing, especially through the reference:
It describes a generalization of a process of linear filtering in the transformed domain (TDF standing for “Transform-Domain Filtering”). More particularly, this generalization is established in the case where the first transform (inverse). T1, and the second transform (direct) T2, are of the same size. The generalization consists firstly in extending the process to the case where the transforms are not of the same size. This process is then termed “non-uniform TDF” (or NTDF). It is thereafter extended to the case where in addition to the filtering, multirate processing operations (subsampling and oversampling) are added in the transformed domain, this resulting in the “Multirate-TDF” (MTDF).
Proposed as an application is the changing of resolution in the transform domain (TDRT standing for “Transform-Domain Resolution Translation”), particularly for image and video applications (conversion between CIF and QCIF image formats) where the transform is a DCT (standing for “Discrete Cosine Transform”). This reference is therefore interested only in filtering in the transformed domain. The process set forth is restricted only to cases of transforms with no overlap such as a DCT, a DST, or the like, but could not typically be applied to transforms with overlap such as an MLT (standing for “Modulated Lapped Transform”) and, more generally, to any type of filter bank with maximum decimation, these filters possibly having moreover a finite or infinite impulse response.
As regards the conversion between DCT domains of different sizes, still for the transcoding of images and video, the following reference may be cited: “Direct Transform to Transform Computation”, A. N. Skodras, IEEE Signal Processing Letters, Vol. 6, No. 8, August 1999, pages: 202-204.
In this document is proposed a process for switching between DCT transforms of different sizes for an image subsampling in the DCT domain. One of the applications of this process would be transcoding. Additionally, this process is restricted to the construction of a transformed vector of size N from two adjacent transformed vectors each of size N/2.
A process for converting between the representations of the signal in the MDCT domain and the DFT domain (Discrete Fourier Transform) is presented in document US-2003/0093282.
It was developed with the objective of converting the audio signal into a representation where it can be easily modifiable. Specifically, the TDAC filter banks are more practical and are used more in audio coders, contrary to the DFT filter banks. Additionally, carrying out, a processing or modifications on the components of the signal in this transformed domain is neither adequate nor sufficiently flexible in view of the existence of spectral aliasing components. On the other hand, the DFT representation is more useful when modifications are to be made on the audio signal such as a change of timescale or a shift of pitch. This reference therefore proposes a direct process for converting between MDCT and DFT domain instead of applying the conventional process consisting in synthesizing the temporal signal by an inverse MDCT, then applying the DFT. This process therefore allows modifications to be made directly in the coded domain. The document also proposes the dual process for converting between the DFT and MDCT domains, which would be useful in the case where there was a need to recode the audio signal after modification.
In this reference, the comparison in terms, of complexity with a conventional conversion process shows, no reduction. Additionally, a small gain in memory allowing storage of the data is demonstrated.
However,
The publication: “An Efficient VLSI/FPGA Architecture for Combining an Analysis Filter Bank following a Synthesis Filter Bank”, Ravindra Sande, Anantharaman Balasubramanian, IEEE International Symposium on Circuits and Systems, Vancouver, British Columbia, Canada, May 23-26, 2004, can also be cited.
This publication discloses an efficient structure for implementing a system consisting of a synthesis filter bank, with L sub-bands, followed by an analysis filter bank with M sub-bands, where M and L are multiples of one another. This structure is efficient for implementation in VLSI integrated technology (“Very Large Scale Integration”) or on FPGA (“Field Programmable Gate Array”) or on parallel processors. It requires fewer logic blocks, low power consumption and makes it possible to extend the degree of parallelism. The process proposed is applicable in situations where one processing based on sub-bands follows another sub-band processing and where the intermediate synthesized signal is unnecessary.
However:
It should also be indicated that the structure of the scheme for converting between sub-band domains exhibits a certain similarity with that of the problem of trans-multiplexing presented in particular in:
Specifically, in trans-multiplexing from TDM to FDM (standing for “Time Domain Multiplexing” to “Frequency Domain Multiplexing”), a synthesis filter bank is used. To reconstruct the interlaced time signals, (that is to say to perform the inverse trans-multiplexing operation from FDM to TDM), an analysis filter bank is used. The structure of the TDM→FDM→TDM system therefore amounts to a cascading of a synthesis filter bank and of an analysis filter bank, this corresponding well to what is also used in a conventional transcoding system. The problem generally posed in these trans-multiplexing systems is to reconstruct the original signals without distortions after the TDM→FDM→TDM operation. This principally involves eliminating the distortions due to the phenomenon of crosstalk which result from the use of non-perfect bandpass filters, in these filter banks. A judicious design of the synthesis and analysis filters, as indicated in the same reference:
“Multirate Systems and Filter Banks”, P. P. Vaidyanathan, Prentice Hall, Englewood Cliffs, N.J., 1993, pages 259-266,
makes it possible to overcome this problem. In the design proposal for these filters, a process is given for merging the synthesis and analysis filter banks, thereby amounting to proposing an intelligent conversion system.
However:
The present invention seeks to improve the situation with respect to the prior art presented above.
For this purpose it proposes a method implemented by computer resources to process data by switching between different sub-band domains, consisting in compacting in one and the same processing the application of a first vector comprising a first number L of respective sub-band components, to a bank of synthesis filters, then to a bank of analysis filters, to obtain a second vector comprising a second number of respective sub-band components. M.
The method within the meaning of the invention comprises the following steps, after determination of a third number K, the least common multiple between the first number L and the second number M:
Thus, the present invention proposes in particular, but not exclusively as will be seen below, a transcoding from any first type of coding, to any second type of coding. It will also be understood that the respective numbers of sub-bands M and L are any natural integers and are not necessarily related by a proportionality relation, in the most general case.
Thus, the method within the meaning of the invention may be applied advantageously to the transcoding of a first type of compression coding/decoding to at least one second type of compression coding/decoding. This application typically consists in compacting in one and the same processing the following steps:
The present invention is also aimed at a computer program product, intended to be stored in a memory of an item of equipment in a communication network, such as a server, a gateway, or else a terminal, and then comprising instructions for the implementation of all or part of the method as claimed in the invention.
The present invention is also aimed at an item of equipment such as a server, a gateway, or else a terminal, intended for a communication network, and comprising computer resources for the implementation of the method as claimed in the invention.
Other characteristics and advantages of the invention will become apparent on examining the detailed description hereinbelow, and the appended drawings in which, in addition to:
a and 2b representing the basic schemes of a perceptual frequency audio compression system, respectively on coding and on decoding,
a and 3b diagrammatically illustrating communication chains using conventional transcoding and intelligent transcoding, respectively, and
a and 5b diagrammatically represent the block diagrams defining the equivalence between the synthesis of the temporal signal and the analysis with a new bank of filters (
a and 20b respectively illustrate a filtering combined with a conversion between sub-band domains, and an equivalent global system, within the meaning of the invention,
a and 21b illustrate the combination of a change of sampling frequency (or “re-sampling”) with a conversion between sub-band domains, conventional and within the meaning of the invention, respectively,
The method of converting between sub-band domains, is described below in a general presentation of the invention.
We consider the L-band synthesis bank used by a first compression coding system and defined by its filters, denoted Fk(z), 0≦k≦L−1, as well as the M-band analysis filter bank used in a second compression system and defined by its filters, denoted Hn(z), 0≦n≦M−1. The two filter banks used in the two compression systems are assumed to be preferentially maximal decimation systems (or “critical sampling systems”), as will be seen later.
We denote by X(z)=[X0(z)X1(z) . . . XL−1(z)]T and Y(z)=[Y0(z)Y1(z) . . . YM−1(z)]T, the vectors of the signals of the sub-bands representing the signal respectively in the domains of the first and second filter banks.
The principle of converting, between sub-band domains is illustrated by
By using multirate blocks, the scheme of
This temporal signal thereafter constitutes the input for the analysis bank with M sub-bands. On each sub-band n, 0≦n≦M−1 it undergoes a filtering by the analysis filter Hn(z) followed by an oversampling operation with factor M. A vector of sub-band signals, of size M, represented in the domain of the z-transform by Y(z) is then obtained at the output of this analysis bank. The synthesis of a time signal is therefore generally necessary in this conventional conversion system, in contradistinction to the conversion system described hereinafter within the meaning of the invention.
The conversion system within the meaning of the invention is therefore now described according to a general expression.
We denote by K the least common multiple of M and L (i.e. K=1 cm(M,L)), and p1 and p2 the natural integers such that:
K=p1M and K=p2L. (1)
We consider U(z)=[X0T(z), X1T(z), . . . Xp
We denote by g(z) the matrix of size M×L grouping together the products between the synthesis and analysis filters. The elements of this matrix may therefore be written as follows:
G
nk(z)=Hn(z)Fk(z), 0≦n≦M−1, 0≦k≦L−1. (2)
and, in matrix form:
g(z)=h(z)fT(z), (3)
where h(z)=[H0(z) H1(z) . . . HM−1(z)]T and f(z)=[F0(z)F1(z) . . . FL−1(z)]T are respectively the vector of the analysis filters of the second filter bank, and the vector of the synthesis filters of the first filter bank.
The conversion between sub-band domains is given by the following formula:
V(z)=T(z)U(z) (4)
The conversion matrix T(z) is of size K×K. Its expression is given by:
T(z)=[v(z)g(z)]|↓k, (5)
where v(z) is the matrix of size p1×p2 whose elements are defined as follows:
v
ij(z)iM−jL, 0≦i≦p1−1 and 0≦j≦p2−1. (6)
The operation denotes the Kronecker product such that:
It is recalled that the operation ↓K denotes decimation by a factor K, corresponding to a subsampling in which only one sample out of K samples is retained.
The conversion system may be schematized as represented in
In
It is recalled that the notation X(z) relates simply to the expression of the vector X according to its z-transform, while the notation X[n] relates to the expression for the vector X in the time domain, convention for the person skilled in the art.
The last block 73_p1−1 to 73_0 of
The input and output blocks of
Advantageously, the conversion system within the meaning of the invention has minimal delay.
Specifically, one of the objectives of the sub-band domain conversion system is to minimize the algorithmic delay introduced. It is therefore necessary to introduce advances to reduce the delay. If we add in:
then formula (5) above becomes:
The exponent eij=aL+b+(iM−jL), 0≦i≦p1−1, 0≦j≦p2−1 varies between the following two extreme values:
e
min
=aL+b−(p2−1)L=aL+b−K+L, for i=0, j=p2−1, (9) a
and
e
max
=aL+b+(p1−1)M=aL+b+K−M, for i=p1−1, j=0. (10)
The element filters of the matrix T(z) are all causal if and only if:
e
max
≦K−1, (11)
i.e.: aL+b≦M−1. (12)
Conversion systems within the meaning of the invention may therefore be constructed with various delays and by making different choices regarding the parameters a and b, but on condition that the inequality (12) is preferentially satisfied.
The parameters a and b may therefore be seen as adjustment parameters making it possible to act on the algorithmic delay introduced by the system for converting between sub-band domains.
For a conversion system with minimal algorithmic delay, it is appropriate to introduce the maximum possible advance. The choice of a and b is therefore preferentially made in such a way that:
e
max
=K−1, (13)
i.e.: aL+b=M−1. (14)
For this choice, formula (8) becomes:
or else:
T(z)=[v(z)g(z)]|↓k, (16)
where, here, v(z) is the matrix whose elements are defined as follows:
v
ij(z)=zM−1+iM−jL, 0≦i≦p1−1 and 0≦j≦p2−1. (17)
Relation (16) is therefore the general formula for the conversion matrix T(z), which makes it possible to reduce to the minimum the algorithmic delay introduced by the conversion system within the meaning of the invention.
In what follows, we shall consider the case of a conversion system with minimal delay.
If we use the notation eij=M−1+(iM−jL), with 0≦i≦p1−1 and 0≦j≦p2−1, then the following interpretation of the matrix elements └zeijg(z)┘|↓k of the matrix T(z) may be given on the basis of formula (15):
It will be noted that the polyphase components considered in relation (18) correspond to a decomposition of type 1 to order K, as described for example in the aforesaid reference:
This interpretation therefore makes it possible to construct the matrix T(z), directly from the polyphase components of type 1 to order K of the product filters Gnk(z)=Hn(z)Fk(z) (0≦n≦M−1 and 0≦k≦L−1) and of the corresponding, filters constructed by adding delays.
To express the elements of the matrix T(z) more explicitly, we write:
T(z)=[Tml(z)]0≦m, l≦K−1, (19)
The element filters of the matrix T(z) may therefore be written as follows:
for 0≦m, l≦K−1.
In the latter formula (20), the integers i, n and j, k depend on l and on m as follows:
where └x┘ denotes the integer part of the real number x.
The notation Gnkr(z) (with 0≦r≦K−1) indicates the polyphase component number r of the filter Gnk(z), resulting from a decomposition of type 1 to order K.
The polyphase components Gnkr(z) (with 0≦r≦K−1) may be determined directly if the synthesis filters and the analysis filters have finite impulse responses (or “FIR”). In the case where one or both filter banks use recursive filters (with infinite impulse responses or “IIR”), the product filters Gnk(z) also have infinite impulse responses. It is indicated that a general process for performing such a decomposition is indicated in annex A, entitled “Polyphase decomposition of recursive filters” from the reference: “Traitement du signal audio dans le domaine codé: techniques et applications” [Audio signal processing in the coded domain: techniques and applications], A. Benjelloun Touimi, doctoral thesis from the école nationale supérieure des télécommunications de Paris, May 2001.
Indicated hereinafter is a solution within the meaning of the invention for the particular case where M=pL.
In the case where M=pL, it happens that K=1 cm(M,L)=M and p1=1 whilst p2=p. Formula (4) then becomes:
Y(z)=T(z)U(z). (23)
where U(z)=[X0T(z), X1T(z), . . . XpT1(z)]T is the vector of polyphase components of order p of the vector of signals X(z).
The conversion matrix in this case is of size M×M and may be written as follows:
T(z)=[[zpL−1g(z)]|↓M, [z(p−1)L−1g(z)]|↓M, . . . , [zL−1g(z)]|↓M]. (24)
This matrix is therefore the row vector consisting respectively of the polyphase components of general index (p−k)L−1 (where 0≦k≦p−1), according to a decomposition of type 1 to order M, of the matrix g(z), of products of synthesis and analysis filters.
More explicitly, the element filters of the matrix T(z) may be written as follows:
T
m1(z)=Gmj(p−k)L−1(z), 0≦m,l≦M−1, (25)
where j and k are integers obtained from l through the relations:
The notation Gmjr(z) (with 0≦r≦M−1) is aimed at the polyphase component of general index r of the filter Gmj(z), resulting from a decomposition to order M.
The scheme of the conversion system is given in this particular case in
Indicated hereinbelow is a solution within the meaning of the invention for the particular case where L=pM.
In this particular case, it happens that K=1 cm(M,L)=L and p1=p whilst p2=1. Formula (4) then becomes:
V(z)=T(z)X(z), (27)
where V(z)=[Y0T(z), Y1T(z), . . . YpT1(z)]T is the vector of polyphase components of order p of the vector of signals Y(z).
The conversion matrix in this case is of size L×L and may be written as follows:
This matrix is therefore the column vector consisting respectively of the polyphase components of general index (k+1)M−1 (with 0≦k≦p−1), according to a decomposition of type 1 to order L, of the matrix g(z) of products of synthesis and analysis filters.
More explicitly, the element filters of the matrix T(z) may be written as follows:
T
m1(z)=Gil(k+1)M−1(z), 0≦m, l≦L−1, (29)
where i and k are integers obtained from m through:
The notation Gilr(z) (with 0≦r≦L−1) indicates the polyphase component of general index r of the filter Gil(z), resulting from a decomposition to order L.
A possible choice for the parameters a and b consists in taking a=0 and b=M−1. Other choices may be envisaged on condition that the equality (14) is preferentially satisfied so as to end up with a system with minimal delay.
The scheme of the conversion system is given in this case in
The conversion system within the meaning of the invention will now be described according to the aspect of a linear periodically time varying system. It is indicated in this case that the filters of the synthesis and analysis banks are preferentially critical sampling filters.
The scheme of the conversion system given by
To determine the period of this system and find its equivalent structure which clearly illustrates this property, we firstly set out the particular cases L=pM and M=pL hereinbelow.
We denote by fs the sampling frequency of the signal in the time domain, and fs
In the particular case where L=pM, taking account of the scheme of
A
k(z)=[z(k+1)M−1g(z)]|↓L, 0≦k≦p−1, (32)
This system does not have the same bit rate at input and at output. The bit rate at input is fs
It will also be noted that the output of the system Y[n], at the instant nTs
where k=n mod p.
In the other particular case where M=pL, taking account of formula (24) for the conversion matrix applied in this case, the scheme of
This conversion system may be viewed as an LPTV system with period pTs
A
k(z)=[z(p−k)L−1g(z)]|↓M, 0≦k≦p−1, (33)
The bit rate at the input of this system is fs
It is indicated moreover that the output of the conversion system Y[n], at the instant nTs
((n−1)p+k+1)Ts
We now describe the manner of operation of the system in the general case where M and L are not necessarily related by a proportionality relation. Taking account of the form of the matrix T(z) given by relation (15), of the scheme of
A
ij(z)=[zM−1ziM−jLg(z)]|↓K, 0≦j≦p2−1. (34)
The whole set of these subsystems operates in parallel and one of their outputs is chosen periodically as output of the system with a period p1Ts
therefore p1Ts
The two switches. 151 and 152 represented respectively at the input and the output of the structure of
which is also the operating frequency of the transfer matrices. Aij(z).
The output of the system Y[n], at the instant nTs
The bit rate at the input of this system is fs
It is recalled that the expressions for the filters Aij,nk(z) (where 0≦n≦M−1 and 0≦k≦L−1), the elements of a transfer matrix Aij(z), depend on eij, hence on the indices i and j, and may be written as follows:
A
ij,nk(z)=Gnke
and Aij,nk(z)=z−1GnkK+e
Described below is an advantageous implementation of the conversion system within the meaning of the invention.
We will denote by N1 the length of the filters Fk(z) (where 0≦k≦L−1), and by N2 the length of the filters Hn(z) (where 0≦n≦L−1). These notations are used only in the case where these filters have finite impulse responses and have the same length for each of the two filter banks.
The following expressions will be used for the vectors at the input and at the output of the matrix filtering block based on T(z):
U(z)=[U0(z)U1(z) . . . UK−1(z)]T, (39)
and V(z)=[V0(z)V1(z) . . . VK−1(z)]T. (40)
An implementation based on matrix filtering results directly from formula (4) and from the scheme representative of the conversion system of the general
In the case of finite impulse response synthesis and analysis filter banks, all the element filters of the matrix T(z) will also be finite impulse response filters. Conventionally, it is possible in this case to use fast filtering processes based on convolution-multiplication properties.
In the case of infinite impulse response filters, it is indicated that it is possible to factorize certain denominators between the elements of the matrix T(z) during implementation.
An implementation using an overlap transform is now described. It is assumed here that the filters of the synthesis and analysis banks are of the finite impulse response and maximal decimation type.
The conversion matrix T(z) is expressed as follows:
where the Pn are matrices of size K×K, and N corresponds to the maximum of the lengths of the filters Tml(z), the elements of T(z).
This length N, in the most general case, is given by the following expression:
where r0 is given by:
r
0=(N1+N2−2)mod K. (43)
In what follows, the following definition of the length N is used:
taking account of variations on a case by case basis.
The operation of filtering by the matrix T(z) can then be written as follows:
We consider the matrix P, of size NK×K, defined by:
The system can therefore be constructed by a matrix transform P, followed by an operation of, addition with overlap. This implementation is similar to the synthesis part of an overlap transform “LT”, as described in particular in: “Signal Processing with Lapped Transforms”, H. S. Malvar, Artech House, Inc. 1992.
It is represented in
The computation procedure for converting between sub-band domains may then be summarized as follows:
W[n]=PU[n]. (47)
Described hereinbelow is an implementation based on the representation of the system in the guise of an LPTV system, according to a preferred embodiment.
The method presented hereinbelow provides a parallelism in the processing and an efficient utilization of the computer resources (software or hardware) for the implementation of the method. It is therefore a currently preferred embodiment, at least in the case of finite impulse response filter banks.
We consider the matrices Bij, (with 0≦i≦p1−1 and 0≦j≦p2−1), of size NM×L, as the transformed matrices associated with each of the transfer matrices Aij(z) defined above. If these matrices are expressed by
where the matrices Bij,n are of size M×L, then the matrix Bij may be defined as follows:
B
ij
=[B
ij,0
T
B
ij,1
T
. . . B
ij,N−1
T]T. (48)
As each transfer matrix Aij(z) contains filters of identical lengths and which depend on the value of eij, then the corresponding matrix Bij also depends on eij. The matrices Bij contain zero sub-matrices and their forms are given as follows:
B
ij
=[B
ij,0
T
B
ij,1
T . . . Bij,N−3TBij,N−2T0L×M]T. (49)
B
ij
=[B
ij,0
T
B
ij,1
T
. . . B
ij,N−3
T0L×M0L×M]T. (50)
B
ij=[0L×MBij,1T . . . Bij,N−3TBij,N−2TBij,N−1T]T. (51)
It will be noted that this case exists only if. K+emin≦r0−1. Now, emin=M+L−1−K, so that the existence condition for this case is such that r0≧M+L.
B
ij=[0L×MBij,1T . . . Bij,N−3TBij,N−2T0L×M]T. (52)
It is recalled that 0L×M denotes the zero matrix of size L×M.
Advantageously, the zero blocks of the matrices Bij allow a reduction in computation during a transformation of an input vector by this matrix.
The following relation will be noted between the sub-matrices Pn of P and the sub-matrices Bij,n:
The computation procedure for converting between sub-band domains is illustrated in
The addition with overlap of step 2.c is done on vectors of length NM with an overlap of (N−1)M elements.
It will be noted that this procedure is still based on the principle of the scheme of
In the particular case M=pL, we express
with 0≦j≦p−1, and we denote by Bj the corresponding transformed matrix. This matrix has the following form:
The computational steps for converting between sub-band domains, as is illustrated in
In the particular case where L=pM we write:
and we denote by Bi the corresponding transformed matrix. This matrix has the following form:
The computational steps for converting, between sub-band domains is illustrated in
The filter banks most widely used in audio coding are described hereinbelow. It is also indicated that the parameters of the conversion system for various cases of switching between filter banks using such coding formats are given in
For a conversion between modulated cosine FIR filter banks, the filter bank is characterized by the fact that the analysis and synthesis filters are obtained through a cosine modulation of a low-pass prototype filter H(z). For a filter bank with M bands, the expression for the impulse responses of the analysis and synthesis filters is given in by:
with 0≦n≦N−1 and
and where h[n] is the impulse response of the prototype filter, of length N.
Filter banks of this type possess the property of perfect reconstruction if additionally the following conditions are satisfied:
Equations (57), (58) and the conditions above make it possible to completely characterize a modulated cosine and perfect reconstruction filter bank.
These modulated cosine and perfect reconstruction filter banks are the basis of all the filter banks of contemporary audio coders. Even the pseudo-QMF filter bank of the MPEG-1/2 layer I&II coders may be associated with this category provided that the prototype filter is sufficiently well designed to consider that perfect reconstruction is satisfied.
For the conversions between MDCT transforms of different sizes, constituting a particular case of modulated cosine and perfect reconstruction filter banks, an example may be the TDAC filter bank for which N=2M and m=1. The latter may be considered to be an MLT transform (standing for “Modulated Lapped Transform”) also known by the name MDCT (standing for “Modified DCT”). This transform is used in the majority of contemporary frequency audio coders (MPEG-2/4 AAC, PAC, MSAudio, TDAC, etc.).
The expressions for the synthesis and analysis filter banks are given by:
To ensure perfect reconstruction, the window h[n] must satisfy the symmetry condition: h└l┘=h└2M−1−l┘, and power complementarity condition: h2└l┘+h2└l+M┘=1.
A possible and simple choice for the prototype filter satisfying these conditions is given by the following sinusoidal window:
This choice of window is used in the TDAC and G.722.1 coders. Another choice consists in taking a window derived from the Kaiser-Bessel window (or “KBD”) as in the case of MPEG-4 AAC, BSAC, Twin VQ and AC-3 coders.
It will thus be understood that formulae (59) and (60) and the choice of the window h[n] therefore completely define the filter bank corresponding to the MDCT transform.
As far as a conversion between the PQMF filter bank of MPEG-1 and an MDCT is, concerned, it is indicated that the filter bank in the MPEG-1/2 Layer I&II coder is a pseudo-QMF with M=32 bands. These analysis and synthesis filters are defined as follows:
for 0≦k≦31 and 0≦n≦511.
The coefficients h[n] of the impulse response of the prototype filter may be found in:
The values provided in the MPEG-1. Audio Layer I-II
20. standard correspond to the window (−1)lh(2lM+j), with 0≦j≦2M−1 and 0≦l≦m−1.
Described below is an aspect of the invention according to which the conversion between sub-band domains would be combined with a filtering processing.
During a transcoding operation, it is possible to perform an intermediate processing on the decoded signal before recoding it in the new format. Several cases of multimedia signal processing (audio, image and video) are based on linear filtering. The following examples may be cited:
Audio filtering by HRTF filters (“Head Related Transfer Functions”) for sound spatialization. This is one of the interesting cases of combining transcoding and spatialization. A possible application would typically be processing in teleconferencing audio bridges.
With respect to the block diagram of
The conversion system combined with filtering may be modeled by one and the same type of scheme as that represented in
{tilde over (T)}(z)=[v(z){tilde over (g)}(z)]|↓K, (64)
where {tilde over (g)}(z) is the matrix of size M×L whose elements are given by:
{tilde over (G)}
nk(z)=Hn(z)S(z)Fk(z), 0≦n≦M−1, 0≦k≦L−1. (65)
In the expression (64) above, the matrix v(z) corresponds to the definition of formula (17). More explicitly, formula (64) may then be written:
A conversion between sub-band domains combined with a change of sampling frequency will now be described.
We consider here the case where a change of sampling frequency is performed on the synthesized temporal signal before being re-analyzed by the second analysis bank. The system within the meaning of the invention therefore combines conversion between sub-band domains and change of sampling frequency, as illustrated in
In
where Q and R are natural integers assumed to be relatively prime, hence such that gcd(Q,R)=1, without loss of generality.
In this system, the filter SPB(z) is a low-pass filter with normalized cut-off frequency {tilde over (f)}c=min (π/Q,π/R) and with passband gain Q.
Here we define K′ as the least common multiple of QL and RM (K′=1 cm(QL,RM)) and q1, q2 the two natural integers such that:
K′=q1RM and K′=q2QL. (67)
It will be noted that q1 and q2 are relatively prime.
In this case we consider the vector Û(z)=[{circumflex over (X)}0T(z), {circumflex over (X)}1T(z), . . . {circumflex over (X)}q
The conversion system combined with the change of sampling frequency may be modeled by the diagram of
{circumflex over (T)}(z)=[{circumflex over (v)}(z){circumflex over (g)}(z)]|↓K′, (68)
where ĝ(z) is the matrix of size M×L whose elements are given by:
Ĝ
nk(z)=Hn(zR)SPB(z)Fk(zQ), 0≦n≦M−1, 0≦k≦L−1, (69)
and {circumflex over (v)}(z) is the matrix whose elements are defined as follows:
{circumflex over (v)}
ij(z)=ziRM−jQL, 0≦i≦q1−1, 0≦j≦q2−1. (70)
while also complying with the following relation:
{circumflex over (V)}(z)={circumflex over (T)}(z){circumflex over (U)}(z). (71)
According to formula (69), Ĝnk(z) is interpreted as the result of the convolution of the filter Hn(z) oversampled by a factor R, of the filter SPB(z) and of the filter Fk(z) oversampled by a factor Q.
To reduce the delay of the global system, it is possible to choose the matrix {circumflex over (v)}(z) whose elements are defined as follows:
{circumflex over (v)}
ij(z)=zC
where cmax=max {nεN such that h≦RM−1 and n is divisible by gcd (L,R)}.
The same interpretation can be given to the formulation of the matrix {circumflex over (T)}(z) as that given above. Thus, the filters {circumflex over (T)}ml(z), with 0≦m≦q1M−1 and 0≦l≦q2L−1, the elements of this matrix, may be written as follows:
for 0≦m≦q1M−1 and 0≦l≦q2L−1, and where e′ij=cmax+iRM−jQL. The integers i, n and j, k are obtained directly from l and from m by:
The same developments and explanations given for the system for converting between sub-band domains remain valid for this new combined system on replacing the matrix T(z) by {circumflex over (T)}(z) and on taking account of the parameters which characterize it. The system then takes the form of a linear periodically time varying system (LPTV). The preferred process of implementation described above and the simplification of the system in certain particular cases may be envisaged in this application also. It will however be noted that the particular cases to be distinguished in the present system relate to the case where RM and QL are multiples of one another.
In this case, the system according to
Â
ij(z)=[zc
In the case of an implementation using an overlap transform, preferably under the assumption that the synthesis and analysis filter banks, as well as the low-pass filter used for re-sampling, have finite impulse responses, so that:
where the matrices {circumflex over (B)}ij,n are of size M×L,
the following definition of the matrices {circumflex over (B)}ij such as represented in
{circumflex over (B)}
ij
=[{circumflex over (B)}
ij,0
T
{circumflex over (B)}
ij,1
T
. . . {circumflex over (B)}
ij,N′−1
T]T, 0≦i≦q1−1 and 0≦j≦q2−1. (77)
In general, it will be understood that the present invention gives a generic solution for converting, a representation of a signal from one sub-band domain (or transform) to another. The method is preferentially applied in the context where the filter banks used by the two compression systems are of maximal decimation type, as was seen above.
Although the detailed description above is essentially of interest in audio coding, the embodiments described may be envisaged for all sub-band or transform-based coders of multimedia signals, in particular those used in video, image, speech coding, or the like. These embodiments may also be implemented in any device exhibiting a cascade of a synthesis bank and of an analysis bank, in particular in the following examples:
Echo cancellation or sub-band noise suppression algorithm followed by a sub-band coder.
Sub-band decoder followed by echo cancellation or sub-band suppression algorithm.
It will thus be understood that the application of the invention is in no way limited to a simple transcoding between two different coding formats.
Nevertheless, a few applications to audio transcoding will be described below.
Transcoding between audio coding formats is growing in importance having regard to the current diversity of existing terminals and transport and access networks.
According to the service and the delivery scenario for the audio content, the transcoding may intervene at various points in the transmission chain. In what follows, a few possible cases are distinguished.
Broadcasting relates to digital broadcasting systems which use various types of audio coders. Thus, in Europe (DVB standard), MPEG-2 BC audio Layer II coders are indicated. On the other hand, in the USA, the Dolby AC-3 coder is advocated. In Japan, the MPEG-2 AAC coder is chosen. The transcoding mechanism TRANS is advantageous in a gateway GW in the network RES for transmitting audio content arising from a server SER and destined for a first terminal. TER1, equipped with a decoder DEC1 and another terminal TER2, equipped with another decoder DEC2, as represented in
In so-called multicast streaming applications, a single content is preferentially transmitted to several terminals TER1, TER2, for reasons of bandwidth optimization in the transport network RES. Personal adaptation is done at the level of the last node of the network for each end user. These users may have terminals supporting different decoders, hence the usefulness of transcoding in the node of the network, as represented in the previous.
In the case of unicast streaming, the transcoding TRANS (
In “download” mode, the audio content is stored in a given coding format. It is transcoded in real time so as to be compatible with the terminal on each request of a user before being downloaded.
In group communication (teleconferencing, audioconferencing, or the like), the terminals involved may have different capacities in terms of coders/decoders. In a centralized teleconferencing architecture, implementing an audio bridge, a transcoding may intervene at the bridge level.
Table 3 below now indicates a few possible, advantageous, transcodings between audio coding formats according to the fields of application.
Number | Date | Country | Kind |
---|---|---|---|
0409820 | Sep 2004 | FR | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/FR2005/002127 | 8/23/2005 | WO | 00 | 3/18/2008 |