This Patent application claims the benefit, under 35 U.S.C. § 365 of European Patent Application No. 16306129.4 filed on 9 Sep. 2016.
The field of the disclosure is that of signal (or source) separation in a mixture of signals (i.e. in a sum of signals).
More particularly, the disclosure relates to a method for separating signals in a mixture of signals. The disclosure can be applied notably, but not exclusively, to the field of audio source separation.
The disclosure also relates to the corresponding method encoding (or mixing) method and corresponding computer program products, devices and bitstream.
As audio source separation has remained a challenging task, the use of prior information about the sources to guide the separation process has been largely considered in the literature and often referred to as informed source separation (ISS). Such information can be for instance music score (as proposed in “J. Fritsch and M. D. Plumbley, “Score informed audio source separation using constrained nonnegative matrix factorization and score synthesis,” in IEEE Int. Conf. on Acoustics, Speech, and Signal Processing (ICASSP), 2013, pp. 888-891”), text transcript (as proposed in “L. Le Magoarou, A. Ozerov, and N. Q. K. Duong, “Text-informed audio source separation. example-based approach using non-negative matrix partial co-factorization,” Journal of Signal Processing Systems, pp. 1-5, 2014”), or information extracted from the sources themselves (as proposed for instance in “M. Parvaix and L. Girin, “Informed source separation of linear instantaneous under-determined audio mixtures by source index embedding,” IEEE Transactions on Audio, Speech, and Language Processing, vol. 19, no. 6, pp. 1721-1733, 2011.”)
The latter case concerns audio coding applications where the so-called “side information” is extracted at the encoding stage where the original sources are known, and then used to guide the source estimation at the decoding stage where only the mixture is observed. It is also related to spatial audio object coding (SAOC), a recent standardization approach in the MPEG audio group (see “J. Engdegard, B. Resch, C. Falchand O. Hellmuth, J. Hilpert, A. Holzer, L. Terentiev, J. Breebaart, J. Koppens, E. Schuijers, and W. Oomen, “Spatial audio object coding (SAOC)—The upcoming mpeg standard on parametric object based audio coding,” in 124th Audio Engineering Society Convention (AES), May 2008”), for the same type of practical application.
However, as many known parametric coding schemes, the encoding processes of both ISS and SAOC require remarkable computation cost.
There is thus a need for an efficient method for encoding a mixture of signals that allows further separation of the signals after reception of the mixture while helping limiting the overhead in the transmitted bitstream in view of a more effcicient transmission.
A particular aspect of the present disclosure relates to a method for encoding at least two signals.
According to at least one embodiment of the present disclosure, said method comprises:
According to at least one embodiment of the present disclosure, said sampling locations are based on a sampling distribution.
According to at least one embodiment of the present disclosure, said sampling distribution is computed as a function of an energy content of said mixture in said time-frequency representation.
According to at least one embodiment of the present disclosure, said sampling distribution is computed based on a first graph G connecting locations in said time-frequency representation based on a similarity between at least two first feature vectors based on said mixture, similar feature vectors at different locations in said time-frequency representation indicating a contribution of similar signals at said different locations.
According to at least one embodiment of the present disclosure, said sampling distribution is computed by obtaining at least two different first graphs and electing one of said first graphs for deriving the sampling locations, and wherein the method comprises transmitting a parameter representative of said electing.
According to at least one embodiment, the method comprises:
Thus, at least one embodiment of the present disclosure proposes a new and inventive solution for the encoding of at least two signals in the perspective of an efficient transmission in term of bit rate. More precisely, it is proposed to rely on the transmission of the mixture (i.e. the sum) of the signals instead of the transmission of the signals themselves. This thus requires separating the signals from the mixture after reception of the mixture.
For this to be possible, a map Z representative of locations, in the time-frequency (TF) plane, of the signals that compose the mixture to be transmitted is computed, thus allowing for the further separation of the signals. Then, in some embodiments of the present disclosure, only the samples of it, in the form of a list of values are transmitted on top of the mixture signals. Such an embodiment can help limiting the overhead in the bitstream to be transmitted while allowing the separation after reception.
According to at least one embodiment, the method comprises coding the list of values ZΩ, said coding delivering information representative of the first list of values. This representative information can be for instance a second list of values Zc.
Thus, the list of values ZΩ is further coded (e.g. differential coding or an arithmetic coding). Such an embodiment can also help limiting the overhead in the bitstream to be transmitted, and thus the bitrate of the bitstream at the end.
According to another aspect, the present disclosure relates to a method for separating at least one signal from a mixture of at least two signals.
According to at least one embodiment of the present disclosure, said method comprises:
According to at least one embodiment of the present disclosure, said estimating of an estimated map {circumflex over (Z)} comprises filling elements of said estimated map {circumflex over (Z)} corresponding to said sampling locations with values in said first list of values ZΩ associated with said sampling locations in said time-frequency representation.
According to at least one embodiment of the present disclosure, said estimating of said map {circumflex over (Z)} comprises reconstructing missing elements of said map {circumflex over (Z)}, corresponding to locations different from the sampling locations.
According to at least one embodiment of the present disclosure, said sampling locations are based on a sampling distribution.
According to at least one embodiment of the present disclosure, said sampling distribution is computed as a function of an energy content of said mixture in said time-frequency representation.
According to at least one embodiment of the present disclosure, said sampling distribution is computed based on a first graph G connecting locations in said time-frequency representation based on a similarity between at least two first feature vectors based on said mixture, similar feature vectors at different locations in said time-frequency representation indicating a contribution of similar signals at said different locations.
According to at least one embodiment of the present disclosure, said estimated map {circumflex over (Z)} is computed based on said sampling locations, on said list of values ZΩ, and on a second graph G′ connecting locations in said time-frequency representation based on a similarity between at least two second feature vectors based on said mixture, similar feature vectors at different locations in said time-frequency representation indicating a contribution of similar signals at said different locations.
According to at least one embodiment of the present disclosure, the method comprises:
Thus, an estimate {circumflex over (Z)} of the map Z is obtained based on a reduced number of values (compared to the actual size of the map Z), retrieved from the list of values ZΩ. Such an embodiment can allow a separation of the signals in the mixture while helping to limit the amount of information transmitted on top of the mixture.
According to one embodiment, the act of obtaining the sampling locations is carried out using a same sampling distribution as the one used, in a method for encoding, for delivering the first list of values ZΩ.
Thus, according to at least one embodiment, the estimate {circumflex over (Z)} can be based on a correct association between the values in the first list of values ZΩ and the sampling locations.
According to one embodiment, the act of estimating of an estimated map {circumflex over (Z)} comprises filling elements of the estimated map {circumflex over (Z)} corresponding to the sampling locations with values in the first list of values ZΩ associated with the sampling locations in the time-frequency plane.
According to another embodiment, estimating of an estimated map {circumflex over (Z)} comprises reconstructing missing elements of the estimated map {circumflex over (Z)}, corresponding to locations different from the sampling locations.
Thus, the reconstructing can for instance use at least one predefined value. In such an embodiment, the estimate {circumflex over (Z)} of the map Z can be derived in a very simple and efficient way at the decoder side.
According to yet another embodiment, estimating of an estimated map {circumflex over (Z)} comprises:
Such an embodiment allows restoring at least partially the information of the original map Z through the estimation of the estimate {circumflex over (Z)} of the map Z. It can notably take advantage of the information in the graph G′ that indicates the connection between nodes in the time-frequency plane in which a given source signal is active). Such an embodiment can be based only, or mostly, on the knowledge of the mixture signal (thus allowing limiting the bitrate of the bitstream by avoiding transmitting each of the signals).
According to one embodiment, the first list of values ZΩ is obtained by decoding a second list of values Zc.
Thus, the overhead in the bitstream on top of the mixture signal can be further limited.
According to one embodiment, the act of obtaining sampling locations comprises:
According to one embodiment, the act of obtaining a sampling distribution comprises using a predetermined sampling distribution.
Thus, the sampling locations can be derived in a very efficient and robust way for both the encoding and the signal separation.
According to one embodiment, the act of obtaining a sampling distribution comprises computing the sampling distribution as a function of an energy content of the mixture in the time-frequency plane.
Thus, in at least one embodiment, the sampling locations can be derived taking into account the locations where the signals have their energy, i.e. where the information they carry is located in practice.
According to one embodiment, the act of obtaining a sampling distribution comprises:
Thus, the sampling locations can be derived optimally for sampling k-bandlimited signals (see definition for k-bandlimited signals given below in relation with block 150c2 in
According to one embodiment, the act of obtaining a sampling distribution in the method for encoding at least two signals comprises obtaining at least two different first graph and electing one of the first graphs for deriving the sampling locations, and wherein the act of transmitting the mixture and the second list of values comprises transmitting a parameter representative of said electing.
Thus, a method for obtaining the first feature vectors can be elected on the coder side and used on the decoder side.
According to one embodiment, the method for separating at least one signal from a mixture of at least two signals comprises obtaining a parameter to be used for obtaining the first feature vectors in said act of obtaining a sampling distribution.
Thus, the method for obtaining the feature vectors can for instance be selected according to this parameter for the signal separation.
According to one embodiment, the act of obtaining the sampling locations based on the sampling distribution comprises:
Thus, in at least one embodiment, the sampling locations can be derived in a very efficient and robust way for both the encoding and the signal separation when chosen deterministically from a sampling distribution. Conversely, the use of a seed, shared between the encoder and the source separator, can allow however a flexibility in the determination of the sampling locations.
According to one embodiment, the act of obtaining first or second feature vectors enforces a method belonging to the group comprising:
Deep neuronal networks (DNN) can be trained on datasets containing signals of interest. The features can thus be adapted to these types of signals, which can potentially help improving the performance of the method. NMF and NTF are well-known tools to model audio signals. They do not need require pre-training and are thus more generic than DNN.
According to one embodiment, the similarity in between the first feature vectors or in between the second feature vectors can be based on the use of a l1 and/or a l2 norm.
Thus, whereas the l2 norm (also known as Euclidean norm) is the most widely used norm for comparing vectors, the 11 norm is more robust than the l2 norm when comparing feature vectors that are globally similar except at few entries (outliers vectors). The construction of the graph might be more robust to outliers in the feature vectors. The l1 norm is furthermore simpler to compute.
According to one embodiment, at least one of the at least two signals in the mixture can be an audio signal.
The disclosed method can also apply when audio signals are superposed with other kind of signals in the mixture.
Another aspect of the present disclosure relates to a computer program product comprising program code instructions for implementing the above-mentioned methods (in any of their different embodiments), when the program is executed on a computer or a processor.
According to at least one embodiment of the present disclosure, said computer program product comprising program code instructions for implementing, when said program is executed on a computer or a processor, a method for encoding at least two signals, the method comprising:
According to at least one embodiment of the present disclosure, said computer program product comprising program code instructions for implementing, when said program is executed on a computer or a processor, a method for separating at least one signal from a mixture of at least two signals, wherein said method comprises:
Notably, the present disclosure relates to a computer program product comprising program code instructions for implementing, when the program is executed on a computer or a processor, a method for encoding at least two signals comprising:
values based on said first list of values ZΩ; and/or a method for separating at least one signal from a mixture of at least two signals, comprising:
Another aspect of the present disclosure relates to a non-transitory computer-readable carrier medium storing a computer program product which, when executed by a computer or a processor causes the computer or the processor to carry out the above-mentioned methods (in any of their different embodiments).
According to at least one embodiment of the present disclosure, said non-transitory computer-readable carrier medium storing a computer program product which, when executed by a computer or a processor causes the computer or the processor to carry out a method for encoding at least two signals comprising:
According to at least one embodiment of the present disclosure, said non-transitory computer-readable carrier medium storing a computer program product which, when executed by a computer or a processor causes the computer or the processor to carry out a method for separating at least one signal from a mixture of at least two signals, wherein said method comprises:
Notably, the present disclosure relates to a non-transitory computer-readable carrier medium storing a computer program product which, when executed by a computer or a processor causes the computer or the processor to carry out a method for encoding at least two signals comprising:
and/or a method for separating at least one signal from a mixture of at least two signals, comprising:
Another aspect of the present disclosure relates to a device for encoding at least two signals.
According to at least one embodiment of the present disclosure, said device comprises at least one processor configured for:
According to at least one embodiment of the present disclosure, said at least one processor is configured for acquiring at least one of said two signals and said mixture from an input element of a user interface of said device.
According to at least one embodiment of the present disclosure, said at least one processor is configured for:
Such a device is particularly adapted for implementing the method for encoding at least two signals according to the present disclosure (according to any of the various aforementioned embodiments).
Thus, the characteristics and advantages of this device are the same as the method for encoding described above. Therefore, they are not described in more detail.
According to some embodiments of the present disclosure, said at least one processor is configured for acquiring at least one of said two signals and said mixture from an input element of a user interface of said device. Such an input element can be a microphone or an array of microphones for instance.
According to some embodiments of the present disclosure, the device can be for instance a set-top-box, a tablet, a gateway, a television, a mobile video phone, a personal computer, a digital video camera or a car entertainment system.
Another aspect of the present disclosure relates to a device for separating at least one signal from a mixture of at least two signals.
According to at least one embodiment of the present disclosure, said device comprises at least one processor configured for:
According to at least one embodiment of the present disclosure, said device comprises said at least one processor is configured for outputting at least one of said at least two signals and said mixture to an output element of user interface of said device.
According to at least one embodiment of the present disclosure, said at least one processor configured for:
Such a device is particularly adapted for implementing the method for separating at least one signal from a mixture of at least two signals according to the present disclosure (according to any of the various aforementioned embodiments).
Thus, the characteristics and advantages of this device are the same as the method for separating described above. Therefore, they are not described in more detail.
According to some embodiments of the present disclosure, said at least one processor is configured for outputting at least one of said at least two signals and said mixture to an output element of user interface of said device. Such an output element can be an audio speaker for instance.
According to some embodiments of the present disclosure, the device can be for instance a set-top-box, a tablet, a gateway, a television, a mobile video phone, a personal computer, a digital video camera or a car entertainment system.
Another aspect of the present disclosure relates to a bitstream representative of a mixture of at least two signals.
According to some embodiments of the present disclosure, said bitstream comprises said mixture of at least two signals and information representative of a first list of values ZΩ obtained as sampling values of a map Z representative of locations of said at least two signals in a time-frequency plane taken at sampling locations.
According to some embodiments of the present disclosure, the bitstream comprises the mixture of at least two signals and a second list of values based on a first list of values ZΩ obtained as sampling values of a map Z representative of locations of the at least two signals in a time-frequency plane taken at sampling locations.
Such bitstream is delivered by a device implementing the method for encoding at least two signals according to the present disclosure, and intended to be used by a device implementing the method for separating at least one signal from a mixture of at least two signals according to the present disclosure (according to any of their various aforementioned embodiments).
Thus, the characteristics and advantages of this bitstream are the same as the methods described above. Therefore, they are not described in more detail.
Another aspect of the present disclosure relates to a system comprising a first device for encoding at least two signals as disclosed above and a second device for separating at least one signal from a mixture of at least two signals as disclosed above, the second device receiving, from the first device, the mixture of the at least two signals and the second list of values based on the first list of values ZΩ, wherein said obtaining of sampling locations enforce a same predetermined sampling distribution in both first and second devices.
Thus, the estimate {circumflex over (Z)} in the decoder can be based on a correct association between the values in the first list of values ZΩ and the sampling locations.
Other features and advantages of embodiments shall appear from the following description, given by way of indicative and non-exhaustive examples and from the appended drawings, of which:
In all of the figures of the present document, the same numerical reference signs designate similar elements and steps.
The disclosure relates to separating signals of a mixture of signals (i.e. in a sum of signals), can be applied notably, but not exclusively, to the field of audio source separation. As such, the disclosure is of interest in emerging applications in smartphone, TV, games requiring the ability to efficiently compress audio objects on the encoding side (for saving bandwidth in transmission), and to separate them on the decoding side. However, the disclosure can be applied in any other field where it can be of interest of transmitting efficiently a mixture of signal and separating them after reception.
The disclose also relates to generating information enabling such separation and/or to transmitting (and receiving) such information on top of the transmitted mixture. The general principle of the disclosed method consists in computing a map representative of locations, in the time-frequency (TF) plane, of the signals that compose, or at least is included in, the mixture to be transmitted. The map is then sampled taking into account notably of sampling locations in the time-frequency plane and the sampled map transmitted with the mixture. The separation of the signals from the mixture can thus be performed based on an estimate of the map reconstructed from the sampled map.
Referring now to
In block 160, a mixture signal x=s1+. . . +sj can be obtained from the source signals sj, j from 1 to J.
In block 110, a map Z representative of the localization in a time-frequency plane of the signals sj, j from 1 to J, that compose the mixture signal x=s1+. . . +sj is computed.
Indeed, audio signals are usually almost disjoint in the time-frequency representation, i.e. only one source signal sj is predominantly active at each TF point. A binary mask showing this activation for a given source can thus be a good indicator to recover sources from the mixture.
In the present embodiment, for deriving the map Z, a short-term Fourier transform (SIFT) of x is computed and it is assumed that only one signal is active at each TF point. Under this assumption, deriving the map Z is equivalent in identifying which signal j is active in what location in the TF domain.
According to that, denoting X∈F×N and Sj∈F×N the complex matrices of the SIFT coefficients of the mixture x and of the source signal sj respectively, the map Z can be derived by computing first:
for each source signal sj, j from 1 to J. In the above equation, ⊙ and Ø stand for the element-wise product and division, respectively. We then determine which unique source signal is dominantly active at each TF point (f,n) by checking which Mj has the largest entry at (f,n). We thus obtain a map Z∈{1, . . . f}F×N whose entries are
Consequently, the value of the map Z considered at TF point (f,n) can directly give the index of the source j that is active at that TF point.
Note that with the above definition, in the case where all sources signals are inactive at a TF point, then one of the source index can be arbitrarily chosen. In a variant, this is an index corresponding to a predefined state that can be chosen as an “active” source. For instance, the chosen index can be an index that the decoder aiming at separating the source signals can interpret as meaning “no source is active at that TF point (f,n)”.
It can be seen that with the knowledge of X and Z, the activation of all the sources can be determined by constructing, for each source index j, a binary activation matrix M;∈{0,1}F×N that satisfies
and by computing the inverse STFT of X⊙M; to obtain the estimate of source j.
In block 120, the map Z is sampled at sampling locations in the TF plane that can be derived according to the method disclosed in relation with block 150 described below.
In at least some embodiments, such sampling can allow reducing the quantity of information to be transmitted on top of the mixture signal x for allowing a further separation of the source signals sj, j from 1 to J, that compose the mixture.
For this to be possible, sampling locations ω1 to ωm can be provided in a deterministic order so that the corresponding values of the map Z taken at those sampling locations are also sorted in a deterministic order (for instance, in their successive order of generation) and stored accordingly in a list of values ZΩ (e.g.
that takes the form of a row or column vector), Ω={ω1, . . . ωm} denoting the set of sampling locations. The knowledge of the sampling locations and/or of the deterministic order of the sampling locations can therefore allow performing the reverse operation as discussed below in relation with block 220 in
In block 150, the sampling locations used in block 120 for sampling the map Z are obtained.
Various embodiments of the method in block 150 for obtaining those sampling locations are disclosed below in relation with block 150a, 150b and 150c in
In block 130, the values in the list of values ZΩ can be coded for delivering a coded sampled map Zc.
Indeed, it appears that the elements in ZΩ can take only J values. One strategy for representing those elements can thus consist in coding each value using log2 (J) bits. As all values do not appear with the same probability, another strategy can consist in coding this list of symbols using, e.g., arithmetic coding. Still another strategy can consist in using differential coding before arithmetic coding.
In such an embodiment, it can be proposed to reorder the indices in Ω as follows. We travel across the time-frequency plane starting from the lowest time index and lowest frequency, then going towards the largest time index, and continue in zigzag towards the highest frequencies. The indices are reordered in order of appearance during this travel. Even though the indices in Ω are selected at random, the inventor noticed that, in some embodiments, for the sampling distributions that can potentially lead to the best results, this reordering make appear sequence of constant values: the same source remains active for a while. To take potentially advantage of this effect, it is proposed in some embodiments to use differential coding to encode the reordered list. For simplicity, let assume that the indices ω1 to ωm are ordered as just described. We compute the sequence {tilde over (Z)} ∈{0, . . . , J−1}m that satisfies {tilde over (Z)}[1]{tilde over (Z)}[ω1]−1 and
{tilde over (Z)}[i]{tilde over (Z)}[ωi]−{tilde over (Z)}[ωi−1]mod J for all i ∈{2, . . . , m}
which is then coded using arithmetic coding.
In this embodiment, the coded sampled map Zc can be obtained from the sequence {tilde over (Z)}. Block 100 then transmits both the mixture signal x and the coded sampled map Zc in order to allow a further separation of the source signals sj, j from 1 to J, that compose the mixture based on the coded sampled map Zc.
Referring now to
In the embodiments illustrated by
In the exemplary embodiment of block 150a, the sampling distribution (e.g. uniform distribution, Gaussian distribution, etc.) can be obtained in block 150a2.
For instance, it can be a sampling distribution defined in advance, notably a sampling distribution that does not depend on the mixture signal x.
In block 150a1, the sampling locations can then be obtained as a function of the sampling distribution obtained in block 150a2.
For instance, in one variant, the sampling locations can be chosen deterministically from the sampling distribution (e.g. one can choose the locations where the sampling distribution has the largest values). In this variant, it is not required to transmit an extra parameter on top of the coded sampled map Zc as long as the method enforced for separating the signals in the mixture does know the criterion used for selecting the sampling locations deterministically from the sampling distribution and does apply the same operations on its own for generating the sampling locations in the same deterministic order.
In another variant, the sampling locations can be chosen randomly according to the sampling distribution. In practice, a pseudo-random generator may be used. One needs to share the seed of this generator to obtain the same sampling locations at the encoder and the decoder. The seed can whether be transmitted on top of the coded sampled map Zc, or be predefined and fixed in advance, so that there is no need to transmit it. In both cases, the sampling locations are generated in the same deterministic order on both the transmit side and on the receive side for separating the source signals.
In another exemplary embodiment illustrated in block 150b, the sampling distribution is obtained in block 150a2b from a criterion relating to the energy distribution of the mixture x in the spectral domain.
More precisely, in block 150b2, the spectrogram of the mixture x can be obtained and normalized for it to match the characteristics of a sampling distribution.
In block 150b1, the sampling distribution obtained in block 150b2 can be used for obtaining the sampling locations according to one of the variants disclosed above in relation with block 150a1.
In the exemplary embodiments illustrated in block 150c, the sampling distribution is obtained in block 150a2c from a graph G connecting locations in the time-frequency plane based on the characteristics of the mixture signals x. Here the graph G is built for providing information on the TF points on which a given source signal is active. In other words, the inventors propose, in some embodiments, to use a graph that connects nodes in the time-frequency plane in which a given source signal is active for deriving an optimal sampling distribution for obtaining the sampling locations to be used for sampling the map Z.
However, it must be noted that the inventors propose as well to use, in some embodiments, such graph, that links the nodes in the time-frequency plane in which a given source signal is active, for obtaining (or estimating) an estimate {circumflex over (Z)} of the map Z from the list of values ZΩ as disclosed below in relation with block 250 in
Back to block 150c, we get from a general perspective that such graph G can be defined as the association of a set of nodes (i.e. the locations in the time-frequency plane in the present application) of edges (i.e. the nodes that can be estimated to be “close” to, or in the “neighborhood” of a given node according to a given metric), and an adjacency matrix A ∈ such that:
A[i,j]=A[j,i]>0 if (i,j)∈ ε and A[i,j]=0 otherwise.
It must be noted that the adjacency matrix, that links the nodes in the edges, is indeed symmetrical, i.e. if a i-th node is decided to be “adjacent” (in the meaning that the same source signal is active in the two nodes) to a j-th node, then it seems reasonable that the j-th node is decided to be “adjacent” to the i-th node. Consequently, the element a(i,j) in A that reflects this “adjacent” characteristic between the i-th node and the j-th node is equal to element a(j,i).
In at least one embodiment, the graph can be built based on the similarity between feature vectors associated to the locations (i.e. the nodes) in the time-frequency plane, similar feature vectors at different locations in the time-frequency plane indicating a contribution of similar source signals at those different locations in the time-frequency plane.
Consequently, in block 150c4, feature vectors can be obtained from the mixture signal x, and only from the mixture signal.
Indeed, at least some embodiments of the present disclosure can help limiting the overhead in the bitstream on top of the mixture signal. Notably, some embodiments of the present disclosure propose a method in which the feature vectors, the graph G, and thus the sampling distribution at the end (which needs to be obtained on the receive side too when separating the source signals from the mixture), can be obtained independently from any additional information in the bitstream on top of the mixture signal x. In other embodiments, some other parameters (like a parameter representative of an elected graph as detailed below) can be also transmitted.
In the illustrated embodiment, it is proposed to use for instance a Non-negative Matrix Factorization (NMF) method for obtaining the feature vectors from the mixture signal x.
More particularly, the spectrogram V ∈F×N of x (i.e. V[f,n]=|X[f,n]|2) can be first computed and then factorized by solving the following optimization problem (see “C. Févotte, N. Bertin, and J. Durrieu, “Non-negative matrix factorization with the ltakura-Saito divergence with application to music analysis,” Neural Computation, vol. 21, no. 3, pp. 793-830, 2009”):
is the Itakura-Saito (IS) divergence—as an example of the considered divergence. However, other types of divergences such as Kullback-Leibler divergence or Euclidien distance can also be used.
In this NMF, W* is the spectral dictionary, H* is the time activation matrix, and Q is the number of NMF components. To solve (Eq-2), the matrices W and H can be initialized with random non-negative values and can be iteratively updated via the multiplicative update rule until convergence, as detailed for instance in the above-cited reference.
When Q≧J is appropriately chosen, the above NMF has the tendency to isolate the spectral characteristics of each source, i.e. W*[:,I] is a spectral characteristic of one of the source and H*[I,:] indicates the contribution of this characteristic in the overall spectrogram at each instant (Note that one source is usually characterized by several NMF components). At each TF point (f,n), the following Q-dimensional feature vector f(f,n) is obtained
f
(f,n)=(W[f,1]H[1, n], . . . W[f,Q]H[Q,n])T.
This feature vector can provide hint to indicate which spectral characteristic is active at the TF point (f,n). As only one source is essentially active at each TF point, connecting feature vectors f(f,n) that are similar connects nodes for which the same source is active.
In other embodiments, feature vectors can be obtained based on a Deep Neural Network method (DNN) (see US patent document U.S. Pat. No. 9,368,110 B1) or a Non-negative Tensor Factorization (NTF) (see “A. Ozerov, A. Liutkus, R. Badeau, and G. Richard, “Coding based informed source separation: Nonnegative tensor factorization approach,” IEEE Transactions on Audio, Speech, and Language Processing, vol. 21, no. 8, pp. 1699-1712, August 2013”).
Deep neuronal networks (DNN) can indeed be trained on datasets containing signals of interest. The feature vectors can thus be adapted to these types of signals, which can potentially help improving the performance of the method. NMF and NTF are well-known tools to model audio signals. They do not need require pre-training and are thus more generic than DNN.
In block 150c3, the graph G is built based on the feature vectors obtained from the mixture signal x in block 150c4.
For that, and in order to simplify notations, let i ∈ {1, . . . , NF} index each time frequency point (f,n), and substitute fi for f(f,n). Let also z ∈ {1, . . . J}NF be the vectorised version of Z.
In order to construct the graph G, we connect each feature vector to its eight nearest neighbors (in the sense of l1 norm), which gives a set | 8NF edges. The l1 norm is a mathematical norm for vectors which is defined as follows. For any vector χ ∈N, the l1 norm satisfies ∥χ∥1=|χ[i]| (http://mathworld.wolfram.com/L1-Norm.html). This norm is also called the taxicab norm or the Manhattan norm (https://en.wikipedia.org/wiki/Norm_(mathematics)#Taxicab_norm_or_Manhattan_norm).
The L1 norm can be used for instance for comparing feature vectors that are globally similar except at few entries (outliers vectors). The adjacency matrix A ∈ NF×NF of G satisfies
where μ>0 is the mean of the values in the set {∥fi−fi′∥1:(i,i′)∈ ε}.
As the quality of the feature vectors depends on the choice of Q, in variants, several NMF can be performed for different values of Q and all the feature vectors obtained can be concatened before constructing the graph G.
In a variant, this is the l2 norm that is used for estimating the similarity in between the feature vectors, and not the l1 norm. The l2 norm is a mathematical norm for vectors which is defined as follows. For any vector χ ∈ , the l2 norm satisfies ∥χ∥2=(Σi=1N|χ[i]|2)1/2 (http://mathworld.wolfram.com/L2-Norm.html). This norm is also called the Euclidean norm (https://en.wikipedia.org/wiki/Norm_(mathematics)#Euclidean_norm).
In block 150c2, the sampling distribution is computed based on the graph G.
More particularly, in the present embodiment, the sampling probability distribution is defined on the nodes of G. This distribution can be represented by p ∈ . We obviously have ∥p∥1=1. The i-th entry of p, i.e. pi represents the probability of sampling node i. The samples are then chosen by selecting independently m different nodes according to p. We denote the set of selected indices Ω{ω1, . . . ωm} ⊂.
For that, let introduce the degree matrix D ∈ which is the diagonal matrix with entries satisfying
The Laplacian of the graph is then defined as L=D−A. It is a real, symmetric, positive semi-definite matrix following the properties of A introduced above. Its real normalized eigenvectors form an orthonormal matrix
U=(u1, . . . , )∈ .
The corresponding real eigenvalues are denoted 0=λ1≦. . . ≦.
Here, we recall that for any signal z ∈ living on the nodes of G, its Fourier representation is {circumflex over (z)} UT z (Note that the Fourier coefficients {circumflex over (z)} are ordered in increasing frequencies). A signal z is k-bandlimited on G if its Fourier coefficients {circumflex over (z)}k+1, . . . , are null as recalled in the above cited reference. More generally, we say that a signal is smooth on G if its energy is essentially concentrated at the lowest frequencies.
The probability of sampling node i, i.e. pi, is then defined as
where δi is the Dirac centered at node i and Uk=(u1, . . . , uk). It is indeed proven in “G Puy, N. Tremblay, R. Gribonval, and P. Vandergheynst, “Random sampling of bandlimited signals on graphs,” Appl. Comput. Harmon. Anal., in press, 2016” that in that case only m=0 (k. log (k)) measurements can be sufficient to sample a k-bandlimited signal, with high probability.
In the illustrated embodiments, in block 150c1, the sampling distribution obtained in block 150c2 can be used for obtaining the sampling locations according to one of the variants disclosed above in relation with block 150a1.
In another embodiment, feature vectors can be obtained by enforcing different methods (e.g. NMF, DNN or NTF) in block 150c4 so that different graphs are built.
Then, at least one graph G is elected, whether manually or automatically, for deriving the sampling locations. Electing this graph can comprise, for example, by performing source separation using the different graphs and computing the source separation quality. For instance, the graph yielding the best result can be elected. The quality can be computed, for example, by the signal-to-distorsion ratio (SDR). The SDR is a benchmarked metric grading the overall signal distortion (see “E. Vincent, R. Gribonval, and C. Fvotte, “Performance measurement in blind audio source separation,” IEEE Transactions on Audio, Speech, and Language Processing, vol. 14, no. 4, pp.1462-1469, 2006”). One can also measure the quality using the signal-to-noise ratio or any perceptual quality measure such as the PAQM (see “J. G. Beerends and J. A. Stemerdink, “A Perceptual Audio Quality Measure Based on a Psychoacoustic Sound Representation”, J. Audio Eng. Soc, vol. 40(12), pp. 963-978, 1992.”
In one variant, a parameter representative of the method used for obtaining the feature vectors used for building the graph G is transmitted in block 100 on top of the mixture signal x and of the list of values ZΩ, thus allowing determining feature vectors on the receive side for further separation of the source signals in the mixture based on the same method.
Referring now to
In block 230, the decoding of the sampled map Zc is performed in order to obtain the list of values ZΩ that was encoded in block 130. As such, the inverse coding scheme as performed in block 130 is implemented in block 230 (e.g. inverse differential coding or inverse arithmetic coding)
The sampling locations can be obtained in block 250, and used in block 220 for estimating an estimate {circumflex over (Z)} of the map Z.
The various embodiments disclosed above in relation with block 150 in
However, the sampling locations obtained in block 250 should be the same as the ones used on the transmit side for sampling the map Z. Indeed, as detailed below in relation with block 220, this allows reconstructing correctly the estimate {circumflex over (Z)} of the map Z based on the list of values ZΩ delivered by the decoding act in block 230.
This may require using the same sampling distribution as on the transmit side in block 150, and thus in the embodiments corresponding to the method disclosed in relation with block 150c, to enforce the same method for obtaining the feature vectors. In the embodiment where feature vectors can be obtained enforcing different methods (e.g. NMF, DNN or NTF) on the transmit side in block 150c4 (thus leading to having different graphs built for having one to be elected), the parameter sent on top of the mixture signal x and of the list of values ZΩ can allow selecting the “correct” method (that is to say the method that has been elected and used at the transmitting side) to be enforced in block 250 for obtaining the feature vectors and thus the graph G′.
In block 220, an estimate {circumflex over (Z)} of the map Z can be obtained based on the list of values ZΩ obtained in block 230 and on the sampling locations obtained in block 250.
Based on the sampling locations, the elements of the map Z corresponding to those sampling locations in the TF plane can be filled with corresponding elements in the list of values ZΩ according to the method disclosed above in relation with block 120 in
More precisely, in some embodiments, it can be assumed that the sampling locations obtained in block 250 are provided in a deterministic order so that a value sorted with a given rank r in the ordered list of values ZΩ can be associated to a sampling location at TF point (f,n) corresponding to the r-th sampling location obtained in block 250.
However, for this operation to allow achieving the correct estimated map, this requires also that the same sampling locations are obtained in the same deterministic order in block 250 as in block 150 for the generation of the list of values ZΩ. In particular, the same sampling distribution may be used.
After the association of the values in the list of values ZΩ with the corresponding elements of the estimated map {circumflex over (Z)}, a predefined value (e.g. a null value) is assigned to the remaining elements of the estimated map {circumflex over (Z)}.
In this embodiment, the information in the estimated map {circumflex over (Z)} only corresponds to the information present in the list of values ZΩ that was transmitted with the mixture signal x. The source signals sj, j from 1 to J, in x can then be separated based on this estimated map {circumflex over (Z)} in block 210.
In another embodiment disclosed in relation with block 220a, the missing information can be estimated on the basis of a graph in order to take advantage of the information in this object that indicates the connection between nodes in the time-frequency plane in which a given source signal is active.
For that, in block 220a3, feature vectors can be obtained based on the received mixture signal x. In some embodiments, like in the illustrated embodiment, the feature vectors can be obtained independently from any other information. Here again, a motivation for such approach can be to help limiting the additional information to be transmitted in the bitstream on top of the mixture signal x.
According to that, it can be proposed to use a method as disclosed above in relation with block 150c4 for obtaining feature vectors (e.g. NMF, DNN or NTF). However, it must be noted that the method used for deriving the present feature vectors may be different than the one used for deriving the feature vectors involved in the determination sampling distribution both on the transmit side (see block 150c4) and on the receive side (see block 250). Indeed, whereas the method used in blocks 150c4 and 250 should be the same for achieving the same sampling locations both on the transmit side and on the receive side for achieving the source signal separation, the method used in block 220a3 can be different.
In block 220a2, a graph G′ is built based on the feature vectors obtained in block 220a3.
For this the method disclosed in relation with block 150c3 in
In block 220a1, an estimated map {circumflex over (Z)} is estimated based on the graph G′ obtained in block 220a2, on the list of values ZΩ obtained in block 230, and on the sampling locations obtained in block 250.
In one embodiment, it is proposed to reconstruct the binary activation matrix M*j for at least some of the source signals sj, j from 1 to J, (for instance for each of the source signals sj), from which one can deduce an estimate {circumflex over (Z)} of the map Z (recall the correspondence between those entities given by (Eq-1)). More precisely, it is proposed to reconstruct the binary masks m*j (m*j ∈{0,1}NF) that are the vectorized version of M*j.
Indeed, if Z is smooth on G′ then the masks m*j are also smooth on G′ by construction. The sampled binary mask (m*j)Ω (i.e. the binary mask m*j restricted to the sample locations, in the same way as ZΩ is the restriction of Z to those sample locations according to the method of association between the values in ZΩ and the sample locations as disclosed in relation with blocks 150 and 220) can thus directly be deduced from ZΩ as we have
The J masks mj can thus be reconstructed using the reconstruction result given in “G Puy, N. Tremblay, R. Gribonval, and P. Vandergheynst, “Random sampling of bandlimited signals on graphs,” Appl. Comput. Harmon. Anal., in press, 2016” which proves that one can stably and accurately estimate (m*j)Ω by solving
where γ>0, L is the sparse Laplacian matrix defined above in relation with block 150c2, and P ∈m×m is the diagonal matrix that satisfies
P
u=pu−1/2 .
In one embodiment, the estimated {tilde over (m)}j of the mask can be obtained by solving the constrained version of the above problem (obtained for γ→0+), i.e.
However, in other embodiments, other constrained version of the above problem can be used.
In those embodiments, the source signals can then be separated from the mixture using the estimated masks {tilde over (m)}j as an estimate {tilde over (Z)} of the map in block 210.
Referring now to
The device can be for instance an audio and/or video content acquiring device, like a smart phone or a camera, comprising for instance a user interface including input elements like a microphone, an array of microphones, and/or at least one camera. It can also be a device without any audio and/or video acquiring capabilities but with audio and/or video processing capabilities. For instance, in some embodiment, the electronic device can comprise a communication interface, like a receiving interface to receive an audio and/or an audio video signal like at least one of the source signals sj, or a mixture of those signals, to be processed according to at least one of the methods of the present disclosure. This communication interface is optional. Indeed, in some embodiments, the electronic device can process audio and/or audio-visual signals stored in a medium readable by the electronic device, received or acquired by the electronic device.
The device can also comprise a user interface comprising output means, like a display and/or a loudspeaker, adapted to output at least one of the source signals s,, or the mixture of those signals, processed according to at least one of the methods of the present disclosure.
In an embodiment, the devices 300, 400 for implementing the disclosed methods comprise a non-volatile memory 303, 403 (e.g. a read-only memory (ROM) or a hard disk), a volatile memory 301, 401 (e.g. a random-access memory or RAM) and a processor 302, 402. The non-volatile memory 303, 403 is a non-transitory computer-readable carrier medium. It stores executable program code instructions, which are executed by the processor 302, 402 in order to enable implementation of the methods described above (method for encoding signals and method for separating signals in a mixture) in their various embodiment disclosed in relationship with
Notably, in some embodiments, the processor can be configured for:
Notably, in some other embodiments, the processor can be configured for:
Upon initialization, the aforementioned program code instructions are transferred from the non-volatile memory 303, 403 to the volatile memory 301, 401 so as to be executed by the processor 302, 402. The volatile memory 301, 401 likewise includes registers for storing the variables and parameters required for this execution.
All the steps of the above disclosed methods (method for encoding signals and method for separating signals in a mixture) may be implemented equally well:
by the execution of a set of program code instructions executed by a reprogrammable computing machine such as a PC type apparatus, a DSP (digital signal processor) or a microcontroller. This program code instructions can be stored in a non-transitory computer-readable carrier medium that is detachable (for example a floppy disk, a CD-ROM or a DVD-ROM) or non-detachable; or
by a dedicated machine or component, such as an FPGA (Field Programmable Gate Array), an ASIC (Application-Specific Integrated Circuit) or any dedicated hardware component.
In other words, the disclosure is not limited to a purely software-based implementation, in the form of computer program instructions, but that it may also be implemented in hardware form or any form combining a hardware portion and a software portion.
As can be appreciated by one skilled in the art, aspects of the present principles can be embodied as a system, method, or computer readable medium. Accordingly, aspects of the present disclosure can take the form of a hardware embodiment, a software embodiment (including firmware, resident software, micro-code, and so forth), or an embodiment combining software and hardware aspects that can all generally be referred to herein as a “circuit”, “module” or “system”. Furthermore, aspects of the present principles can take the form of a computer readable storage medium. Any combination of one or more computer readable storage medium may be utilized.
A computer readable storage medium can take the form of a computer readable program product embodied in one or more computer readable medium and having computer readable program code embodied thereon that is executable by a computer. A computer readable storage medium as used herein is considered a non-transitory storage medium given the inherent capability to store the information therein as well as the inherent capability to provide retrieval of the information therefrom. A computer readable storage medium can be, for example, but is not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing.
It is to be appreciated that the following, while providing more specific examples of computer readable storage media to which the present principles can be applied, is merely an illustrative and not exhaustive listing as is readily appreciated by one of ordinary skill in the art: a portable computer diskette, a hard disk, a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing.
Thus, for example, it can be appreciated by those skilled in the art that the block diagrams presented herein represent conceptual views of illustrative system components and/or circuitry of some embodiments of the present principles. Similarly, it can be appreciated that any flow charts, flow diagrams, state transition diagrams, pseudo code, and the like represent various processes which may be substantially represented in computer readable storage media and so executed by a computer or processor, whether such computer or processor is explicitly shown.
Number | Date | Country | Kind |
---|---|---|---|
16306129.4 | Sep 2016 | EP | regional |