An embodiment of the invention is related to digital signal processing techniques for automatically detecting that a microphone has been partially occluded, and using such a finding to modify a noise estimate that is being computed based on signals from the microphone and from another microphone. Other embodiments are also described.
Mobile phones enable their users to conduct conversations in many different acoustic environments. Some of these are relatively quiet while others are quite noisy. There may be high background or ambient noise levels, for instance, on a busy street or near an airport or train station. To improve intelligibility of the speech of the near-end user as heard by the far-end user, an audio signal processing technique known as ambient noise suppression can be implemented in the mobile phone. During a mobile phone call, the ambient noise suppressor operates upon an uplink signal that contains speech of the near-end user and that is transmitted by the mobile phone to the far-end user's device during the call, to clean up or reduce the amount of the background noise that has been picked up by the primary or talker microphone of the mobile phone. There are various known techniques for implementing the ambient noise suppressor. For example, using a second microphone that is positioned and oriented to pickup primarily the ambient sound, rather than the near-end user's speech, the ambient sound signal is electronically subtracted from the talker signal and the result becomes the uplink. In another technique, the talker signal passes through an attenuator that is controlled by a voice activity detector, so that the talker signal is attenuated during time intervals of no speech, but not in intervals that contain speech. A challenge is in how to respond when one of the microphones is partially occluded, e.g. by accident when the user partially covers one.
An electronic audio processing system is described that uses multiple microphones, e.g. for purposes of noise estimation and noise reduction. A microphone occlusion detector generates a partial occlusion signal, which may be used to adjust a calculation of the noise estimate. In particular, the occlusion detection may be used to select a 1-mic noise estimate, instead of a 2-mic noise estimate, when the partial occlusion signal indicates that a second microphone is occluded. This helps maintain proper noise suppression even when a user's finger, hand, ear, face, or any object (e.g., protective cover or casing for a device) has inadvertently partially occluded the second microphone, during speech activity, and during no speech but high background noise levels. The microphone occlusion detectors may also be used with other audio processing systems that rely on the signals from at least two microphones.
The above summary does not include an exhaustive list of all aspects of the present invention. It is contemplated that the invention includes all systems and methods that can be practiced from all suitable combinations of the various aspects summarized above, as well as those disclosed in the Detailed Description below and particularly pointed out in the claims filed with the application. Such combinations have particular advantages not specifically recited in the above summary.
The embodiments of the invention are illustrated by way of example and not by way of limitation in the figures of the accompanying drawings in which like references indicate similar elements. It should be noted that references to “an” or “one” embodiment of the invention in this disclosure are not necessarily to the same embodiment, and they mean at least one.
Several embodiments of the invention with reference to the appended drawings are now explained. While numerous details are set forth, it is understood that some embodiments of the invention may be practiced without these details. In other instances, well-known circuits, structures, and techniques have not been shown in detail so as not to obscure the understanding of this description.
There are two audio or recorded sound channels shown, for use by various component blocks of the noise reduction (also referred to as noise suppression) system. Each of these channels carries the audio signal from a respective one of the two microphones 41, 42. It should be recognized however that a single recorded (or digitized) sound channel could also be obtained by combining the signals of multiple microphones, such as via beamforming. This alternative is depicted in the figure by the additional microphones and their connections in dotted lines. It should also be noted that in one approach, all of the processing depicted in
A pair of noise estimators 43, 44 operate in parallel to generate their respective noise estimates, by processing the two audio signals from mic1 and mic2. The noise estimator 43 is also referred to as noise estimator B, whereas the noise estimator 44 can be referred to as noise estimator A. In one instance, the estimator A performs better than the estimator B in that it is more likely to generate a more accurate noise estimate, while the microphones are picking up a near-end-user's speech and non-stationary background acoustic noise during a mobile phone call.
In one embodiment, for stationary noise, such as noise that is heard while riding in a car (which may include a combination of exhaust, engine, wind, and tire noise), the two estimators A, B should provide, for the most part, similar estimates. However, in some instances there may be more spectral detail provided by the estimator A, which may be due to a better voice activity detector, VAD, being used as described below, and the ability to estimate noise even during speech activity. On the other hand, when there are significant transients in the noise, such as babble (e.g., in a crowded room) and road noise (that is heard when standing next to a road on which cars are driving by), the estimator A can be more accurate in that case because it is using two microphones. That is because in estimator B, some transients could be interpreted as speech, thereby excluding them (erroneously) from the noise estimate.
In one embodiment, estimator A may be deemed more accurate in estimating non-stationary noises than estimator B (which may essentially be a stationary noise estimator). Estimator A might also misidentify more speech as noise, if there is not a significant difference in voice power between a primarily voice signal at mic1 (41) and a primarily noise signal at mic2 (42). This can happen, for example, if the talker's mouth is located the same distance from each microphone. In one embodiment of the invention, the sound pressure level (SPL) of the noise source is also a factor in determining whether estimator A is more accurate than estimator B—above a certain (very loud) level, estimator A may be less accurate at estimating noise than estimator B. In another instance, the estimator A is referred to as a 2-mic estimator, while estimator B is a 1-mic estimator, although as pointed out above the references 1-mic and 2-mic here refer to the number of input audio channels, not the actual number of microphones used to generate the channel signals.
The noise estimators A, B operate in parallel, where the term “parallel” here means that the sampling intervals or frames over which the audio signals are processed have to, for the most part, overlap in terms of absolute time. In one embodiment, the noise estimate produced by each estimator A, B is a respective noise estimate vector, where this vector has several spectral noise estimate components, each being a value associated with a different audio frequency bin. This is based on a frequency domain representation of the discrete time audio signal, within a given time interval or frame. A combiner-selector 45 receives the two noise estimates and generates a single output noise estimate. In one instance, the combiner-selector 45 combines, for example as a linear combination, its two input noise estimates to generate its output noise estimate. However, in other instances, the combiner-selector 45 may select the input noise estimate from estimator A, but not the one from estimator B, and vice-versa.
The noise estimator B may be a conventional single-channel or 1-mic noise estimator that is typically used with 1-mic or single-channel noise suppression systems. In such a system, the attenuation that is applied in the hope of suppressing noise (and not speech) may be viewed as a time varying filter that applies a time varying gain (attenuation) vector, to the single, noisy input channel, in the frequency domain. Typically, such a gain vector is based to a large extent on Wiener theory and is a function of the signal to noise ratio (SNR) estimate in each frequency bin. To achieve noise suppression, frequency bins with low SNR are attenuated while those with high SNR are passed through unaltered, according to a well know gain versus SNR curve. Such a technique tends to work well for stationary noise such as fan noise, far field crowd noise, car noise, or other relatively uniform acoustic disturbance. Non-stationary and transient noises, however, pose a significant challenge, which may be better addressed by the noise estimation and reduction system depicted in
Still referring to
Each of the estimators 43, 44, and therefore the combiner-selector 45, may update its respective noise estimate vector in every frame, based on the audio data in every frame, and on a per frequency bin basis. The spectral components within the noise estimate vector may refer to magnitude, energy, power, energy spectral density, or power spectral density, in a single frequency bin.
One of the use cases of the user audio device is during a mobile phone call, where one of the microphones, in particular mic2, can become partially occluded, due to the user's finger, hand, ear, face or any object for example covering an acoustic port in the housing of the handheld mobile device. The partial occlusion causes a severe distortion of the detected voice signal if the partially occluded mic2 is used as a noise reference. Thus, it is important to detect the partial occlusion and revert back to a noise suppression mode that does not use the partially occluded mic. Therefore, at that point, the system should automatically switch to or rely more strongly on the 1-mic estimator B (instead of the 2-mic estimator A). This may be achieved by adding a microphone partial occlusion detector 49 whose output generates a microphone partial occlusion signal that represents a measure of how severely, or how likely it is that, one of the microphones is partially occluded. The combiner-selector 45 is modified to respond to the partial occlusion signal by accordingly changing its output noise estimate. For example, the combiner-selector 45 selects the first noise estimate (1-mic estimator B) for its output noise estimate, and not the second noise estimate (2-mic estimator A), when the partial occlusion signal crosses a threshold indicating that the second one of the microphones (here, mic 42) is partially occluded or is more occluded. The combiner-selector 45 can return to selecting the 2-mic estimator A for its output, once the partial occlusion has been removed, with the understanding that a different partial occlusion signal threshold may be used in that case (so as to employ hysteresis corresponding to a few dBs for instance) to avoid oscillations.
Referring now to
The partial occlusion detectors A, B may have different thresholds (inflection points), so that one of them is better suited to detect occlusions in a no speech condition in which the level of background noise is at a low or mid level, while the other can better detect occlusions in either a) a no speech condition in which the background noise is at a high level or b) in a speech condition.
In one embodiment, an electronic system for audio noise processing and for noise reduction, using a plurality of microphones includes a first noise estimator to process a first audio signal from a first one of the microphones and to generate a first noise estimate. A second noise estimator processes the first audio signal and a second audio signal from a second one of the microphones, in parallel with the first noise estimator, and generates a second noise estimate. A microphone partial occlusion detector determines a low frequency band separation of the signals and a high frequency band separation of the signals to generate a microphone partial occlusion function that indicates whether one of the microphones is partially occluded. The microphone partial occlusion detector compares the high frequency band separation of the signals and the low frequency band separation of the signals. The microphone partial occlusion function takes on a high value that indicates partial occlusion when a difference between the high frequency band separation of the signals and the low frequency band separation of the signals is greater than a threshold. The microphone partial occlusion function takes on a low value that indicates no partial occlusion when the difference is less than the threshold. The first and second audio signals are converted from a time domain to a frequency domain to generate a measure of strength (e.g., power, energy) of the first audio signal (e.g., power spectrum of first signal, herein after “ps_first signal”) and a measure of strength of the second audio signal (e.g., power spectrum of second signal, herein after “ps_second signal”). The low band frequency separation is computed with the following equation:
SEPlowband=1/M[summation of k=1 to M bins][10*log 10{[ps_first signal(k)}−10*log 10{[ps_second signal(k)]}]
In one embodiment, M is a frequency bin closest to 1 KHz.
The high band frequency separation is computed with the following equation:
SEPhighband=(1/(N−M))[summation of k=M+1 to N bins][10*log 10{[ps_first signal(k)}−10*log 10{[ps_second signal(k)]}]
In one embodiment, M is a frequency bin closest to 1 KHz.
The system further includes a combiner-selector to receive the first and second noise estimates, and to generate an output noise estimate using the first and second noise estimates. The combiner-selector generates its output noise estimate also based on the microphone partial occlusion function. The combiner-selector selects the first noise estimate for its output noise estimate, and not the second noise estimate, when the microphone partial occlusion function indicates that the second one of the microphones is partially occluded.
In one embodiment of the invention, in the microphone partial occlusion detector 49, the first and second audio signals from mic1 and mic2, respectively, are processed and converted from a time domain to a frequency domain to compute a measure of strength (e.g., power spectra (generically referred to here as “ps_first signal” and “ps_second signal”)), such as in dB, of two microphone output (audio) signals x1 and x2. A fast fourier transform (FFT) and raw power spectra are computed. The power spectra of the first signal (e.g., mic1) and the second signal (e.g., mic2) are vectors containing the powers for all the frequency bins. Thus, “ps_first signal(k)” and “ps_second signal(k)” is the power in the k-th frequency bin. The following vector is used as a measure of separation between the first signal (e.g., mic1) and the second signal (e.g., mic2):
SEP=1/N[summation of k=1 to N bins][10*log 10{[ps_first signal(k)}−10*log 10{[ps_second signal(k)]}]
The summation occurs from k=1 to N bins for a full frequency band separation. Each input frame (or time interval) has N frequency bins and corresponds to a single data point in a time domain. Further, a low frequency band and high frequency band separation are defined with the following equations:
SEPlowband=1/M[summation of k=1 to M bins][10*log 10{[ps_first signal(k)}−10*log 10{[ps_second signal(k)]}]
SEPhighband=(1/(N−M))[summation of k=M+1 to N bins][10*log 10{[ps_first signal(k)}−10*log 10{[ps_second signal(k)]}]
Where M is the frequency bin closest to an arbitrary frequency (e.g., 0.5-3 KHz, 0.8 KHz, 0.9 KHz, 1 KHz, 1.1 KHz, 1.2 KHz, etc.) that depends upon a form factor of a device. In one embodiment, M is a frequency bin closest to 1 KHz.
M depends on the sampling rate and the block size used for the FFT. For the SEPlowband each input frame has M frequency bins while for the SEPhighband each input frame has N-M frequency bins.
Next, the lowband and highband SEP are time smoothed as follows:
SEPlowband′=alpha*SEPlowband+(1−alpha)*SEPlowband
SEPhighband′=alpha*SEPhighband+(1−alpha)*SEPhighband
where alpha is a smoothing factor between 0 and 1.
A partial occlusion detection function is then evaluated that is a function of a low frequency band separation and a high frequency band separation of “ps_first signal” and “ps_second signal”, e.g. at the computed low frequency band separation and the high frequency band separation of “ps_first signal” and “ps_second signal” with a metric D equaling high frequency band separation minus low frequency band separation.
At operation 702, for each input frame, the device computes a microphone partial occlusion detection function (e.g., a separation metric D) based on a low frequency band separation of first and second audio output signals of first and second microphones respectively of the device and a high frequency band separation of the first and second signals. At operation 704, for each input frame, the device determines if the microphone partial occlusion detection function (e.g., the separation metric D) is greater than a threshold (e.g., a threshold value of 5 to 15 dB, a threshold value of approximately 10 dB). At operation 706, the device determines that a partial occlusion for one of the microphones (e.g., mic2) has occurred if the microphone partial occlusion detection function (e.g., the separation metric D) is greater than the threshold.
At operation 802, for each input frame, the device computes a microphone partial occlusion detection function (e.g., a separation metric D) based on a low frequency band separation of first and second audio output signals of first and second microphones respectively of the device and a high frequency band separation of the first and second signals. At operation 804, for each input frame, the device determines if the microphone partial occlusion detection function (e.g., the separation metric D) is greater than a threshold (e.g., a threshold value of 5 to 15 dB, a threshold value of approximately 10 dB) and a partial occlusion condition of a microphone is currently not detected. At operation 806, the device determines that a partial occlusion for one of the microphones (e.g., mic2) has occurred if the microphone partial occlusion detection function (e.g., the separation metric D) is greater than the threshold and the partial occlusion condition of a microphone is currently not detected at operation 806. Otherwise, at operation 808, for each input frame, the device determines if the microphone partial occlusion detection function (e.g., the separation metric D) is less than a threshold (e.g., a threshold value of 5 to 15 dB, a threshold value of approximately 10 dB) and a partial occlusion condition of a microphone is currently detected. If so, then at operation 810 the partial occlusion condition of a microphone is changed to being not detected. If not, then the process flow returns to operation 804.
The threshold for the methods 700 and 800 may be variable depending on conditions of use including environmental conditions (e.g., airport, noisy street, geometry of room) type of housing and spatial arrangement of the mics for the device. For example, a full band separation may typically vary from 8 to 12 dB and have a threshold set for this range in the full band separation. The threshold may be adjusted for a full band separation that is significantly different than the typical range of 8 to 12 dB.
In one embodiment, a full occlusion algorithm runs in parallel with a partial occlusion algorithm as discussed in methods 700 and 800. When any type of mic2 occlusion (e.g., full occlusion, partial occlusion) is detected, a noise suppression algorithm switches from a two mic noise estimate to using a one mic (e.g., mic1) noise estimate. The noise algorithm switches back to the two mic noise estimate when no occlusion is detected.
As seen in
Turning now to
The user-level functions of the mobile device 2 are implemented under the control of an applications processor 19 or a system on a chip (SoC) that is programmed in accordance with instructions (code and data) stored in memory 28 (e.g., microelectronic non-volatile random access memory). The terms “processor” and “memory” are generically used here to refer to any suitable combination of programmable data processing components and data storage that can implement the operations needed for the various functions of the device described here. An operating system 32 may be stored in the memory 28, with several application programs, such as a telephony application 30 as well as other applications 31, each to perform a specific function of the device when the application is being run or executed. The telephony application 30, for instance, when it has been launched, unsuspended or brought to the foreground, enables a near-end user of the device 2 to “dial” a telephone number or address of a communications device 4 of the far-end user (see
For wireless telephony, several options are available in the device 2 as depicted in
The uplink and downlink signals for a call that is conducted using the cellular radio 18 can be processed by a channel codec 16 and a speech codec 14 as shown. The speech codec 14 performs speech coding and decoding in order to achieve compression of an audio signal, to make more efficient use of the limited bandwidth of typical cellular networks. Examples of speech coding include half-rate (HR), full-rate (FR), enhanced full-rate (EFR), and adaptive multi-rate wideband (AMR-WB). The latter is an example of a wideband speech coding protocol that transmits at a higher bit rate than the others, and allows not just speech but also music to be transmitted at greater fidelity due to its use of a wider audio frequency bandwidth. Channel coding and decoding performed by the channel codec 16 further helps reduce the information rate through the cellular network, as well as increase reliability in the event of errors that may be introduced while the call is passing through the network (e.g., cyclic encoding as used with convolutional encoding, and channel coding as implemented in a code division multiple access, CDMA, protocol). The functions of the speech codec 14 and the channel codec 16 may be implemented in a separate integrated circuit chip, some times referred to as a baseband processor chip. It should be noted that while the speech codec 14 and channel codec 16 are illustrated as separate boxes, with respect to the applications processor 19, one or both of these coding functions may be performed by the applications processor 19 provided that the latter has sufficient performance capability to do so.
The applications processor 19, while running the telephony application program 30, may conduct the call by enabling the transfer of uplink and downlink digital audio signals (also referred to here as voice or speech signals) between itself or the baseband processor on the network side, and any user-selected combination of acoustic transducers on the acoustic side. The downlink signal carries speech of the far-end user during the call, while the uplink signal contains speech of the near-end user that has been picked up by the primary microphone 8. The acoustic transducers include an earpiece speaker 6 (also referred to as a receiver), a loud speaker or speaker phone (not shown), and one or more microphones including the primary microphone 8 that is intended to pick up the near-end user's speech primarily, and a secondary microphone 7 that is primarily intended to pick up the ambient or background sound. The analog-digital conversion interface between these acoustic transducers and the digital downlink and uplink signals is accomplished by an analog audio codec 12. The latter may also provide coding and decoding functions for preparing any data that may need to be transmitted out of the mobile device 2 through a connector (not shown), as well as data that is received into the device 2 through that connector. The latter may be a conventional docking connector that is used to perform a docking function that synchronizes the user's personal data stored in the memory 28 with the user's personal data stored in the memory of an external computing system such as a desktop or laptop computer.
Still referring to
The downlink signal path receives a downlink digital signal from either the baseband processor (and speech codec 14 in particular) in the case of a cellular network call, or the applications processor 19 in the case of a WLAN/VOIP call. The signal is buffered and is then subjected to various functions, which are also referred to here as a chain or sequence of functions. These functions are implemented by downlink processing blocks or audio signal processors 21, 22 that may include, one or more of the following which operate upon the downlink audio data stream or sequence: a noise suppressor, a voice equalizer, an automatic gain control unit, a compressor or limiter, and a side tone mixer.
The uplink signal path of the audio signal processor 9 passes through a chain of several processors that may include an acoustic echo canceller 23, an automatic gain control block, an equalizer, a compander or expander, and an ambient noise suppressor 24. The latter is to reduce the amount of background or ambient sound that is in the talker signal coming from the primary microphone 8, using, for instance, the ambient sound signal picked up by the secondary microphone 7. Examples of ambient noise suppression algorithms are the spectral subtraction (frequency domain) technique where the frequency spectrum of the audio signal from the primary microphone 8 is analyzed to detect and then suppress what appear to be noise components, and the two microphone algorithm (referring to at least two microphones being used to detect a sound pressure difference between the microphones and infer that such is produced by speech of the near-end user rather than noise). The functional unit blocks of the noise suppression system depicted in
While certain embodiments have been described and shown in the accompanying drawings, it is to be understood that such embodiments are merely illustrative of and not restrictive on the broad invention, and that the invention is not limited to the specific constructions and arrangements shown and described, since various other modifications may occur to those of ordinary skill in the art. For example, the 2-mic noise estimator can also be used with multiple microphones whose outputs have been combined into a single “talker” signal, in such a way as to enhance the talkers voice relative to the background/ambient noise, for example, using microphone array beam forming or spatial filtering. This is indicated in
Number | Name | Date | Kind |
---|---|---|---|
6898566 | Benyassine et al. | May 2005 | B1 |
6963649 | Vaudrey et al. | Nov 2005 | B2 |
7536301 | Jaklitsch et al. | May 2009 | B2 |
7761106 | Konchitsky | Jul 2010 | B2 |
8019091 | Burnett et al. | Sep 2011 | B2 |
8046219 | Zurek et al. | Oct 2011 | B2 |
8068619 | Zhang et al. | Nov 2011 | B2 |
8194882 | Every et al. | Jun 2012 | B2 |
8204252 | Avendano | Jun 2012 | B1 |
8204253 | Solbach | Jun 2012 | B1 |
8275609 | Wang | Sep 2012 | B2 |
8374362 | Ramakrishnan et al. | Feb 2013 | B2 |
8401178 | Chen et al. | Mar 2013 | B2 |
8521530 | Every et al. | Aug 2013 | B1 |
9100756 | Dusan et al. | Aug 2015 | B2 |
9215527 | Saric et al. | Dec 2015 | B1 |
20040181397 | Gao | Sep 2004 | A1 |
20070230712 | Belt et al. | Oct 2007 | A1 |
20070237339 | Konchitsky | Oct 2007 | A1 |
20070274552 | Konchitsky et al. | Nov 2007 | A1 |
20080201138 | Visser et al. | Aug 2008 | A1 |
20090190769 | Wang et al. | Jul 2009 | A1 |
20090196429 | Ramakrishnan | Aug 2009 | A1 |
20090220107 | Every | Sep 2009 | A1 |
20100081487 | Chen et al. | Apr 2010 | A1 |
20100091525 | Lalithambika et al. | Apr 2010 | A1 |
20100100374 | Park et al. | Apr 2010 | A1 |
20110106533 | Yu | May 2011 | A1 |
20110317848 | Ivanov | Dec 2011 | A1 |
20120121100 | Zhang et al. | May 2012 | A1 |
20120130713 | Shin et al. | May 2012 | A1 |
20120185246 | Zhang et al. | Jul 2012 | A1 |
20120209601 | Jing | Aug 2012 | A1 |
20120310640 | Kwatra et al. | Dec 2012 | A1 |
20130054231 | Jeub et al. | Feb 2013 | A1 |
20130282372 | Visser et al. | Oct 2013 | A1 |
20130329895 | Dusan et al. | Dec 2013 | A1 |
20130332157 | Iyengar et al. | Dec 2013 | A1 |
20140126745 | Dickins et al. | May 2014 | A1 |
20150110284 | Niemisto et al. | Apr 2015 | A1 |
20150221322 | Iyengar et al. | Aug 2015 | A1 |
Entry |
---|
Jeub, Marco , et al., “Noise Reduction for Dual-Microphone Mobile Phones Exploiting Power Level Differences”, Acoustics, Speech and Signal Processing (ICASSP), 2012 IEEE International Conference, Mar. 25-30, 2012, ISSN: 1520-6149, E-ISBN: 978-1-4673-0044-5, pp. 1693-1696. |
Khoa, Pham C., “Noise Robust Voice Activity Detection”, Nanyang Technological University, School of Computer Engineering, a thesis, 2012, Admitted Prior Art, Title page, pp. i-ix, and pp. 1-26. |
Schwander, Teresa , et al., “Effect of Two-Microphone Noise Reduction on Speech Recognition by Normal-Hearing Listeners”, Journal of Rehabilitation Research and Development, vol. 24, No. 4, Fall 1987, pp. 87-92. |
Tashev, Ivan , et al., “Microphone Array for Headset with Spatial Noise Suppressor”, Microsoft Research, One Microsoft Way, Redmond, WA, USA, In Proceedings of Ninth International Workshop on Acoustics, Echo and Noise Control, Sep. 2005, 4 pages. |
Verteletskaya, Ekaterina , et al., “Noise Reduction Based on Modified Spectral Subtraction Method”, IAENG International Journal of Computer Science, 38:1, IJCS 38 1 10, (Advanced online publication: Feb. 10, 2011), 7 pages. |
Widrow, Bernard , et al., “Adaptive Noise Cancelling: Principles and Applications”, Proceedings of the IEEE, vol. 63, No. 12, Dec. 1975, ISSN: 0018-9219, pp. 1692-1716 and 1 additional page. |
“Sound Basics”, Acoustic and vibrations, Internet document at: http://www.acousticvibration.com/sound-basis.htm, Admitted Prior Art, 3 pages, Dec. 30, 2013. |
Nemer, Elias, “Acoustic Noise Reduction for Mobile Telephony”, Nortel Networks, Admitted Prior Art, 18 pages, Jan. 2000. |
Number | Date | Country | |
---|---|---|---|
20150334489 A1 | Nov 2015 | US |