The present invention relates generally to noise cancellation for audio signal processing and more particularly to testing and calibration of a sound processing system with noise cancellation based on null steering.
Directional microphone systems are designed to sense sound from a particular source such as a desired speaker located in a specified direction while rejecting, filtering out, blocking, or otherwise attenuating sound from other sources such as undesired bystanders or noise located in other directions. To achieve a high degree of directionality, microphones typically include an array of two or microphone sensors or transducers contained in a mechanical enclosure. The enclosure typically includes one or more acoustic ports for receiving sound and additional material for guiding sound from within the beam angle to sensing elements and blocking sound from other directions.
Directional microphones may be beneficially applied to a variety of applications such as conference rooms, home automation, automotive voice commands, personal computers, telephone headsets, personal digital assistants, and the like. These applications typically have one or more desired sources of sound accompanied by one or more noise sources. In such applications, it is desired to increase the signal to noise ratio (SNR) between the desired source and unwanted interferers. Attempts to do so using frequency filtering are largely unsuccessful because the frequencies to be filtered out are typically the same as the desired source, for example, in a telephone headset that seeks to preserve the desired speaker's voice while simultaneously canceling the voices of people other than the speaker such as bystanders. Sound sources other than the desired speaker are referred to herein as interferers.
Because the sound signals from the desired speaker and unwanted interferers are typically emitted from different locations relative to the microphone, the spatial separation between the speaker and interferers can be exploited to separate the desired sound signal from the unwanted interferer sound signal using spatial filters such as a delay-and-sum beamformer or a Griffiths-Jim adaptive beamformer. More specifically, nulls in the directional sensitivity pattern of the microphone array may be used for interference cancellation, while a fixed gain in a known directional location (e.g., corresponding to the desired speaker) may be used to preserve the sound signals emitted by the desired speaker.
For example,
A fixed null-steering system such as a well-known beamformer filters the microphone signal produced by sensor M1 and subtracts it from the microphone signal produced by sensor M2 to generate an output signal that suppresses sound signals attributed to INT, thereby creating a fixed sensitivity pattern (also known as polar response pattern). However, in many applications, the location and direction of the interferer (INT) may not be known and/or may change even though the location and direction of the desired speaker SPKR remains constant. In such applications, adaptive filters may be employed to continually modify the system response (e.g., by continuously modifying the polar response pattern) so that the sound processing system steers a “null” in the direction of the interferer. To distinguish between the desired speaker SPKR and the unwanted interferer INT, sound processing systems may employ a combination of fixed beamformers and adaptive filters.
For example,
The difference signal is provided as an input signal to adaptive filter 230, which includes an output to generate a filtered difference output signal FD and includes a control terminal to receive a tuning signal from signal power estimator (SPE) 240. The filtered difference signal FD is subtracted from SUM in subtraction circuit 222 to generate an output signal OUT that dynamically preserves sound components of SPKR while suppressing sound components of INT over a range of changing directions for INT.
As known in the art, SPE circuit 240 estimates the signal power of the output signal OUT, and in response thereto generates a tuning signal (TN) that is used to continuously tune the adaptive filter 230. Although not shown for simplicity, for some applications, the SPE circuit generates the tuning signal TN for the adaptive filter 230 in response to both the output signal OUT and the difference signal (DIFF). Adaptive filter 230, which is typically a finite impulse response (FIR) filter, is continuously tuned in response to TN to suppress the dominant source components in DIFF so that INT sound components are suppressed from its output signal FD. More specifically, the polar response pattern of adaptive filter 230 is continuously modified to continuously steer the null in the direction of INT to minimize the sound energy attributed to INT from the filtered difference signal FD.
It is important to note that adaptive beamformers of type shown in
Thus, when the filtered difference signal FD is subtracted from the sum signal SUM at subtraction circuit 222, the resultant output signal is a directionally sensitive signal in which the INT components are suppressed and the SPKR components are preserved. For example, if the sum signal SUM is represented as a SPKR component S plus an INT component INTSUM and the filtered difference signal FD represents the estimate of ISUM the output signal OUT=S+INTSUM−FD≈S, and the transfer function of the adaptive filter is H(ω)=INTSUM/FD.
Although effective in providing a directional sensitivity pattern that can dynamically steer a null in the direction of INT, the adaptive filter employed by systems such the Griffiths-Jim circuit 200 requires a complicated algorithm to continuously steer the null in the direction of the interferer INT. In addition, the adaptive filter itself is typically a very complex circuit requiring numerous cascaded filtering stages and various adjustable tap delay lines, which not only consumes a large circuit area but also may be difficult to design and implement.
Applicant has developed a response select null steering circuit that includes a beamformer, a summing circuit, a plurality of separate filtering circuits, and a selection circuit. In response to input signals generated by microphone sensors receiving sound signals from a desired speaker and an unwanted interferer, the summing circuit generates a sum signal containing signal components of both the speaker and the interferer. The beamformer generates a difference signal that suppresses signal components of the desired speaker so that the difference signal contains primarily only the signal components of the interferer. Each filtering circuit includes a fixed filter and a subtraction circuit that together provide a different polar response pattern that exhibits a null in a unique direction relative to the desired speaker. In this manner, each filtering circuit may be individually configured to suppress sound signals from an interferer located in a direction associated with the null in the corresponding polar response pattern of the filter. The selection circuit receives the output signals from the various filtering circuits and selects the output signal that has the least amount of signal energy, where the output signal having the least signal energy achieves the best suppression of the unwanted interferer.
However, existing module testers are not sufficient to properly test such response select null steering circuits. As a result, a new module tester is needed that can properly test and calibrate circuits such as the response select null steering circuits described herein.
Like reference numerals refer to corresponding parts throughout the drawing figures.
Embodiments of the present invention are described below in the context of a testing and calibrating an exemplary embodiment of a response select null steering circuit for simplicity only. It is to be understood that tester embodiments described herein can be used to test and calibrate other types of null steering and/or audio processing circuits. In the following description, for purposes of explanation, specific nomenclature is set forth to provide a thorough understanding of the present invention. In other instances, well-known circuits and devices are shown in block diagram form to avoid obscuring the present invention unnecessarily. For example, the interconnection between circuit elements or circuit blocks may be shown or described as multi-conductor or single conductor signal lines. Each of the multi-conductor signal lines may alternatively be single-conductor signal lines, and each of the single-conductor signal lines may alternatively be multi-conductor signal lines. Signals and signaling paths shown or described as being single-ended may also be differential, and signals and signaling paths shown or described as being differential may also be single-ended. Further, the logic states of various signals described herein are exemplary and therefore may be reversed or otherwise modified as generally known in the art. Accordingly, the present invention is not to be construed as limited to specific examples described herein but rather includes within its scope all embodiments defined by the appended claims.
Test modules of the present embodiments are described below with respect to the null-steering response select circuit 300 of
In response to sound generated by INT and SPKR, sensor M1 produces a first input signal IN1 and sensor M2 produces a second input signal IN2. IN1 is provided to a delay element 301A that produces a delayed input signal IN1D. For some embodiments, delay element 301A is a second-order low-pass filter (LPF) of the Bessel type that produces a relatively constant delay over a desired frequency range. More specifically, delay element 301A performs an input filtering operation, Δs, on the M1 microphone signal IN1 that preserves the SPKR in a given direction, and well-known gain element 301B provides a near-field gain factor A to signal IN2 to compensate for SPKR being in the near field. The near-field gain factor A allows preservation of a desired source such as the SPKR based on distance as well as direction relative to M1-M2, and provides additional attenuation of the INT in the same direction as the speaker, but at a different distance from the microphone array than the SPKR. This feature can be expanded to multiple microphones and multiple gains. For other embodiments, delay element 301A may employ other types of filters.
For exemplary embodiments described herein, sensors M1-M2 are omni-directional sound transducers in which M1 and M2 may be modeled as follows:
M1
XF=e−jωΔ
M2
XR=1 (2)
However, for other embodiments, sensors M1-M2 may be configured to have any suitable directional sensitivity.
Signals IN1D and IN2 are summed at summing circuit 303 to generate a sum signal (SUM) containing signal components of both the SPKR and INT, and signal IN1D is subtracted from IN2 by subtraction circuit 302 to generate a difference signal (DIFF) in which signal components of SPKR are suppressed so that DIFF contains mostly signal components of INT. Thus, sensors M1-M2, delay element 301A, and subtraction circuit 302 together form a fixed beamformer that suppresses SPKR from DIFF according to the polar response pattern implemented by delay element 301A.
Further, for other embodiments, a second delay element (not shown for simplicity) may be provided between gain element 301B and summing circuit 303, where the second delay element provides a filtering function for IN2 that expands the sensitivity pattern to the back half-plane in the direction opposite the SPKR (i.e., along the 180° axis).
The difference signal DIFF is provided as an input signal to each of the plurality of filtering circuits 310(1)-310(n). Each filtering circuit 310 includes a fixed filter 311 and a subtraction circuit 312. Each filter 311 has an input to receive DIFF and has an output coupled to a corresponding subtraction circuit 312, which subtracts the filtered difference signal FDx provided by the filter 311 from the sum signal SUM to generate a corresponding filter output signal OUTx, where “x” denotes an integer between 1 and n corresponding to one of the filtering circuits 310(1)-310(n). The filter output signals OUT1-OUTn output from corresponding filtering circuits 310(1)-310(n) are provided to selection circuit 320, which selects the filter output signal OUTx that provides the best INT suppression as the selected minimum-energy output signal OUTmin for the null steering circuit 300.
Each of the plurality of filters 311(1)-311(n) is a fixed filter having a different magnitude and phase response so that the filters have polar response patterns with nulls in different directions which may be specified by the corner frequency of the corresponding filter. The filters 311(1)-311(n) may be any type of filter, and each may be configured to have a polar response pattern with a null in a designated direction. In this manner, each of filters 311(1)-311(n) may be optimized to provide INT suppression in a designated direction, which is in contrast to prior art adaptive techniques such as the Griffiths-Jim beamformer circuit that is configured to continuously steer the null in the direction of a dominant interferer.
Thus, in accordance with some embodiments of the present invention, each of the filters 311(1)-311(n) is a separate filter that corresponds to a null in a particular direction. Moreover, any number of null angles or directions can be selected by providing a corresponding number of filters 311. Thus, each of filters 311(1)-311(n) may be “assigned” to a corresponding assigned interferer direction by configuring the polar response pattern of the filter to create null in the sensitivity pattern in the corresponding assigned direction. In this manner, the audio space surrounding the microphone sensor array may be divided into segments, and the frequency response of each filter may be specifically tailored to suppress interferer sound signals emitted from a corresponding assigned segment.
The filters 311 may be derived assuming the signal model shown above in (1) and (2). For some embodiments, the filters 311 may be characterized by a transfer function H(s) as shown in (3), where m indexes the null direction:
The gain factor may be expressed as K shown below in (4), where A is a near-field gain parameter:
The zero of each filter 311 may be expressed as:
and the pole of each filter may be expressed as:
The time constant appearing in both the zero and pole equations is
Δ′m=Δm+Δs (7)
where the time-delay corresponding to the selectable-null is
and compensating for the time-delay corresponding to the speaker direction yields
For example, referring again to
The polar response patterns of
Referring again to
The selection circuit 320 selects one of the filter output signals OUT1-OUTn that provides the best cancellation of the interferer INT while preserving the SPKR sound signals. Any suitable technique and/or circuit may be employed to perform the function of selection circuit 320. For example,
The compare circuit 420 compares the power level signals PL1-PLn provided by respective SPE circuits 410(1)-410(n) with each other to determine which of the corresponding filter output signals OUT1-OUTn has the least amount of energy, and selects that signal to be output as the minimum-energy output signal OUTmin. Selection circuit 420 may be implemented using any suitable compare and select circuits.
An exemplary operation of one embodiment of null steering circuit 300 is described below with respect to the illustrative flow chart 900 of
Inverter 802 and switches SW1-SW2 are well-known. For some embodiments, inverter 802 is a CMOS inverter, although other signal inversion circuits may be used. For one embodiment, switches SW1 and SW2 are well-known CMOS transmission gates. For another embodiment, switches SW1 and SW2 are NMOS or PMOS pass gates. For other embodiments, other switching circuits may be used.
In operation, if the signal power of OUT1 is less than the signal power of OUT2, comparator 801 drives SEL to a first state that causes SW1 to pass OUT1 as the selected minimum-energy output signal OUTmin and that causes SW2 to not pass OUT2. Conversely, if the signal power of OUT2 is less than the signal power of OUT1, comparator 801 drives SEL to a second state that causes SW2 to pass OUT2 as OUTmin and that causes SW1 to not pass OUT1.
For some embodiments, comparator 801 is implemented as a high-gain op-amp. Further, for some embodiments, the comparator 801 or its op-amp implementation may employ hysteresis to prevent switching between filtering circuits 310 in response to relatively small changes in signal power of OUT1 and OUT2 (e.g., to provide smoother transitions and to avoid spurious switching). For other embodiments, the comparator 801 or its op-amp implementation may employ a time-averaging technique when changing the output signal selection, for example, so that the null steering circuit 300 changes the selection of filters 311 only if the INT changes locations (or direction relative to the SPKR) for more than a predetermined period of time. In this manner, a very brief variation in location of the INT does not cause the null steering circuit 300 to changes its selection of filters 311.
The operation of selection circuit 800 in switching between various filtered signals (e.g., OUT1 and OUT2) may be performed either instantaneously or over a period of time (e.g., either gradually or time-averaged). For some applications, it may be desired to switch the output signal selection between filters 311 in a gradual manner (e.g., as the INT moves from a first location corresponding to the null effected by the first filter 311(1) to a second location corresponding to the null effected by the second filter 311(2)). For such applications, the selection circuit 800 may be modified to more gradually switch between the selection of filter signals OUT1-OUT2. For other embodiments, a cross-fade circuit 811 may be coupled to the output of comparator 801, as shown in
For other applications, it may be desired to extend the signal power range over which the selection circuit operates. For example,
Referring again to
Preferably, embodiments of the response select null steering circuits described above are implemented using analog circuitry. Analog implementations use much less power than their digital equivalents. More specifically, to be a low power solution, for which embodiments of the present invention are especially suited for, the analog circuitry is preferred over digital circuitry. For example, the primary driver of power consumption in a digital circuit is switching between 0 (logic low) and 1 (logic high), which requires charging and discharging nodal capacitances from ground to the power supply voltage in a short period of time. In contrast, an analog implementation does not require such drastic signal swings in such a short period of time. Further, because a single signal is represented digitally using several bits, several nodes must be simultaneously charged and discharged for each operation, whether a computation or a memory access. In analog, a signal is represented by a voltage on one or at most two nodes if a single-ended or differential scheme is used respectively.
In a digital implementation, the period of time required to charge and discharge each node is driven by the clock frequency and the clock frequency is driven by the number of operations that need to occur between signal samples. The signal sample rate is determined to be at least twice the frequency of the highest frequency content of the signals to be processed, which results in significant power consumption.
Further, an operation that can be implemented almost instantaneously in analog may require more computational steps in a digital solution. Additionally, several analog operations can occur in parallel whereas a typical digital solution would process each step serially. The more serial steps needed within the required sampling rate described above will increase the needed clock frequency and therefore drive up the power of the digital solution. In the analog design, power can be traded for area.
Finally, an analog implementation does not need data converters and the power they would require. The null response-select solution of the present invention is easier to implement in analog, as opposed to implementing a solution using a fully adaptive filter. Moreover, the allowable null-angles are more easily controllable with the response-select architecture of the present invention.
Null-Filter Frequency Response Derivation
Referring again to
Xs(ω)=A+e−ωΔ′
and the difference-path signal (DIFF) is given by
XD(ω)=A−e−jωΔ′
For the interferer to be cancelled, the following condition has to be met
Xs(ω)−H(ω)XD(ω)=0
Given the previous results, the null-filter transfer function required to cancel an interferer from a given direction over the frequency range of operation may therefore be expressed as
Substituting s=jω leads to
It is desirable to implement this frequency response by an analog filter, i.e. a ratio of two polynomials in the variable s=jω. This leads to the use of Padé approximants.
Bilinear Transform
The bilinear transform is a special case of a Padé approximant to e−sΔ′ where L=1 and M=1. This approximant is given by
The resulting null filter is given by
Where
define the gain factor, zero corner frequency, and pole corner frequency.
Thus, the bilinear transform yields a stable filter. Embodiments of the present invention that include a first filter 311(1) providing a null at 90° and a second filter 311(2) providing a null at 180° utilizes this filter approximation.
Embodiments of the sound processing system described above suppress unwanted noise from an interferer by selecting one of a plurality of fixed filters each providing interferer suppression in a given direction. Applicants have found the above-described embodiments to be effective in suppressing unwanted noise from a variety of interferers (e.g., including background noise such as air condition humming, passing objects such as people talking near the speaker and passing vehicles, and so on). However, mismatches between amplifiers and microphones, and other non-ideal behavior of the system components may adversely affect system performance. Examples of mismatches and other non-ideal behavior include gain mismatches between amplifiers, and sensitivity and phase mismatches between microphones. These non-idealities can be detected during a manufacturing process for the sound processing systems and calibration performed on the sound processing systems to compensate for the presence of these non-idealities. Accordingly, additional embodiments of the sound processing system include programmable components that can be adjusted to compensate for certain non-idealities. In one embodiment, the sound processing system includes adjustable gain and delay elements, as well as control signals that adjust the gain and delay elements. The sound processing system also includes non-volatile programmable memory to store calibration data, and one or more debug outputs that are configurable to output one or more internal signals of the sound processing system.
Also described below are embodiments of a testing and calibration system (“test system”) used to perform testing and calibration of the sound processing systems in order to label each sound processing system under testing as passing or failing; the test system can also be used to adjust the sound processing systems to best match desired response characteristics. Methods to perform testing and calibration steps for the sound processing systems are described as well.
The computing system 1010 is any well-known personal computer or server configurable to execute instructions to transmit commands and data to control the DAQ and control hardware 1020. The computing system 1010 includes one or more processors to execute instructions to control the DAQ and control hardware 1020 and the test board 1031. The instructions being executed may correspond to a test program.
In one embodiment, the test program is implemented in LabView programming language. The test program is configured to assign each sound processing system a bin assignment based on test results corresponding to the sound processing system. The bin assignment may be a passing bin assignment or a failing bin assignment. A failing bin assignment may also contain further information such as which particular test the sound processing system failed. A passing bin assignment may also contain further information such as performance characteristics of the sound processing system. The performance characteristics may be used to select the passing sound processing systems for use in different applications. The test program may also be configured to log individual test results for further analysis after the tests are completed. The computing system 1010 receives data from the DAQ and control hardware 1020 to perform analysis and calculations in order to determine if a test performed on the SPS 1033 has passed or failed. The DAQ and control hardware 1020 is coupled to the computing system 1010 through a bi-directional data bus 1015. The bi-directional data bus 1015 may be a PCI or USB bus, or any other type of well-known signaling configuration. According to one embodiment, the DAQ and control hardware 1020 is a PCI card within the computing system 1010. According to other embodiments, the DAQ and control hardware 1020 is external to the computing system 1010 and is coupled to the computing system 1010 through an USB bus 1015.
The DAQ and control hardware 1020 is configured to generate analog and digital signals for use in testing and configuring the SPS 1033 and/or the test board 1031. The analog signals may be audio signals that are transmitted to the sound generator 1032. The digital signals may be configuration signals to program the SPS 1033 to compensate for mismatches or other non-idealities and/or cause the SPS 1033 to enter into a testing mode. The digital signals may also be power-up command sequences used to initiate a start-up sequence in either the test board 1031 and/or the SPS 1033. The DAQ and control hardware 1020 is also configured to receive analog and digital signals from the test board 1031. These signals may be responses from the SPS 1033 that is to be analyzed during a test of the SPS 1033. According to some embodiments, the DAQ and control hardware 1020 includes power regulators and power lines to provide power to one or more of (i) the test board 1031, (ii) the sound generator 1032, and (iii) the SPS 1033.
In one embodiment, the test bench 1030 is an enclosure having the test board 1031 mounted therein. The test bench 1030 also includes a mounting mechanism (not pictured) for the SPS 1033. The mounting mechanism can be a socket or a spring-loaded jig, or any other mechanism that allows for contact between the pins of the SPS 1033 and a pogopin assembly coupled to the test board 1031. In certain embodiments, the mounting mechanism is located within the test bench 1030 to isolate the SPS 1033 from acoustic noise originating from outside the test bench 1030. Alternatively, the mounting mechanism may be attached to an outer surface of the test bench enclosure 1030 to provide acoustic isolation for the SPS 1033. The mounting mechanism may form an acoustic cavity surrounding the SPS 1033 in order to isolate the SPS 1033 from acoustic noise.
In one embodiment, five of the six surfaces of the test bench enclosure 1030 is composed of phenolic plastic. The sixth surface, a detachable surface having the mounting mechanism attached on one side, is composed of galvanized aluminum. The test bench enclosure 1030 also may be composed of any other sound-absorbing material.
The sound generator 1032 is positioned at a location within the test bench 1030 to properly generate test sound signals to the SPS 1033. According to some embodiments, the sound generator 1032 is located immediately next to the mounting mechanism or within the acoustic cavity of the mounting mechanism. Alternatively, the sound generator 1032 may be positioned at a distance from the SPS 1033 and the mounting mechanism, and a sound pipe is provided within the test bench 1030 to transfer sound waves generated by the speaker to the SPS 1033. The length of the sound pipe is determined based on the frequency of the generated test sound signal. The sound generator 1032 is coupled to the test board 1031 via an audio cable transmitting audio signals. The sound generator 1032 may also be coupled directly to an output sound port of the computing system 1010. According to certain embodiments, multiple sound generators may be provided within the test bench. For example, a sound generator may be provided along a longitudinal axis (e.g. 101 of
The test board 1031 acts as an intermediate communication hub between the DAQ and control hardware 1020 and the SPS 1033, and includes circuit components that are configurable to optimally transmit signals between the DAQ and control hardware 1020 and the SPS 1033. The DAQ and control hardware 1020 includes precision measurement instrumentations to measure amplitudes of signals received at the DAQ and control hardware 1020. The DAQ and control hardware 1020 also includes measurement instrumentations to measure phase differences between signals received at the DAQ and control hardware 1020. The test board 1031 is coupled to the DAQ and control hardware 1020 to receive and transmit data, and receive one or more power signals from the DAQ and control hardware 1020. The test board is also coupled to the sound generator 1032 and SPS 1033. The test board 1031 transmits configuration commands and data to the SPS 1033 through one or more signal lines (CONFIG) and receives debug signals from the SPS 1033 through one or more other signal lines (DEBUG). The DEBUG signals are transmitted by the test board 1031 to the DAQ and control hardware 1020 and are subsequently analyzed by the DAQ and control hardware 1020. The DEBUG signals correspond with certain signals of the SPS 1033 transmitted during a test mode of the SPS 1033 for analysis and testing. The DEBUG signals may be internal signals of the SPS 1033 which are not outputted during non-testing modes of operation. The DEBUG signals can also include an main output of the SPS 1033, such as the signal OUT_min depicted in
According to other embodiments, the testing system 1000 may be configured to concurrently test and configure at least two sound processing systems. For example, multiple mounting mechanisms may be included in the test bench 1030 to concurrently secure two or more sound processing systems. Each of the mounting mechanisms may be acoustically isolated individually such that there is no interference between the different test sound signals.
Two microphones M1 and M2 are coupled to the input stage 1130. The microphone M1 is coupled to transmit a first input signal IN1 to the delay element 1101A. The microphone M2 is coupled to transmit a second input signal IN2 to the gain element 1101B. Each of the delay and gain elements has an input to receive a corresponding configuration signal. Delay element 1101A has an input to receive CTRL_A, a configuration signal for adjusting the signal gain and the delay of the delay element 1101A. Gain element 1101B has an input to receive CTRL_B, a configuration signal used for adjusting the signal gain of the gain element 1101B. The configuration signals CTRL_A and CTRL_B may be transmitted over the signal line CONFIG of
The delay element 1101A has an output to transmit a signal IN1D to a switch 1104. The delay element 1101A is configured to delay the input signal IN1 by a programmable delay and amplify the input signal IN1 by a first programmable signal gain factor to obtain IN1D. The relationship between IN1D and IN1 may be expressed as:
IN1D(t)=A1·IN1(t−D)
where t is time in seconds, A1 is the first programmable gain factor, and D is the programmable delay factor.
The gain element 1101B has an output to transmit a signal IN2A to a delay switch 1105. The gain element 1101B is configured to amplify IN2 by a second programmable signal gain factor. The relationship between IN2A and IN1 may be expressed as:
IN2A(t)=A2·IN2(t)
Where t is time in seconds, and A2 is the second programmable gain factor.
The switch 1104 is configurable to be coupled to the subtraction circuit 1102 and the summing circuit 1103 or a debug output signal line TEST_OUT_A. The debug output signal line TEST_OUT_A is one of the signal lines DEBUG of
The subtraction circuit 1102 operates in a similar manner as the subtraction circuit 302 of
The summing circuit 1103 operates in a similar manner as the summing circuit 303 of
The switches 1104-1107 are individually controlled by select signals (not shown) transmitted to the switches 1104-1107 from the test board 1131. The switches may be mechanical switches, MOSFET switches, or the like. During a testing and calibration mode, the switches 1104-1107 may be configured to transmit one or more of IN1D, IN2A, SUM, or DIFF to the test board 1131 via the signal lines TEST_OUT_A and TEST_OUT_B. As an example, during a test testing the delay element 1101A and the gain element 1101B, the switches 1104 and 1105 are configured to be coupled to TEST_OUT_A and TEST_OUT_B, respectively. At the same time, the switches 1106 and 1107 are configured to be uncoupled from TEST_OUT_A and TEST_OUT_B so as to not introduce unwanted signals to TEST_OUT_A and TEST_OUT_B.
At step 1201, a power up sequence is performed. The power-up sequence includes applying a supply voltage from the test board to the SPS 1033. Digital power-up commands and data may also be transmitted to the SPS 1033 during the power-up sequence. The power-up sequence may also include powering up the test board 1031 if the test board 1031 is in an off state.
At step 1202, a continuity test is performed to check if current levels (ICC) are within specified current thresholds. If the current levels of the SPS 1033 are above or below critical threshold levels, the SPS 1033 is assigned to a fail bin at step 1209. If the SPS 1033 passes the continuity test, further testing is performed.
At step 1203, a gain balancing test is performed. In the gain balancing test, a test sound signal is generated by the sound generator 1032. Amplitudes of the outputs of the delay element 1101A and gain element 1101B (the signals IN1D and IN2A, respectively), generated in response to the test sound signal, are checked against one or more amplitude thresholds. The switches 1104 and 1105 are configured to output the signals IN1D and IN2A as the debug output signals TEST_OUT_A and TEST_OUT_B, respectively. If the amplitudes of the signals IN1D and IN2A do not satisfy the passing requirements, the SPS 1033 is assigned by the test program (executing on the computing system 1010) to the fail bin at step 1209. If the amplitudes of the signals IN1D and IN2A satisfy the passing requirements, adjustments in the gains of the delay element 1101A and the gain element 1101B may still be made to improve system performance of the SPS 1033. If the gain balancing test passes, additional testing is performed.
At step 1204, a phase mismatch test is performed. The phase mismatch test measures the signals IN1D and IN2A in response to a test sound signal generated by the sound generator 1032. The phase mismatch between the signals IN1D and IN2A are measured and compared to a phase mismatch threshold. If the measured phase mismatch exceeds the phase mismatch threshold, the SPS 1033 is assigned to the fail bin at step 1209. If the measured phase mismatch is below the phase match threshold, the test system 1000 continues onto step 1205 to additional steps in the testing and calibration procedure. In addition, the programmable delay of the delay element 1101A may be adjusted to decrease the phase mismatch between the signals IN1D and IN2A.
At step 1205, non-volatile (NV) programming is performed. During the gain balancing and phase mismatch tests, programmable gains and delays were adjusted to improve performance of the SPS 1033. During the NV programming, the adjusted programmable gains of delay element 1101A and gain element 1101B are stored in a non-volatile storage element within the SPS 1033. The programmable delay of the delay element 1101A may also be stored in the non-volatile storage element. The NV programming step 1205 ensures that for subsequent testing and calibration steps as well as for non-testing operations of the SPS 1033, the adjusted programmable gains and delays are used to achieve the optimal performance. After the NV programming is complete, the test system 1000 is configured to perform a noise cancellation and sensitivity test at step 1206.
During the noise cancellation and sensitivity test at step 1206, the noise cancellation ability of the SPS 1033 and an overall sensitivity of the SPS 1033 in response to test sound signals from the sound generator 1032 are measured. The noise cancellation ability of the SPS 1033 is characterized using one or more depth values. A depth value represents the intensity of the output of the SPS 1033 in a noise cancellation mode (or beam-steering mode) compared with the intensity of the output of the SPS 1033 when the noise cancellation mode is off (or omni-directional mode) in response to the same acoustic signal generated by the sound generator 1032. If the one or more depth values and the overall sensitivity of the SPS 1033 do not satisfy passing criteria, the SPS 1033 is assigned to a fail bin at step 1209. Otherwise, the test system 1000 performs a frequency response test at step 1207.
The frequency response test measures the output of the SPS 1033 in response to a multi-tone test sound signal generated by the sound generator 1032. In response to the multi-tone test sound signal, the SPS 1033 outputs a multi-tone output signal. The intensity of each frequency component of the multi-tone output signal is measured. If each of the frequency components has an intensity level within a certain range, the frequency response test is passed and the SPS 1033 is assigned to a passing bin at step 1208. Otherwise, the SPS 1033 is assigned to a failing bin at step 1209. After the SPS 1033 is assigned to a passing or failing bin at steps 1208 and 1209, respectively, the sound processing system is powered-down and removed from the mounting mechanism.
Other additional steps may be performed in the testing and calibration process illustrated in
At step 1301, initialization for the gain balancing test 1203 is performed. One or more control signals are transmitted from the test board 1031 to the SPS 1033, causing the SPS 1033 to enter into a test mode. The one or more control signals include signals causing the switch 1104 to be coupled to the debug output signal line TEST_OUT_A to cause the debug output signal line TEST_OUT_A to transmit the output of the delay element 1101A (IN1D) to the test board 1031. Similarly, the debug output signal line TEST_OUT_B transmits the output of the gain element 1101B (IN2A) to the test board 1031. Also at step 1301, a test sound signal is generated by the sound generator 1032. According to one embodiment, the test sound signal is a single-tone acoustic signal having a frequency of 1 kHz and a pre-determined amplitude.
At step 1302, the amplitude of the signal IN1D is measured. The measurement of the amplitude of the signal IN1D can be performed by the precision measurement instrumentation within the DAQ and control hardware 1020. The first time step 1302 is performed, a first counter value is reset and is incremented every time step 1302 is subsequently performed. The first counter value represents a number of tries in adjusting the gain of the delay element 1101A. At step 1303 the amplitude of signal IN1D is compared against a first set of pre-determined thresholds. The first set of pre-determined thresholds includes a first upper amplitude threshold and a first lower amplitude threshold. The upper and lower thresholds are determined based at least in part on the amplitude of the test sound signal. The threshold values define a range of amplitude values for the signal IN1D that allows for desired performance of the SPS 1033. If the amplitude of the signal IN1D is determined to be not within the range between the first set of threshold values, the first counter value is compared against a first limit value (1305). The first limit value corresponds with a maximum number of tries in adjusting the gain of the delay element 1101A before the SPS 1033 fails the gain balancing test 1203. If the counter value (i.e. the number of tries in adjusting the gain of the delay element 1101A) exceeds the first limit value, the sound processing system fails the gain balancing test at step 1307. If the counter value does not exceed the first limit value, the gain of the delay element 1101A is adjusted. The adjustment of the gain of the delay element can be based on the difference between the measured amplitude of the IN1D signal and the first set of threshold values. For example, if the amplitude of the signal IN1D is larger than the first upper amplitude threshold, the gain of the delay element 1101A is decreased. Following step 1308, step 1302 is performed again.
Steps 1302, 1303, 1305 and 1308 are repeated until the measured amplitude of the IN1D signal is within the range defined by the first set of thresholds or the first counter value exceeds the first limit value. If the amplitude of the signal IN1D is measured to be within the range defined by the first set of thresholds, the amplitude of IN2A is measured at step 1304. A second counter value is reset the first time step 1304 is performed and is incremented every time step 1304 is subsequently performed. At step 1306, the measured amplitude of the signal IN2A is compared against second set of pre-determined amplitude thresholds. If the measured amplitude of the signal IN2A is not within the range defined by the second set of amplitude thresholds, the second counter value is compared against a second limit value (1309). If the second counter value exceeds the second limit value, the sound processing system fails the gain balancing test at step 1307. If the second counter value does not exceed the second limit value, the gain of the gain element 1101B is adjusted based on the difference between the measured amplitude of the IN2A signal and the second set of threshold values. After step 1310, step 1304 is repeated.
Steps 1304, 1306, 1309, and 1310 are repeated until either the amplitude of the signal IN2A is measured to be within the range defined by the second set of thresholds or the second counter value exceeds the second limit value. If the amplitude of the signal IN2A is determined to be within the range defined by the second set of thresholds (1306), the SPS 1033 passes the gain balance test at step 1311.
In one embodiment, the sound generator 1032 is positioned along the horizontal axis 102 (e.g.
It should be appreciated that the gain balancing test 1203 may also be used to test and adjust for gain mismatches and non-idealities in the gains of the delay element 1101A and the gain element 1101B.
At step 1401, control signals are transmitted from the test board 1031 to the SPS 1033, causing the SPS 1033 to enter into a test mode. The signals IN1D and IN2A are output as debug output signals. A test sound signal is generated by the sound generator 1032.
At step 1402, a first phase difference is determined by measuring the difference in phase between the signal IN1D and the test sound signal. The phase measurement may be performed by a phase measurement unit within the DAQ and control hardware 1020.
At step 1402, a second phase difference is determined by measuring the difference in phase between the signal IN2A and the test sound signal. At step 1403, the second phase difference is subtracted from the first phase difference to obtain a relative phase difference between IN1D and IN2A. Alternatively the first phase difference may be subtracted from the second phase difference to obtain the relative phase difference.
At step 1405, the absolute value of the relative phase difference is compared against a phase mismatch threshold value. If the absolute value of the relative phase difference is greater than the phase mismatch threshold value, the SPS 1033 fails the phase mismatch test 1204 at step 1406. If the absolute value of the relative phase difference is less than the phase mismatch threshold value, the SPS 1033 passes the phase mismatch test 1204 at step 1407.
According to an alternative embodiment, the relative phase difference is determined directly by measuring the phase difference between IN1D and IN2A. According to other embodiments, the delay of the delay element 1101A may be adjusted to compensate for phase mismatch between microphones M1 and M2. It should also be appreciated that the phase mismatch test may also be used to test for phase mismatches introduced by the delay element 1101A and gain element 1101B.
At step 1501, a test sound signal is generated along the horizontal axis 102 by the sound generator 1032. For example, the sound generator 1032 may be provided at the 90° direction to generate the test sound signal. At step 1502, the directional filters of selectable directional filter stages 340 are bypassed in the output signal path and the SPS 1033 outputs an omni-directional output signal (i.e. beam steering and noise-cancellation is turned off). This may be achieved by directly transmitting the output of M1 or M2 as the output of the SPS 1033.
At step 1503, the amplitude of the omni-directional output signal is measured. At step 1504, the overall sensitivity of the SPS 1033 is calculated based on the measured amplitude of the omni-directional output signal and the amplitude of the test sound signal. At step 1505, the calculated overall sensitivity is compared against two sensitivity threshold values. If the calculated sensitivity does not fall within the two sensitivity threshold values, the SPS 1033 fails the overall sensitivity check at step 1506. As a result, the SPS 1033 also fails the noise cancellation and sensitivity test 1206.
At step 1507, a broadside noise cancellation mode is engaged on the SPS 1033 to cancel acoustic signals from generated along the horizontal axis 102. Referring back to
At step 1508, the amplitude of the output of the SPS 1033 is measured. The output of the SPS 1033 while in the broadside noise cancellation mode is called the broadside-null output signal. At step 1509, the broadside-null output signal is checked against one or more criteria. If the broadside-null output signal fails to satisfy the one or more criteria, the SPS 1033 fails the broadside interference cancellation check at step 1509 and also fails the noise cancellation and sensitivity test. According to one embodiment, the one or more criteria include a criterion that the measured amplitude of the broadside-null output is at least 12 dB less than the measured amplitude of the omni-directional output signal.
At step 1511, a running mode is engaged for the SPS 1033. The running mode is a mode of operation of the SPS 1033 where the selection circuit 320 selects one of a plurality of signals output by the directional filters based on the energies of each of the plurality of signals. At step 1512, the amplitude of the output signal of the SPS 1033 operating in the running mode is measured. The measured amplitude of the running mode output signal is checked against the measured amplitude of the broadside-null output signal. According to one embodiment, if the measured amplitude of the running mode output signal is within a certain voltage value of the measured amplitude of the broadside-null signal, the SPS 1033 passes the running mode check, as well as the noise-cancellation and sensitivity test at 1515. Otherwise, the SPS 1033 fails the running mode check at 1514 and also fails the noise-cancellation and sensitivity test 1206.
At step 1601, control signals are generated and transmitted by the test board 1031 to the SPS 1033 to cause the SPS 1033 to enter into a test mode. A test sound signal is generated by the sound generator 1032. The test sound signal may be a multi-tone signal, a chirp, a plurality of impulses at different frequencies, or any other acoustic signal having components of different frequencies.
At step 1602, the signal IN1D is measured and characterized by the DAQ and control hardware 1020. The amplitudes of the different frequency components of the signal IN1D are measured.
At step 1603, the run mode is engaged and the output of the sound processing system is measured and characterized by the DAQ and control hardware 1020. The amplitudes of the different frequency components of the run mode output signal are measured.
At step 1604, the measured amplitudes of the run mode output signal are normalized to the measured amplitudes of the IN1D signal. The normalized amplitudes are then checked for a flatness requirement (1605). According to one embodiment, the flatness requirement dictates that all normalized amplitudes are to be within 3 dB of each other. If the normalized amplitudes meet the flatness requirement, the SPS 1033 passes the frequency response test at step 1606. If the normalized amplitudes do not meet the flatness requirement, the SPS 1033 fails the frequency response test at step 1607.
Although the invention has been described with reference to specific exemplary embodiments thereof, it will be evident that various modifications and changes may be made thereto without departing from the broader spirit and scope of the invention as set forth in the appended claims. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense.
This application claims the benefit under 35 USC 119(e) of the and commonly owned U.S. Provisional Application No. 61/079,065 entitled “Module Tester” filed on Jul. 8, 2008, which is incorporated by reference herein.
Number | Name | Date | Kind |
---|---|---|---|
7171008 | Elko | Jan 2007 | B2 |
20070244698 | Dugger et al. | Oct 2007 | A1 |
20080175407 | Zhang et al. | Jul 2008 | A1 |
20100027809 | Liu et al. | Feb 2010 | A1 |
Number | Date | Country | |
---|---|---|---|
61079065 | Jul 2008 | US |