Super directional beamforming design and implementation

Information

  • Patent Grant
  • 6594367
  • Patent Number
    6,594,367
  • Date Filed
    Monday, October 25, 1999
    25 years ago
  • Date Issued
    Tuesday, July 15, 2003
    21 years ago
Abstract
A sensor array receiving system which incorporates one or more filters that are capable of adaptive and/or fixed operation. The filters are defined by a multiple of coefficients and the coefficients are set so as to maximize the signal to noise ratio of the receiving array's output. In one preferred embodiment, the filter coefficients are adaptively determined and are faded into a predetermined group of fixed values upon the occurrence of a specified event. Thereby, allowing the sensor array to operate in both the adaptive and fixed modes, and providing the array with the ability to employ the mode most favorable for a given operating environment. In another preferred embodiment, the filter coefficients are set to a fixed group of values which are determined to be optimal for a predefined noise environment.
Description




FIELD OF THE INVENTION




This invention relates to signal processing, and more particularly, to processing the signals received by an array of sensors in order to minimize the amount of noise received by the array when the array is being used to receive a desired signal.




BACKGROUND OF THE INVENTION




Beamforming is a term used to designate the operations associated with forming spatial sensitivity pattern for an array of sensors. Classical beamforming is defined as “delay and sum beamforming”. In delay and sum beamforming, a source transmits a wave that propagates and arrives at an array of sensors at different times, depending on the source direction and the array geometry. The outputs of the sensors of the array are delayed, to compensate for the delay in time of arrival of the source's wave, which originated from the preferred direction, and summed, to provide a classical directional beamformer output. The effect of sources that are located at directions other than the preferred direction (referred to as the looking direction) is reduced by the beamforming process, resulting in maximum sensitivity of the process towards the preferred direction.




The array of sensors can be, for example, an array of microphones receiving an acoustic sound source. The beamforming process can be used to map sound sources (in a sonar system for example), or to emphasize a sound source whose direction is known, by modifying the compensating delays and “steering” the look direction of the array. The beam-width—usually defined as the difference between the two angles, in which the output energy is reduced by 3 dB relative to the beam center—depends on the array length, frequency of the received signal and propagation speed of the received signal (in our example the speed of sound). For many practical purposes the beam-width of the array will not be sufficiently narrow, and enlarging the array length is not desired. For those cases a more directional beamforming process is required.




Moreover, while delay and sum beamforming, does not provide optimum noise reduction. If the sensors' outputs are filtered (a different filter to each sensor) and the outputs of the filters summed, one can obtain a different shape of the beamformer output and improve noise reduction. With a careful design it is possible, for example, to create a null (zero reception) towards a given direction. If a noise source's direction is known and a null is placed in that direction, improved noise reduction can be realized as compared to the noise reduction of the classic delay and sum beamformer.




Two basic approaches have been developed to obtain optimum performance of a beamformer in the presence of noise. The first one, presented in Monzingo and Miller—Introduction to Adaptive Arrays (Wiley, N.Y.) pp. 89-105 and 155-216 shows that if a filter is created for each sensor that for each frequency will have gain weights of










w
opt

=



C

-
1



v


v






C

-
1



v






(
1
)













the output of the beamformer will have optimum performance in terms of noise reduction. The above weights will maintain a unity gain at the look direction (no distortion of the desired signal) while providing minimum energy at the output. The two assumptions (minimum energy and no signal degradation) will result minimum noise at the output. In Eq. (1) C is the noise covariance matrix and it may be expressed as:








C=E{y*y




T


}  (2) where










y




T




=[y




1


(


f


)


y




2


(


f


) . . .


y




n


(


f


)]  (3)






is the noise measurement at the elements, and v is the steering vector towards the look direction, expressed as:









v
=


[







-
j






wr0










-
j






wr1










-
j







wr


(

n
-
1

)







]






where





(
4
)













τ


0


−τ(n−1) are the steering delays introduced to elements 0−n respectively by a target originated at the look direction. Further, the filtered elements approach was extended by Frost (O. L. Frost, III, “An Algorithm for Linearly Constrained Adaptive Array Processing,”


Proc. IEEE, vol


. 60, no. 8, pp. 926-935, August 1972.) to provide an adaptive beamformer in which the weights would adapt themselves so that they converge to provide the optimum solution.




The second basic approach to obtain optimum beamformer performance was developed by Griffiths (L. J. Griffiths and C. W. Jim, “An Alternative Approach to Linearly Constrained Adaptive Beamforming,”


IEEE Trans. Antennas Propagat


., vol. AP-30, no. 1, pp. 27-34, January 1982.) who suggested using a Noise Canceling (NC) approach to the optimum beamformer problem. In his approach the adaptive coefficient are updated by the Least Mean Squares (LMS) algorithm. Griffiths proposed using the elements' signals to obtain a main channel, in which both the signal and the noise are present, and reference channels, in which only noise is present (i.e. which are signal free). The main channel can be generated through one of the elements alone, or through classic delay and sum beamforming. The reference channels can be generated through the subtraction of one element from another, or by forming any other linear combination of elements that would provide a zero output at the look direction (i.e. the signal direction). The main channel and the reference channels are utilized by an adaptive LMS Widrow filter to obtain an optimum beamformer (see Adaptive Noise Canceling: Principals and Applications—Widrow, Glover, McCool—


Proc. IEEE


vol. 63 no. 12 1692-1716, December 1975). In this adaptive beamformer each reference channel is filtered (i.e. each channel signal is convolved with a set of filter coefficients), the filtered channels are summed together to obtain the noise estimation, and the noise estimation is subtracted from the main channel to provide a noise free signal. The filter coefficients in the Griffiths solution converge to








w




opt




=C




−1




p


  (5) where






C is the noise covariance matrix and p is the correlation vector between the beam output and the reference channels. Note that with this approach the steering is done through the creation of the reference channels and the beam, so there is no steering vector towards the look direction in equation (5). Griffiths showed that, for an n elements system, if one creates n−1 reference channels, the LMS approach would converge to the same optimum solution as Frost.




Objects and Summary of the Invention




It has been recognized that while the two approaches to optimum beamforming discussed above were primarily developed to provide an adaptive solution, they also teach us what the optimum solution would be given the noise covariance matrix. A non-adaptive approach, in which predetermined filters are designed and used, is sometimes more appealing than an adaptive approach. The fixed beam (non-adaptive) approach is much less computationally intensive, it is much less sensitive to leakage of the desired signal to the reference channels and it does not give rise to distortion in the desired signal. Also, the fixed approach has the potential to handle some types of noises better than an adaptive process, such as reverberation and diffused low noises. On the other hand, one may not want to give up the adaptive process, because it provides the best immunity to significant directional noises. A hybrid system that uses both adaptive and non-adaptive techniques provides a system which realizes the advantages of both techniques.




Further, it has been recognized that while the above described optimum beamforming techniques provide the solution given the noise covariance matrix, they do not show how to determine this matrix for a particular noise scenario. Also, the equations show how the required weights for each frequency can be computed, but they do not show how to implement the time domain filters that will approximate the weighting solution. The prior work in this area does not discuss how such time domain filters would be designed or implemented in a combined adaptive/non-adaptive beamforming system. Moreover, there is no teaching as to techniques for overcoming differences in the elements' sensitivity, phase, or the influence of packaging and other mechanical interferences on the performance of the fixed beam.




In view of the above considerations, it is an object of the invention to provide a sensor array beamforming system capable of optimal noise reduction performance.




It is another object of the invention to provide a simple and easy method to design optimal filters in a sensor array beamforming system.




It is still another object the invention to provide a simple and easy way to implement the optimal system in as a fixed solution system or as a combined fixed and adaptive system.




It is yet another object of the invention to provide a method to design optimum filters for a sensor array beamforming system that would take into consideration the specific characteristics of the sensors (microphones for example), and other mechanical or acoustical features that influence the performance of the array.




In order to realize the above objects of the invention and overcome the drawbacks of prior systems, the invention provides a sensor array receiving system which incorporates one or more filters that are capable of adaptive and/or fixed operation. The filters are defined by a multiple of coefficients and the coefficients are set so as to maximize the signal to noise ratio of the receiving array's output. In one preferred embodiment, the filter coefficients are adaptively determined and are faded into a predetermined group of fixed values upon the occurrence of a specified event. Thereby, allowing the sensor array to operate in both the adaptive and fixed modes, and providing the array with the ability to employ the mode most favorable for a given operating environment. In another preferred embodiment, the filter coefficients are set to a fixed group of values which are determined to be optimal for a predefined noise environment.




