The invention relates to processing speech in noisy surroundings.
The invention relates particularly, but in non-limiting manner, to processing speech signals picked up by telephone devices for motor vehicles.
Such appliances include a sensitive microphone that picks up not only the user's voice, but also the surrounding noise, which noise constitutes a disturbing element that, under certain circumstances, can go so far as to make the speaker's speech incomprehensible. The same applies if it is desired to perform shape recognition voice recognition techniques, since it is difficult to recognize shape for words that are buried in a high level of noise.
This difficulty, which is associated with surrounding noise, is particularly constraining with “hands-free” devices. In particular, the large distance between the microphone and the speaker gives rise to a relatively high level of noise that makes it difficult to extract the useful signal buried in the noise.
Furthermore, the very noisy surroundings typical of the motor car environment present spectral characteristics that are not steady, i.e. that vary in unforeseeable manner as a function of driving conditions: driving over deformed surfaces or cobblestones, car radio in operation, etc.
Some such devices provide for using a plurality of microphones, generally two microphones, and they obtain a signal with a lower level of disturbances by taking the average of the signals that are picked up, or by performing other operations that are more complex. In particular, a so-called “beamforming” technique enables software means to establish directionality that improves the signal-to-noise ratio, however the performance of that technique is very limited when only two microphones are used.
Furthermore, conventional techniques are adapted above all to filtering noise that is diffuse and steady, coming from around the device and occurring at comparable levels in the signals that are picked up by both of the microphones.
In contrast, noise that is not steady, i.e. that noise varies in unforeseeable manner as a function of time, is not distinguished from speech and is therefore not attenuated.
Unfortunately, in a motor car environment, such non-steady noise that is directional occurs very frequently: a horn blowing, a scooter going past, a car overtaking, etc.
One of the difficulties in filtering such non-steady noise stems from the fact that it presents characteristics in time and in three-dimensional space that are very close to the characteristics of speech, thus making it difficult firstly to estimate whether speech is present (given that the speaker does not speak all the time), and secondly to extract the useful speech signal from a very noisy environment such as a motor vehicle cabin.
One of the objects of the invention is to take advantage of the multi-microphone structure of the device in order to detect such non-steady noise in a three-dimensional spatial manner, and then to distinguish amongst all of the non-steady components (also referred to as “transients”), those that are non-steady noise components and those that are speech components, and finally to process the signal as picked up in order to de-noise it in effective manner while minimizing the distortions introduced by the processing.
Below, the term “lateral noise” is used to designate directional non-steady noise having an arrival direction that is spaced apart from the arrival direction of the useful signal, and the term “privileged cone” is used to designate the direction or angular sector in three-dimensional space in which the source of the useful signal (speaker's speech) is located relative to the array of microphones. When a sound source is detected as lying outside the privileged cone, that sound is therefore lateral noise, and it is to be attenuated.
The starting point of the invention consists in associating the non-steady properties in time and frequency with directionality in three-dimensional space in order to detect a type of noise that is otherwise difficult to distinguish from speech, and then to deduce therefore a probability that speech is present, which probability is used in attenuating the noise.
More precisely, the invention provides a method of de-noising a noisy sound signal picked up by a plurality of microphones of a multi-microphone audio device that is operating in noisy surroundings. The noisy sound signal comprises a useful speech component coming from a directional speech source and an unwanted noise component, the noise component itself including a lateral noise component that is non-steady and directional.
By way of example, one such method is disclosed by: I. Cohen, Analysis of two-channel generalized sidelobe canceller (GSC) with post-filtering, IEEE Transactions on Speech and Audio Processing, Vol. 11, No. 6, November 2003, pp. 684-699.
Essentially, and in a manner characteristic of the invention, the method comprises the following processing steps that are performed in the frequency domain:
a) combining a plurality of signals picked up by the corresponding plurality of microphones to form a noisy combined signal;
b) from the noisy combined signal, estimating a pseudo-steady noise component contained in said noisy combined signal;
c) from the pseudo-steady noise component estimated in step b) and from the noisy combined signal, calculating a probability of transients being present in the noisy combined signal;
d) from the plurality of signals picked up by the corresponding plurality of microphones and from the probability of transients being present as calculated in step c), estimating a main arrival direction of transients;
e) from the main arrival direction of transients as estimated in step d), calculating a probability of speech being present on the basis of a three-dimensional spatial criterion suitable for distinguished amongst the transients between useful speech and lateral noise; and
f) from the probability of speech being present as calculated in step e), and from the noisy combined signal, selectively reducing noise by applying variable gain specific to each frequency band and to each time frame.
According to various advantageous subsidiary implementations:
There follows a description of an implementation of the method of the invention with reference to the accompanying FIGURE.
The method of the invention is implemented by software means that can be broken down schematically as a certain'number of modules 10 to 24 as shown in
The processing is implemented in the form of appropriate algorithms executed by a microcontroller or by a digital signal processor. Although for clarity of description the various processes are shown as being in the form of distinct modules, they implement elements that are common and that correspond in practice to a plurality of functions performed overall by the same software.
The signal that is to be de-noised comes from a plurality of signals picked up by an array of microphones (which in a minimum configuration may comprise an array of only two microphones) arranged in a predetermined configuration.
The array of microphones picks up the signal emitted by the useful signal source (speech signal), and the differences of position between the microphones give rise to a set of phase shifts and variations in amplitude in the recordings of the signals as emitted by the useful signal source.
More precisely, the microphone of index n delivers a signal:
xn(t)=an×s(t−τn)+vn(t)
where an is the amplitude attenuation due to the loss of energy between the position of the sound source s and the microphone, τn is the phase shift between the emitted signal and the signal received by the microphone, and vn represents the value of the diffuse noise field at the position of the microphone.
Insofar as the source is spaced apart from the microphone by at least a few centimeters, it is possible to make the approximation that the sound source emits a plane wave. The delays τn can then be calculated from the angle θs defined as the angle between the right bisectors between microphone pairs (n, m) and the reference direction corresponding to the source s of the useful signal. When the system under consideration has two microphones with a right bisector that intersects the source, then the angle θs is zero.
Fourier Transform of the Signals Picked Up by the Microphones (Blocks 10)
The signal in the time domain xn(t) from each of the N microphones is digitized, cut up into frames of T time points, time windowed by a Hanning type window, and then the fast Fourier transform FFT (short-term transform) Xn(k,l) is calculated for each of these signals:
Xn(k,l)=an·dn(k)×S(k,l)+Vn(k,l)
with:
dn(k)=e−i2πfkτn
l being the index of the time frame;
k being the index of the frequency band; and
fk being the center frequency of the frequency band of index k.
Building a Partially De-Noised Combined Signal (Block 12)
The signals Xn(k,l) may be combined with one another by a simple prefiltering technique of delay and sum type beamforming that is applied to obtain a partially de-noised combined signal X(k,l):
Specifically, it should be observed that since the number of microphones is limited, this processing achieves only a small improvement in the signal/noise ratio, of the order of only 1 decibel (dB).
When the system under consideration has two microphones of right bisector that intersects the source, the angle θS is zero and the processing comprises mere averaging from the two microphones.
Estimating the Pseudo-Steady Noise (Block 14)
The purpose of this step is to calculate an estimate of the pseudo-steady noise component {circumflex over (V)}(k,l) that is present in the signal X(k,l).
Very many publications exist on this topic, given that estimating and reducing pseudo-steady noise is a well-known problem that is quite well resolved. Various methods are effective and usable for obtaining {circumflex over (V)}(k,l), in particular an algorithm for estimating the energy of the pseudo-steady noise by minima control recursive averaging (MCRA), such as that described by I. Cohen and B. Berdugo in Noise estimation by minima controlled recursive averaging for robust speech enhancement, IEEE Signal Processing Letters, Vol. 9, No. 1, pp. 12-15, January 2002.
Calculating the Probability of Transients being Present (Block 16)
The term “transients” covers all non-steady signals, including both the useful speech and sporadic non-steady noise, that may present energy that is equivalent or sometimes greater than that of the useful speech (a vehicle going past, a siren, a horn, speech from other people, etc.).
It is possible to detect these transients with the help of the previously established estimate of the pseudo-steady noise component {circumflex over (V)}(k,l) by subtracting that estimate from the overall signal X(k,l).
The detailed description below of blocks 18 and 20 explains how it is possible to discriminate amongst these transients between those that correspond to useful speech and those that correspond to non-steady noise and that have characteristics that are similar to useful speech.
The processing performed by the block 16 consists solely in calculating a probably pTransient(k,l) that transient signals are present, without making any distinction between useful speech and non-steady unwanted noise. The algorithm is as follows:
For each frame l and for each frequency band k,
The constants TSRmin and TSRmax are selected to correspond to situations that are typical, being close to reality.
Calculating the Arrival Directions of Transients (Block 18)
This calculation takes advantage of the fact that, unlike the pseudo-steady component of noise that is diffuse, transients are often directional, i.e. they come from a point sound source (such as the mouth of the speaker or the useful speech, or the engine of a motorcycle for lateral noise). It is therefore appropriate to calculate the arrival direction of such signals, which direction is generally well defined, and to compare this arrival direction with the angle θs, corresponding to the direction from which useful speech originates, so as to determine whether the non-steady signal under consideration is useful or unwanted, and thus discriminate between useful speech and non-steady noise.
The first step consists in estimating the arrival direction of the transient.
The method used here is based on making use of the probability pTransient(k,l) that transients are present as determined by the block 18 in the manner described above.
More precisely, three-dimensional space is subdivided into angular sectors, each corresponding to a direction that is defined by an angle θi,iε[1,M] (e.g. M=19 for the following collection of angles {−90°, −80°, . . . , 0°, . . . +80°, +90°}). It should be observed that there is no connection between the number N of microphones and the number M of angles tested. For example, it is entirely possible to test ten angles (M=10) while using only one pair of microphones (N=2).
Each angle θi is tested to determine which is the closest to the arrival direction of the non-steady signal under investigation. To do this, each pair of microphones (n,m) is taken into consideration and a corresponding estimate of the arrival direction Pn,m(θi, k,l) is calculated, with the modulus thereof being at a maximum when the angle θi under test is the closest to the arrival direction of the transient.
By way of example, this estimator may rely on a cross-correlation calculation having the form:
Pn,m(θi,k,l)=E(Xm(k,l)·
with
ln,m being the distance between the microphones of indices n and m; and
c being the speed of sound.
A conventional first method consists in estimating the arrival direction as the angle that maximizes the modulus of this estimator, i.e.:
Another method, that is preferably used here, consists in weighting the estimator Pn,m(θi,k,l) by the probability pTransient(k,l) of the presence of transients and in defining a new decision strategy. The corresponding arrival direction estimator is then:
PNew
The estimator may be averaged over the pairs of microphones (n,m):
Integrating the probability of the presence of transients into the arrival direction estimator presents three major advantages:
There follows an explanation of the decision-making rules that make it possible on the basis of PNew:
A direction estimate can be supplied only if that ∥PNew(θmax,k,l)∥ exceeds a given threshold PMIN.
This first rule serves to ensure over the portion (k,l) of the under consideration that the probability of a transient being present and the cross-correlation level are high enough for estimation to be well-founded.
If θmax lies outside the privileged cone, an angle estimate is confirmed only if PNew is increasing monotonically over the range [θs−θmax; θmax].
This second rule analyses the content of the “privileged cone”, corresponding to the angular sector within which the source s is centered and that presents an angular extent of θ0. This privileged cone is defined by angles θ such that |θ−θs|≦θ0.
“Lateral” noise corresponds to a signal having an arrival direction that lies outside the privileged cone, and it is therefore considered that lateral noise is present if |θmax-θs| exceeds the threshold θ0.
To confirm this detection of lateral noise, it is necessary to verify that a useful speech signal is not simultaneously being input to the system.
To do this, PNew(θmax,k,l) is compared with the values of PNew(θi,k,l) as obtained for other angles, in particular those belonging to the privileged cone. This rule thus serves to ensure that there is no local maximum in the privileged cone.
If θmax lies outside the privileged cone for the first occasion in the frame l under consideration, then an angle estimate is validated only if:
PNew(θmax,k,l)≧α1×PNew(θmax,k,l−1)
and if:
If lateral noise is detected, this third rule takes earlier frames into consideration in order to avoid false triggering. It is applied only to the first frame in which lateral noise is presumed, and it verifies that PNew(θmax,k,l) is significantly greater than the corresponding data obtained over the five preceding frames.
The parameters α1 and α2 are selected so as to correspond to situations that are difficult, i.e. close to reality.
If the above three Rules 1 to 3 are satisfied, the direction estimate {circumflex over (θ)}(k,l) is given by:
{circumflex over (θ)}(k,l)=θmax
The last two rules serve to prevent interruptions in the detection of lateral noise. After a detection period, they continue to maintain this state over a time lapse referred to as the “hangover” time, even when the above decision rules are no longer satisfied. This makes it possible to detect possible low-energy periods in non-steady noise.
Rule 4:
If {circumflex over (θ)}(k,l−1) lies outside the privileged cone (for the preceding frame);
if cpt1≦HangoverTime1 (i.e. if the Hangover period has not terminated); and
if PNew({circumflex over (θ)}(k,l−1),k,l) is greater than a given threshold P1, then the angle estimate is maintained and cpt1 is incremented.
Rule 5:
If {circumflex over (θ)}(k,l−1) lies outside the privileged cone (for the preceding frame);
if cpt2≦HangoverTime2; and
if
is greater than a given threshold P2, then the angle estimate is maintained and cpt2 is incremented.
If one of these last two rules (Rule No. 4 or Rule No. 5) is satisfied, it takes priority, giving the result {circumflex over (θ)}(k,l)={circumflex over (θ)}(k,l−1), thus with possible correction of the value of {circumflex over (θ)}(k,l) which is not made equal to θmax but which is maintained at its preceding value.
To summarize, the calculation of {circumflex over (θ)}(k,l) follows three possible paths:
i) if Rule No. 4 or Rule No. 5 is satisfied, then {circumflex over (θ)}(k,l)={circumflex over (θ)}(k,l−1);
ii) otherwise (neither Rule No. 4 nor Rule No. 5 is satisfied), if Rules Nos. 1, 2, and 3 are satisfied, then {circumflex over (θ)}(k,l)=θmax;
iii) else (neither Rule No. 4 nor Rule No. 5 is satisfied, and at least one of Rules Nos. 1, 2, and 3 is not satisfied), then {circumflex over (θ)}(k,l) is not defined.
In a variant, the estimate PNew is averaged over packets of frequency bands K1, K2, . . . , kp:
Cj designating the cardinal sine function of Kj.
Under such circumstances, estimation of the angle θmax is not performed on each frequency band, but on each packet Kj of frequency bands.
It should also be observed that a “full band” approach is possible (p=1, only one angle being implemented per frame).
Finally, it should be observed that the proposed method is compatible with using unidirectional microphones. Under such circumstances, it is common practice to use a linear array (microphones in alignment with their privileged directions being identical) oriented towards the speaker. Under such circumstances, the value of θS is thus naturally known and equal to zero.
Calculating the Probability of Speech being Present on a three-dimensional space criterion (block 20)
The following step, which is characteristic of the method of the invention, consists in calculating a probability for speech being present that is based on the estimated arrival direction {circumflex over (θ)}(k,l) obtained in the manner specified above.
This is a probability that is written pspa(k,l) and which is thus original in that it is calculated on the basis of a spatial criterion (from {circumflex over (θ)}(k,l), and so as to distinguish between non-steady signals forming part of useful speech and unwanted noise. This probability is subsequently used in a conventional de-noising structure (block 22, described below).
The probability pspa(k,l) may be calculated in various ways, giving a binary value, or indeed multiple values. Two examples of calculating pspa(k,l) are described below, it being understood that other relationships may be used for expressing pspa(k,l) on the basis of {circumflex over (θ)}(k,l).
The probability of speech being present takes the values “0” or “1”:
The corresponding algorithm is as follows:
It is possible to calculate pspa(k,l) progressively, e.g. using the following algorithm:
The probability pspa(k,l) that speech is present as calculated by the block 20, itself depending on the probability pTransient(k,l) that transients are present as calculated by the block 16, is used as an input parameter for a conventional de-noising technique.
It is known that the probability of speech being present is a crucial estimator in achieving good operation of a de-noising algorithm, since it underpins obtaining a good estimate of noise and calculating an effective optimum gain level.
It is advantageous to use a de-noising method of the optimally modified log-spectral amplitude (OM-LSA) type such as that described by I. Cohen, Optimal speech enhancement under signal presence uncertainty using log-spectral amplitude estimator, IEEE Signal Processing Letters, Vol. 9, No. 4, April 2002.
Essentially, the application of so-called “log-spectral amplitude” (LSA) gain serves to minimize the mean square distance between the logarithm of the amplitude of the estimated signal and the algorithm of the amplitude of the original speech signal. This second criterion is found to be better than the first since the selected distance is a better match with the behavior of the human ear, and thus gives results that are qualitatively superior. Under all circumstances, the essential idea is to reduce the energy of frequency components that are very noisy by applying low gain to them while leaving intact frequency components suffering little or no noise (by applying gain equal to 1 to them).
The OM-LSA algorithm improves the calculation of the LSA gain to be applied by weighting the conditional probability of speech being present.
In this method, the probability of speech being present is involved at two important moments, for estimating the noise energy and for calculating the final gain, and the probability pspa(k,l) is used on both of these occasions.
If the estimated power spectrum density of the noise is written {circumflex over (λ)}Noise(k,l), then this estimate is given by:
{circumflex over (λ)}Noise(k,l)=αNoise(k,l)·{circumflex over (λ)}Noise(k,l−1)=[1−αnoise(k,l)]·|X(k,l|2
with:
αNoise(k,l)=αB+(1−αB)·pspa(k,l)
It should be observed here that the probability pspa(k,l) modulates the forgetting factor in estimating noise, which is updated more quickly concerning the noisy signal X(k,l) when the probability speech is low, with this mechanism completely conditioning the quality of {circumflex over (λ)}Noise(k,l).
The de-noising gain GOM-LSA(k,l) is given by:
GOM-LSA(k,l)={GH1(k,l)}p
GH1(k,l) being the de-noising gain (which is calculated as a function of the noise estimate {circumflex over (λ)}Noise) described in the above-mentioned article by Cohen; and
Gmin being a constant corresponding to the de-noising applied when speech is considered as being absent.
It should be observed at this point that the probability pspa(k,l) plays a major role in determining the gain GOM-LSA(k,l). In particular, when this probability is zero, the gain equal to Gmin and maximum noise reduction min is applied: for example, if a value of 20 dB is selected for Gmin, then previously detected non-steady noise is attenuated by 20 dB.
The de-noised signal Ŝ(k,l) output by the block 22 is given by:
Ŝ(k,l)=GOM-LSA(k,l)·X(k,l)
It should be observed that such a de-noising structure usually produces a result that is unnatural and aggressive on non-steady noise, which is confused with useful speech. One of the major advantages of the present invention is that it is effective in eliminating such non-steady noise.
Furthermore, in the above expressions, it is possible to use a hybrid probability for the presence of speech phybrid(k,l), i.e. a probability calculated on the basis of pspa(k,l) combined with some other probability for the presence of speech p(k,l), e.g. calculated using the method described in WO 2007/099222 A1 (Parrot SA). This gives:
phyprid(k,l)=min(p(k,l),pspa(k,l))
This hybrid probability makes it possible to benefit from identifying non-steady noise associated with small values of pspa(k,l) and to improve the probability estimate phybrid(k,l) for portions (k,l) where an arrival direction estimate ({circumflex over (θ)}(k,l) has not been defined (producing a probability pspa(k,l) that is forced to the value 1, by security).
The hybrid probability phybrid(k,l) thus combines both non-steady noise detected by pspa(k,l) and other noise (e.g. pseudo-steady noise as detected by p(k,l).
Reconstructing the Signal in the Time Domain (Block 24)
The last step consists in applying an inverse fast Fourier transform iFFT to the signal Ŝ(k,l) to obtain the de-noised speech signal ŝ(t) in the time domain.
Number | Date | Country | Kind |
---|---|---|---|
09 55133 | Jul 2009 | FR | national |
Number | Name | Date | Kind |
---|---|---|---|
5539859 | Robbe et al. | Jul 1996 | A |
5752226 | Chan et al. | May 1998 | A |
5812970 | Chan et al. | Sep 1998 | A |
6130949 | Aoki et al. | Oct 2000 | A |
6167375 | Miseki et al. | Dec 2000 | A |
6192134 | White et al. | Feb 2001 | B1 |
6230123 | Mekuria et al. | May 2001 | B1 |
6243322 | Zakarauskas | Jun 2001 | B1 |
6289309 | deVries | Sep 2001 | B1 |
6339758 | Kanazawa et al. | Jan 2002 | B1 |
6453285 | Anderson et al. | Sep 2002 | B1 |
6535666 | Dogan et al. | Mar 2003 | B1 |
6707910 | Valve et al. | Mar 2004 | B1 |
6748088 | Schaaf | Jun 2004 | B1 |
6910011 | Zakarauskas | Jun 2005 | B1 |
6937980 | Krasny et al. | Aug 2005 | B2 |
6959276 | Droppo et al. | Oct 2005 | B2 |
7062049 | Inoue et al. | Jun 2006 | B1 |
7072831 | Etter | Jul 2006 | B1 |
7072833 | Rajan | Jul 2006 | B2 |
7084801 | Balan et al. | Aug 2006 | B2 |
7117145 | Venkatesh et al. | Oct 2006 | B1 |
7117149 | Zakarauskas | Oct 2006 | B1 |
7231347 | Zakarauskas | Jun 2007 | B2 |
7327852 | Ruwisch | Feb 2008 | B2 |
7395211 | Watson et al. | Jul 2008 | B2 |
7533015 | Takiguchi et al. | May 2009 | B2 |
7567678 | Kong et al. | Jul 2009 | B2 |
7720679 | Ichikawa et al. | May 2010 | B2 |
7725315 | Hetherington et al. | May 2010 | B2 |
7953596 | Pinto | May 2011 | B2 |
7970609 | Hayakawa | Jun 2011 | B2 |
8005237 | Tashev et al. | Aug 2011 | B2 |
8073157 | Mao et al. | Dec 2011 | B2 |
8073689 | Hetherington et al. | Dec 2011 | B2 |
8081772 | Turnbull et al. | Dec 2011 | B2 |
8098842 | Florencio et al. | Jan 2012 | B2 |
8139787 | Haykin et al. | Mar 2012 | B2 |
8140327 | Kennewick et al. | Mar 2012 | B2 |
8150682 | Nongpiur et al. | Apr 2012 | B2 |
8189807 | Cutler | May 2012 | B2 |
20020176589 | Buck et al. | Nov 2002 | A1 |
20030040908 | Yang et al. | Feb 2003 | A1 |
20030147538 | Elko | Aug 2003 | A1 |
20040138882 | Miyazawa | Jul 2004 | A1 |
20050114128 | Hetherington et al. | May 2005 | A1 |
20070230712 | Belt et al. | Oct 2007 | A1 |
20070276660 | Pinto | Nov 2007 | A1 |
20080086309 | Fischer et al. | Apr 2008 | A1 |
20090164212 | Chan et al. | Jun 2009 | A1 |
20090310796 | Seydoux | Dec 2009 | A1 |
20100017206 | Kim et al. | Jan 2010 | A1 |
20100082340 | Nakadai et al. | Apr 2010 | A1 |
20110015924 | Gunel Hacihabiboglu et al. | Jan 2011 | A1 |
20110054891 | Vitte et al. | Mar 2011 | A1 |
20110070926 | Vitte et al. | Mar 2011 | A1 |
20110305345 | Bouchard et al. | Dec 2011 | A1 |
Number | Date | Country |
---|---|---|
1473964 | Nov 2004 | EP |
1473964 | Aug 2006 | EP |
0232356 | Apr 2002 | WO |
Entry |
---|
Alexandre Guérin, Régine Le Bouquin-Jeannés, Gérard Faucon, “A Two-Sensor Noise Reduction System: Applications for Hands-Free Car Kit”, EURASIP Journal on Applied Signal Processing (2003). |
Min-Seok Choia and Hong-Goo Kangb, “A Two-Channel Minimum Mean-Square Error Log-Spectral Amplitude Estimator for Speech Enhancement”—(2008) IEEE. |
Y. Ephraim and D. Malah, “Speech enhancement using a minimum mean-square error Log-spectral amplitude estimator,” IEEE Trans. Acoustics, Speech and Signal Processing, vol. ASSP-33, No. 2, pp. 443-445, Apr. 1985. |
I. Cohen and B. Berdugo “Speech enhancement for non-stationarynoise environments”, 2001, Signal Processing 81 (2001) pp. 2403-2418. |
Cohen, Israel,“Analysis of Two-Channel Generalized Sidelobe Canceller (GSC) With Post-Filtering”, IEE Transactions on Speech and Audio Processing, vol. II, No. 6, Nov. 1, 2003, pp. 684-699. |
Number | Date | Country | |
---|---|---|---|
20110054891 A1 | Mar 2011 | US |