Active noise cancellation (ANC) may be employed to reduce the amount of ambient noise a user hears when wearing headphones. In ANC, a noise signal is measured and a corresponding an anti-noise signal is produced. The anti-noise signal is an approximation of an inverse signal to the noise signal. The noise signal and the anti-noise signal destructively interfere, which may result in some or all of the ambient noise being removed from the user's ear. Generating an accurate anti-noise signal for high quality ANC requires that the corresponding system react quickly to changes in ambient noise. Latency is detrimental to ANC, because failure to react quickly can result in noise that is not properly canceled out. Further, failure of correction circuits to react quickly may result in erroneous noise amplification, bursts of anti-noise that does not cancel out the noise signal, etc. ANC may be further complicated when music is introduced to the headphones. In some cases, ANC may also be unable to distinguish noise from low frequency music. This may result in erroneous removal of the music signal along with the noise signal.
Aspects, features and advantages of embodiments of the present disclosure will become apparent from the following description of embodiments in reference to the appended drawings in which:
Disclosed herein is an example acoustic processing network. The network includes a Digital Signal Processor (DSP) operating at a first frequency and a RAP operating at a higher second frequency. The DSP is capable of generating robust noise filters to support generation of accurate anti-noise signals. The DSP forwards such noise filters to the RAP for implementation. The RAP operates more quickly than the DSP, and hence can react quickly to auditory changes. This reduces latency and maintains an accurate anti-noise signal. The filters provided by the DSP may depend on user input and/or environmental changes. For example, the DSP may change noise filters when a user moves from a quiet environment to a loud environment. As another example, the RAP may employ a compressor circuit that controls adjustable amplifier(s) in a pair of headphones. The compressor circuit may adjust the amplifier(s) based on compressor states, which may limit the speed of volume change in the anti-noise signal. Failure to limit sudden volume changes may result in signal clipping, which may be experienced by the user as pops or clicks of sound. The DSP may adjust compressor states at the RAP based on ambient sound changes to respond to such volume changes. Further, the DSP and RAP may support ambient awareness upon receiving input from a user. Ambient awareness may be associated with a predetermined frequency band, for example a frequency band associated with human speech. The DSP may generate a noise filter that increases the gain for the predetermined frequency band in the noise signal. Accordingly, the RAP amplifies the associated band when generating the anti-noise signal. This may result in cancellation of ambient noise while emphasizing sound (e.g. speech) occurring in a corresponding frequency band. Also, the DSP may provide an audio signal and an audio signal as adjusted based on an expected frequency response of the acoustic processing network. The adjusted audio signal may then be employed by the RAP as a reference point when performing ANC. This allows the RAP to drive the overall output toward the expected audio output instead of driving the output toward zero and canceling some of the audio signal (e.g. canceling low frequency music). Further, the RAP is designed to forward the anti-noise signal to one or more class G controllers, which controls class G amplifier(s) in headphone digital to analog converter (DACs). This supports gain control for the anti-noise signal and further reduces signal artifacts. In addition, the RAP may implement the various noise filters from the DSP by employing biquad filters. Biquad filters may naturally quantize signal samples when storing such samples, which may result in some loss in signal fidelity. In an example, the RAP employs biquad filter(s) implemented to amplify the samples, then quantize the samples, then attenuate the samples. By operating in this order, quantization error is attenuated and hence minimized. This results in a more accurate anti-noise signal.
The DSP 110 is any specialized processing circuit optimized from processing digital signals. The DSP 110 support many different functions. For example, acoustic processing network 100 may operate in a set of headphones. When playing music or other audio to a user, the DSP 110 may receive audio input in digital format from memory and/or a general processing unit. The DSP 110 may generate audio signal(s) 143 corresponding to the audio input. The audio signal 143 is/are any stream(s) of digital data including audio to be played to a user via a speaker 136. For example, the DSP 110 may generate a left audio signal 143 for application to a user's left ear and a right audio signal 143 for application to a user's left ear. In some examples, as discussed below, the DSP 110 may generate a pair of audio signals 143 for each ear, etc. The DSP 110 also generates various noise filters for application to the audio signals 143, for example to compensate for noise caused by operation of the acoustic processing network 100.
When providing ANC, the DSP 110 may also generate noise filters to be employed in the generation of an anti-noise signal. In such case, the DSP 110 receives one or more noise signals 144 from one or more microphones 137. The microphones 137 may include a feedforward (FF) microphone positioned outside of the user's ear canal. A FF microphone is positioned to record ambient noise before such noise is experienced by the user. Hence, the DSP 110 may employ the noise signal 144 from FF microphones 137 to determine a prospective noise to be experienced by the user in the near future. The DSP 110 may then generate a noise filter based on the noise signal 144. The noise filter may then be used (e.g. by the RAP 120) to generate an anti-noise signal to cancel out the noise signal 144. The microphones 137 may also include feedback (FB) microphones. A FB microphone is positioned inside a user's ear canal. Hence, a FB microphone 137 is positioned to record noise actually experienced by the user after the anti-noise signal is applied. Accordingly, the noise signal 144 from a FB microphone 137 can be employed to iteratively adjust the noise filter for the anti-noise signal in order to correct for signal errors. It should be noted that the best performance can be achieved by employing at least a FF and a FB microphone 137 for each ear (e.g. four or more microphones 137). However, ANC can be achieved with only FF or only FB microphones 137.
The DSP 110 may communicate with the RAP 110 by providing control and configuration parameters 141. The parameters 141 may include the noise filters for generating anti-noise signals, noise filters for adjusting the audio signal 143, as well as commands to implement various functionality. The RAP 110 may receive the noise filters from the DSP 110 via the control and configuration parameters 141 and then perform various audio processing tasks. The RAP 110 may be any digital processor optimized for low latency digital filtering. When performing ANC, the RAP 120 may also receive the noise signal 144 from the microphones 137. The RAP 120 may generate an anti-noise signal based on the noise signal 144 and the noise filter from the DSP 110. The anti-noise signal may then be forwarded to a speaker 136 for use in ANC. The RAP 120 may also employ the noise filters from the DSP 110 to modify the audio signal 143 for output to the speaker 136. Hence, the RAP 120 may mix an anti-noise signal and the modified audio signal 143 into an output signal 145. The output signal 145 may then be forwarded to the speaker 136 for playback to the user. The speaker 136 may be any headphone speaker(s). In some cases, the microphones 137 may be physically mounted to a pair of speakers 136 (e.g. a left headphone speaker and a right headphone speaker).
As noted above, the RAP 120 may operate at a higher frequency than the DSP 110, and hence may operate at a lower latency than the DSP 110. For example, the DSP 110 may generate noise filters based on general noise level changes in the environment around the user. For example, the DSP 110 may generate different noise filters when the user moves from a noisy room to a quiet room. Such changes occur relatively slowly, and hence the DSP 110 latency is sufficient for such changes. Meanwhile, the RAP 120 applies the noise filters to rapidly adjust to specific noise changes. For example, the RAP 120 may use a noise filter for a noisy room and use such filters to generate an anti-noise signal to reduce particular perceived noises from a falling plate, a crying child, a slamming door, etc. As a specific example, the latency between receiving a noise signal 144 sample from the microphone 137 and forwarding a corresponding anti-noise signal sample to the speaker 136 may be less than about one hundred microseconds (e.g. about five microseconds).
The DSP 110 may also be configured to obtain various RAP states 142 from the RAP 120 for processing purposes. The RAP states 142 may include various states used by a RAP 120 finite state machine as well as other intermediate signals. The DSP 110 may employ RAP states 142 when determining control and configuration parameters 141. As such, the RAP states 142 provide a feedback from the RAP 120 to the DSP 110, which allows for dynamic control of the RAP 120 by the DSP 110. For example, the RAP 120 may employ audio compression, as discussed below, and the RAP states 142 may include compression states. This allows the DSP 110 to dynamically change compression occurring at the RAP 120. It should also be noted that the RAP 120 may employ interrupts to indicate significant events to the DSP 110 such as signal clipping, completion of feathering, instability detected in left channel, instability detected in right channel, etc. Such interrupts may be enable/disabled individually by employing programmable registers.
As shown in
Communication between the RAP 120 and the DSP 110 (and along the noise signal path) may proceed via a decimator 134. A decimator 134 is any signal processing component that employs decimation to decrease an effective sample rate, and hence frequency of a signal. Accordingly, the decimator 142 is employed to decrease the frequency of the signals (e.g. RAP states 142 signals and noise signals) from the second frequency used by the RAP 120 to the first frequency used by the DSP 120. In other words, the interpolator 135 upconverts/upsamples signals while the decimator 134 downconverts/downsamples signals.
The network 100 also employs one or more a digital to analog converters (DACs) 131 and one or more analog to digital converter (ADCs) 133 to convert between the analog domain and the digital domain. A DAC 131 is any signal processing component that converts a digital signal to an analog signal. An ADC 33 is any signal processing component that converts an analog signal to a digital signal. Specifically, the ADC 133 receives analog noise signal(s) 144 from the microphones 137 and converts such signals into the digital domain for use by the RAP 120 and the DSP 110. Further, the DAC 131 receives the output signal 145 from the RAP 120 (containing the anti-noise signal and/or the audio signal 143) in digital format and converts the output signal 145 into an analog format that can be output by the speaker(s) 136. In some examples, a modulator 132, such as a delta sigma modulator may also be employed to support the DAC 131. A modulator 132 is a signal component that reduces a bit count and increases a frequency of a digital signal as a pre-processing step prior to digital to analog conversion by a DAC 131. A modulator 132 may support the DAC 131 and hence may not be employed in some examples. It should be noted that the modulator 132 and the DAC 131 may have fixed transfer functions. As such, the RAP 120 may be the final block in the audio processing chain with significant configurability.
The DAC 131 may employ an amplifier, such as a class G amplifier, to increase a volume of the output signal 143 to an appropriate level for playback by the speaker 136. The network 100 may employ an amplifier controller 130, such as a class G amplifier controller, to control the DAC 131 amplifier. For example, low volume output signals 145 may require little amplification (e.g. anti-noise signal for a quiet environment and/or a silence in the audio signal 143). Conversely, a high volume output signal 145 may require significant amplification (e.g. a significant anti-noise signal due to a loud noise and/or loud music in audio signal 143). As the DAC 131 may output an anti-noise signal that is potentially highly variable, sudden changes in volume may occur. Such sudden changes may cause audio artifacts. For example, a sudden change from silence to a loud anti-noise signal (e.g. sudden applause in a quiet room) may result in signal clipping by the DAC 131 amplifier when the output signal 145 suddenly increases beyond the capability of the amplifier in the DAC 131. Such clipping is experienced by a user as popping or clicking. To avoid such artifacts, the RAP 120 may forward a copy of the anti-noise signal to a digital to the amplifier controller 130 to support adjusting the DAC 131 amplifier (e.g. by modifying applied voltage) based on the anti-noise signal level. The amplifier controller 130 may dynamically review changes in the anti-noise signal to project potential changes in the output signal 145. The amplifier controller 130 can then modify DAC 131 amplifier setting to lower amplification and save power or increase amplification to prevent clipping based on changes in the anti-noise signal (and/or changes in the audio signal 143). The above function as generally discussed with respect to
It should also be noted that the noise going into a user's ear depends on many factors including the shape of the head and ear, as well as the seal and the fit of the headphones. The acoustic signal produced by a headphone may also depend on the seal between the user's ear and the headphone. In other words a transfer function of the headphone may depend on the seal. Because of these variabilities a single ANC filter design for generating an anti-noise signal may not be optimal for all users. Adaptive ANC leads to an ANC filter design that is optimized for the current user. The adaptive ANC is made possible because the DSP 110 has access to the FF and FB microphone 137 noise signals 144. The DSP 110 can estimate the transfer function between the FF and FB noise signals 144 for a particular user during a calibration phase. For example, the DSP 110 may determine what noise should be inside the ear given the noise at FF microphone 137. A second part of a calibration process may estimates the transfer function of the headphone by playing a specially designed signal into the headphone and recording the FB microphone 137 signal. Once the DSP 110 has computed an optimized FF ANC filter, the DSP 110 can program the coefficients in RAP 120.
The RAP compressor circuit 325 and adjustable amplifier 326 may be employed to mitigate sudden drastic changes in anti-noise signal 342 value. For example, the RAP compressor circuit 325 and adjustable amplifier 326 may mitigate a sudden rise in anti-noise signal 342 value (and associated signal artifacts) due to a car door slam, but may allow the anti -noise signal 342 to rise for a continuous increase in sound due to movement from a quiet room to a loud room. In order to determine how to adjust the adjustable amplifier 326, the RAP compressor circuit 325 considers the compression states stored in the compression state register 323. The compression states may include a peak signal estimate, an instantaneous gain, a target gain, an attack parameter, a release parameter, a peak decay parameter, a hold parameter, and/or a Root Mean Square (RMS) parameter for the anti-noise signal 342. The peak signal estimate includes an estimate of the maximum expected value of the anti-noise signal 342. The peak signal estimate can be employed to determine an appropriate amount of amplification to prevent any portion of the anti-noise signal 342 from being amplified beyond the range of a DAC amplifier (e.g. resulting in clipping). The instantaneous gain indicates the current gain provided by the adjustable amplifier 326 at a specified instant, and the target gain indicates an adjusted gain that the adjustable amplifier 326 should move to in order to adjust for a signal change. The attack parameter indicates the speed at which an increased gain adjustment should be made without causing signal artifacts. A release parameter indicates the speed at which a decreased gain adjustment should be made without causing signal artifacts. The hold parameter indicates how long an increased gain should be provided after the anti-noise signal 342 has returned to a normal value, for example to provide for the possibility the another loud noise will occur. The peak decay parameter indicates the amount the anti-noise signal 342 must vary from a peak value before the anti-noise signal 342 can be considered to have returned to a normal value for purposes of the hold parameter. In addition or in the alternative, the adjustable amplifier 326 may be adjusted based on the RMS of the anti-noise signal 342 to mitigate clipping.
The RAP 320 operates much more quickly than the DSP 310, but may be limited to much less sophisticated compression algorithms. Accordingly, the DSP 310 includes a DSP compressor 311. The DSP compressor 311 is a programmable circuit capable of considering the compression states of the RAP 320 and applying complex compression algorithms to the compression states to determine more accurate adjustable amplifier 326 settings on a slower time scale. As such, the DSP 310 is configured to receive current compression states from the RAP 320 as stored in the compression state register 323. Such data may be communicated via an intermediate signal output (e.g. intermediate signal 242) and/or a RAP states signal path (e.g. RAP states 142). The DSP compressor 311 may determine new compression states based on the noise signal and the current compression states. The DSP compressor 311 may then forward the new compression states to the RAP to support controlling the adjustable amplifier 326. For example, the DSP compressor 311 may forward the new compression states to the compression state register 323, and hence directly program the RAP 320 for compression.
A difficulty arises when applying an anti-noise signal to cancel noise at the same time audio is being played to a user. Specifically, FB microphones in the user's ear canal may record all or part of the audio signal 443 as noise. In such a case, the RAP 420 may generate an anti -noise signal that cancels part of the audio signal 443. For example, the anti-noise signal may cancel out some lower frequency audio from the audio signal 443, which may result in erroneous performance by the headphones. To combat this problem, the DSP 410 includes a second equalizer 413. The second equalizer 413 is substantially similar to the first equalizer 412, but is employed for a different purpose. The DSP 410 and/or the second equalizer 413 model the frequency response of the network 400. The second equalizer 413 then employs the models to generate an expected output signal 449 based on the audio input 448 and a frequency response of the acoustic processing network 400. The expected output signal 449 is effectively a copy of audio signal 443 as modified by the expected effect of the circuitry in network 400. When no audio is provided, an ANC process may attempt to drive the noise to zero. By forwarding the expected output signal 449 to the RAP 420, the ANC process can set the expected output signal 449 as a reference point. As such, the ANC process can drive the output signal from the RAP 420 down to the expected output signal 449 instead of zero. This approach may reduce/remove any ANC effects on the audio signal 443.
Accordingly, the RAP 420 receives the audio signal 443 from the DSP 410. The RAP 420 then mixes the audio signal 443 with an anti-noise signal. The RAP 420 also sets the expected output signal 449 as a reference point when generating the anti-noise signal to mitigate cancelation of the audio signal by the anti-noise signal.
A biquad engine 524 is a circuit that generates digital filters with two poles and two zeros. A pole is a root of the denominator of a polynomial of a transfer function of the system and a zero is a numerator of the polynomial of the transfer function. In other words, the poles push the signal being filtered toward infinity and the zeros push the signal being filtered toward zero. It should be noted that such a filter has an infinite impulse response (IIR) when the poles are non-zero. Such filters may be denoted as biquadratic or biquads, which refers to the concept that the transfer function of the filter is a ratio of two quadratic functions. The biquad engine 524 operates on a higher frequency than the signals processed by the biquad engine 524. As such, the biquad engine 524 can be applied multiple times to a single sample of a signal and/or applied in different ways to different portions of the signal. The biquad engine 524 is programmable, and hence can be employed to create various topologies for processing as discussed below. Although the RAP architecture 500 is described as using biquad filters, other filter architectures, i.e. having other than two zeros and two poles, may be substituted for the biquad filters depending on the particular implementation details.
The multiply accumulator 525 is a circuit that adds and/or multiplies values. For example, the multiply accumulator 525 may be employed to scale signals and/or signal portions. The multiply accumulator 525 may also be employed to compute weighted sums of multiple signals and/or signal portions. The multiply accumulator 525 may accepts output from the biquad engine 524 and vice versa. The data registers 522 may be any memory components for storing data. Specifically, the data registers 522 may store signals, such as output of the biquad engine 524 and/or the multiply accumulator 525. As such, the biquad engine 524, multiply accumulator 525, and the data registers 522 can operate together to iteratively apply mathematical and/or other specialized digital signal alteration processes on a sample of an audio signal 543 and/or a noise signal 544. The audio signal 543 and noise signal 544 may be substantially similar to audio signal 143 and noise signal 144, respectively.
The biquad state memory 521 is a memory module, such as a register, for storing a current biquad state. The biquad engine 524 is programmable to operate as a finite state machine. The biquad state memory 521 stores data indicating the available states and/or the current state of the biquad engine 524. The biquad engine 524 may read data from and store fata to the biquad state memory 521.
In summary, the biquad engine 524 and multiply accumulator 525 may be programmed to implement various topologies by employing state data from the biquad state memory 521. Further, intermediate signal data can be stored in the data registers 522. The RAP architecture 500 receives control and configuration parameters 541, which may be substantially similar to control and configuration parameters 141. The control and configuration parameters 141 include noise filters encoded in terms of biquad coefficients 527 and gain coefficients 526. The biquad engine 524 alters the shape of the signal being operating upon (e.g. audio signals and/or noise signals 543/544) based on the biquad coefficients 527, which may be stored in local memory upon receipt from a DSP. Further, multiply accumulator 525 increases/alters the gain of the signal being operating upon (e.g. audio signals and/or noise signals 543/544) based on the gain coefficients 526, which may be stored in local memory upon receipt from a DSP.
In some cases, gain coefficients may be feathered. Feathering indicates a gradual change from a first value to a second value. The multiply accumulator 525 may act as a feathering unit by implanting feathering coefficients received from a feathering/compression gain 523 input. For example, the multiply accumulator 525 may implement three feathering units for a left channel and three feathering units for a right channel. In another example, the multiply accumulator 525 may implement six feathering units for each channel.
The multiply accumulator 525 may also receive compression states from the feathering/compression gain 523 input. The compression states may be substantially similar to compression states 323, may be stored in local memory, and may be received from a DSP. The multiply accumulator 525 may act as a compressor (e.g. a non-linear processor) that can change the gain applied on a signal if the signal becomes too strong. This may be used to dynamically turn the gain down in the signal flow to avoid clipping. For example, a compressor applied on an anti-noise signal may temporarily reduce the gain when the anti-noise becomes too strong for the DAC. This reduces the ANC strength temporarily, but prevents unpleasant artifacts that arise from signal clipping. The multiply accumulator 525 may implement three compressor units for a left channel and three compressor units for a right channel. In another example, the multiply accumulator 525 may implement six compressor units for each channel.
By employing the various coefficients across a plurality of states in a finite state machine, the RAP architecture 500 may implement one or more programmable biquad filters. These biquad filters may in turn to implement the noise filter from the DSP and generate the anti-noise signal. The RAP architecture 500 may also mix anti-noise/noise signals 544 with audio signals 543. Further, the RAP architecture 500 may apply filters to the audio signals 543 as desired.
The components are coupled together and to external local memory and/or remote signals (e.g. from the DSP) by multiplexer (MUX) 661, MUX 662, and MUX 663 as shown. The components may receive feathering coefficients 623, multiply coefficients 626, and biquad coefficients 627 as shown, which may be substantially similar to feathering/compression gain 523, gain coefficients 526, and biquad coefficients 527, respectively. The components may receive a noise signal 644 from the microphones/speakers for ANC. The noise signal 644 may be substantially similar to noise signal 144. The components may also receive a cycle index 647. The cycle index 647 is data that indicates a current position in the RAPs duty cycle. The various signals, indexes, and coefficients are routed to their respective components via the MUXs 661 -663 as shown.
In operation, the cycle index 647 is employed to select the biquad coefficients 627 for a corresponding state. The biquad coefficients 627 and/or cycle index 647 are forwarded to the biquad engine 624 for application to the noise signal 644. State information may be obtained from biquad memory 621. Also, partial results may be stored in the biquad memory 621 and/or fed back into the biquad coefficients 627 for application in a next state. The completed results may be stored in the biquad output register 662 for output toward the multiply accumulator 625. In addition, the output from the biquad output register 662 can be fed back into the biquad engine 624. Also, the output from the accumulator register 622 can be forwarded back into the biquad engine 624. Further, the noise signal 644 can bypass the biquad engine 624 and move directly to the multiply accumulator 625.
The cycle index 647 is also employed to select the multiply coefficients 626 for a corresponding state. The multiply coefficients 626, feather coefficients 623, and/or cycle index 626 are also forwarded to the multiply accumulator 625 for application to the various inputs. The multiply accumulator 625 may receive as inputs the output of the biquad output register 662, the noise signal 644, and/or the output of the multiply accumulator 625. In other words, the output of the multiply accumulator 625 may be fed back into the input of the multiply accumulator. Once the coefficients are applied to the input(s) based on the corresponding state, the output of the multiply accumulator 625 is stored in the accumulator register 622 for output to other components. The output of the accumulator register 622 and/or the output of the biquad output register 628 may also be forwarded toward a speaker as the output of the RAP architecture 600. The interconnectivity of RAP architecture 600 allows the components to be programmed to implement the various topologies to apply various audio processing schemes as discussed below.
The topology employs amplifiers 729 to amplify the first audio signal 743, the second audio signal 753, and the FB microphone signal 744. Such amplifiers may be implemented by a multiply accumulator, such as multiply accumulator 525 during a first three states by employing gain coefficients. The second audio signal 753 and the FB microphone signal 744 are then mixed by a mixer 725. The mixer 725 may be implanted by a multiply accumulator in a fourth state. The output of the mixer is then forwarded through a series of biquad filters 724, in this example a cascade of eight consecutive biquad filters 724. The biquad filters 724 may be implemented by a multiply accumulator and a biquad engine 524 by employing corresponding sets of biquad coefficients 527 (e.g. over the course of eight states). Meanwhile the FF microphone signal 754 is also sent through a series of biquad filters 724, in this example eight biquad filters 724. The FF microphone signal 754 and the combined second audio signal 753 and FB microphone signal 744 are each amplified by amplifier 729 and combined by a mixer 725 (e.g. each implemented in corresponding states of a multiply accumulator). The combined FF microphone signal 754, second audio signal 753, and FB microphone signal 744 are then forwarded via a feathering amplifier 726 for feathering. This may be implemented by a multiply accumulator employing feather coefficients, for example from a feathering/compression gain 523. The results are then mixed by a mixer 725 (e.g. which may be implemented by a multiply accumulator), resulting in the output 745.
As can be seen by the above discussion, the components of a biquad engine and a multiply accumulator may apply various computations to a sample from each signal at various states. The a biquad engine and a multiply accumulator traverse the various states to implement the topology 700 and hence perform the corresponding computations on the samples, which results in the output 745. Once an output 745 is generated for a set of samples, another set of samples is taken and altered via the various states to result in another output 745, etc. Further, the topology 700 can be changed by reprogramming the biquad engine and multiply accumulator states as associated coefficients.
Topology 800 employs biquad filters 824 which may be implemented by a biquad engine, such as a biquad engine 524 in a manner similar to topology 700. Topology 800 also employs amplifiers 829, mixers 825, and feathering amplifiers 826, which may be implemented by a multiply accumulator, such as a multiply accumulator 525 in a manner similar to topology 700. The topology 800 receives a first audio signal (Audio 1) 843, a second audio signal (Audio 2) 853, a FB microphone signal 844, and a FF microphone signal 854, which are substantially similar to the first audio signal 743, the second audio signal 753, the FB microphone signal 744, and the FF microphone signal 754, respectively.
The FF microphone signal 854 is employed for ambient awareness. For example, the biquad filters 824 in the FF microphone signal 854 path act as an ambient awareness filter. Accordingly, the FF microphone signal 854 path may apply an ambient awareness filter to enhance a predetermined frequency band in the noise signal when the topology 800 is generating an anti-noise signal. This may result in an enhanced predetermined frequency band, such as a speech band. The FF microphone signal 854 path may forward the anti-noise signal with the enhanced predetermined frequency band to a speaker via output 845 for output to a user.
Further, topology 800 employs a first voice microphone signal (voice mic. 1) 848 and a second voice microphone signal (voice mic. 2) 858. Such signals may be recorded by microphone(s), such as microphone 137, positioned to record a user's voice. For example, such microphone(s) may be included on a lapel clip attached to headphones and positioned on a user's chest. Hence, the first voice microphone signal 848 and the second voice microphone signal 858 may include samples of the side tone (e.g. the user's voice).
Functionally, the FB microphone signal 844 and the first voice microphone 848 are each forwarded through a biquad filter 824 and an amplifier 829. Further, the second voice microphone signal 858 and the second audio signal 853 forwarded through amplifiers 829. Such lines are then combined via mixers 825 as shown. The results are forwarded through a set of biquad filters 824, in this case five consecutive filters, and another amplifier 829. Such signals include the side tone, the FB portion of the ANC, the second portion of the audio signal.
Meanwhile, the FF microphone signal 854, which includes the FF portion of the ANC as well as the ambient awareness portion, is forwarded via a feathering amplifier 826. This feathering amplifier 826 may be employed to softly change ambient awareness and ANC modes. The FF microphone signal 854 is then sent in parallel via biquad filters 824, in this case three consecutive filters and five consecutive filters. The results are then amplified via amplifiers 829 and mixed by a mixer 825. A portion of the mixed results are forwarded through a biquad filter 824, an amplifier 829, and a second feathering amplifier 826. Another portion of the mixed results are forwarded in parallel around such components. The path is then mixed back together by a mixer 825. The second feathering amplifier 826 employs a compressor to enable strong FF ANC without signal clipping.
The results of the FF microphone signal 854 path are then amplified by amplifiers 829 before being mixed into the signal path containing the side tone, the FB portion of the ANC, the second portion of the audio signal. As shown, the FF microphone signal 854 path is mixed in before and after the five biquad filters 824 via mixers 825. The results of such signals are passed through another feathering amplifier 826, which is employed to softly turn ANC on and off. Such feathering amplifier 826 may also apply a digital compressor to further mitigate clipping. Further, the first audio signal is amplified via an amplifier 829 and mixed with the rest of the signals via a mixer 825. This may result in an output 845 containing audio signal(s), an FF anti -noise signal, an FB anti-noise signal, a side tone, and ambient awareness emphasis all mixed together for playback to a user via speaker(s).
y[n]=b0x[n]+b1x[n−1]+b2x[n−2]−a1y[n−1]−a2y[n−2] Equation 1
where x[n] is an input to the biquad filter, y[n] is an output from the biquad filter, and b0, b1, b2, a1, and a2 are biquad coefficients, such as biquad coefficients 527 and/or 627. The function of the biquad filter 900 can therefore be modified by modifying the coefficients.
Biquad filter 900 instead employs different coefficients. Specifically, biquad filter 900 employs gain coefficients b0 973, −c1 975, −c2 976, d1 974, and d2 978 as shown. Such gain coefficients 973 may be implemented by adjustable amplifiers. Further, such coefficients are defined mathematically in reference to equation 1 by equations 2-5 below:
Biquad filter 900 also employs mixers 972, which may be implemented by a multiply accumulator. In operation, an input is received at the biquad filter 900. The input is forwarded toward the output via a mixer 982 and gain coefficient b0 973. The input is also forwarded toward previous state 971 block for storage in memory via another mixer 981. On a next cycle/state, the output of previous state block 971 is forwarded via gain coefficient d1 974 to a mixer 983, forwarded via gain coefficient −c1 975 to a mixer 984, and forwarded toward another previous state block 972 via a mixer 985. In another state, the output of previous state 972 is forwarded via gain coefficient d2 978 toward mixer 983. Mixer 983 mixes the output of previous state 972 and gain coefficient d2 978 and the output of previous state 971 and gain coefficient d1 974. The result is then forwarded for mixing with the input at mixer 982. Further, the output of previous state 972 is forwarded toward mixer 984 via gain coefficient −c2 976. Hence, the output of previous state 972 and gain coefficient −c2 976 are mixed with the output of previous state 971 and gain coefficient −c1 975. The results are then forwarded to mixer 981, which mixes the results from mixer 984 with the input for feedback into previous state 971. In addition, the biquad filter 900 employs a switch 977 which applies a gain of zero or a gain of one. When a gain of one is set, the switch 977 allows the output of previous state 972 to feed back into previous state 972 via mixer 985. The switch 977 may be set to zero and all coefficients change according to equation 1 to convert the biquad filter 900 into a so called direct form two biquad filter.
As can be seen, modified input at a first state is mixed with modified input of a second state, which is then mixed with input at a third state. Accordingly, input signal samples continually modify further input samples that are received later in time.
It should be noted that a source of error in a biquad filter is quantization. Quantization occurs when a signal sample is stored, for example at previous state 971 and/or 972. Specifically, quantization is a result of a rounding error when the memory employed to store the sample is not large enough to store the sample at perfect resolution. As noted above, biquads employ poles and zeros. A direct form biquad filter may attenuate the signal by applying zeros, store the signal causing quantization, and then amplify the signal by applying poles. This approach results in errors relating to quantization being amplified. To reach a reasonable signal to noise ratio (SNR), such direct form biquads typically use more bits than biquad filter 900. In contrast, biquad filter 900 amplifies the signal, stores and quantizes the signal, and then attenuates the signal. This approach results in the quantization error being attenuated instead of amplified. As a result, the biquad filter 900 may achieve sixty decibels (dB) lower SNR than a direct form biquad employing a similar number of bits in the previous state memory. Alternatively, for similar SNRs the biquad filter 900 can operate with about ten less bits in memory, which may be a substantial space savings.
The order of operations of the biquad filter 900 can be seen be review of the coefficients. Specifically, b0 973, d1 974, and d2 978 zeros and −c1 975, −c2 976 apply poles. As shown in
In other words, the biquad filter 900 employs poles to amplify portions of a sample of a noise/anti-noise signal. The biquad filter 900 also employs zeros to attenuate portions of the sample of the noise/anti-noise signal. Further, the biquad filter 900 employs a filter register to store a quantization of the sample of the noise/anti-noise signal. In addition, the biquad filter 900 is configured to amplify the sample, prior to quantizing the sample, and then attenuate the sample.
A goal of a biquad design may be to minimize requirements by reducing storage size and current while achieving a desired performance given an input signal type and target filters. As discussed above, the frequencies of interest for the biquad filters used herein are generally in the audio band (e.g. less than 20 kHz), which is significantly smaller than the sample rate (e.g. less an 1 MHz). Biquad filter 900 may significantly outperform biquad designs in this scenario (e.g. when center frequency is much less than sample rate). As an example, when operating at about 6.144 MHz to implement a peaking filter with 40 dB gain at 250 hertz (Hz) with quality factor (Q) of one, biquad filter 900 may generates about 60 dB lower noise than a direct form two biquad with the same number of bits. That may result in savings of about ten bits.
Another feature is that there biquad filter 900 may not require multipliers on the input signal directly. This yields a design that can be pipelined easily. Further, the multiplication by b0 973 is positioned at the very output. As such, the biquad filter 900 acts as a filter followed by final gain stage. This becomes convenient when multiple biquads are employed in series. In that case, the b0 973 multiplications can be combined into a signal multiplication step. So, for a cascade of N biquads, direct form biquads may require 5N multiplications. In contrast, biquad filter 900 only employs 4N+1 multiplications. Having a multiplier at the output of the series cascade may be particularly useful in RAP hardware architecture.
At block 1001, an audio signal is generated at a DSP based on audio input. Further, an expected output signal is also generated at the DSP based on the audio input and a frequency response of an acoustic processing network. The audio signal and the expected output signal are then communicated from the DSP to the RAP as shown in network 400.
At block 1003, a noise signal is also received at the DSP. The noise signal is received from at least one microphone. The DSP generates a noise filter based on the noise signal. The DSP also communicates the noise filter from the DSP to a RAP as shown in network 100. As noted above, the DSP operates at a first frequency, while the RAP operates at a second frequency higher than the first frequency.
At block 1005, the RAP employs current compression states at the RAP to control an adjustable amplifier, for adjusting an anti-noise signal. The current compression states employed by the RAP are communicated from the RAP to the DSP as shown in network 300. The DSP then determines new compression states based on the noise signal and the current compression states. The DSP communicates the new compression states from to the RAP to support controlling the adjustable amplifier. Such compression states may include a peak signal estimate, an instantaneous gain, a target gain, an attack parameter, a release parameter, a peak decay parameter, a hold parameter, a RMS of the anti-noise signal or combinations thereof
At block 1007, the RAP receives the audio signal, the expected output signal, noise filters, and/or new compression states from the DSP, as well as noise signal(s) from the microphone(s) (e.g. FF and/or FB).
At block 1009, the RAP generates an anti-noise signal based on the noise signal and the noise filter for use in ANC. Further, the RAP sets the expected output signal as a reference point when generating the anti-noise signal to mitigate cancelation of the audio signal by the anti-noise signal. The anti-noise signal may be generated at the RAP by configuring programmable biquad filters to implement the noise filter from the DSP. For example, the biquad filters may amplify a sample of the anti-noise signal, then quantize the sample of the anti -noise signal, and then attenuate the sample of the anti-noise filter as shown by biquad 900.
At block 1011, an ambient awareness filter is applied at the RAP to enhance a predetermined frequency band in the noise signal when generating the anti-noise signal as discussed with respect to topology 800. This may result in an enhanced predetermined frequency band, such as a frequency band associated with speech. Additional filters may also be applied to add in a side tone in some examples.
At block 1013, the RAP mixes the audio signal with the anti-noise signal. The RAP also forwards the resulting signal to a speaker for output to a user. Depending on the example, the resulting signal may include, audio, anti-noise, a side tone, an ambient awareness signal with an enhanced predetermined frequency band, and/or any other feature described herein.
At block 1015, the RAP also forwards the anti-noise signal to a DAC amplifier controller to support adjusting a DAC amplifier based on anti-noise signal level in order to mitigate clipping and other artifacts. It should be noted that the method 1000 discussed above attempts to describe simultaneous action of all features disclosed herein. Accordingly, method 1000 contains many optional steps as not all features need be active at all times. Further, method 1000 may operate constantly, and hence may not always operate in the order depicted.
Examples of the disclosure may operate on a particularly created hardware, on firmware, digital signal processors, or on a specially programmed general purpose computer including a processor operating according to programmed instructions. The terms “controller” or “processor” as used herein are intended to include microprocessors, microcomputers, Application Specific Integrated Circuits (ASICs), and dedicated hardware controllers. One or more aspects of the disclosure may be embodied in computer-usable data and computer -executable instructions (e.g. computer program products), such as in one or more program modules, executed by one or more processors (including monitoring modules), or other devices. Generally, program modules include routines, programs, objects, components, data structures, etc. that perform particular tasks or implement particular abstract data types when executed by a processor in a computer or other device. The computer executable instructions may be stored on a non-transitory computer readable medium such as Random Access Memory (RAM), Read Only Memory (ROM), cache, Electrically Erasable Programmable Read-Only Memory (EEPROM), flash memory or other memory technology, Compact Disc Read Only Memory (CD-ROM), Digital Video Disc (DVD), or other optical disk storage, magnetic cassettes, magnetic tape, magnetic disk storage or other magnetic storage devices, and any other volatile or nonvolatile, removable or non-removable media implemented in any technology. Computer readable media excludes signals per se and transitory forms of signal transmission. In addition, the functionality may be embodied in whole or in part in firmware or hardware equivalents such as integrated circuits, field programmable gate arrays (FPGA), and the like. Particular data structures may be used to more effectively implement one or more aspects of the disclosure, and such data structures are contemplated within the scope of computer executable instructions and computer-usable data described herein.
Aspects of the present disclosure operate with various modifications and in alternative forms. Specific aspects have been shown by way of example in the drawings and are described in detail herein below. However, it should be noted that the examples disclosed herein are presented for the purposes of clarity of discussion and are not intended to limit the scope of the general concepts disclosed to the specific examples described herein unless expressly limited. As such, the present disclosure is intended to cover all modifications, equivalents, and alternatives of the described aspects in light of the attached drawings and claims.
References in the specification to embodiment, aspect, example, etc., indicate that the described item may include a particular feature, structure, or characteristic. However, every disclosed aspect may or may not necessarily include that particular feature, structure, or characteristic. Moreover, such phrases are not necessarily referring to the same aspect unless specifically noted. Further, when a particular feature, structure, or characteristic is described in connection with a particular aspect, such feature, structure, or characteristic can be employed in connection with another disclosed aspect whether or not such feature is explicitly described in conjunction with such other disclosed aspect.
Illustrative examples of the technologies disclosed herein are provided below. An embodiment of the technologies may include any one or more, and any combination of, the examples described below.
Example 1 includes an acoustic processing network comprising: a Digital Signal Processor (DSP) operating at a first frequency, the DSP to: receive a noise signal from at least one microphone, and generate a noise filter based on the noise signal; and a Real-Time Acoustic Processor (RAP) operating at a second frequency higher than the first frequency, the RAP to: receive the noise signal from the microphone, receive the noise filter from the DSP, and generate an anti-noise signal based on the noise signal and the noise filter for use in Active Noise Cancellation (ANC).
Example 2 includes the acoustic processing network of Example 1, wherein the RAP includes: an adjustable amplifier to amplify the anti-noise signal, and a compressor circuit to control the adjustable amplifier to mitigate artifacts in the anti-noise signal.
Example 3 includes the acoustic processing network of Example 2, wherein the RAP further includes a compression state register to store compression states, the compressor circuit further to control the adjustable amplifier based on the compression states.
Example 4 includes the acoustic processing network of Example 3, wherein the compression states include a peak signal estimate, an instantaneous gain, a target gain, an attack parameter, a release parameter, a decay parameter, a hold parameter, or combinations thereof.
Example 5 includes the acoustic processing network of Example 3, wherein the compression states include a Root Mean Square (RMS) of the anti-noise signal.
Example 6 includes the acoustic processing network of Examples 1-4, wherein the DSP is further to: receive current compression states from the RAP, determine new compression states based on the noise signal and the current compression states, and forward the new compression states to the RAP to support controlling the adjustable amplifier.
Example 7 includes the acoustic processing network of Examples 1-6, wherein the RAP includes one or more programmable biquad filters to implement the noise filter from the DSP and generate the anti-noise signal.
Example 8 includes the acoustic processing network of Example 7, wherein the biquad filters employ one or more poles to amplify portions of a sample of the anti-noise signal, one or more zeros to attenuate portions of the sample of the anti-noise signal, and a filter register to store a quantization of the sample of the anti-noise signal, the biquad filters to amplify the sample prior to quantizing the sample and then attenuate the sample.
Example 9 includes the acoustic processing network of Examples 1-8, wherein the microphone is a feed forward microphone, and the RAP is further to: apply an ambient awareness filter to enhance a predetermined frequency band in the noise signal when generating the anti-noise signal, resulting in an enhanced predetermined frequency band, and forward the anti-noise signal with the enhanced predetermined frequency band to a speaker for output to a user.
Example 10 includes the acoustic processing network of Examples 1-9, wherein a latency between receiving a noise signal sample from ae microphone and forwarding a corresponding anti-noise signal sample to a speaker is less than one hundred microseconds.
Example 11 includes the acoustic processing network of Examples 1-10, wherein the DSP is further to: generate an audio signal based on audio input, and generate an expected output signal based on the audio input and a frequency response of the acoustic processing network, and wherein the RAP is further to: receive the audio signal from the DSP, mix the audio signal with the anti-noise signal, and set the expected output signal as a reference point when generating the anti-noise signal to mitigate cancelation of the audio signal by the anti-noise signal.
Example 12 includes the acoustic processing network of Examples 1-11, wherein the RAP is further configured to forward the anti-noise signal to a digital to analog converter (DAC) amplifier controller to support adjusting a DAC amplifier based on anti-noise signal level.
Example 13 includes a method comprising: receive a noise signal at a Digital Signal Processor (DSP) operating at a first frequency, the noise signal received from at least one microphone; generating a noise filter at the DSP based on the noise signal; communicate the noise filter from the DSP to a Real-Time Acoustic Processor (RAP) operating at a second frequency higher than the first frequency; receive the noise signal from the microphone at the RAP; generate an anti-noise signal at the RAP based on the noise signal and the noise filter for use in Active Noise Cancellation (ANC).
Example 14 includes the method of Example 13, further comprising employing current compression states at the RAP to control an adjustable amplifier to adjust the anti-noise signal; communicating the current compression states from the RAP to the DSP; determining new compression states at the DSP based on the noise signal and the current compression states, and communicating the new compression states from the DSP to the RAP to support controlling the adjustable amplifier.
Example 15 includes the method of Example 14, wherein the compression states include a peak signal estimate, an instantaneous gain, a target gain, a Root Mean Square (RMS) of the anti-noise signal or combinations thereof.
Example 16 includes the method of Examples 13-15, wherein the anti-noise signal is generated at the RAP by configuring one or more programmable biquad filters to implement the noise filter from the DSP.
Example 17 includes the method of Example 16, wherein the biquad filters amplify a sample of the anti-noise signal, then quantize the sample of the anti-noise signal, and then attenuate the sample of the anti-noise filter.
Example 18 includes the method of Examples 13-17, further comprising: applying an ambient awareness filter at the RAP to enhance a predetermined frequency band in the noise signal when generating the anti-noise signal, resulting in an enhanced predetermined frequency band, and forwarding the anti-noise signal with the enhanced predetermined frequency band to a speaker for output to a user.
Example 19 includes the method of Examples 13-18, further comprising: generating an audio signal at the DSP based on audio input; generating an expected output signal at the DSP based on the audio input and a frequency response of an acoustic processing network; communicating the audio signal from the DSP to the RAP; mixing the audio signal with the anti -noise signal at the RAP; and setting the expected output signal as a reference point when generating the anti-noise signal to mitigate cancelation of the audio signal by the anti-noise signal.
Example 20 includes the method of Examples 13-19, further comprising forwarding the anti-noise signal to a digital to analog converter (DAC) amplifier controller to support adjusting a DAC amplifier based on anti-noise signal level.
The previously described examples of the disclosed subject matter have many advantages that were either described or would be apparent to a person of ordinary skill. Even so, all of these advantages or features are not required in all versions of the disclosed apparatus, systems, or methods.
Additionally, this written description makes reference to particular features. It is to be understood that the disclosure in this specification includes all possible combinations of those particular features. Where a particular feature is disclosed in the context of a particular aspect or example, that feature can also be used, to the extent possible, in the context of other aspects and examples.
Also, when reference is made in this application to a method having two or more defined steps or operations, the defined steps or operations can be carried out in any order or simultaneously, unless the context excludes those possibilities.
Although specific examples of the disclosure have been illustrated and described for purposes of illustration, it will be understood that various modifications may be made without departing from the spirit and scope of the disclosure. Accordingly, the disclosure should not be limited except as by the appended claims.
The present application is a continuation of U.S. Non-provisional patent application Ser. No. 15/916,885, filed Mar. 9, 2018, and entitled “REAL-TIME ACOUSTIC PROCESSOR,” which claims benefit from U.S. Provisional Patent Application No. 62/469,461, filed Mar. 9, 2017, and entitled “REAL-TIME ACOUSTIC PROCESSOR,” the disclosures of both of which are incorporated herein by reference in their entirety.
Number | Date | Country | |
---|---|---|---|
62469461 | Mar 2017 | US |
Number | Date | Country | |
---|---|---|---|
Parent | 15916885 | Mar 2018 | US |
Child | 16404514 | US |