Thus, reference is made to application U.S. Ser. No.: 09/425,790, by Andrea et al., filed on Oct. 22, 1999 and entitled “System and Method for Adaptive Interference Canceling,” which, together with the documents and patents and patent applications cited therein are hereby incorporated by reference; the present invention may be used in conjunction with embodiments disclosed or discussed in Andrea et al. and/or in the documents, patents and patent applications cited in Andrea et al. (and incorporated herein), e.g., the “Superbeam” technology of this invention can be used in conjunction with “DSDA” technology in embodiments disclosed or discussed in Andrea et al. and/or in the documents, patents and patent applications cited in Andrea et al. (and incorporated herein).











BRIEF DESCRIPTION OF THE DRAWINGS




The following detailed description, given by way of example and not intended to limit the present invention solely thereto, will best be appreciated in conjunction with the accompanying drawings, wherein like reference numerals denote like elements and parts, in which:





FIG. 1

is block diagram of a filtered input type beamforming system in accordance with the present invention.





FIG. 2

is a block diagram of a filtered references type beamforming system in accordance the present invention.





FIG. 2A

is a flowchart which shows an illustrative procedure for designing and implementing the fixed filtered references approach.





FIG. 3

is a flowchart showing an illustrative procedure for generating fixed filter coefficients through the use of simulated noise and an actual adaptive system positioned in an an-echoic chamber.





FIG. 4

is a flowchart showing an illustrative procedure for generating fixed filter coefficients through the use of simulated noise, a microphone array positioned in an an-echoic chamber and an actual adaptive system positioned outside an an-echoic chamber.





FIG. 5

is a flowchart showing an illustrative procedure for generating simulated noise and using the simulated noise to generate fixed beamformer coefficients.











DETAILED DESCRIPTION




The following description will be divided into four parts. Part one will detail a method for designing and implementing fixed beam optimal filters based on the filtered input approach. Part two will detail a method for designing and implementing fixed beam optimal filters based on the filtered references approach. Part three will detail a hybrid system that includes both a fixed solution and an adaptive one. Part four will detail two alternative approaches to the design and implementation of fixed beam filters.




1—A method of Designing and Implementing Fixed Beam Optimal Filters Based on the Filtered Input Approach.





FIG. 1

is block diagram of a filtered input type beamforming system in accordance with the present invention. As can be seen from the

FIG. 1

, N microphones


10




1−N


are conditioned and sampled by signal conditioners


12




1−N


. The microphones' samples are respectively stored in time tapped delay lines


14




1−N


and filtered by filters


16




1−N


via convolvers


18




1−N


. The output of the filters is summed up via an adder 20 to provide a fixed beamformer solution. In the

FIG. 1

embodiment, the invention provides a method for creating the noise covariance matrix and then using equation (1) to actually design the coefficients for filters


16




1=N


. It should be noted that the equation provides us with the required coefficients in the frequency domain. The time domain coefficients are obtained from the frequency domain coefficients.




To determine the optimal solution for any given scenario we first define the scenario in terms of the spatial distribution of the interfering sources (directions and relative intensity). For each of the interfering sources we assume a far field model. Let us consider an array of M identical omni-directional sensors with a known arbitrary geometry measuring the wave-field generated by a single far-field source. Let r


i


denote the location of the i-th sensor, where r


i


=[x


i


, y


i


, z


i


] and let φ and θ denote the azimuth and elevation angles of the radiating source, respectively.




Let us now define a differential delay vector, which expresses the delay in time of arrival of the interference wave front to the various elements:









τ


=


[


τ
12

,

τ
13

,





,

τ

1
,
M



]

T


;






τ

1

j





τ
j

-

τ
1




,










where the first sensor serves as a reference and the delays are measured relative to it. The signal “Direction Of Arrival” vector for the far field case is given by:









k
=


[




k
x






k
y






k
z




]

=


[




sin






(
θ
)






cos






(
φ
)







sin






(
θ
)






sin






(
φ
)







cos






(
θ
)





]

.






(
6
)













Let us define a distance matrix R between the sensors of the array









R


[



0






r
2

-

r
1













r
M

-

r
1





]





(
7
)













The time delay between any two sensors is equal to the projection of the distance vector between them along the k vector divided by the wave propagation velocity (sound velocity for example). Consequently, the delay vector can be expressed as follows:









τ
=

-





Rk
c






(
8
)













where c is the wave velocity and the matrix R is composed of the distance vectors between all the sensors and the reference sensor. More explicitly, for sensor j we can write






τ


1j




=[x




1j


cos(θ)sin(φ)+


y




1j


sin(θ)sin(φ)+


z




1j


cos(φ)]/


c


  (9)






Assuming that interference i has an amplitude of s


i


and a Direction Of Arrival vector of k


i


then its measurement by the array can be expressed as the source steering vector multiplied by the source amplitude








y




i


(


f


)=


s




i




b




i


(


f


)=


s




i




e




−jω{overscore (τ)}




=s




i




e




−j2πfRk/c


  (10)






The contribution of source i to the noise covariance matrix is expresses as:








C




i




E{y




i




y




i




1


}  (11)






Since b


i


is deterministic and we assume stationary sources where s


i




2


the power of the source i the above equation is reduced to








C




i




=y




i




y




i




1


  (11a)






Under the assumption that the interferences are uncorrelated we can write








C=ΣC




i


  (12)






If we assume that there is an additive uncorrelated noise (spatially distributed white noise) n to each of the sensors we obtain








C=nI+ΣC




i


  (13) where






I is the unity matrix with a size of [M×M].




So far we obtained the noise covariance matrix for a predetermined noise environment. In order to use equation (1) we need to calculate the steering vector v. This steering vector expresses the look of the array towards a defined direction. The steering vector v is the conjugate of the vector already expressed in equation (4) and it is calculated in the same way as the steering vector of the noise sources (see (8) and (9)) where φ and θ are the azimuth and elevation of the look direction, respectively.




It should be noted that a far field model for the noises was used to obtain the above equations. It is not necessarily desirable to use a far field model for the target (desired signal). For example, one may want to implement a focusing effect on the target in near field situations. Such an effect can be obtained by manipulating the steering vector accordingly.




The fixed solution technique of

FIG. 1

, using equation (1), provides a way to calculate the gain weights of each sensor in an array for each frequency. More specifically, for each frequency of interest the system of

FIG. 1

, equation (1) is solved to yield one weight for each filter (w


opt


is a vector with the number of elements being equal to the number of sensors). Thus, if it is desired to obtain the optimum weights for ten frequencies, for example, equation (1) is solved for ten frequencies and each filter


16




1−N


is then defined by ten frequency domain weights—the set of frequency domain weights for each filter defining the filter's frequency domain response.




Once the frequency response for each filter is determined, it is necessary to design the time domain filters to provide the determined frequency response. If the weights (or “gains”) are real numbers—meaning that the desired filter has a linear phase—we can use the weights with any of the well-known methods to design the filter for each sensor. For example, a Remez Exchange Method can be used. For simple cases such as when the array is linear and the noise sources are positioned in a symmetric structure around the look direction, the gain weights would be real numbers. If the gain weights are complex numbers, such as when the noise structure is not symmetric, the required filter will not have a linear phase. For these cases one can feed the weights for each filter to an IFFT (Inverse Fast Fourier Transform) procedure to obtain the time domain function that would provide the desired frequency response and phases for the filter.




2—A Method for Designing and Implementing Fixed Beam Optimal Filters Based on the Filtered References Approach.





FIG. 2

is a block diagram of a filtered references type beamforming system in accordance the present invention. As can be seen from

FIG. 2

, N microphones


26




1−N


are conditioned and sampled by signal conditioners


28




1−N


. The microphone outputs are processed by a delay and sum beamformer


30


to provide a beam channel, and by a reference channel processor


32


which is typical of an LMS beamforming system. As shown, the beam channel may be formed via the classic delay and sum beamforming process on the inputs, however the alternatives include any linear combination of sensor outputs that will provide a maximum towards the looking (listening) direction. The reference channels are processed such that a null is placed towards the looking direction. It may be obtained by subtracting one microphone form the other, or by forming some other linear combination of sensor outputs. The output of the reference channels is respectively stored in tapped delay lines


34




1−L


(L may or may not be equal to N) and filtered by filters


36




1−L


via convolvers


38




1−N


The filtered reference channel output is summed via an adder


40


and subtracted via a subtractor


42


from the beamformer output as delayed by a delay line


44


. This structure is typical to adaptive beamformers, where the reference channels are filtered by adaptive filters and then summed and subtracted from the delayed main beam signal. In our case, the filters are fixed (non adaptive) and pre-designed. The method is highly practical in systems that already have the structure of an adaptive beamformer, which can be applied to both the adaptive solution and the fixed solution.




In the filtered references embodiment of

FIG. 2

, the filters' coefficients are designed and determined using equation (5). More particularly, the noise covariance matrix is determined and then used in equation (5) to determine the filter coefficients. As was the case in the filtered input embodiment of

FIG. 1

, equation (5) provides filter coefficients in the frequency domain and it is necessary to obtain the time domain coefficients from the frequency domain coefficients.




Equation (5) is expressed as








w




opt




=C




−1




p


where






C is the noise covariance matrix as measured by the reference channels, and p is the correlation vector between the main channel (beam) output and the reference channels. We obtain the noise covariance matrix using techniques that are similar to those used in the filtered inputs approach. The difference is that we need to obtain the noise received as it appears in the reference channels, and not as it appears at each sensor. To do this, we first obtain the contribution of each noise source to each sensor (the same y


i


that we obtained in the previous method), and then find the contribution of each noise source to each reference channels. The reference channels are generally relatively flat sensitivity patterns having nulls pointing to the array look direction. The reference channels are created using linear combinations of the elements' outputs after they have been steered to the look direction. For example x


1


+x


2


−(x


3


+x


4


) may be a reference channel after the inputs (denoted as x


n


) have been appropriately delayed to compensate for the look direction. These relations can be expressed as a nulling matrix N (note again that in order to guarantee a signal free reference the sum of the elements of each row in the matrix should be 0).




Example for nulling matrix for an array of four microphones and three reference channels is









N
=


1
4



[



1


1



-
1




-
1






-
3



1


1


1




1


1


1



-
3




]






(
14
)













Note also that for an n elements array only n−1 independent nulls can be created. If we denote v as the steering vector to the look direction than we can obtain the contribution of the a noise source i to the reference channels through the following equation:








x




i




=N


·diag(


v





y




i


  (15)






where diag(v) is the diagonal matrix which elements are the element of the vector v (for broad side array diag(v)=I—the unity matrix), y


i


is the interference contribution of noise source i measured by the array elements as described above, N is the a Nulling matrix used to create the reference channels and x


i


is the contribution of interference of noise source i as measured by the reference channels. Through equation (15) the contribution of a noise source is “transferred” from the array elements to the reference channels.




The overall noise measured the reference channels is the sum of the noise contributed by each interference.








x=Σx




i


  (16)






where x is the noise measured at the reference channels. The contribution of each x


i


to the noise covariance matrix is expressed as








C




i




=E{x




i




x




i




1


}  (17)






As in the case of equation (11), since x is a multiplication of a stationery signal by a deterministic one (the steering elements) the equation is reduced to








C




i




=x




i




x




i




1


  (17a)






Under the assumption that the interferences are uncorrelated we can write








C=ΣC




i


  (18)






If we assume that there is an additive uncorrelated noise n (spatially distributed white noise) to each of the sensors we obtain








C=nI+ΣC




i


  (19) where






I is the unity matrix with a size of [M×M].




We now need to find the correlation vector p. This vector expresses the correlation between the beam signal and the reference channels. The correlation vector p is given by:








p=Σp




i


  (20)






where p


i


is given by








p




i


=beam


i




x




i


  (21)






and






beam


i




=v




t




y




i


  (22)






After obtaining both C and p equation (5) is used to find the gain weights for each frequency. The practicality of obtaining the weight for a series of discrete frequencies and the actual design of the filters was demonstrated above in relation to the filtered inputs method of FIG.


1


.




An illustrative procedure for designing and implementing the fixed filtered references approach is shown in FIG.


2


A. As can be seen from the figure, the first steps are to define the desired noise scenario, the array configuration and frequency range and resolution (step


50


), and to initialize certain variables to be used in the procedure(step


52


). Next, the contribution of a first noise source to the noise covariance matrix—at the array output—is computed (step


54


). The noise source's contribution to reference channel noise covariance matrix is then computed on the basis of the source's contribution at the array output, the nulling matrix and the steering vector toward the array look direction (step


56


) is computed, and the correlation vector between the beam signal and the reference channels for the source is determined (step


58


).




At this point a determination is made as to whether each source has been considered in steps


52


-


58


(step


60


). If not all noise sources have been considered, a count variable is incremented (step


62


) and steps


52


-


58


are performed for the next noise source. If all noise sources have been considered, the contributions of each noise source to each reference channel are summed to generate a reference channel covariance matrix and the beam/reference channels correlation vectors are added to determine a beam/reference channel correlation matrix (step


64


). Once the reference channel noise covariance matrix and correlation matrix are determined for a particular frequency under consideration, a filter coefficient corresponding to that frequency is determined for each channel according to equation (5) (step


66


).




A determination is then made if each desired frequency has been considered (step


68


) If not all frequencies have been considered, a count variable is incremented (step


70


) and steps


52


-


68


are performed for the next frequency. If all frequencies have been considered, a filter design program is used to obtain the filter time domain coefficients that approximate the desired response as defined by the frequency domain coefficients determined in step


66


(step


72


).




3—A Hybrid System That Includes Both a Fixed Solution and an Adaptive one




Adaptive systems are designed to provide the optimum solution to the noise environment at any time. Using the reference channel type approach, an adaptive system measures and studies the noise sources through the reference channels and subtracts it utilizing LMS filters. A major problem of an adaptive system is the leakage problem. The desired signal “leaks” into the reference channel nulls due to differences in the sensors' sensitivity and phases, or due to mechanical imperfections. The leakage of the desired signal into the nulls causes the system to try and cancel the desired signal as though it was noise, and thereby causes distortion in reception of the desired signal. One way to prevent signal distortion due to leakage is by blocking (or freezing) the adaptive process when a strong desired signal is detected, and thus prevent the adaptive process from attempting to cancel the desired signal. However, regardless of the logic of the adaptive process blockage, blocking has the effect of locking the noise reduction filters on the solution existing immediately before blockage commenced, resulting in the filters losing their relevancy in time.




In order to overcome the ameliorate the problems associated with leakage and blocking, the present invention provides a system in which the filters' coefficients drift form their adaptive solution into a pre-designed fixed solution. The system initializes its filters' coefficients with the fixed pre-designed solution and fades into the fixed solution whenever the adaptive process is blocked. The drifting mechanism is implemented in the following way: let w


i


(n) be the i-th coefficient of an adaptive filter at time n, and let w(0) be the fixed value of that filter coefficient, then








w




i


(


n


+1)=


w




i


(


n


)*γ+


w




i


(0)*(1−γ)  (23) where






γ determines how fast the filter will converge into its fixed solution.




The drifting process of the invention serves another purpose. It has been shown that the adaptive process may explode (or diverge) due to numerical problems when the process is performed by a fixed-point processor (see Limited-Precision Effects in Adaptive Filtering—John M. Cioffi—IEEE Transactions on Circuits and Systems vol cas-34 no. 7, July 1987). To prevent such a divergent breakdown, it is sometimes useful to apply a “leaky filter”. A leaky filter multiplies its coefficients by a number smaller than one before they get updated, thus preventing divergence due to numerical problems. Although the leaky process does not allow the filter to converge to the optimum solution, it prevents mathematical divergence.




The use of the decaying process proposed here will eliminate the need to use a strong leaky process (or any leaky process) since whenever the adaptive process is blocked the whole adaptive process is actually reset. Also it is possible to be more generous in the blocking logic—meaning it is possible to allow it to happen more often, since the filter will fade into a sub optimal, but fairly good, solution and the pitfalls normally associated with blocking are avoided.




4—Alternative Approaches to Design and Implement Fixed Beam Filters




In parts one and two of this description fixed beamformer implementations of the invention were presented. In these two implementations one simulates a noise structure by placing noise sources in the sphere, then the noise covariance matrix is calculated and the optimum filter for that noise structure is obtained. In part three of the description a hybrid beamformer implementation was discussed. In the third implementation, an adaptive process is employed when there are significant noises to adapt to, and the fixed solution kicks in when the adaptive process in inhibited for some reason (e.g. a strong signal).




It is proposed here that, assuming one has the infrastructure for an adaptive solution, it can be utilized to obtain the fixed solution using the adaptive process. For example, lets assume that the adaptive process is implemented on an off line system using high-level language (like Matlab for example). One can simulate the noise structure off-line, i.e. obtain the noise signal on each of the microphones (time domain noise sources multiplied by the source steering vector). This noise data can then be fed into the simulated off-line adaptive process. Once the adaptive process converges, one can read the final values of the filters' coefficients and use them as the optimum solution for the pre-defined noise situation. The disadvantage of using the adaptive process in a simulated environment to obtain the fixed weights is that it is time consuming. Large data files need to be prepared for the filters to converge and the adaptive process is a very computation intensive when it is done off-line. Also, the existence of an adaptive system simulation has been assumed, and if one does not exist it needs to be prepared. The advantage of this method is that it would provide a more accurate solution than the direct methods. The reason is that the direct methods determine the gain weight in the frequency domain. It is then necessary to go through a filter design process that is, by nature, an approximation and includes inherent compromises, over which we have no control. Even more so, in the methods discussed in parts one and two each filter is designed separately and we have no guaranty that the overall beamformer performance (using all the filters concurrently) could not provide a better solution.




Running the simulated data through the adaptive process assure us that we get the optimum solution for the simulated scenario, that is for the simulated noise environment and array structure. For example, if we use the reference channel type adaptive filter, the solution will take into account the specific way we actually implemented the reference channels—which the separate filter design discussed in part two does not take into account.




Another approach proposed in this invention assumes that there is a real time working adaptive system. The simulated noise data can be stored on a recording media, such as a multi-channel digital tape recorder, or a computer equipped with a multi-channel sound card. The noise data can be injected into the real time working system which will converge to the solution, freeze the final filters' coefficients and either store them permanently as the fixed solution or transmit them to a hosting system to be burned into the fixed beamformer solution. The advantage of this method is that once the noise data is prepared, the solution is obtained very fast. The adaptive filter will converge within seconds. Another advantage of this method is that the fixed solution will take into account all kinds of implementation related issues like—fixed point and numerical inaccuracies, final dynamic range of the system, differences in the input ports of the processor like different A/D converters and so on.




Taking the above approach one step further, the present invention proposes to create a simulated noise environment using loudspeakers in an an-echoic chamber, then running the adaptive system in the chamber and freezing the final values of coefficients as the fixed array solution. Loudspeakers are placed in an an-echoic chamber to simulate a certain noise scenario—for example two loudspeakers can be placed on each side of the array at 40 degrees and 75 degrees azimuth angle. A simulated noise is played through the loudspeakers—for example pink wide band noise. The adaptive system runs and converges (within seconds) and the final filters' coefficients are stored. The process can be automated—the adaptive system is put in a calibration mode, the adaptive system converges and than stores coefficients converged to as in its own memory as the fixed solution. The calibrated system is than switched off from the calibration mode for normal operation.




The advantage of using the actual working adaptive system is that the convergence solution takes into account not just the process itself with all its peculiarities like dynamic range of the processor and the exact implementation of the filters, but also unknown factors like the microphones sensitivities and phases, mechanical interferences and so on. This is particularly important since it has been observed that the fixed solution is very sensitive to some parameters like mismatch in phases. Also, if the sensors are microphones, for example, and cardioids (uni directional) microphones are used instead of omni directional microphones, then the mismatch in phase may be such that the actual performance of the filters may be far from what was pre-designed. The packaging of the microphone (or other sensor) array may also affect the performance strongly. Using the real working adaptive system to adaptively generate the fixed solution coefficients takes all these parameters into account and ensures an optimum solution the given system.




The disadvantage of the method is that, in general, it is necessary to use many simulated noise sources in order to achieve desirable performance improvement. Use of one noise source located at one side of an array, for example, may cause the array to adapt such that the noise source is effectively cancelled while the beam shape on the array side opposite is undesirable. However, for a relatively small array, where the fixed super directionality is most needed, few noise sources will usually be sufficient to provide an improved performance. For instance, in a four cardioids microphone array with an aperture of 6″ four noise sources are sufficient to provide a noise rejection of 20 dB at angles over 30 degrees from the look direction.




An illustrative procedure for generating fixed filter coefficients through the use of simulated noise and an actual adaptive system positioned in an an-echoic chamber is shown FIG.


3


. The first step is to create four random noise files having a white or pink spectrum and a duration of 30 seconds or more (step


74


). Next, four speakers and an adaptive beamforming system are place in an an-echoic chamber, with the angles between the speakers and array look direction being set at −70°, −40°, 40° and 70° (step


76


). The four noise files are fed to the loudspeakers (step


78


) and the adaptive system is allowed to converge to the optimal solution and the filter coefficients corresponding to the optimal solution are stored (step


80


).




Another technique to calibrate a system is proposed here. The microphone array is placed in the an-echoic chamber and the simulated noise is played through the loudspeakers. The output of the array is recorded (no real time DSP system is present in the chamber). The recorded output is then replayed into the real time system. The adaptive process converges and the final filters' coefficients are stored and burned into the system as the fixed array solution. This method is sometimes more practical when the automatic calibration and burning mechanism is not implemented. It is highly inconvenient to perform the down loading and uploading of the coefficient from a system that is positioned in the chamber. This operation usually requires a development system (like In Circuit Emulator or a simulator). It is much more convenient to do the recording in the chamber and perform the down loading and uploading of coefficients outside were the development system is located.




An illustrative procedure for generating fixed filter coefficients through the use of simulated noise, a microphone array positioned in an an-echoic chamber and an actual adaptive system positioned outside an an-echoic chamber is shown in FIG.


4


. As in the procedure of

FIG. 3

, the first step in the

FIG. 4

procedure is to create four random noise files having a white or pink spectrum and a duration of 30 (step


82


). The next is to place four speakers and an a microphone array in an an-echoic chamber, with the angles between the speakers and array look direction being set at −70°, −40°, 40° and 70° (step


84


). The four noise files are fed to the loudspeakers (step


86


) and the microphone array's output is recorded on a multi-channel recorder (step


88


). The recorded output is then played into an adaptive beamformer system which is located outside the an-echoic chamber and the beamformer is allowed to converge to the optimal solution, the coefficients corresponding to the optimal solution being stored for use as the fixed filter coefficients (step


90


).





FIG. 5

shows an illustrative procedure for generating simulated noise and using the simulated noise to generate fixed beamformer coefficients. The first step in the procedure is to define the desired noise field scenario and the array configuration (step


90


). Next, a counting variable indicative of the noise source being considered is initialized to one (step


94


). A random signal is generated to represent the noise emanating from the source under consideration (step


96


), and for each sensor, the contribution of noise from the source under consideration is calculated. Calculation of noise source contributions involves; initializing to one a counting variable indicative of the sensor under consideration (step


98


); determining the time delay from the source to the sensor under consideration, relative to the time delay to other sensors (step


100


); and determining the noise source contribution based on the random signal generated in step


96


and the time delay (step


102


).




After the noise contribution of a source to a particular sensor is calculated, a determination is made as to whether all sensors have been considered (step


104


). If all sensors have not been considered, the sensor counting variable is incremented (step


106


) and the procedure returns to step


98


. When all sensors have been considered for a particular source, a determination is made as to whether all sources have been considered (step


108


), and if not, the source counting variable is incremented (step


110


) and the procedure returns to step


96


. Once the contribution of each noise source to each sensor has been calculated the generation of the simulated noise data is complete. The noise data is then fed to an adaptive procedure which is allowed to converge, and the coefficients derived from the converged operation are stored for use as the optimal fixed coefficients (step


112


).




While the present invention has been particularly shown and described in conjunction with preferred embodiments thereof, it will be readily appreciated by those of ordinary skill in the art that various changes may be made without departing from the spirit and scope of the invention. Therefore, it is intended that the appended claims be interpreted as including the embodiments described herein as well as all equivalents thereto.



Claims
  • 1. A sensor array for receiving a signal that includes a desired signal and noise, comprising:a plurality of sensors; a plurality of filters for filtering the output of each sensor, each filter being defined by one or more filter coefficients; and a means for combining the outputs of said filters to form a sensor array output signal; wherein said filter coefficients are adaptively determined so as to maximize the signal to noise ratio of the array output signal, and wherein upon the occurrence of a predetermined event the adaptive determination of said filter coefficients is stopped and said filter coefficients are faded into a predetermined set of fixed coefficients; the fixed filter coefficients being determined by solving directly and non-adaptively an equation wopt=C-1⁢vvC-1⁢v where C is the noise covariance matrix, v is the steering vector toward the array look direction, and wopt is a vector having a number of components equal to the number of sensors, and where solving said equation for “n” frequencies provides “n”coefficients for each filter.
  • 2. The sensor array as set forth in claim 1, wherein said sensors are microphones.
  • 3. The sensor array as set forth in claim 1, wherein said filter coefficients are frequency domain coefficients such that for each said filter said frequency domain coefficients determine the frequency response of said filter.
  • 4. The sensor array as set forth in claim 1, wherein said filter coefficients are time domain coefficients.
  • 5. The sensor array as set forth in claim 4, further comprising:a plurality of delay lines, said delay lines corresponding to respective outputs of said sensors and receiving respective outputs from said sensors; and a plurality of convolvers, corresponding to respective outputs of said delay lines, said convolvers being operative to receive respective outputs from said delay lines and convolve the received outputs with respective filter coefficients to generate a plurality of filtered delay line outputs; wherein said plurality of filtered delay line outputs are combined by said means for combining to form said array output.
  • 6. The sensor array as set forth in claim 5, further comprising a plurality of signal conditioners for receiving respective outputs from said sensors, sampling the received outputs and passing the sampled received outputs to respective delay lines.
  • 7. The sensor array as set forth in claim 1, wherein said fixed filter coefficients are determined by placing the array in a simulated noise environment, letting the adaptation of the filter weights converge to a solution and then setting the fixed filter coefficients equal to the coefficients of the converged adaptive solution.
  • 8. The sensor array as set forth in claim 1, wherein said fixed filter coefficients are determined by simulating a noise environment and the array's response to said noise environment, letting the simulated adaptation of the filter weights converge to a solution and then storing the coefficients of the converged adaptive solution for use as the fixed weights of an actual array.
  • 9. A sensor array for receiving a signal that includes a desired signal and noise, comprising:a plurality of sensors; a plurality of filters for filtering the output of each sensor, each filter being defined by one or more filter coefficients; and a means for combining the outputs of said filters to form a sensor array output signal; wherein said filter coefficients are adaptively determined so as to maximize the signal to noise ratio of the array output signal, and wherein upon the occurrence of a predetermined event the adaptive determination of said filter coefficients is stopped and said filter coefficients are faded into a predetermined set of fixed coefficients; the fixed filter coefficients being determined by solving directly and non-adaptively an equation wopt=C-1⁢vvC-1⁢v where C is the noise covariance matrix, v is the steering vector toward the array look direction, and wopt is a vector having a number of components equal to the number of sensors, and where solving said equation for “n” frequencies provides “n” coefficients for each filter; and wherein said fixed filter coefficients are determined by simulating a noise environment, recording the simulated noise generated in said environment, playing back said simulated noise for reception by the array, letting the adaptation of the filter weights converge to a solution and then setting the fixed filter coefficients of the array equal to the coefficients of the converged adaptive solution.
  • 10. An sensor array for receiving signal that includes a desired signal and noise, comprising:a plurality of sensors; a delay and sum beamformer for combining the outputs of said sensors to generate a beamformer output; a reference channel processor for combining the outputs of said sensors to generate one or more reference channel signals; at least one filter for each said reference channel, each said filter being defined by one or more coefficients; and means for combining the outputs of said filters with said beamformer output to generate a sensor array output signal; wherein said reference channel processor and said filters operate to maximize the signal to noise ratio of the array output signal, wherein said filter coefficients are adaptively determined so as to maximize the signal to noise ratio of the array output signal, and wherein upon the occurrence of a predetermined event the adaptive determination of said filter coefficients is stopped and said filter coefficients faded into a predetermined set of fixed coefficients; the fixed filter coefficients being determined by solving directly and non-adaptively an equation wopt=C−1p  where C is the noise covariance matrix, p is a vector representing the correlation between the output of said beamformer and the output of said reference channels, and wopt is a vector having a number of components equal to the number of sensors, and where solving said equation for “n” frequencies provides “n” coefficients for each filter.
  • 11. The sensor array as set forth in claim 10, wherein said sensors are microphones.
  • 12. The sensor array as set forth in claim 10, wherein said filter coefficients are frequency domain coefficients such that for each said filter said frequency domain coefficients determine the frequency response of said filter.
  • 13. The sensor array as set forth in claim 10, wherein said filter coefficients are time domain coefficients.
  • 14. The sensor array as set forth in claim 13, further comprising:a main channel delay line for delaying the output of said beamformer; a plurality of reference channel delay lines, said reference channel delay lines corresponding to respective reference channel signals and receiving respective reference channel signals; and a plurality of convolvers, corresponding to respective outputs of said reference channel delay lines, said convolvers being operative to receive respective outputs from said reference channel delay lines and convolve the received outputs with respective filter coefficients to generate a plurality of filtered delay line outputs; wherein said plurality of filtered delay line outputs and said main channel delay line output are combined by said means for combining to form said array output.
  • 15. The sensor array as set forth in claim 14, further comprising a plurality of signal conditioners for receiving respective outputs from said sensors, sampling the received outputs and passing the sampled received outputs to said delay and sum beamformer and said reference channel processor.
  • 16. The sensor array as set forth in claim 10, wherein said fixed filter coefficients are determined by placing the array in a simulated noise environment, letting the adaptation of the filter weights converge to a solution and then setting the fixed filter coefficients equal to the coefficients of the converged adaptive.
  • 17. The sensor array as set forth in claim 10, wherein said fixed filter coefficients are determined by simulating a noise environment and the array's response to said noise environment, letting the simulated adaptation of the filter weights converge to a solution and then storing the coefficients of the converged adaptive solution for use as the fixed weights of an actual array.
  • 18. An sensor array for receiving signal that includes a desired signal and noise, comprising:a plurality of sensors; a delay and sum beamformer for combining the outputs of said sensors to generate a beamformer output; a reference channel processor for combining the outputs of said sensors to generate one or more reference channel signals; at least one filter for each said reference channel, each said filter being defined by one or more coefficients; and means for combining the outputs of said filters with said beamformer output to generate a sensor array output signal; wherein said reference channel processor and said filters operate to maximize the signal to noise ratio of the array output signal, wherein said filter coefficients are adaptively determined so as to maximize the signal to noise ratio of the array output signal, and wherein upon the occurrence of a predetermined event the adaptive determination of said filter coefficients is stopped and said filter coefficients faded into a predetermined set of fixed coefficients; the fixed filter coefficients being determined by solving directly and non-adaptively an equation wopt=C−1p  where C is the noise covariance matrix, p is a vector representing the correlation between the output of said beamformer and the output of said reference channels, and wopt is a vector having a number of components equal to the number of sensors, and where solving said equation for “n” frequencies provides “n” coefficients for each filter; and wherein said fixed filter coefficients are determined by simulating a noise environment, recording the simulated noise generated in said environment, playing back said simulated noise for reception by the array, letting the adaptation of the filter weights converge to a solution and then setting the fixed filter coefficients of the array equal to the coefficients of the converged adaptive solution.
  • 19. A method of processing a received signal that includes a desired signal and noise, comprising the steps of:providing an array of sensors; filtering the output of each sensor through a filter, each filter being defined by one or more filter coefficients; and combining the outputs of said filters to form a sensor array output signal; wherein said filter coefficients are adaptively determined so as to maximize the signal to noise ratio of the array output signal, and wherein upon the occurrence of a predetermined event the adaptive determination of said filter coefficients is stopped and said filter coefficients are faded into a predetermined set of fixed coefficients; the fixed filter coefficients being determined by solving directly and non-adaptively an equation wopt=C-1⁢vvC-1⁢v where C is the noise covariance matrix, v is the steering vector toward the array look direction, and wopt is a vector having a number of components equal to the number of sensors, and where solving said equation for “n” frequencies provides “n” coefficients for each filter.
  • 20. The method according to claim 19, wherein said sensors are microphones.
  • 21. The method according to claim 19, wherein said filter coefficients are frequency domain coefficients such that for each said filter said frequency domain coefficients determine the frequency response of said filter.
  • 22. The method according to claim 19, wherein said filter coefficients are time domain coefficients.
  • 23. The method according to claim 22, further comprising the steps of:receiving the outputs of said sensors at a plurality of respective delay lines; receiving the outputs of said delay lines at respective convolvers; convolving the received delay line outputs with respective filter coefficients to generate a plurality of filtered delay line outputs; and combining said plurality of filtered delay line outputs to generate said array output.
  • 24. The sensor array as set forth in claim 23, further comprising the steps of:receiving the outputs of said sensors at respective signal conditioners; and sampling the received outputs and passing the sampled received outputs to respective delay lines.
  • 25. The sensor array as set forth in claim 19, wherein said fixed filter coefficients are determined by placing the array in a simulated noise environment, letting the adaptation of the filter weights converge to a solution and then setting the fixed filter coefficients equal to the coefficients of the converged adaptive solution.
  • 26. The sensor array as set forth in claim 19, wherein said fixed filter coefficients are determined by simulating a noise environment and the array's response to said noise environment, letting the simulated adaptation of the filter weights converge to a solution and then storing the coefficients of the converged adaptive solution for use as the fixed weights of an actual array.
  • 27. A method of processing a received signal that includes a desired signal and noise, comprising the steps of:providing an array of sensors; filtering the output of each sensor through a filter, each filter being defined by one or more filter coefficients; and combining the outputs of said filters to form a sensor array output signal; wherein said filter coefficients are adaptively determined so as to maximize the signal to noise ratio of the array output signal, and wherein upon the occurrence of a predetermined event the adaptive determination of said filter coefficients is stopped and said filter coefficients are faded into a predetermined set of fixed coefficients; the fixed filter coefficients being determined by solving directly and non-adaptively an equation wopt=C-1⁢vvC-1⁢v where C is the noise covariance matrix, v is the steering vector toward the array look direction, and wopt is a vector having a number of components equal to the number of sensors, and where solving said equation for “n” frequencies provides “n” coefficients for each filter; and wherein said fixed filter coefficients are determined by simulating a noise environment, recording the simulated noise generated in said environment, playing back said simulated noise for reception by the array, letting the adaptation of the filter weights converge to a solution and then setting the fixed filter coefficients of the array equal to the coefficients of the converged adaptive solution.
  • 28. A method for receiving a signal that includes a desired signal and noise, comprising the steps of:providing an array of sensors; generating a beamformer output by passing the outputs of said sensors through a delay and sum beamformer; generating one or more reference channel signals by passing the outputs of said sensors through a reference channel processor; filtering each reference channel using at least one filter, each said filter being defined by one or more coefficients; and combining the outputs of said filters with said beamformer output to generate a sensor array output signal; wherein said reference channel processor and said filters operate to maximize the signal to noise ration of the array output signal, wherein said filter coefficients are adaptively determined so as to maximize the signal to noise ratio of the array output signal, and wherein upon the occurrence of a predetermined event the adaptive determination of said filter coefficients is stopped and said filter coefficients are faded into a predetermined set of fixed coefficients; the fixed filter coefficients being determined by solving directly and non-adaptively an equation wopt=C−1p  where C is the noise covariance matrix, p is a vector representing the correlation between the output of said beamformer and the output of said reference channels, and wopt is a vector having a number of components equal to the number of sensors, and where solving said equation for “n” frequencies provides “n” coefficients for each filter.
  • 29. The method according to claim 28, wherein said sensors are microphones.
  • 30. The method according to claim 28, wherein said filter coefficients are frequency domain coefficients such that for each said filter said frequency domain coefficients determine the frequency response of said filter.
  • 31. The method according to claim 28, wherein said filter coefficients are time domain coefficients.
  • 32. The method according to claim 31, further comprising the steps of:delaying the output of said beamformer via a main channel delay line; delaying said reference channel signals via respective reference channel delay lines; convolving the outputs of said reference channel delay lines with respective filter coefficients to generate a plurality of filtered delay line outputs; and combining said filtered delay line outputs and said main channel delay line output to generate said array output.
  • 33. The method according to claim 32, further comprising the steps of:receiving the outputs of said sensors at respective signal conditioners; and sampling the received outputs and passing the sampled received outputs to said delay and sum beamformer and said reference channel processor.
  • 34. The method according to claim 28, wherein said fixed filter coefficients are determined by placing the array in a simulated noise environment, letting the adaptation of the filter weights converge to a solution and then setting the fixed filter coefficients equal to the coefficients of the converged adaptive.
  • 35. The method according to claim 28, wherein said fixed filter coefficients are determined by simulating a noise environment and the array's response to said noise environment, letting the simulated adaptation of the filter weights converge to a solution and then storing the coefficients of the converged adaptive solution for use as the fixed weights of an actual array.
  • 36. A method for receiving a signal that includes a desired signal and noise, comprising the steps of:providing an array of sensors; generating a beamformer output by passing the outputs of said sensors through a delay and sum beamformer; generating one or more reference channel signals by passing the outputs of said sensors through a reference channel processor; filtering each reference channel using at least one filter, each said filter being defined by one or more coefficients; and combining the outputs of said filters with said beamformer output to generate a sensor array output signal; wherein said reference channel processor and said filters operate to maximize the signal to noise ration of the array output signal, wherein said filter coefficients are adaptively determined so as to maximize the signal to noise ratio of the array output signal, and wherein upon the occurrence of a predetermined event the adaptive determination of said filter coefficients is stopped and said filter coefficients are faded into a predetermined set of fixed coefficients; the fixed filter coefficients being determined by solving directly and non-adaptively an equation wopt=C−1p  where C is the noise covariance matrix, p is a vector representing the correlation between the output of said beamformer and the output of said reference channels, and wopt is a vector having a number of components equal to the number of sensors, and where solving said equation for “n” frequencies provides “n” coefficients for each filter; and wherein said fixed filter coefficients are determined by simulating a noise environment, recording the simulated noise generated in said environment, playing back said simulated noise for reception by the array, letting the adaptation of the filter weights converge to a solution and then setting the fixed filter coefficients of the array equal to the coefficients of the converged adaptive solution.
  • 37. A sensor array for receiving a signal that includes a desired signal and noise, comprising:a plurality of sensors; a plurality of filters for filtering the output of each sensor, each filter being defined by one or more filter coefficients; and a means for combining the outputs of said filters to form a sensor array output signal; wherein said filter coefficients are determined by solving an equation wopt=C-1⁢vvC-1⁢v where C is the noise covariance matrix, v is the steering vector toward the array look direction, and wopt is a vector having a number of components equal to the number of sensors, and where solving said equation for “n” frequencies provides “n” coefficients for each filter; and wherein said noise covariance matrix is determined by defining a spatial distribution of noise sources; defining a delay vector for each noise source using said spatial distribution, said delay vector expressing the relative times of arrival of the wavefront from said noise source at each sensor; defining a steering vector for each said noise source based on said delay vector; using said steering vector to determine the contribution of each noise source to said noise covariance matrix; and generating said noise covariance matrix by adding the contributions of each noise source and a matrix indicative of spatially distributed white noise.
  • 38. The sensor array as set forth in claim 37, wherein said equation is solved for “n” frequencies to yield “n” coefficients for each filter, and for each filter, said “n”coefficients are used to generate filter design values according to an operation selected from the group consisting of a Remez Exchange operation and an Inverse Fourier Transform operation.
  • 39. An sensor array for receiving signal that includes a desired signal and noise, comprising:a plurality of sensors; a delay and sum beamformer for combining the outputs of said sensors to generate a beamformer output; a reference channel processor for combining the outputs of said sensors to generate one or more reference channel signals; at least one filter for each said reference channel, each said filter being defined by one or more coefficients; and means for combining the outputs of said filters with said beamformer output to generate a sensor array output signal; wherein said filter coefficients are determined by solving an equation wopt=C−1p  where C is the noise covariance matrix, p is a vector representing the correlation between the output of said beamformer and the output of said reference channels, and wopt is a vector having a number of components equal to the number of sensors, and where solving said equation for “n” frequencies provides “n” coefficients for each filter; and wherein said noise covariance matrix is determined by defining a spatial distribution of noise sources; defining a delay vector for each noise source using said spatial distribution, said delay vector expressing the relative times of arrival of the wavefront from said noise source at each sensor; defining a steering vector for each said noise source based on said delay vector; using said steering vector to determine the contribution of each noise source to said noise covariance matrix as measured at the sensors; defining a nulling matrix which indicates how said filter outputs are combined to generate said reference channels; determining an array steering vector towards the array look direction; determining the contribution of each noise source to each reference channel based on said contribution of each noise source at said sensors, said nulling matrix and said array steering vector; and generating said noise covariance matrix by adding the contributions of each noise source to said reference channels and a matrix indicative of spatially distributed white noise.
  • 40. The sensor array as set forth in claim 39, wherein said equation is solved for “n” frequencies to yield “n” coefficients for each filter, and for each filter, said “n” coefficients are used to generate filter design values according to an operation selected from the group consisting of a Remez Exchange operation and an Inverse Fourier Transform operation.
  • 41. A method of processing a received signal that includes a desired signal and noise, comprising the steps of:providing an array of sensors; filtering the output of each sensor through a filter, each filter being defined by one or more filter coefficients; and combining the outputs of said filters to form a sensor array output signal; wherein said filter coefficients are determined by solving an equation wopt=C-1⁢vvC-1⁢v where C is the noise covariance matrix, v is the steering vector toward the array look direction, and wopt is a vector having a number of components equal to the number of sensors, and where solving said equation for “n” frequencies provides “n” coefficients for each filter; and wherein said noise covariance matrix is determined by defining a spatial distribution of noise sources; defining a delay vector for each noise source using said spatial distribution, said delay vector expressing the relative times of arrival of the wavefront from said noise source at each sensor; defining a steering vector for each said noise source based on said delay vector; using said steering vector to determine the contribution of each noise source to said noise covariance matrix; and generating said noise covariance matrix by adding the contributions of each noise source and a matrix indicative of spatially distributed white noise.
  • 42. The method according to in claim 41, wherein said equation is solved for “n” frequencies to yield “n” coefficients for each filter, and for each filter, said “n” coefficients are used to generate filter design values according to an operation selected from the group consisting of a Remez Exchange operation and an Inverse Fourier Transform operation.
  • 43. A method of processing a received signal that includes a desired signal and noise, comprising the steps of:providing an array of sensors; generating a beamformer output by passing the outputs of said sensors through a delay and sum beamformer; generating one or more reference channel signals by passing the outputs of said sensors through a reference channel processor; filtering each reference channel using at least one filter, each said filter being defined by one or more coefficients; and combining the outputs of said filters with said beamformer output to generate a sensor array output signal; wherein said filter coefficients are determined by solving an equation wopt=C−1p  where C is the noise covariance matrix, p is a vector representing the correlation between the output of said beamformer and the output of said reference channels, and wopt is a vector having a number of components equal to the number of sensors, and where solving said equation for “n” frequencies provides “n” coefficients for each filter; and wherein said noise covariance matrix is determined by defining a spatial distribution of noise sources; defining a delay vector for each noise source using said spatial distribution, said delay vector expressing the relative times of arrival of the wavefront from said noise source at each sensor; defining a steering vector for each said noise source based on said delay vector; using said steering vector to determine the contribution of each noise source to said noise covariance matrix as measured at the sensors; defining a nulling matrix which indicates how said filter outputs are combined to generate said reference channels; determining an array steering vector towards the array look direction; determining the contribution of each noise source to each reference channel based on said contribution of each noise source at said sensors, said nulling matrix and said array steering vector; and generating said noise covariance matrix by adding the contributions of each noise source to said reference channels and a matrix indicative of spatially distributed white noise.
  • 44. The method according to claim 43, wherein said equation is solved for “n” frequencies to yield “n” coefficients for each filter, and for each filter, said “n” coefficients are used to generate filter design values according to an operation selected from the group consisting of a Remez Exchange operation and an Inverse Fourier Transform operation.
CROSS-REFERENCE TO RELATED APPLICATIONS

This application is related to application U.S. Ser. No.: 09/425,790, by Andrea et al., filed on Oct. 22, 1999 and entitled “System and Method for Adaptive Interference Canceling,” hereby incorporated by reference.

US Referenced Citations (256)
Number Name Date Kind
2379514 Fisher Jul 1945 A
2972018 Hawley et al. Feb 1961 A
3098121 Wadsworth Jul 1963 A
3101744 Warnaka Aug 1963 A
3170046 Leale Feb 1965 A
3247925 Warnaka Apr 1966 A
3262521 Warnaka Jul 1966 A
3298457 Warnaka Jan 1967 A
3330376 Warnaka Jul 1967 A
3394226 Andrews, Jr. Jul 1968 A
3416782 Warnaka Dec 1968 A
3422921 Warnaka Jan 1969 A
3562089 Warnaka et al. Feb 1971 A
3702644 Fowler et al. Nov 1972 A
3830988 Mol et al. Aug 1974 A
3889059 Thompson et al. Jun 1975 A
3890474 Glicksberg Jun 1975 A
4068092 Ikoma et al. Jan 1978 A
4122303 Chaplin et al. Oct 1978 A
4153815 Chaplin et al. May 1979 A
4169257 Smith Sep 1979 A
4239936 Sakoe Dec 1980 A
4241805 Chance, Jr. Dec 1980 A
4243117 Warnaka Jan 1981 A
4261708 Gallagher Apr 1981 A
4321970 Thigpen Mar 1982 A
4334740 Wray Jun 1982 A
4339018 Warnaka Jul 1982 A
4363007 Haramoto et al. Dec 1982 A
4409435 Ono Oct 1983 A
4417098 Chaplin et al. Nov 1983 A
4433435 David Feb 1984 A
4442546 Ishigaki Apr 1984 A
4453600 Thigpen Jun 1984 A
4455675 Bose et al. Jun 1984 A
4459851 Crostack Jul 1984 A
4461025 Franklin Jul 1984 A
4463222 Poradowski Jul 1984 A
4473906 Warnaka et al. Sep 1984 A
4477505 Warnaka Oct 1984 A
4489441 Chaplin et al. Dec 1984 A
4490841 Chaplin et al. Dec 1984 A
4494074 Bose Jan 1985 A
4495643 Orban Jan 1985 A
4517415 Laurence May 1985 A
4527282 Chaplin et al. Jul 1985 A
4530304 Gardos Jul 1985 A
4539708 Norris Sep 1985 A
4559642 Miyaji et al. Dec 1985 A
4562589 Warnaka et al. Dec 1985 A
4566118 Chaplin et al. Jan 1986 A
4570155 Skarman et al. Feb 1986 A
4581758 Coker et al. Apr 1986 A
4589136 Poldy et al. May 1986 A
4589137 Miller May 1986 A
4600863 Chaplin et al. Jul 1986 A
4622692 Cole Nov 1986 A
4628529 Borth et al. Dec 1986 A
4630302 Kryter Dec 1986 A
4630304 Borth et al. Dec 1986 A
4636586 Schiff Jan 1987 A
4649505 Zinser, Jr. et al. Mar 1987 A
4653102 Hansen Mar 1987 A
4653606 Flanagan Mar 1987 A
4654871 Chaplin et al. Mar 1987 A
4658426 Chabries et al. Apr 1987 A
4672674 Clough et al. Jun 1987 A
4683010 Hartmann Jul 1987 A
4696043 Iwahara et al. Sep 1987 A
4718096 Meisel Jan 1988 A
4731850 Levitt et al. Mar 1988 A
4736432 Cantrell Apr 1988 A
4741038 Elko et al. Apr 1988 A
4750207 Gebert et al. Jun 1988 A
4752961 Kahn Jun 1988 A
4769847 Taguchi Sep 1988 A
4771472 Williams, III et al. Sep 1988 A
4783798 Leibholz et al. Nov 1988 A
4783817 Hamada et al. Nov 1988 A
4783818 Graupe et al. Nov 1988 A
4791672 Nunley et al. Dec 1988 A
4802227 Elko et al. Jan 1989 A
4811404 Vilmur et al. Mar 1989 A
4833719 Carme et al. May 1989 A
4837832 Fanshel Jun 1989 A
4847897 Means Jul 1989 A
4862506 Landgarten et al. Aug 1989 A
4878188 Ziegler et al. Oct 1989 A
4908855 Ohga et al. Mar 1990 A
4910718 Horn Mar 1990 A
4910719 Thubert Mar 1990 A
4928307 Lynn May 1990 A
4930156 Norris May 1990 A
4932063 Nakamura Jun 1990 A
4937871 Hattori Jun 1990 A
4947356 Elliott et al. Aug 1990 A
4951954 MacNeill Aug 1990 A
4955055 Fujisaki et al. Sep 1990 A
4956867 Zarek et al. Sep 1990 A
4959865 Stettiner et al. Sep 1990 A
4963071 Larwin et al. Oct 1990 A
4965834 Miller Oct 1990 A
4977600 Ziegler Dec 1990 A
4985925 Langberg et al. Jan 1991 A
4991433 Warnaka et al. Feb 1991 A
5001763 Moseley Mar 1991 A
5010576 Hill Apr 1991 A
5018202 Takahashi et al. May 1991 A
5023002 Schweizer et al. Jun 1991 A
5029218 Nagayasu Jul 1991 A
5046103 Warnaka et al. Sep 1991 A
5052510 Gossman Oct 1991 A
5070527 Lynn Dec 1991 A
5075694 Donnangelo et al. Dec 1991 A
5086385 Launey et al. Feb 1992 A
5086415 Takahashi et al. Feb 1992 A
5091954 Sasaki et al. Feb 1992 A
5097923 Ziegler et al. Mar 1992 A
5105377 Ziegler, Jr. Apr 1992 A
5117461 Moseley May 1992 A
5121426 Bavmhauer Jun 1992 A
5125032 Meister et al. Jun 1992 A
5126681 Ziegler, Jr. et al. Jun 1992 A
5133017 Cain et al. Jul 1992 A
5134659 Moseley Jul 1992 A
5138663 Moseley Aug 1992 A
5138664 Kimura et al. Aug 1992 A
5142585 Taylor Aug 1992 A
5192918 Sugiyama Mar 1993 A
RE34236 Taylor Apr 1993 E
5208864 Kaneda May 1993 A
5209326 Harper May 1993 A
5212764 Ariyoshi May 1993 A
5219037 Smith et al. Jun 1993 A
5226077 Lynn et al. Jul 1993 A
5226087 Ono Jul 1993 A
5241692 Harrison et al. Aug 1993 A
5251263 Andrea et al. Oct 1993 A
5251863 Gossman et al. Oct 1993 A
5260997 Gattey et al. Nov 1993 A
5272286 Cain et al. Dec 1993 A
5276740 Inanaga et al. Jan 1994 A
D344730 Gattey et al. Mar 1994 S
5311446 Ross et al. May 1994 A
5311453 Denenberg et al. May 1994 A
5313555 Kamiya May 1994 A
5313945 Friedlander May 1994 A
5315661 Gossman et al. May 1994 A
5319736 Hunt Jun 1994 A
5327506 Stites, III Jul 1994 A
5332203 Gossman et al. Jul 1994 A
5335011 Addeo et al. Aug 1994 A
5348124 Harper Sep 1994 A
5353347 Irissou et al. Oct 1994 A
5353376 Oh et al. Oct 1994 A
5361303 Eatwell Nov 1994 A
5365594 Ross et al. Nov 1994 A
5375174 Denenberg Dec 1994 A
5381473 Andrea et al. Jan 1995 A
5381481 Gammie et al. Jan 1995 A
5384843 Masuda et al. Jan 1995 A
5402497 Nishimoto et al. Mar 1995 A
5402669 Pla et al. Apr 1995 A
5412735 Engebretson et al. May 1995 A
5414769 Gattey et al. May 1995 A
5414775 Scribner et al. May 1995 A
5416845 Qun May 1995 A
5416847 Boze May 1995 A
5416887 Shimada May 1995 A
5418857 Eatwell May 1995 A
5423523 Gossman et al. Jun 1995 A
5431008 Ross et al. Jul 1995 A
5432859 Yang et al. Jul 1995 A
5434925 Nadim Jul 1995 A
5440642 Denenberg et al. Aug 1995 A
5448637 Yamaguchi et al. Sep 1995 A
5452361 Jones Sep 1995 A
5457749 Cain et al. Oct 1995 A
5469087 Eatwell Nov 1995 A
5471106 Curtis et al. Nov 1995 A
5471538 Sasaki et al. Nov 1995 A
5473214 Hildebrand Dec 1995 A
5473701 Cezanee et al. Dec 1995 A
5473702 Yoshida et al. Dec 1995 A
5475761 Eatwell Dec 1995 A
5481615 Eatwell et al. Jan 1996 A
5485515 Allen et al. Jan 1996 A
5493615 Burke et al. Feb 1996 A
5502869 Smith et al. Apr 1996 A
5511127 Warnaka Apr 1996 A
5511128 Lindeman Apr 1996 A
5515378 Roy, III et al. May 1996 A
5524056 Killion et al. Jun 1996 A
5524057 Akiho et al. Jun 1996 A
5526432 Denenberg Jun 1996 A
5546090 Roy, III et al. Aug 1996 A
5546467 Denenberg Aug 1996 A
5550334 Langley Aug 1996 A
5553153 Eatwell Sep 1996 A
5563817 Ziegler, Jr. et al. Oct 1996 A
5568557 Ross et al. Oct 1996 A
5581620 Brandstein et al. Dec 1996 A
5592181 Cai et al. Jan 1997 A
5592490 Barratt et al. Jan 1997 A
5600106 Langley Feb 1997 A
5604813 Evans et al. Feb 1997 A
5615175 Cater et al. Mar 1997 A
5617479 Hildebrand et al. Apr 1997 A
5619020 Jones et al. Apr 1997 A
5621656 Langley Apr 1997 A
5625697 Bowen et al. Apr 1997 A
5625880 Goldburg et al. Apr 1997 A
5627746 Ziegler, Jr. et al. May 1997 A
5627799 Hoshuyama May 1997 A
5638022 Eatwell Jun 1997 A
5638454 Jones et al. Jun 1997 A
5638456 Conley et al. Jun 1997 A
5642353 Roy, III et al. Jun 1997 A
5644641 Ikeda Jul 1997 A
5649018 Gifford et al. Jul 1997 A
5652770 Eatwell Jul 1997 A
5652799 Ross et al. Jul 1997 A
5657393 Crow Aug 1997 A
5664021 Chu et al. Sep 1997 A
5668747 Obashi Sep 1997 A
5673325 Andrea et al. Sep 1997 A
5676353 Jones et al. Oct 1997 A
5689572 Ohki et al. Nov 1997 A
5692053 Fuller et al. Nov 1997 A
5692054 Parrella et al. Nov 1997 A
5699436 Claybaugh et al. Dec 1997 A
5701344 Wakui Dec 1997 A
5715319 Chu Feb 1998 A
5715321 Andrea et al. Feb 1998 A
5719945 Fuller et al. Feb 1998 A
5724270 Posch Mar 1998 A
5727073 Ikeda Mar 1998 A
5732143 Andrea et al. Mar 1998 A
5745581 Eatwell et al. Apr 1998 A
5748749 Miller et al. May 1998 A
5768473 Eatwell et al. Jun 1998 A
5774859 Houser et al. Jun 1998 A
5798983 Kuhn et al. Aug 1998 A
5812682 Ross et al. Sep 1998 A
5815582 Claybaugh et al. Sep 1998 A
5825897 Andrea et al. Oct 1998 A
5825898 Marash Oct 1998 A
5828768 Eatwell et al. Oct 1998 A
5835608 Warnaka et al. Nov 1998 A
5838805 Warnaka et al. Nov 1998 A
5874918 Czarnecki et al. Feb 1999 A
5909460 Dent Jun 1999 A
5909495 Andrea Jun 1999 A
5914912 Yang Jun 1999 A
6084973 Green et al. Jul 2000 A
6178248 Marash Jan 2001 B1
Foreign Referenced Citations (36)
Number Date Country
2640324 Mar 1978 DE
3719963 Mar 1988 DE
4008595 Sep 1991 DE
0 059 745 Sep 1982 EP
0 380 290 Aug 1990 EP
0 390 386 Oct 1990 EP
0 411 360 Feb 1991 EP
0 509 742 Oct 1992 EP
0 483 845 Jan 1993 EP
0 583 900 Feb 1994 EP
0 595 457 May 1994 EP
0 721 251 Jul 1996 EP
0 724 415 Nov 1996 EP
2305909 Oct 1976 FR
1 160 431 Aug 1969 GB
1 289 993 Sep 1972 GB
1 378 294 Dec 1974 GB
2 172 769 Sep 1986 GB
2 239 971 Jul 1991 GB
2 289 593 Nov 1995 GB
56-89194 Jul 1981 JP
59-64994 Apr 1984 JP
62-189898 Aug 1987 JP
1-149695 Jun 1989 JP
1-314098 Dec 1989 JP
2-070152 Mar 1990 JP
3-169199 Jul 1991 JP
3-231599 Oct 1991 JP
4-16900 Jan 1992 JP
WO 8809512 Dec 1988 WO
WO 9205538 Apr 1992 WO
WO 9217019 Oct 1992 WO
WO 9416517 Jul 1994 WO
WO 9508906 Mar 1995 WO
WO 9615541 May 1996 WO
WO 9723068 Jun 1997 WO
Non-Patent Literature Citations (23)
Entry
Oppenheim Schafer, Digital Signal Processing (Prentice Hall) pp. 542-545.
P.P. Vaidyanathan, “Multirate Digital Filters, Filter Banks, Polyphase Networks, and Applications; A Tutorial,” IEEE Proc., vol. 78, No. 1, Jan. 1990.
P.P. Vaidyanathan, “Quadrature Mirror Filter Banks, M-band Extensions and Perfect-Reconstruction Techniques,” IEEE ASSP Magazine, Jul. 1987, pp. 4-20.
Rabiner et al., IEEE Trans. on Acous., vol. ASSP-24, No. 5, Oct. 1976, pp. 399-418.
Rubiner et al., Digital Processing of Speech Signals (Prentice Hall, 1978) pp. 130-135.
Sapontis, Probability, Lambda Variables and Structural Processes, pp. 467-474.
Scott C. Douglas, “A Family of Normalized LMS Algorithms,” IEEE Signal Proc. Letters, vol. 1, No. 3, Mar. 1994.
Sewald et al., “Application of . . . Beamforming to Reject Turbulence Noise in Airducts,” IEEE ICASSP vol. 5, No. CONF-21, May 7, 1996, pp. 2734-2737.
White, Moving-Coil Earphone Design, 1963, pp. 188-194.
Widrow et al., “Adaptive Noise Canceling: Principles and Applications,” Proc. IEEE, vol. 63, No. 12, Dec. 1975, pp. 1692-1716.
Youla et al., IEEE Trans. on Acous., vol. MI-1, No. 2, Oct. 1982, pp. 81-101.
B.D. Van Veen and K.M. Buckley, “Beamforming: A Versatile Approach to Spatial Filtering,” IEEE ASSN Magazine, vol. 5, No. 2, Apr. 1988, pp. 4-24.
Beranek, Acoustics (American Institute of Physics, 1986) pp. 116-135.
Boll, IEEE Trans. on Acous., vol. ASSP-27, No. 2, Apr. 1979, pp. 113-120.
Daniel Sweeney, “Sound Conditioning Through DSP”, The Equipment Authority, 1994.
Edward J. Foster, “Switched on Silence”, Popular Science, 1994, p. 33.
John M. Cioffi, “Limited-Precision Effects in Adaptive Filtering,” IEEE Trans. on Circuits, vol. CAS-34, No. 7, Jul. 1987.
Kuo, Automatic Control of Systems, pp. 504-585.
L.J. Griffiths and C.W. Jim, “An Alternative Approach to Linearly Constrained Adaptive Beamforming,” IEEE Trans. on Antennas, vol. AP-30, No. 1, Jan. 1982, pp. 27-34.
Luenberger, Optimization by Vector Space Method, pp. 134-138.
Monzingo and Miller, Introduction to Adaptive Arrays, (Wiley, NY) pp. 89-105; 155-216.
O.L. Frost III, “An Algorithm for Linearly Constrained Adpative Array Processing,”0 Proc. IEEE, vol. 60, No. 8, pp. 926-935, Aug. 1972.
Ogata, Modern Contol Engineering, pp. 474-508.