Variable ANR transform compression

Information

  • Patent Grant
  • 8472637
  • Patent Number
    8,472,637
  • Date Filed
    Sunday, April 25, 2010
    14 years ago
  • Date Issued
    Tuesday, June 25, 2013
    11 years ago
Abstract
Apparatus and method of reducing the provision of ANR at an one end of a range of frequencies at which the ANR is provided without reducing the provision of the ANR at the other end of the range of frequencies by repeatedly reconfiguring coefficients of one or more digital filters to reduce the provision of ANR at the one end in increments at a first recurring interval, and then later reversing the reduction in the provision of the ANR at the one end by repeatedly reconfiguring coefficients of the one or more digital filters in increments at a second recurring interval.
Description
TECHNICAL FIELD

This disclosure relates to personal active noise reduction (ANR) devices to reduce acoustic noise in the vicinity of at least one of a user's ears.


BACKGROUND

Headphones and other physical configurations of personal ANR device worn about the ears of a user for purposes of isolating the user's ears from unwanted environmental sounds have become commonplace. In particular, ANR headphones in which unwanted environmental noise sounds are countered with the active generation of anti-noise sounds, have become highly prevalent, even in comparison to headphones or ear plugs employing only passive noise reduction (PNR) technology, in which a user's ears are simply physically isolated from environmental noises. Especially of interest to users are ANR headphones that also incorporate audio listening functionality, thereby enabling a user to listen to electronically provided audio (e.g., playback of recorded audio or audio received from another device) without the intrusion of unwanted environmental noise sounds.


Unfortunately, despite various improvements made over time, existing personal ANR devices continue to suffer from a variety of drawbacks. Foremost among those drawbacks are undesirably high rates of power consumption leading to short battery life, undesirably narrow ranges of audible frequencies in which unwanted environmental noise sounds are countered through ANR, instances of unpleasant ANR-originated sounds, and instances of actually creating more unwanted noise sounds than whatever unwanted environmental sounds may be reduced.


SUMMARY

An ANR circuit employs first, second and third buffers to buffer ANR settings in preparation for configuring one or more components of the ANR circuit during operation and in synchronization with the transfer of at least one piece of digital data within the ANR circuit. The first and second buffers are alternately used to carry out such configuring, while the third buffer stores a “failsafe” ANR settings to be automatically used in configuring the one or more components of the ANR circuit in response to an indication of instability in the provision feedback-based ANR, feedforward-based ANR and/or pass-through audio being detected.


In one aspect, an ANR circuit includes a first ADC; a DAC; a first digital filter; a first pathway within the ANR circuit through which digital data representing sounds flows from the first ADC to the DAC through at least the first digital filter at a first data transfer rate through at least part of the first pathway; a first ANR settings buffer and a second ANR settings buffer to be alternately employed in configuring at least one ANR setting in synchronization with a transfer of a piece of digital data transferred through at least part of the first pathway at the first data transfer rate; and a third ANR settings buffer to store at least one failsafe ANR setting to configure the at least one ANR setting in response to an instance of instability being detected in the ANR circuit.


Implementations may include, and are not limited to, one or more of the following features. The at least one ANR setting may include at least one of a coefficient setting of the first digital filter, a selection of a type of digital filter from among a plurality of available types of digital filters for the first digital filter, an interconnection of the first pathway, and the first data transfer rate. The ANR circuit may further include a processing device and a storage in which is stored a sequence of instructions that when executed by the processing device, causes the processing device to maintain the first, second and third ANR settings buffers within the storage and monitor digital data representing sounds flowing through the first pathway for an indication of instability in the ANR circuit. The ANR circuit may further include a VGA incorporated into the first pathway, wherein the at least one ANR setting comprises a gain setting of the VGA. The ANR circuit may further include an interface by which the ANR circuit is able to be coupled to an external processing device from which the at least one ANR setting is received. The ANR circuit may further include a first filter block incorporated into the first pathway, wherein the first filter block comprises a plurality of digital filters including the first digital filter; the first filter block is configurable to cause the first digital filter and other digital filters of the first filter block to cooperate to implement a transfer function; and the at least one ANR setting comprises a specification of the transfer function. The ANR circuit may further include a second ADC, a second digital filter, and a second pathway within the ANR circuit through which digital data representing sounds flows from the second ADC to the DAC through at least the second digital filter at a second data transfer rate through at least part of the second pathway; wherein the first and second pathways are combined at a first location along the first pathway and at a second location along the second pathway; and wherein the at least one ANR setting comprises at least one of a specification of where the first location is along the first pathway and a specification of where the second location is along the second pathway.


In one aspect, a method of configuring at least one ANR setting of an ANR circuit having a first pathway through which digital data representing sounds flows from a first ADC to a DAC through at least a first digital filter and at a first data transfer rate through at least part of the first pathway includes: alternately employing a first ANR settings buffer and a second ANR settings buffer to configure the at least one ANR setting in synchronization with a transfer of a piece of digital data transferred through at least part of the first pathway at the first data transfer rate; storing at least one failsafe ANR setting in a third ANR settings buffer; and employing the third ANR settings buffer to configure the at least one ANR setting in response to an instance of instability being detected in the ANR circuit.


Implementations may include, and are not limited to, one or more of the following features. The method may further include storing the at least one ANR setting in one of the first and second ANR settings buffers to configure at least one of a coefficient setting of the first digital filter, a selection of a type of digital filter from among a plurality of available types of digital filters for the first digital filter, an interconnection of the first pathway, the first data transfer rate, a gain setting of a VGA incorporated into the first pathway, and a transfer function implemented by a filter block comprising a plurality of digital filters including the first digital filter. The method may further include awaiting receipt of the at least one ANR setting from an external processing device coupled to an interface of the ANR circuit and storing the at least one ANR setting in one of the first and second ANR settings buffers. The method may further include storing a failsafe gain setting for a VGA incorporated into a pathway in the third ANR settings buffer; monitoring a signal output by the DAC; and employing the third ANR settings buffer to configure the VGA with the failsafe gain setting in response to detecting an indication of impending clipping in the signal output by the DAC as an indication of an instance of instability in the ANR circuit. The method may further include storing at least one ANR setting in one of the first and second ANR settings buffers; awaiting receipt of a signal by the ANR circuit; and employing the one of the first and second ANR settings buffers to configure the at least one ANR setting in response to receiving the ANR circuit receiving the signal.


Apparatus and method of an ANR circuit providing both feedforward-based and feedback-based ANR, possibly of a personal ANR device, compressing both feedforward and feedback reference sounds detected by feedforward and feedback microphones, respectively, in response to the acoustic energy of the feedforward reference noise sound reaching a predetermined level.


In another aspect, an ANR circuit includes a first VGA to compress a feedforward reference sound represented by a signal output by a feedforward microphone detecting an external noise sound in an environment external to a casing as the feedforward reference sound, a second VGA to compress a feedback reference sound represented by a signal output by a feedback microphone detecting a cavity noise sound within a cavity defined by the casing as the feedback reference sound, at least one filter to generate a feedforward anti-noise sound from the feedforward reference sound, at least another filter to generate a feedback anti-noise sound from the feedback reference sound, and a compression controller coupled to the first and second VGAs to operate the first and second VGAs to coordinate compression of the feedforward and feedback reference sounds in response to the acoustic energy of the external noise sound reaching a first threshold.


Implementations may include, and are not limited to, one or more of the following features. The first VGA may be an analog VGA interposed between the feedforward microphone and the at least one filter, and the compression controller monitors the acoustic energy of the external noise sound by monitoring the signal output by the feedforward microphone. The ANR may further include a first ADC to convert the signal output by the feedforward microphone from analog to digital form, wherein the first VGA may be a digital VGA interposed between first ADC and the at least one filter, and wherein the compression controller receives the signal from the feedforward microphone in digital form through the first ADC to monitor the acoustic energy of the external noise sound. The ANR may further include a DAC to convert a combination of the feedforward and feedback anti-noise sounds from being represented with digital data to being represented by an analog signal to be conveyed to an audio amplifier to drive an acoustic driver to acoustically output the combination of feedforward and feedback anti-noise sounds into the cavity, wherein the compression controller receives the digital data representing the combination of the feedforward and feedback anti-noise sounds, and the compression controller is structured to determine that the acoustic energy of the external noise sound reaches the first threshold in response to the amplitude of the combination of the feedforward and feedback anti-noise sounds reaching another threshold. The ANR circuit may further include an audio amplifier outputting an analog signal representing a combination of the feedforward and feedback anti-noise sounds to an acoustic driver to cause the acoustic driver to acoustically output the combination of the feedforward and feedback anti-noise sounds into the cavity, wherein the compression controller monitors the analog signal output by the audio amplifier and representing the combination of the feedforward and feedback anti-noise sounds, and the compression controller is structured to determine that the acoustic energy of the external noise sound reaches the first threshold in response to the amplitude of the analog signal representing the combination of the feedforward and feedback anti-noise sounds reaching another threshold. The ANR may further include a DAC to convert a combination of the feedforward and feedback anti-noise sounds from being represented with digital data to being represented by an analog signal to be conveyed to an audio amplifier to drive an acoustic driver to acoustically output the combination of feedforward and feedback anti-noise sounds into the cavity, wherein the compression controller monitors the analog signal output by the DAC, and the compression controller is structured to determine that the acoustic energy of the external noise sound reaches the first threshold in response to detecting an occurrence of an audio artifact in the analog signal. The ANR circuit may further include an audio amplifier outputting an analog signal representing a combination of the feedforward and feedback anti-noise sounds to an acoustic driver to cause the acoustic driver to acoustically output the combination of the feedforward and feedback anti-noise sounds into the cavity, wherein the compression controller monitors the analog signal output by the audio amplifier, and the compression controller is structured to determine that the acoustic energy of the external noise sound reaches the first threshold in response to detecting an occurrence of an audio artifact in the analog signal. The compression controller may operate the first VGA to compress the feedforward reference sound to an increasingly greater degree than the compression controller operates the second VGA to compress the feedback reference sound as the acoustic energy of the external noise sound rises further above the first threshold.


The compression controller may be structured to change the first threshold in response to a change in what audible frequency is predominant in the external noise sound. Further, the compression controller may be structured to lower the first threshold in response to what audible frequency is predominant in the external noise sound changing from a higher audible frequency to a lower audible frequency, and wherein the controller raises the first threshold in response to what audible frequency is predominant in the external noise sound changing from a lower audible frequency to a higher audible frequency.


The compression controller may be structured to operate the first VGA and the second VGA to compress both the feedforward and feedback reference sounds in response to the acoustic energy of the external noise sound reaching the first threshold, and to operate the first VGA to compress the feedforward reference sound and operates the second VGA to refrain from compressing the feedback reference sound in response to the acoustic energy of the external noise sound remaining below the first threshold while rising above a second threshold, where the second threshold is lower than the first threshold. Further, the compression controller may be structured to operate the first VGA to compress the feedforward reference sound to an increasingly greater degree as the acoustic energy of the external noise sound rises further above the first threshold until the firsts VGA is operated to have a gain close to zero, and to operate the second VGA to compress the feedback reference sound to an increasingly greater degree as the acoustic energy of the external noise sound rises further above the first threshold and without regard to whether or not the first VGA has been operated to have a gain close to zero. Further, the compression controller may be structured to operate the first VGA to compress the feedforward reference sound to an increasingly greater degree as the acoustic energy of the external noise sound rises further above the first threshold until the acoustic energy reaches a third threshold, and to operate the second VGA to compress the feedback reference sound to an increasingly greater degree as the acoustic energy of the external noise sound rises further above the first threshold and without regard to whether or not the acoustic energy of the external noise sound rises above the third threshold, where the third threshold is higher than the first threshold.


In another aspect, a personal ANR device includes a first casing defining a first cavity structured to be acoustically coupled to a first ear canal of a first ear of a user of the personal ANR device; a first feedforward microphone carried by the first casing in a manner that acoustically couples the first feedforward microphone to an environment external to the first casing to detect a first external noise sound in the environment external to the first casing, and structured to output a signal representing the first external noise sound as a first feedforward reference sound; a first feedback microphone disposed within the first cavity to detect a cavity noise sound within the first cavity, and structured to output a signal representing the cavity noise sound as a first feedback reference sound; a first acoustic driver disposed within the first casing to acoustically output a first feedforward anti-noise sound and first feedback anti-noise sound into the first cavity; and a first ANR circuit coupled to the first feedforward microphone to receive the signal representing the first feedforward reference sound, coupled to the first feedback microphone to receive the signal the representing first feedback reference sound, and coupled to the first acoustic driver to drive the first acoustic driver to acoustically output the first feedforward and first feedback anti-noise sounds; wherein the first ANR circuit is structured to generate the first feedforward anti-noise sound from the first feedforward reference sound, structured to generate the first feedback anti-noise sound from the first feedback reference sound, and structured to coordinate compression of the first feedforward and first feedback reference sounds in response to the acoustic energy of the first external noise sound reaching a first threshold.


Implementations may include, and are not limited to, one or more of the following features. The ANR circuit may be structured to compress the first feedforward reference sound to an increasingly greater degree than the ANR circuit compresses the first feedback reference sound as the acoustic energy of the first external noise sound rises further above the first threshold.


The ANR circuit may be structured to change the first threshold in response to a change in what audible frequency is predominant in the first external noise sound. Further, the ANR circuit may be structured to lower the first threshold in response to what audible frequency is predominant in the external noise sound changing from a higher audible frequency to a lower audible frequency, and to raise the first threshold in response to what audible frequency is predominant in the external noise sound changing from a lower audible frequency to a higher audible frequency.


The ANR circuit may be structured to compress both the first feedforward and first feedback reference sounds in response to the acoustic energy of the first external noise sound reaching the first threshold, and to compress the feedforward reference sound and refrains from compressing the first feedback reference sound in response to the acoustic energy of the first external noise sound remaining below the first threshold while rising above a second threshold, where the second threshold is lower than the first threshold. Further, the ANR circuit may be structured to compress the feedforward reference sound to an increasingly greater degree as the acoustic energy of the first external noise sound rises further above the first threshold until the feedforward reference has been compressed to a degree where the feedforward reference sound has been reduced in amplitude to close to zero, and to compress the feedback reference sound to an increasingly greater degree as the acoustic energy of the first external noise sound rises further above the first threshold and without regard to whether or not the feedforward reference sound has been reduced in amplitude to close to zero.


The personal ANR device may further include a second casing defining a second cavity structured to be acoustically coupled to a second ear canal of a second ear of the user; a second feedforward microphone carried by the second casing in a manner that acoustically couples the second feedforward microphone to an environment external to the second casing to detect a second external noise sound in the environment external to the second casing, and structured to output a signal representing the second external noise sound as a second feedforward reference sound; a second feedback microphone disposed within the second cavity to detect a cavity noise sound within the second cavity, and structured to output a signal representing the cavity noise sound as a second feedback reference sound; and a second acoustic driver disposed within the second casing to acoustically output a second feedforward anti-noise sound and second feedback anti-noise sound into the second cavity. Further, the personal ANR device may further include a second ANR circuit coupled to the second feedforward microphone to receive the signal representing the second feedforward reference sound, coupled to the second feedback microphone to receive the signal the representing second feedback reference sound, and coupled to the second acoustic driver to drive the second acoustic driver to acoustically output the second feedforward and second feedback anti-noise sounds; wherein the second ANR circuit is structured to generate the second feedforward anti-noise sound from the second feedforward reference sound, structured to generate the second feedback anti-noise sound from the second feedback reference sound, and structured to coordinate compression of the second feedforward and second feedback reference sounds in response to the acoustic energy of the second external noise sound reaching the first threshold. Further, the first ANR circuit may be coupled to the second feedforward microphone to receive the signal representing the second feedforward reference sound, coupled to the second feedback microphone to receive the signal the representing second feedback reference sound, and coupled to the second acoustic driver to drive the second acoustic driver to acoustically output the second feedforward and second feedback anti-noise sounds; and the first ANR circuit may be structured to generate the second feedforward anti-noise sound from the second feedforward reference sound, and structured to generate the second feedback anti-noise sound from the second feedback reference sound. Still further, the first ANR circuit may be structured to coordinate compression of the second feedforward and second feedback reference sounds in response to the acoustic energy of the second external noise sound reaching the first threshold. Still further, the first ANR circuit may be structured to coordinate compression of the first feedforward, the first feedback, the second feedforward and the second feedback reference sounds in response to the acoustic energy of the first external noise sound reaching the first threshold.


Apparatus and method of reducing the provision of ANR at an one end of a range of frequencies at which the ANR is provided without reducing the provision of the ANR at the other end of the range of frequencies by repeatedly reconfiguring coefficients of one or more digital filters to reduce the provision of ANR at the one end in increments at a first recurring interval, and then later reversing the reduction in the provision of the ANR at the one end by repeatedly reconfiguring coefficients of the one or more digital filters in increments at a second recurring interval.


In one aspect, a personal ANR device includes an acoustic driver; an ANR circuit coupled to the acoustic driver to operate the acoustic driver to acoustically output ANR anti-noise sounds to provide ANR at a location adjacent an ear of a user of the personal ANR device across a range of frequencies having a lower limit and an upper limit; and at least one digital filter of the ANR circuit. Further, the at least one digital filter is configurable with a plurality of coefficients to implement an ANR transform to derive the ANR anti-noise sounds from ANR reference noise sounds; the ANR circuit is configured to repeatedly reconfigure the at least one digital filter with different pluralities of coefficient values at a first recurring interval to reduce the provision of the ANR at one of the lower limit and the upper limit without reducing a magnitude at which the ANR is provided at the other one of the lower limit and the upper limit in response to an event adversely affecting the provision of the ANR at the one of the lower limit and the upper limit; and the ANR circuit is configured to repeatedly reconfigure the at least one digital filter with different pluralities of coefficient values at a second recurring interval to reverse the reduction in the provision of the ANR at the one of the lower limit and the upper limit in response to the event adversely affecting the provision of the ANR at the one of the lower limit and the upper limit having ceased.


Implementations may include, and are not limited to, one or more of the following features. The first recurring interval may be shorter than the second recurring interval; and the first recurring interval may be selected to enable the reduction in the provision of the ANR at the one of the lower limit and the upper limit quickly enough to minimize audible artifacts arising from the event, while avoiding generating an audible artifact arising from repeatedly reconfiguring the at least one digital filter. The event may be selected from a set of events consisting of an instance of clipping in the acoustic outputting of the anti-noise sounds, an instance of instability in providing ANR, an instance of a sound having an excessive amplitude, and an occurrence of an audio artifact. The first recurring interval may be on the order of 10 msec and the second recurring interval may be on the order of 100 msec. The ANR may include feedback-based ANR provided across a first range of frequencies having a lower limit and an upper limit, and feedforward-based ANR provided across a second range of frequencies having a lower limit and an upper limit; the personal ANR device may include a feedback microphone detecting feedback reference noise sounds to enable provision of the feedback-based ANR and a feedforward microphone detecting feedforward reference noise sounds to enable provision of the feedforward-based ANR; and reducing provision of the ANR at the one of the lower limit and the upper limit may include reducing provision of both the feedback-based ANR and the feedforward-based ANR at one of the lower limits and the upper limits of both the feedback-based and feedforward-based ANR in steps at the first recurring interval. The personal ANR device may further include a first buffer of the ANR circuit and a second buffer of the ANR circuit, wherein the ANR circuit alternately employs the first and second buffers to repeatedly reconfigure the at least one digital filter with different pluralities of coefficient values at the first recurring intervals and at the second recurring intervals.


The provision of the ANR at the one of the lower limit and the upper limit may be reduced by moving the one of the lower limit and the upper limit in steps with each of the first recurring intervals to reduce the range of frequencies, wherein a slope at the one of the lower limit and the upper limit is substantially maintained as the one of the lower limit and the upper limit is moved. The reduction in provision of the ANR at the one of the lower limit and the upper limit may be reversed by moving the one of the lower limit and the upper limit in steps with each of the second recurring intervals to return the range of frequencies to what the range of frequencies was before the reduction in provision of the ANR at the one of the lower limit and the upper limit, wherein the slope at the one of the lower limit and the upper limit is substantially maintained as the one of the lower limit and the upper limit is moved.


The provision of the ANR at the one of the lower limit and the upper limit may be reduced by changing a slope at the one of the lower limit and the upper limit to make the slope more shallow in steps with each of the first recurring intervals, wherein a transition bandwidth occupied by the slope widens as a cutoff frequency associated with the slope is moved inward into the range of frequencies in steps with each of the first recurring intervals. The reduction in provision of the ANR at the one of the lower limit and the upper limit may be reversed by changing the slope at the one of the lower limit and the upper limit to make the slope more steep in steps with each of the second recurring intervals, wherein the transition bandwidth occupied by the slope narrows as a cutoff frequency associated with the slope is moved outward in steps with each of the first recurring intervals back to what the cutoff frequency was before the reduction in provision of the ANR.


In one aspect, A method includes repeatedly reconfiguring at least one digital filter with different pluralities of coefficient values at a first recurring interval to reduce a provision of ANR by the at least one digital filter at one of the lower limit and the upper limit of a range of frequencies at which the at least one digital filter provides the ANR without reducing a magnitude at which the ANR is provided at the other one of the lower limit and the upper limit in response to an event adversely affecting the provision of the ANR at the one of the lower limit and the upper limit; repeatedly reconfiguring the at least one digital filter with different pluralities of coefficient values at a second recurring interval to reverse the reduction in the provision of the ANR at the one of the lower limit and the upper limit in response to the event adversely affecting the provision of the ANR at the one of the lower limit and the upper limit having ceased; and ceasing to reverse the reduction in the provision of the ANR in response to the event recurring as the at least one digital filter is repeatedly reconfigured with different pluralities of coefficient values at the second recurring interval to reverse the reduction in the provision of the ANR.


Implementations may include, and are not limited to, one or more of the following features. The first recurring interval may be shorter than the second recurring interval; and the first recurring interval may be selected to enable the reduction in the provision of the ANR at the one of the lower limit and the upper limit quickly enough to minimize audible artifacts arising from the event, while avoiding generating an audible artifact arising from repeatedly reconfiguring the at least one digital filter. The event may be selected from a set of events consisting of an instance of clipping in the acoustic outputting of the anti-noise sounds, an instance of instability in providing ANR, an instance of a sound having an excessive amplitude, and an occurrence of an audio artifact. The first recurring interval may be on the order of 10 msec and the second recurring interval may be on the order of 100 msec. The ANR may include feedback-based ANR provided across a first range of frequencies having a lower limit and an upper limit, and feedforward-based ANR provided across a second range of frequencies having a lower limit and an upper limit; and reducing provision of the ANR at the one of the lower limit and the upper limit may include reducing provision of both the feedback-based ANR and the feedforward-based ANR at one of the lower limits and the upper limits of both the feedback-based and feedforward-based ANR in steps at the first recurring interval.


Reducing the provision of the ANR at the one of the lower limit and the upper limit may include moving the one of the lower limit and the upper limit in steps with each of the first recurring intervals to reduce the range of frequencies, wherein a slope at the one of the lower limit and the upper limit is substantially maintained as the one of the lower limit and the upper limit is moved. Reversing the reduction in provision of the ANR at the one of the lower limit and the upper limit may include moving the one of the lower limit and the upper limit in steps with each of the second recurring intervals to return the range of frequencies to what the range of frequencies was before the reduction in provision of the ANR at the one of the lower limit and the upper limit, wherein the slope at the one of the lower limit and the upper limit is substantially maintained as the one of the lower limit and the upper limit is moved.


Reducing the provision of the ANR at the one of the lower limit and the upper limit may include changing a slope at the one of the lower limit and the upper limit to make the slope more shallow in steps with each of the first recurring intervals, wherein a transition bandwidth occupied by the slope widens as a cutoff frequency associated with the slope is moved inward into the range of frequencies in steps with each of the first recurring intervals. Reversing the reduction in provision of the ANR at the one of the lower limit and the upper limit may include changing the slope at the one of the lower limit and the upper limit to make the slope more steep in steps with each of the second recurring intervals, wherein the transition bandwidth occupied by the slope narrows as a cutoff frequency associated with the slope is moved outward in steps with each of the first recurring intervals back to what the cutoff frequency was before the reduction in provision of the ANR.


Other features and advantages of the invention will be apparent from the description and claims that follow.





DESCRIPTION OF THE DRAWINGS


FIG. 1 is a block diagram of portions of an implementation of a personal ANR device.



FIGS. 2
a through 2f depict possible physical configurations of the personal ANR device of FIG. 1.



FIGS. 3
a and 3b depict possible internal architectures of an ANR circuit of the personal ANR device of FIG. 1.



FIGS. 4
a through 4g depict possible signal processing topologies that may be adopted by the ANR circuit of the personal ANR device of FIG. 1.



FIGS. 5
a through 5e depict possible filter block topologies that may be adopted by the ANR circuit of the personal ANR device of FIG. 1.



FIGS. 6
a through 6c depict possible variants of triple-buffering that may be adopted by the ANR circuit of the personal ANR device of FIG. 1.



FIG. 7
a depicts a possible additional portion of the internal architecture of FIG. 3a.



FIG. 7
b depicts a possible additional portion of the internal architecture of FIG. 3b.



FIG. 8 is a flowchart of a possible boot loading sequence that may be adopted by the ANR circuit of the personal ANR device of FIG. 1.



FIG. 9
a depicts a possible internal architecture of an ADC of the ANR circuit of the personal ANR device of FIG. 1.



FIG. 9
b depicts a possible additional portion of any of the signal processing topologies of FIGS. 4a through 4g.



FIGS. 10
a and 10b depict possible additional portions of any of the signal processing topologies of FIGS. 4a through 4g.



FIG. 11 depicts possible additional aspects of any of the signal processing topologies of FIGS. 4a through 4g



FIG. 12
a depicts a possible additional portion of the internal architecture of FIG. 3a.



FIG. 12
b depicts a possible additional portion of the internal architecture of FIG. 3b.



FIG. 13 depicts possible coordinated compression responses to various acoustic energy levels of noise sounds at various frequencies of noise sounds.



FIG. 14 depicts possible additional aspects of any of the signal processing topologies of FIGS. 4a through 4g to implement frequency-dependent compression of at least one ANR reference sound.



FIG. 15 depicts aspects of an exemplary application of the signal processing topology aspects of FIG. 14.



FIGS. 16 and 17 depict exemplary application of altering an ANR transform implemented in any of the signal processing topologies of FIGS. 4a through 4g where compression of amplitude might otherwise have been employed.



FIG. 18 depicts possible additional aspects of any of the signal processing topologies of FIGS. 4a through 4g to implement the altering of an ANR transform in ways such what is as exemplified in FIGS. 16 and 17.





DETAILED DESCRIPTION

What is disclosed and what is claimed herein is intended to be applicable to a wide variety of personal ANR devices, i.e., devices that are structured to be at least partly worn by a user in the vicinity of at least one of the user's ears to provide ANR functionality for at least that one ear. It should be noted that although various specific implementations of personal ANR devices, such as headphones, two-way communications headsets, earphones, earbuds, wireless headsets (also known as “earsets”) and ear protectors are presented with some degree of detail, such presentations of specific implementations are intended to facilitate understanding through the use of examples, and should not be taken as limiting either the scope of disclosure or the scope of claim coverage.


It is intended that what is disclosed and what is claimed herein is applicable to personal ANR devices that provide two-way audio communications, one-way audio communications (i.e., acoustic output of audio electronically provided by another device), or no communications, at all. It is intended that what is disclosed and what is claimed herein is applicable to personal ANR devices that are wirelessly connected to other devices, that are connected to other devices through electrically and/or optically conductive cabling, or that are not connected to any other device, at all. It is intended that what is disclosed and what is claimed herein is applicable to personal ANR devices having physical configurations structured to be worn in the vicinity of either one or both ears of a user, including and not limited to, headphones with either one or two earpieces, over-the-head headphones, behind-the-neck headphones, headsets with communications microphones (e.g., boom microphones), wireless headsets (i.e., earsets), single earphones or pairs of earphones, as well as hats or helmets incorporating one or two earpieces to enable audio communications and/or ear protection. Still other physical configurations of personal ANR devices to which what is disclosed and what is claimed herein are applicable will be apparent to those skilled in the art.


Beyond personal ANR devices, what is disclosed and claimed herein is also meant to be applicable to the provision of ANR in relatively small spaces in which a person may sit or stand, including and not limited to, phone booths, car passenger cabins, etc.



FIG. 1 provides a block diagram of a personal ANR device 1000 structured to be worn by a user to provide active noise reduction (ANR) in the vicinity of at least one of the user's ears. As will also be explained in greater detail, the personal ANR device 1000 may have any of a number of physical configurations, some possible ones of which are depicted in FIGS. 2a through 2f. Some of these depicted physical configurations incorporate a single earpiece 100 to provide ANR to only one of the user's ears, and others incorporate a pair of earpieces 100 to provide ANR to both of the user's ears. However, it should be noted that for the sake of simplicity of discussion, only a single earpiece 100 is depicted and described in relation to FIG. 1. As will also be explained in greater detail, the personal ANR device 1000 incorporates at least one ANR circuit 2000 that may provide either or both of feedback-based ANR and feedforward-based ANR, in addition to possibly further providing pass-through audio. FIGS. 3a and 3b depict a couple of possible internal architectures of the ANR circuit 2000 that are at least partly dynamically configurable. Further, FIGS. 4a through 4e depict some possible signal processing topologies and FIGS. 5a through 5e depict some possible filter block topologies that may the ANR circuit 2000 maybe dynamically configured to adopt. Further, the provision of either or both of feedback-based ANR and feedforward-based ANR is in addition to at least some degree of passive noise reduction (PNR) provided by the structure of each earpiece 100. Still further, FIGS. 6a through 6c depict various forms of triple-buffering that may be employed in dynamically configuring signal processing topologies, filter block topologies and/or still other ANR settings.


Each earpiece 100 incorporates a casing 110 having a cavity 112 at least partly defined by the casing 110 and by at least a portion of an acoustic driver 190 disposed within the casing to acoustically output sounds to a user's ear. This manner of positioning the acoustic driver 190 also partly defines another cavity 119 within the casing 110 that is separated from the cavity 112 by the acoustic driver 190. The casing 110 carries an ear coupling 115 surrounding an opening to the cavity 112 and having a passage 117 that is formed through the ear coupling 115 and that communicates with the opening to the cavity 112. In some implementations, an acoustically transparent screen, grill or other form of perforated panel (not shown) may be positioned in or near the passage 117 in a manner that obscures the cavity and/or the passage 117 from view for aesthetic reasons and/or to protect components within the casing 110 from damage. At times when the earpiece 100 is worn by a user in the vicinity of one of the user's ears, the passage 117 acoustically couples the cavity 112 to the ear canal of that ear, while the ear coupling 115 engages portions of the ear to form at least some degree of acoustic seal therebetween. This acoustic seal enables the casing 110, the ear coupling 115 and portions of the user's head surrounding the ear canal (including portions of the ear) to cooperate to acoustically isolate the cavity 112, the passage 117 and the ear canal from the environment external to the casing 110 and the user's head to at least some degree, thereby providing some degree of PNR.


In some variations, the cavity 119 may be coupled to the environment external to the casing 110 via one or more acoustic ports (only one of which is shown), each tuned by their dimensions to a selected range of audible frequencies to enhance characteristics of the acoustic output of sounds by the acoustic driver 190 in a manner readily recognizable to those skilled in the art. Also, in some variations, one or more tuned ports (not shown) may couple the cavities 112 and 119, and/or may couple the cavity 112 to the environment external to the casing 110. Although not specifically depicted, screens, grills or other forms of perforated or fibrous structures may be positioned within one or more of such ports to prevent passage of debris or other contaminants therethrough and/or to provide a selected degree of acoustic resistance therethrough.


In implementations providing feedforward-based ANR, a feedforward microphone 130 is disposed on the exterior of the casing 110 (or on some other portion of the personal ANR device 1000) in a manner that is acoustically accessible to the environment external to the casing 110. This external positioning of the feedforward microphone 130 enables the feedforward microphone 130 to detect environmental noise sounds, such as those emitted by an acoustic noise source 9900, in the environment external to the casing 110 without the effects of any form of PNR or ANR provided by the personal ANR device 1000. As those familiar with feedforward-based ANR will readily recognize, these sounds detected by the feedforward microphone 130 are used as a reference from which feedforward anti-noise sounds are derived and then acoustically output into the cavity 112 by the acoustic driver 190. The derivation of the feedforward anti-noise sounds takes into account the characteristics of the PNR provided by the personal ANR device 1000, characteristics and position of the acoustic driver 190 relative to the feedforward microphone 130, and/or acoustic characteristics of the cavity 112 and/or the passage 117. The feedforward anti-noise sounds are acoustically output by the acoustic driver 190 with amplitudes and time shifts calculated to acoustically interact with the noise sounds of the acoustic noise source 9900 that are able to enter into the cavity 112, the passage 117 and/or an ear canal in a subtractive manner that at least attenuates them.


In implementations providing feedback-based ANR, a feedback microphone 120 is disposed within the cavity 112. The feedback microphone 120 is positioned in close proximity to the opening of the cavity 112 and/or the passage 117 so as to be positioned close to the entrance of an ear canal when the earpiece 100 is worn by a user. The sounds detected by the feedback microphone 120 are used as a reference from which feedback anti-noise sounds are derived and then acoustically output into the cavity 112 by the acoustic driver 190. The derivation of the feedback anti-noise sounds takes into account the characteristics and position of the acoustic driver 190 relative to the feedback microphone 120, and/or the acoustic characteristics of the cavity 112 and/or the passage 117, as well as considerations that enhance stability in the provision of feedback-based ANR. The feedback anti-noise sounds are acoustically output by the acoustic driver 190 with amplitudes and time shifts calculated to acoustically interact with noise sounds of the acoustic noise source 9900 that are able to enter into the cavity 112, the passage 117 and/or the ear canal (and that have not been attenuated by whatever PNR) in a subtractive manner that at least attenuates them.


The personal ANR device 1000 further incorporates one of the ANR circuit 2000 associated with each earpiece 100 of the personal ANR device 1000 such that there is a one-to-one correspondence of ANR circuits 2000 to earpieces 100. Either a portion of or substantially all of each ANR circuit 2000 may be disposed within the casing 110 of its associated earpiece 100. Alternatively and/or additionally, a portion of or substantially all of each ANR circuit 2000 may be disposed within another portion of the personal ANR device 1000. Depending on whether one or both of feedback-based ANR and feedforward-based ANR are provided in an earpiece 100 associated with the ANR circuit 2000, the ANR circuit 2000 is coupled to one or both of the feedback microphone 120 and the feedforward microphone 130, respectively. The ANR circuit 2000 is further coupled to the acoustic driver 190 to cause the acoustic output of anti-noise sounds.


In some implementations providing pass-through audio, the ANR circuit 2000 is also coupled to an audio source 9400 to receive pass-through audio from the audio source 9400 to be acoustically output by the acoustic driver 190. The pass-through audio, unlike the noise sounds emitted by the acoustic noise source 9900, is audio that a user of the personal ANR device 1000 desires to hear. Indeed, the user may wear the personal ANR device 1000 to be able to hear the pass-through audio without the intrusion of the acoustic noise sounds. The pass-through audio may be a playback of recorded audio, transmitted audio, or any of a variety of other forms of audio that the user desires to hear. In some implementations, the audio source 9400 may be incorporated into the personal ANR device 1000, including and not limited to, an integrated audio playback component or an integrated audio receiver component. In other implementations, the personal ANR device 1000 incorporates a capability to be coupled either wirelessly or via an electrically or optically conductive cable to the audio source 9400 where the audio source 9400 is an entirely separate device from the personal ANR device 1000 (e.g., a CD player, a digital audio file player, a cell phone, etc.).


In other implementations pass-through audio is received from a communications microphone 140 integrated into variants of the personal ANR device 1000 employed in two-way communications in which the communications microphone 140 is positioned to detect speech sounds produced by the user of the personal ANR device 1000. In such implementations, an attenuated or otherwise modified form of the speech sounds produced by the user may be acoustically output to one or both ears of the user as a communications sidetone to enable the user to hear their own voice in a manner substantially similar to how they normally would hear their own voice when not wearing the personal ANR device 1000.


In support of the operation of at least the ANR circuit 2000, the personal ANR device 1000 may further incorporate one or both of a storage device 170, a power source 180 and/or a processing device (not shown). As will be explained in greater detail, the ANR circuit 2000 may access the storage device 170 (perhaps through a digital serial interface) to obtain ANR settings with which to configure feedback-based and/or feedforward-based ANR. As will also be explained in greater detail, the power source 180 may be a power storage device of limited capacity (e.g., a battery).



FIGS. 2
a through 2f depict various possible physical configurations that may be adopted by the personal ANR device 1000 of FIG. 1. As previously discussed, different implementations of the personal ANR device 1000 may have either one or two earpieces 100, and are structured to be worn on or near a user's head in a manner that enables each earpiece 100 to be positioned in the vicinity of a user's ear.



FIG. 2
a depicts an “over-the-head” physical configuration 1500a of the personal ANR device 1000 that incorporates a pair of earpieces 100 that are each in the form of an earcup, and that are connected by a headband 102. However, and although not specifically depicted, an alternate variant of the physical configuration 1500a may incorporate only one of the earpieces 100 connected to the headband 102. Another alternate variant of the physical configuration 1500a may replace the headband 102 with a different band structured to be worn around the back of the head and/or the back of the neck of a user.


In the physical configuration 1500a, each of the earpieces 100 may be either an “on-ear” (also commonly called “supra-aural”) or an “around-ear” (also commonly called “circum-aural”) form of earcup, depending on their size relative to the pinna of a typical human ear. As previously discussed, each earpiece 100 has the casing 110 in which the cavity 112 is formed, and that 110 carries the ear coupling 115. In this physical configuration, the ear coupling 115 is in the form of a flexible cushion (possibly ring-shaped) that surrounds the periphery of the opening into the cavity 112 and that has the passage 117 formed therethrough that communicates with the cavity 112.


Where the earpieces 100 are structured to be worn as over-the-ear earcups, the casing 110 and the ear coupling 115 cooperate to substantially surround the pinna of an ear of a user. Thus, when such a variant of the personal ANR device 1000 is correctly worn, the headband 102 and the casing 110 cooperate to press the ear coupling 115 against portions of a side of the user's head surrounding the pinna of an ear such that the pinna is substantially hidden from view. Where the earpieces 100 are structured to be worn as on-ear earcups, the casing 110 and ear coupling 115 cooperate to overlie peripheral portions of a pinna that surround the entrance of an associated ear canal. Thus, when correctly worn, the headband 102 and the casing 110 cooperate to press the ear coupling 115 against portions of the pinna in a manner that likely leaves portions of the periphery of the pinna visible. The pressing of the flexible material of the ear coupling 115 against either portions of a pinna or portions of a side of a head surrounding a pinna serves both to acoustically couple the ear canal with the cavity 112 through the passage 117, and to form the previously discussed acoustic seal to enable the provision of PNR.



FIG. 2
b depicts another over-the-head physical configuration 1500b that is substantially similar to the physical configuration 1500a, but in which one of the earpieces 100 additionally incorporates a communications microphone 140 connected to the casing 110 via a microphone boom 142. When this particular one of the earpieces 100 is correctly worn, the microphone boom 142 extends from the casing 110 and generally alongside a portion of a cheek of a user to position the communications microphone 140 closer to the mouth of the user to detect speech sounds acoustically output from the user's mouth. However, and although not specifically depicted, an alternative variant of the physical configuration 1500b is possible in which the communications microphone 140 is more directly disposed on the casing 110, and the microphone boom 142 is a hollow tube that opens on one end in the vicinity of the user's mouth and on the other end in the vicinity of the communications microphone 140 to convey sounds from the vicinity of the user's mouth to the vicinity of the communications microphone 140.



FIG. 2
b also depicts the other of the earpieces 100 with broken lines to make clear that still another variant of the physical configuration 1500b of the personal ANR device 1000 is possible that incorporates only the one of the earpieces 100 that incorporates the microphone boom 142 and the communications microphone 140. In such another variant, the headband 102 would still be present and would continue to be worn over the head of the user.



FIG. 2
c depicts an “in-ear” (also commonly called “intra-aural”) physical configuration 1500c of the personal ANR device 1000 that incorporates a pair of earpieces 100 that are each in the form of an in-ear earphone, and that may or may not be connected by a cord and/or by electrically or optically conductive cabling (not shown). However, and although not specifically depicted, an alternate variant of the physical configuration 1500c may incorporate only one of the earpieces 100.


As previously discussed, each of the earpieces 100 has the casing 110 in which the open cavity 112 is formed, and that carries the ear coupling 115. In this physical configuration, the ear coupling 115 is in the form of a substantially hollow tube-like shape defining the passage 117 that communicates with the cavity 112. In some implementations, the ear coupling 115 is formed of a material distinct from the casing 110 (possibly a material that is more flexible than that from which the casing 110 is formed), and in other implementations, the ear coupling 115 is formed integrally with the casing 110.


Portions of the casing 110 and/or of the ear coupling 115 cooperate to engage portions of the concha and/or the ear canal of a user's ear to enable the casing 110 to rest in the vicinity of the entrance of the ear canal in an orientation that acoustically couples the cavity 112 with the ear canal through the ear coupling 115. Thus, when the earpiece 100 is properly positioned, the entrance to the ear canal is substantially “plugged” to create the previously discussed acoustic seal to enable the provision of PNR.



FIG. 2
d depicts another in-ear physical configuration 1500d of the personal ANR device 1000 that is substantially similar to the physical configuration 1500c, but in which one of the earpieces 100 is in the form of a single-ear headset (sometimes also called an “earset”) that additionally incorporates a communications microphone 140 disposed on the casing 110. When this earpiece 100 is correctly worn, the communications microphone 140 is generally oriented towards the vicinity of the mouth of the user in a manner chosen to detect speech sounds produced by the user. However, and although not specifically depicted, an alternative variant of the physical configuration 1500d is possible in which sounds from the vicinity of the user's mouth are conveyed to the communications microphone 140 through a tube (not shown), or in which the communications microphone 140 is disposed on a boom (not shown) connected to the casing 110 and positioning the communications microphone 140 in the vicinity of the user's mouth.


Although not specifically depicted in FIG. 2d, the depicted earpiece 100 of the physical configuration 1500d having the communications microphone 140 may or may not be accompanied by another earpiece having the form of an in-ear earphone (such as one of the earpieces 100 depicted in FIG. 2c) that may or may not be connected to the earpiece 100 depicted in FIG. 2d via a cord or conductive cabling (also not shown).



FIG. 2
e depicts a two-way communications handset physical configuration 1500e of the personal ANR device 1000 that incorporates a single earpiece 100 that is integrally formed with the rest of the handset such that the casing 110 is the casing of the handset, and that may or may not be connected by conductive cabling (not shown) to a cradle base with which it may be paired. In a manner not unlike one of the earpieces 100 of an on-the-ear variant of either of the physical configurations 1500a and 1500b, the earpiece 100 of the physical configuration 1500e carries a form of the ear coupling 115 that is configured to be pressed against portions of the pinna of an ear to enable the passage 117 to acoustically couple the cavity 112 to an ear canal. In various possible implementations, ear coupling 115 may be formed of a material distinct from the casing 110, or may be formed integrally with the casing 110.



FIG. 2
f depicts another two-way communications handset physical configuration 1500f of the personal ANR device 1000 that is substantially similar to the physical configuration 1500e, but in which the casing 110 is shaped somewhat more appropriately for portable wireless communications use, possibly incorporating user interface controls and/or display(s) to enable the dialing of phone numbers and/or the selection of radio frequency channels without the use of a cradle base.



FIGS. 3
a and 3b depict possible internal architectures, either of which may be employed by the ANR circuit 2000 in implementations of the personal ANR device 1000 in which the ANR circuit 2000 is at least partially made up of dynamically configurable digital circuitry. In other words, the internal architectures of FIGS. 3a and 3b are dynamically configurable to adopt any of a wide variety of signal processing topologies and filter block topologies during operation of the ANR circuit 2000. FIGS. 4a-g depict various examples of signal processing topologies that may be adopted by the ANR circuit 2000 in this manner, and FIGS. 5a-e depict various examples of filter block topologies that may also be adopted by the ANR circuit 2000 for use within an adopted signal processing topology in this manner. However, and as those skilled in the art will readily recognize, other implementations of the personal ANR device 1000 are possible in which the ANR circuit 2000 is largely or entirely implemented with analog circuitry and/or digital circuitry lacking such dynamic configurability.


In implementations in which the circuitry of the ANR circuit 2000 is at least partially digital, analog signals representing sounds that are received or output by the ANR circuit 2000 may require conversion into or creation from digital data that also represents those sounds. More specifically, in both of the internal architectures 2200a and 2200b, analog signals received from the feedback microphone 120 and the feedforward microphone 130, as well as whatever analog signal representing pass-through audio may be received from either the audio source 9400 or the communications microphone 140, are digitized by analog-to-digital converters (ADCs) of the ANR circuit 2000. Also, whatever analog signal is provided to the acoustic driver 190 to cause the acoustic driver 190 to acoustically output anti-noise sounds and/or pass-through audio is created from digital data by a digital-to-analog converter (DAC) of the ANR circuit 2000. Further, either analog signals or digital data representing sounds may be manipulated to alter the amplitudes of those represented sounds by either analog or digital forms, respectively, of variable gain amplifiers (VGAs).



FIG. 3
a depicts a possible internal architecture 2200a of the ANR circuit 2000 in which digital circuits that manipulate digital data representing sounds are selectively interconnected through one or more arrays of switching devices that enable those interconnections to be dynamically configured during operation of the ANR circuit 2000. Such a use of switching devices enables pathways for movement of digital data among various digital circuits to be defined through programming. More specifically, blocks of digital filters of varying quantities and/or types are able to be defined through which digital data associated with feedback-based ANR, feedforward-based ANR and pass-through audio are routed to perform these functions. In employing the internal architecture 2200a, the ANR circuit 2000 incorporates ADCs 210, 310 and 410; a processing device 510; a storage 520; an interface (I/F) 530; a switch array 540; a filter bank 550; and a DAC 910. Various possible variations may further incorporate one or more of analog VGAs 125, 135 and 145; a VGA bank 560; a clock bank 570; a compression controller 950; a further ADC 955; and/or an audio amplifier 960.


The ADC 210 receives an analog signal from the feedback microphone 120, the ADC 310 receives an analog signal from the feedforward microphone 130, and the ADC 410 receives an analog signal from either the audio source 9400 or the communications microphone 140. As will be explained in greater detail, one or more of the ADCs 210, 310 and 410 may receive their associated analog signals through one or more of the analog VGAs 125, 135 and 145, respectively. The digital outputs of each of the ADCs 210, 310 and 410 are coupled to the switch array 540. Each of the ADCs 210, 310 and 410 may be designed to employ a variant of the widely known sigma-delta analog-to-digital conversion algorithm for reasons of power conservation and inherent ability to reduce digital data representing audible noise sounds that might otherwise be introduced as a result of the conversion process. However, as those skilled in the art will readily recognize, any of a variety of other analog-to-digital conversion algorithms may be employed. Further, in some implementations, at least the ADC 410 may be bypassed and/or entirely dispensed with where at least the pass-through audio is provided to the ANR circuit 2000 as digital data, rather than as an analog signal.


The filter bank 550 incorporates multiple digital filters, each of which has its inputs and outputs coupled to the switch array 540. In some implementations, all of the digital filters within the filter bank 550 are of the same type, while in other implementations, the filter bank 550 incorporates a mixture of different types of digital filters. As depicted, the filter bank 550 incorporates a mixture of multiple downsampling filters 552, multiple biquadratic (biquad) filters 554, multiple interpolating filters 556, and multiple finite impulse response (FIR) filters 558, although other varieties of filters may be incorporated, as those skilled in the art will readily recognize. Further, among each of the different types of digital filters may be digital filters optimized to support different data transfer rates. By way of example, differing ones of the biquad filters 554 may employ coefficient values of differing bit-widths, or differing ones of the FIR filters 558 may have differing quantities of taps. The VGA bank 560 (if present) incorporates multiple digital VGAs, each of which has its inputs and outputs coupled to the switch array 540. Also, the DAC 910 has its digital input coupled to the switch array 540. The clock bank 570 (if present) provides multiple clock signal outputs coupled to the switch array 540 that simultaneously provide multiple clock signals for clocking data between components at selected data transfer rates and/or other purposes. In some implementations, at least a subset of the multiple clock signals are synchronized multiples of one another to simultaneously support different data transfer rates in different pathways in which the movement of data at those different data transfer rates in those different pathways is synchronized.


The switching devices of the switch array 540 are operable to selectively couple different ones of the digital outputs of the ADCs 210, 310 and 410; the inputs and outputs of the digital filters of the filter bank 550; the inputs and outputs of the digital VGAs of the VGA bank 560; and the digital input of the DAC 910 to form a set of interconnections therebetween that define a topology of pathways for the movement of digital data representing various sounds. The switching devices of the switch array 540 may also be operable to selectively couple different ones of the clock signal outputs of the clock bank 570 to different ones of the digital filters of the filter bank 550 and/or different ones of the digital VGAs of the VGA bank 560. It is largely in this way that the digital circuitry of the internal architecture 2200a is made dynamically configurable. In this way, varying quantities and types of digital filters and/or digital VGAs may be positioned at various points along different pathways defined for flows of digital data associated with feedback-based ANR, feedforward-based ANR and pass-through audio to modify sounds represented by the digital data and/or to derive new digital data representing new sounds in each of those pathways. Also, in this way, different data transfer rates may be selected by which digital data is clocked at different rates in each of the pathways.


In support of feedback-based ANR, feedforward-based ANR and/or pass-through audio, the coupling of the inputs and outputs of the digital filters within the filter bank 550 to the switch array 540 enables inputs and outputs of multiple digital filters to be coupled through the switch array 540 to create blocks of filters. As those skilled in the art will readily recognize, by combining multiple lower-order digital filters into a block of filters, multiple lower-order digital filters may be caused to cooperate to implement higher order functions without the use of a higher-order filter. Further, in implementations having a variety of types of digital filters, blocks of filters may be created that employ a mix of filters to perform a still greater variety of functions. By way of example, with the depicted variety of filters within the filter bank 550, a filter block (i.e., a block of filters) may be created having at least one of the downsampling filters 552, multiple ones of the biquad filters 554, at least one of the interpolating filters 556, and at least one of the FIR filters 558.


In some implementations, at least some of the switching devices of the switch array 540 may be implemented with binary logic devices enabling the switch array 540, itself, to be used to implement basic binary math operations to create summing nodes where pathways along which different pieces of digital data flow are brought together in a manner in which those different pieces of digital data are arithmetically summed, averaged, and/or otherwise combined. In such implementations, the switch array 540 may be based on a variant of dynamically programmable array of logic devices. Alternatively and/or additionally, a bank of binary logic devices or other form of arithmetic logic circuitry (not shown) may also be incorporated into the ANR circuit 2000 with the inputs and outputs of those binary logic devices and/or other form of arithmetic logic circuitry also being coupled to the switch array 540.


In the operation of switching devices of the switch array 540 to adopt a topology by creating pathways for the flow of data representing sounds, priority may be given to creating a pathway for the flow of digital data associated with feedback-based ANR that has as low a latency as possible through the switching devices. Also, priority may be given in selecting digital filters and VGAs that have as low a latency as possible from among those available in the filter bank 550 and the VGA bank 560, respectively. Further, coefficients and/or other settings provided to digital filters of the filter bank 550 that are employed in the pathway for digital data associated with feedback-based ANR may be adjusted in response to whatever latencies are incurred from the switching devices of the switch array 540 employed in defining the pathway. Such measures may be taken in recognition of the higher sensitivity of feedback-based ANR to the latencies of components employed in performing the function of deriving and/or acoustically outputting feedback anti-noise sounds. Although such latencies are also of concern in feedforward-based ANR, feedforward-based ANR is generally less sensitive to such latencies than feedback-based ANR. As a result, a degree of priority less than that given to feedback-based ANR, but greater than that given to pass-through audio, may be given to selecting digital filters and VGAs, and to creating a pathway for the flow of digital data associated with feedforward-based ANR.


The processing device 510 is coupled to the switch array 540, as well as to both the storage 520 and the interface 530. The processing device 510 may be any of a variety of types of processing device, including and not limited to, a general purpose central processing unit (CPU), a digital signal processor (DSP), a reduced instruction set computer (RISC) processor, a microcontroller, or a sequencer. The storage 520 may be based on any of a variety of data storage technologies, including and not limited to, dynamic random access memory (DRAM), static random access memory (SRAM), ferromagnetic disc storage, optical disc storage, or any of a variety of nonvolatile solid state storage technologies. Indeed, the storage 520 may incorporate both volatile and nonvolatile portions. Further, it will be recognized by those skilled in the art that although the storage 520 is depicted and discussed as if it were a single component, the storage 520 may be made up of multiple components, possibly including a combination of volatile and nonvolatile components. The interface 530 may support the coupling of the ANR circuit 2000 to one or more digital communications buses, including digital serial buses by which the storage device 170 (not to be confused with the storage 520) and/or other devices external to the ANR circuit 2000 (e.g., other processing devices, or other ANR circuits) may be coupled. Further, the interface 530 may provide one or more general purpose input/output (GPIO) electrical connections and/or analog electrical connections to support the coupling of manually-operable controls, indicator lights or other devices, such as a portion of the power source 180 providing an indication of available power.


In some implementations, the processing device 510 accesses the storage 520 to read a sequence of instructions of a loading routine 522, that when executed by the processing device 510, causes the processing device 510 to operate the interface 530 to access the storage device 170 to retrieve one or both of the ANR routine 525 and the ANR settings 527, and to store them in the storage 520. In other implementations, one or both of the ANR routine 525 and the ANR settings 527 are stored in a nonvolatile portion of the storage 520 such that they need not be retrieved from the storage device 170, even if power to the ANR circuit 2000 is lost.


Regardless of whether one or both of the ANR routine 525 and the ANR settings 527 are retrieved from the storage device 170, or not, the processing device 510 accesses the storage 520 to read a sequence of instructions of the ANR routine 525. The processing device 510 then executes that sequence of instructions, causing the processing device 510 to configure the switching devices of the switch array 540 to adopt a topology defining pathways for flows of digital data representing sounds and/or to provide differing clock signals to one or more digital filters and/or VGAs, as previously detailed. In some implementations, the processing device 510 is caused to configure the switching devices in a manner specified by a portion of the ANR settings 527, which the processing device 510 is also caused to read from the storage 520. Further, the processing device 510 is caused to set filter coefficients of various digital filters of the filter bank 550, gain settings of various VGAs of the VGA bank 560, and/or clock frequencies of the clock signal outputs of the clock bank 570 in a manner specified by a portion of the ANR settings 527.


In some implementations, the ANR settings 527 specify multiple sets of filter coefficients, gain settings, clock frequencies and/or configurations of the switching devices of the switch array 540, of which different sets are used in response to different situations. In other implementations, execution of sequences of instructions of the ANR routine 525 causes the processing device 510 to derive different sets of filter coefficients, gain settings, clock frequencies and/or switching device configurations in response to different situations. By way of example, the processing device 510 may be caused to operate the interface 530 to monitor a signal from the power source 180 that is indicative of the power available from the power source 180, and to dynamically switch between different sets of filter coefficients, gain settings, clock frequencies and/or switching device configurations in response to changes in the amount of available power.


By way of another example, the processing device 510 may be caused to monitor characteristics of sounds represented by digital data involved in feedback-based ANR, feedforward-based ANR and/or pass-through audio to determine whether or not it is desirable to alter the degree feedback-based and/or feedforward-based ANR provided. As will be familiar to those skilled in the art, while providing a high degree of ANR can be very desirable where there is considerable environmental noise to be attenuated, there can be other situations where the provision of a high degree of ANR can actually create a noisier or otherwise more unpleasant acoustic environment for a user of a personal ANR device than would the provision of less ANR. Therefore, the processing device 510 may be caused to alter the provision of ANR to adjust the degree of attenuation and/or the range of frequencies of environmental noise attenuated by the ANR provided in response to observed characteristics of one or more sounds. Further, as will also be familiar to those skilled in the art, where a reduction in the degree of attenuation and/or the range of frequencies is desired, it may be possible to simplify the quantity and/or type of filters used in implementing feedback-based and/or feedforward-based ANR, and the processing device 510 may be caused to dynamically switch between different sets of filter coefficients, gain settings, clock frequencies and/or switching device configurations to perform such simplifying, with the added benefit of a reduction in power consumption.


The DAC 910 is provided with digital data from the switch array 540 representing sounds to be acoustically output to an ear of a user of the personal ANR device 1000, and converts it to an analog signal representing those sounds. The audio amplifier 960 receives this analog signal from the DAC 910, and amplifies it sufficiently to drive the acoustic driver 190 to effect the acoustic output of those sounds.


The compression controller 950 (if present) monitors the sounds to be acoustically output for an indication of their amplitude being too high, indications of impending instances of clipping, actual instances of clipping, and/or other impending or actual instances of other audio artifacts. The compression controller 150 may either directly monitor digital data provided to the DAC 910 or the analog signal output by the audio amplifier 960 (through the ADC 955, if present). In response to such an indication, the compression controller 950 may alter gain settings of one or more of the analog VGAs 125, 135 and 145 (if present); and/or one or more of the VGAs of the VGA bank 560 placed in a pathway associated with one or more of the feedback-based ANR, feedforward-based ANR and pass-through audio functions to adjust amplitude, as will be explained in greater detail. Further, in some implementations, the compression controller 950 may also make such an adjustment in response to receiving an external control signal. Such an external signal may be provided by another component coupled to the ANR circuit 2000 to provide such an external control signal in response to detecting a condition such as an exceptionally loud environmental noise sound that may cause one or both of the feedback-based and feedforward-based ANR functions to react unpredictably.



FIG. 3
b depicts another possible internal architecture 2200b of the ANR circuit 2000 in which a processing device accesses and executes stored machine-readable sequences of instructions that cause the processing device to manipulate digital data representing sounds in a manner that can be dynamically configured during operation of the ANR circuit 2000. Such a use of a processing device enables pathways for movement of digital data of a topology to be defined through programming. More specifically, digital filters of varying quantities and/or types are able to be defined and instantiated in which each type of digital filter is based on a sequence of instructions. In employing the internal architecture 2200b, the ANR circuit 2000 incorporates the ADCs 210, 310 and 410; the processing device 510; the storage 520; the interface 530; a direct memory access (DMA) device 540; and the DAC 910. Various possible variations may further incorporate one or more of the analog VGAs 125, 135 and 145; the ADC 955; and/or the audio amplifier 960. The processing device 510 is coupled directly or indirectly via one or more buses to the storage 520; the interface 530; the DMA device 540; the ADCs 210, 310 and 410; and the DAC 910 to at least enable the processing device 510 to control their operation. The processing device 510 may also be similarly coupled to one or more of the analog VGAs 125, 135 and 145 (if present); and to the ADC 955 (if present).


As in the internal architecture 2200a, the processing device 510 may be any of a variety of types of processing device, and once again, the storage 520 may be based on any of a variety of data storage technologies and may be made up of multiple components. Further, the interface 530 may support the coupling of the ANR circuit 2000 to one or more digital communications buses, and may provide one or more general purpose input/output (GPIO) electrical connections and/or analog electrical connections. The DMA device 540 may be based on a secondary processing device, discrete digital logic, a bus mastering sequencer, or any of a variety of other technologies.


Stored within the storage 520 are one or more of a loading routine 522, an ANR routine 525, ANR settings 527, ANR data 529, a downsampling filter routine 553, a biquad filter routine 555, an interpolating filter routine 557, a FIR filter routine 559, and a VGA routine 561. In some implementations, the processing device 510 accesses the storage 520 to read a sequence of instructions of the loading routine 522, that when executed by the processing device 510, causes the processing device 510 to operate the interface 530 to access the storage device 170 to retrieve one or more of the ANR routine 525, the ANR settings 527, the downsampling filter routine 553, the biquad filter routine 555, the interpolating filter routine 557, the FIR routine 559 and the VGA routine 561, and to store them in the storage 520. In other implementations, one or more of these are stored in a nonvolatile portion of the storage 520 such that they need not be retrieved from the storage device 170.


As was the case in the internal architecture 2200a, the ADC 210 receives an analog signal from the feedback microphone 120, the ADC 310 receives an analog signal from the feedforward microphone 130, and the ADC 410 receives an analog signal from either the audio source 9400 or the communications microphone 140 (unless the use of one or more of the ADCs 210, 310 and 410 is obviated through the direct receipt of digital data). Again, one or more of the ADCs 210, 310 and 410 may receive their associated analog signals through one or more of the analog VGAs 125, 135 and 145, respectively. As was also the case in the internal architecture 2200a, the DAC 910 converts digital data representing sounds to be acoustically output to an ear of a user of the personal ANR device 1000 into an analog signal, and the audio amplifier 960 amplifies this signal sufficiently to drive the acoustic driver 190 to effect the acoustic output of those sounds.


However, unlike the internal architecture 2200a where digital data representing sounds were routed via an array of switching devices, such digital data is stored in and retrieved from the storage 520. In some implementations, the processing device 510 repeatedly accesses the ADCs 210, 310 and 410 to retrieve digital data associated with the analog signals they receive for storage in the storage 520, and repeatedly retrieves the digital data associated with the analog signal output by the DAC 910 from the storage 520 and provides that digital data to the DAC 910 to enable the creation of that analog signal. In other implementations, the DMA device 540 (if present) transfers digital data among the ADCs 210, 310 and 410; the storage 520 and the DAC 910 independently of the processing device 510. In still other implementations, the ADCs 210, 310 and 410 and/or the DAC 910 incorporate “bus mastering” capabilities enabling each to write digital data to and/or read digital data from the storage 520 independently of the processing device 510. The ANR data 529 is made up of the digital data retrieved from the ADCs 210, 310 and 410, and the digital data provided to the DAC 910 by the processing device 510, the DMA device 540 and/or bus mastering functionality.


The downsampling filter routine 553, the biquad filter routine 555, the interpolating filter routine 557 and the FIR filter routine 559 are each made up of a sequence of instructions that cause the processing device 510 to perform a combination of calculations that define a downsampling filter, a biquad filter, an interpolating filter and a FIR filter, respectively. Further, among each of the different types of digital filters may be variants of those digital filters that are optimized for different data transfer rates, including and not limited to, differing bit widths of coefficients or differing quantities of taps. Similarly, the VGA routine 561 is made up of a sequence of instructions that cause the processing device 510 to perform a combination of calculations that define a VGA. Although not specifically depicted, a summing node routine may also be stored in the storage 520 made up of a sequence of instructions that similarly defines a summing node.


The ANR routine 525 is made up of a sequence of instructions that cause the processing device 510 to create a signal processing topology having pathways incorporating varying quantities of the digital filters and VGAs defined by the downsampling filter routine 553, the biquad filter routine 555, the interpolating filter routine 557, the FIR filter routine 559 and the VGA routine 561 to support feedback-based ANR, feedforward-based ANR and/or pass-through audio. The ANR routine 525 also causes the processing device 510 to perform the calculations defining each of the various filters and VGAs incorporated into that topology. Further, the ANR routine 525 either causes the processing device 510 to perform the moving of data among ADCs 210, 310 and 410, the storage 520 and the DAC 910, or causes the processing device 510 to coordinate the performance of such moving of data either by the DMA device 540 (if present) or by bus mastering operations performed by the ADCs 210, 310 and 410, and/or the DAC 910.


The ANR settings 527 is made up of data defining topology characteristics (including selections of digital filters), filter coefficients, gain settings, clock frequencies, data transfer rates and/or data sizes. In some implementations, the topology characteristics may also define the characteristics of any summing nodes to be incorporated into the topology. The processing device 510 is caused by the ANR routine 525 to employ such data taken from the ANR settings 527 in creating a signal processing topology (including selecting digital filters), setting the filter coefficients for each digital filter incorporated into the topology, and setting the gains for each VGA incorporated into the topology. The processing device 510 may be further caused by the ANR routine 525 to employ such data from the ANR settings 527 in setting clock frequencies and/or data transfer rates for the ADCs 210, 310 and 410; for the digital filters incorporated into the topology; for the VGAs incorporated into the topology; and for the DAC 910.


In some implementations, the ANR settings 527 specify multiple sets of topology characteristics, filter coefficients, gain settings, clock frequencies and/or data transfer rates, of which different sets are used in response to different situations. In other implementations, execution of sequences of instructions of the ANR routine 525 causes the processing device 510 to derive different sets of filter coefficients, gain settings, clock frequencies and/or data transfer rates for a given signal processing topology in different situations. By way of example, the processing device 510 may be caused to operate the interface 530 to monitor a signal from the power source 180 that is indicative of the power available from the power source 180, and to employ different sets of filter coefficients, gain settings, clock frequencies and/or data transfer rates in response to changes in the amount of available power.


By way of another example, the processing device 510 may be caused to alter the provision of ANR to adjust the degree of ANR required in response to observed characteristics of one or more sounds. Where a reduction in the degree of attenuation and/or the range of frequencies of noise sounds attenuated is possible and/or desired, it may be possible to simplify the quantity and/or type of filters used in implementing feedback-based and/or feedforward-based ANR, and the processing device 510 may be caused to dynamically switch between different sets of filter coefficients, gain settings, clock frequencies and/or data transfer rates to perform such simplifying, with the added benefit of a reduction in power consumption.


Therefore, in executing sequences of instructions of the ANR routine 525, the processing device 510 is caused to retrieve data from the ANR settings 527 in preparation for adopting a signal processing topology defining the pathways to be employed by the processing device 510 in providing feedback-based ANR, feedforward-based ANR and pass-through audio. The processing device 510 is caused to instantiate multiple instances of digital filters, VGAs and/or summing nodes, employing filter coefficients, gain settings and/or other data from the ANR settings 527. The processing device 510 is then further caused to perform the calculations defining each of those instances of digital filters, VGAs and summing nodes; to move digital data among those instances of digital filters, VGAs and summing nodes; and to at least coordinate the moving of digital data among the ADCs 210, 310 and 410, the storage 520 and the DAC 910 in a manner that conforms to the data retrieved from the ANR settings 527. At a subsequent time, the ANR routine 525 may cause the processing device 510 to change the signal processing topology, a digital filter, filter coefficients, gain settings, clock frequencies and/or data transfer rates during operation of the personal ANR device 1000. It is largely in this way that the digital circuitry of the internal architecture 2200b is made dynamically configurable. Also, in this way, varying quantities and types of digital filters and/or digital VGAs may be positioned at various points along a pathway of a topology defined for a flow of digital data to modify sounds represented by that digital data and/or to derive new digital data representing new sounds, as will be explained in greater detail.


In some implementations, the ANR routine 525 may cause the processing device 510 to give priority to operating the ADC 210 and performing the calculations of the digital filters, VGAs and/or summing nodes positioned along the pathway defined for the flow of digital data associated with feedback-based ANR. Such a measure may be taken in recognition of the higher sensitivity of feedback-based ANR to the latency between the detection of feedback reference sounds and the acoustic output of feedback anti-noise sounds.


The processing device 510 may be further caused by the ANR routine 525 to monitor the sounds to be acoustically output for indications of the amplitude being too high, clipping, indications of clipping about to occur, and/or other audio artifacts actually occurring or indications of being about to occur. The processing device 510 may be caused to either directly monitor digital data provided to the DAC 910 or the analog signal output by the audio amplifier 960 (through the ADC 955) for such indications. In response to such an indication, the processing device 510 may be caused to operate one or more of the analog VGAs 125, 135 and 145 to adjust at least one amplitude of an analog signal, and/or may be caused to operate one or more of the VGAs based on the VGA routine 561 and positioned within a pathway of a topology to adjust the amplitude of at least one sound represented by digital data, as will be explained in greater detail.



FIGS. 4
a through 4g depict some possible signal processing topologies that may be adopted by the ANR circuit 2000 of the personal ANR device 1000 of FIG. 1. As previously discussed, some implementations of the personal ANR device 1000 may employ a variant of the ANR circuit 2000 that is at least partially programmable such that the ANR circuit 2000 is able to be dynamically configured to adopt different signal processing topologies during operation of the ANR circuit 2000. Alternatively, other implementations of the personal ANR device 1000 may incorporate a variant of the ANR circuit 2000 that is substantially inalterably structured to adopt one unchanging signal processing topology.


As previously discussed, separate ones of the ANR circuit 2000 are associated with each earpiece 100, and therefore, implementations of the personal ANR device 1000 having a pair of the earpieces 100 also incorporate a pair of the ANR circuits 2000. However, as those skilled in the art will readily recognize, other electronic components incorporated into the personal ANR device 1000 in support of a pair of the ANR circuits 2000, such as the power source 180, may not be duplicated. For the sake of simplicity of discussion and understanding, signal processing topologies for only a single ANR circuit 2000 are presented and discussed in relation to FIGS. 4a-g.


As also previously discussed, different implementations of the personal ANR device 1000 may provide only one of either feedback-based ANR or feedforward-based ANR, or may provide both. Further, different implementations may or may not additionally provide pass-through audio. Therefore, although signal processing topologies implementing all three of feedback-based ANR, feedforward-based ANR and pass-through audio are depicted in FIGS. 4a-g, it is to be understood that variants of each of these signal processing topologies are possible in which only one or the other of these two forms of ANR is provided, and/or in which pass-through audio is not provided. In implementations in which the ANR circuit 2000 is at least partially programmable, which of these two forms of ANR are provided and/or whether or not both forms of ANR are provided may be dynamically selectable during operation of the ANR circuit 2000.



FIG. 4
a depicts a possible signal processing topology 2500a for which the ANR circuit 2000 may be structured and/or programmed. Where the ANR circuit 2000 adopts the signal processing topology 2500a, the ANR circuit 2000 incorporates at least the DAC 910, the compression controller 950, and the audio amplifier 960. Depending, in part on whether one or both of feedback-based and feedforward-based ANR are supported, the ANR circuit 2000 further incorporates one or more of the ADCs 210, 310, 410 and/or 955; filter blocks 250, 350 and/or 450; and/or summing nodes 270 and/or 290.


Where the provision of feedback-based ANR is supported, the ADC 210 receives an analog signal from the feedback microphone 120 representing feedback reference sounds detected by the feedback microphone 120. The ADC 210 digitizes the analog signal from the feedback microphone 120, and provides feedback reference data corresponding to the analog signal output by the feedback microphone 120 to the filter block 250. One or more digital filters within the filter block 250 are employed to modify the data from the ADC 210 to derive feedback anti-noise data representing feedback anti-noise sounds. The filter block 250 provides the feedback anti-noise data to the VGA 280, possibly through the summing node 270 where feedforward-based ANR is also supported.


Where the provision of feedforward-based ANR is also supported, the ADC 310 receives an analog signal from the feedforward microphone 130, digitizes it, and provides feedforward reference data corresponding to the analog signal output by the feedforward microphone 130 to the filter block 350. One or more digital filters within the filter block 350 are employed to modify the feedforward reference data received from the ADC 310 to derive feedforward anti-noise data representing feedforward anti-noise sounds. The filter block 350 provides the feedforward anti-noise data to the VGA 280, possibly through the summing node 270 where feedback-based ANR is also supported.


At the VGA 280, the amplitude of one or both of the feedback and feedforward anti-noise sounds represented by the data received by the VGA 280 (either through the summing node 270, or not) may be altered under the control of the compression controller 950. The VGA 280 outputs its data (with or without amplitude alteration) to the DAC 910, possibly through the summing nodes 290 where talk-through audio is also supported.


In some implementations where pass-through audio is supported, the ADC 410 digitizes an analog signal representing pass-through audio received from the audio source 9400, the communications microphone 140 or another source and provides the digitized result to the filter block 450. In other implementations where pass-through audio is supported, the audio source 9400, the communications microphone 140 or another source provides digital data representing pass-through audio to the filter block 450 without need of analog-to-digital conversion. One or more digital filters within the filter block 450 are employed to modify the digital data representing the pass-through audio to derive a modified variant of the pass-through audio data in which the pass-through audio may be re-equalized and/or enhanced in other ways. The filter block 450 provides the pass-through audio data to the summing node 290 where the pass-through audio data is combined with the data being provided by the VGA 280 to the DAC 910.


The analog signal output by the DAC 910 is provided to the audio amplifier 960 to be amplified sufficiently to drive the acoustic driver 190 to acoustically output one or more of feedback anti-noise sounds, feedforward anti-noise sounds and pass-through audio. The compression controller 950 controls the gain of the VGA 280 to enable the amplitude of sound represented by data output by one or both of the filter blocks 250 and 350 to be reduced in response to indications of impending instances of clipping, actual occurrences of clipping and/or other undesirable audio artifacts being detected by the compression controller 950. The compression controller 950 may either monitor the data being provided to the DAC 910 by the summing node 290, or may monitor the analog signal output of the audio amplifier 960 through the ADC 955.


As further depicted in FIG. 4a, the signal processing topology 2500a defines multiple pathways along which digital data associated with feedback-based ANR, feedforward-based ANR and pass-through audio flow. Where feedback-based ANR is supported, the flow of feedback reference data and feedback anti-noise data among at least the ADC 210, the filter block 250, the VGA 280 and the DAC 910 defines a feedback-based ANR pathway 200. Similarly, where feedforward-based ANR is supported, the flow of feedforward reference data and feedforward anti-noise data among at least the ADC 310, the filter block 350, the VGA 280 and the DAC 910 defines a feedforward-based ANR pathway 300. Further, where pass-through audio is supported, the flow of pass-through audio data and modified pass-through audio data among at least the ADC 410, the filter block 450, the summing node 290 and the DAC 910 defines a pass-through audio pathway 400. Where both feedback-based and feedforward-based ANR are supported, the pathways 200 and 300 both further incorporate the summing node 270. Further, where pass-through audio is also supported, the pathways 200 and/or 300 incorporate the summing node 290.


In some implementations, digital data representing sounds may be clocked through all of the pathways 200, 300 and 400 that are present at the same data transfer rate. Thus, where the pathways 200 and 300 are combined at the summing node 270, and/or where the pathway 400 is combined with one or both of the pathways 200 and 300 at the summing node 400, all digital data is clocked through at a common data transfer rate, and that common data transfer rate may be set by a common synchronous data transfer clock. However, as is known to those skilled in the art and as previously discussed, the feedforward-based ANR and pass-through audio functions are less sensitive to latencies than the feedback-based ANR function. Further, the feedforward-based ANR and pass-through audio functions are more easily implemented with sufficiently high quality of sound with lower data sampling rates than the feedback-based ANR function. Therefore, in other implementations, portions of the pathways 300 and/or 400 may be operated at slower data transfer rates than the pathway 200. Preferably, the data transfer rates of each of the pathways 200, 300 and 400 are selected such that the pathway 200 operates with a data transfer rate that is an integer multiple of the data transfer rates selected for the portions of the pathways 300 and/or 400 that are operated at slower data transfer rates.


By way of example in an implementation in which all three of the pathways 200, 300 and 400 are present, the pathway 200 is operated at a data transfer rate selected to provide sufficiently low latency to enable sufficiently high quality of feedback-based ANR that the provision of ANR is not unduly compromised (e.g., by having anti-noise sounds out-of-phase with the noise sounds they are meant to attenuate, or instances of negative noise reduction such that more noise is actually being generated than attenuated, etc.), and/or sufficiently high quality of sound in the provision of at least the feedback anti-noise sounds. Meanwhile, the portion of the pathway 300 from the ADC 310 to the summing node 270 and the portion of the pathway 400 from the ADC 410 to the summing node 290 are both operated at lower data transfer rates (either the same lower data transfer rates or different ones) that still also enable sufficiently high quality of feedforward-based ANR in the pathway 300, and sufficiently high quality of sound in the provision of the feedforward anti-noise through the pathway 300 and/or pass-through audio through the pathway 400.


In recognition of the likelihood that the pass-through audio function may be even more tolerant of a greater latency and a lower sampling rate than the feedforward-based ANR function, the data transfer rate employed in that portion of the pathway 400 may be still lower than the data transfer rate of that portion of the pathway 300. To support such differences in transfer rates in one variation, one or both of the summing nodes 270 and 290 may incorporate sample-and-hold, buffering or other appropriate functionality to enable the combining of digital data received by the summing nodes 270 and 290 at different data transfer rates. This may entail the provision of two different data transfer clocks to each of the summing nodes 270 and 290. Alternatively, to support such differences in transfer rates in another variation, one or both of the filter blocks 350 and 450 may incorporate an upsampling capability (perhaps through the inclusion of an interpolating filter or other variety of filter incorporating an upsampling capability) to increase the data transfer rate at which the filter blocks 350 and 450 provide digital data to the summing nodes 270 and 290, respectively, to match the data transfer rate at which the filter block 250 provides digital data to the summing node 270, and subsequently, to the summing node 290.


It may be that in some implementations, multiple power modes may be supported in which the data transfer rates of the pathways 300 and 400 are dynamically altered in response to the availability of power from the power source 180 and/or in response to changing ANR requirements. More specifically, the data transfer rates of one or both of the pathway 300 and 400 up to the points where they are combined with the pathway 200 may be reduced in response to an indication of diminishing power being available from the power supply 180 and/or in response to the processing device 510 detecting characteristics in sounds represented by digital data indicating that the degree of attenuation and/or range of frequencies of noise sounds attenuated by the ANR provided can be reduced. In making determinations of whether or not such reductions in data transfer rates are possible, the processing device 510 may be caused to evaluate the effects of such reductions in data transfer rates on quality of sound through one or more of the pathways 200, 300 and 400, and/or the quality of feedback-based and/or feed-forward based ANR provided.



FIG. 4
b depicts a possible signal processing topology 2500b for which the ANR circuit 2000 may be structured and/or programmed. Where the ANR circuit 2000 adopts the signal processing topology 2500b, the ANR circuit 2000 incorporates at least the DAC 910, the audio amplifier 960, the ADC 210, a pair of summing nodes 230 and 270, and a pair of filter blocks 250 and 450. The ANR circuit 2000 may further incorporate one or more of the ADC 410, the ADC 310, a filter block 350 and a summing node 370.


The ADC 210 receives and digitizes an analog signal from the feedback microphone 120 representing feedback reference sounds detected by the feedback microphone 120, and provides corresponding feedback reference data to the summing node 230. In some implementations, the ADC 410 digitizes an analog signal representing pass-through audio received from the audio source 9400, the communications microphone 140 or another source and provides the digitized result to the filter block 450. In other implementations, the audio source 9400, the communications microphone 140 or another source provides digital data representing pass-through audio to the filter block 450 without need of analog-to-digital conversion. One or more digital filters within the filter block 450 are employed to modify the digital data representing the pass-through audio to derive a modified variant of the pass-through audio data in which the pass-through audio may be re-equalized and/or enhanced in other ways. One or more digital filters within the filter block 450 also function as a crossover that divides the modified pass-through audio data into higher and lower frequency sounds, with data representing the higher frequency sounds being output to the summing node 270, and data representing the lower frequency sounds being output to the summing node 230. In various implementations, the crossover frequency employed in the filter block 450 is dynamically selectable during operation of the ANR circuit 2000, and may be selected to effectively disable the crossover function to cause data representing all frequencies of the modified pass-through audio to be output to either of the summing nodes 230 or 270. In this way, the point at which the modified pass-through audio data is combined with data for the feedback ANR function within the signal processing topology 2500a can be made selectable.


As just discussed, feedback reference data from the ADC 210 may be combined with data from the filter block 450 for the pass-through audio function (either the lower frequency sounds, or all of the modified pass-through audio) at the summing node 230. The summing node 230 outputs the possibly combined data to the filter block 250. One or more digital filters within the filter block 250 are employed to modify the data from summing node 230 to derive modified data representing at least feedback anti-noise sounds and possibly further-modified pass-through audio sounds. The filter block 250 provides the modified data to the summing node 270. The summing node 270 combines the data from the filter block 450 that possibly represents higher frequency sounds of the modified pass-through audio with the modified data from the filter block 250, and provides the result to the DAC 910 to create an analog signal. The provision of data by the filter block 450 to the summing node 270 may be through the summing node 370 where the provision of feedforward-based ANR is also supported.


Where the crossover frequency employed in the filter block 450 is dynamically selectable, various characteristics of the filters making up the filter block 450 may also be dynamically configurable. By way of example, the number and/or type of digital filters making up the filter block 450 may be dynamically alterable, as well as the coefficients for each of those digital filters. Such dynamic configurability may be deemed desirable to correctly accommodate changes among having no data from the filter block 450 being combined with feedback reference data from the ADC 210, having data from the filter block 450 representing lower frequency sounds being combined with feedback reference data from the ADC 210, and having data representing all of the modified pass-through audio from the filter block 450 being combined with feedback reference data from the ADC 210.


Where the provision of feedforward-based ANR is also supported, the ADC 310 receives an analog signal from the feedforward microphone 130, digitizes it, and provides feedforward reference data corresponding to the analog signal output by the feedforward microphone 130 to the filter block 350. One or more digital filters within the filter block 350 are employed to modify the feedforward reference data received from the ADC 310 to derive feedforward anti-noise data representing feedforward anti-noise sounds. The filter block 350 provides the feedforward anti-noise data to the summing node 370 where the feedforward anti-noise data is possibly combined with data that may be provided by the filter block 450 (either the higher frequency sounds, or all of the modified pass-through audio).


The analog signal output by the DAC 910 is provided to the audio amplifier 960 to be amplified sufficiently to drive the acoustic driver 190 to acoustically output one or more of feedback anti-noise sounds, feedforward anti-noise sounds and pass-through audio.


As further depicted in FIG. 4b, the signal processing topology 2500b defines its own variations of the pathways 200, 300 and 400 along which digital data associated with feedback-based ANR, feedforward-based ANR and pass-through audio, respectively, flow. In a manner not unlike the pathway 200 of the signal processing topology 2500a, the flow of feedback reference data and feedback anti-noise data among the ADC 210, the summing nodes 230 and 270, the filter block 250 and the DAC 910 defines the feedback-based ANR pathway 200 of the signal processing topology 2500b. Where feedforward-based ANR is supported, in a manner not unlike the pathway 300 of the signal processing topology 2500a, the flow of feedforward reference data and feedforward anti-noise data among the ADC 310, the filter block 350, the summing nodes 270 and 370, and the DAC 910 defines the feedforward-based ANR pathway 300 of the signal processing topology 2500b. However, in a manner very much unlike the pathway 400 of the signal processing topology 2500a, the ability of the filter block 450 of the signal processing topology 2500b to split the modified pass-through audio data into higher frequency and lower frequency sounds results in the pathway 400 of the signal processing topology 2500b being partially split. More specifically, the flow of digital data from the ADC 410 to the filter block 450 is split at the filter block 450. One split portion of the pathway 400 continues to the summing node 230, where it is combined with the pathway 200, before continuing through the filter block 250 and the summing node 270, and ending at the DAC 910. The other split portion of the pathway 400 continues to the summing node 370 (if present), where it is combined with the pathway 300 (if present), before continuing through the summing node 270 and ending at the DAC 910.


Also not unlike the pathways 200, 300 and 400 of the signal processing topology 2500a, the pathways 200, 300 and 400 of the signal processing topology 2500b may be operated with different data transfer rates. However, differences in data transfer rates between the pathway 400 and both of the pathways 200 and 300 would have to be addressed. Sample-and-hold, buffering or other functionality may be incorporated into each of the summing nodes 230, 270 and/or 370. Alternatively and/or additionally, the filter block 350 may incorporate interpolation or other upsampling capability in providing digital data to the summing node 370, and/or the filter block 450 may incorporate a similar capability in providing digital data to each of the summing nodes 230 and 370 (or 270, if the pathway 300 is not present).



FIG. 4
c depicts another possible signal processing topology 2500c for which the ANR circuit 2000 may be structured and/or programmed. Where the ANR circuit 2000 adopts the signal processing topology 2500c, the ANR circuit 2000 incorporates at least the DAC 910, the audio amplifier 960, the ADC 210, the summing node 230, the filter blocks 250 and 450, the VGA 280, another summing node 290, and the compressor 950. The ANR circuit 2000 may further incorporate one or more of the ADC 410, the ADC 310, the filter block 350, the summing node 270, and the ADC 955. The signal processing topologies 2500b and 2500c are similar in numerous ways. However, a substantial difference between the signal processing topologies 2500b and 2500c is the addition of the compressor 950 in the signal processing topology 2500c to enable the amplitudes of the sounds represented by data output by both of the filter blocks 250 and 350 to be reduced in response to the compressor 950 detecting actual instances or indications of impending instances of clipping and/or other undesirable audio artifacts.


The filter block 250 provides its modified data to the VGA 280 where the amplitude of the sounds represented by the data provided to the VGA 280 may be altered under the control of the compression controller 950. The VGA 280 outputs its data (with or without amplitude alteration) to the summing node 290, where it may be combined with data that may be output by the filter block 450 (perhaps the higher frequency sounds of the modified pass-through audio, or perhaps the entirety of the modified pass-through audio). In turn, the summing node 290 provides its output data to the DAC 910. Where the provision of feedforward-based ANR is also supported, the data output by the filter block 250 to the VGA 280 is routed through the summing node 270, where it is combined with the data output by the filter block 350 representing feedforward anti-noise sounds, and this combined data is provided to the VGA 280.



FIG. 4
d depicts another possible signal processing topology 2500d for which the ANR circuit 2000 may be structured and/or programmed. Where the ANR circuit 2000 adopts the signal processing topology 2500d, the ANR circuit 2000 incorporates at least the DAC 910, the compression controller 950, the audio amplifier 960, the ADC 210, the summing nodes 230 and 290, the filter blocks 250 and 450, the VGA 280, and still other VGAs 445, 455 and 460. The ANR circuit 2000 may further incorporate one or more of the ADCs 310 and/or 410, the filter block 350, the summing node 270, the ADC 955, and still another VGA 360. The signal processing topologies 2500c and 2500d are similar in numerous ways. However, a substantial difference between the signal processing topologies 2500c and 2500d is the addition of the ability to direct the provision of the higher frequency sounds of the modified pass-through audio to be combined with other audio at either or both of two different locations within the signal processing topology 2500d.


One or more digital filters within the filter block 450 are employed to modify the digital data representing the pass-through audio to derive a modified variant of the pass-through audio data and to function as a crossover that divides the modified pass-through audio data into higher and lower frequency sounds. Data representing the lower frequency sounds are output to the summing node 230 through the VGA 445. Data representing the higher frequency sounds are output both to the summing node 230 through the VGA 455 and to the DAC 910 through the VGA 460. The VGAs 445, 455 and 460 are operable both to control the amplitudes of the lower frequency and higher frequency sounds represented by the data output by the filter block 450, and to selectively direct the flow of the data representing the higher frequency sounds. However, as has been previously discussed, the crossover functionality of the filter block 450 may be employed to selectively route the entirety of the modified pass-through audio to one or the other of the summing node 230 and the DAC 910.


Where the provision of feedforward-based ANR is also supported, the possible provision of higher frequency sounds (or perhaps the entirety of the modified pass-through audio) by the filter block 450 through the VGA 460 and to the DAC 910 may be through the summing node 290. The filter block 350 provides the feedforward anti-noise data to the summing node 270 through the VGA 360.



FIG. 4
e depicts another possible signal processing topology 2500e for which the ANR circuit 2000 may be structured and/or programmed. Where the ANR circuit 2000 adopts the signal processing topology 2500e, the ANR circuit 2000 incorporates at least the DAC 910; the audio amplifier 960; the ADCs 210 and 310; the summing nodes 230, 270 and 370; the filter blocks 250, 350 and 450; the compressor 950; and a pair of VGAs 240 and 340. The ANR circuit 2000 may further incorporate one or both of the ADCs 410 and 955. The signal processing topologies 2500b, 2500c and 2500e are similar in numerous ways. The manner in which the data output by each of the filter blocks 250, 350 and 450 are combined in the signal processing topology 2500e is substantially similar to that of the signal processing topology 2500b. Also, like the signal processing topology 2500c, the signal processing topology 2500e incorporates the compression controller 950. However, a substantial difference between the signal processing topologies 2500c and 2500e is the replacement of the single VGA 280 in the signal processing topology 2500c for the separately controllable VGAs 240 and 340 in the signal processing topology 2500e.


The summing node 230 provides data representing feedback reference sounds possibly combined with data that may be output by the filter block 450 (perhaps the lower frequency sounds of the modified pass-through audio, or perhaps the entirety of the modified pass-through audio) to the filter block 250 through the VGA 240, and the ADC 310 provides data representing feedforward reference sounds to the filter block 350 through the VGA 340. The data output by the filter block 350 is combined with data that may be output by the filter block 450 (perhaps the higher frequency sounds of the modified pass-through audio, or perhaps the entirety of the modified pass-through audio) at the summing node 370. In turn, the summing node 370 provides its data to the summing node 270 to be combined with data output by the filter block 250. The summing node 270, in turn, provides its combined data to the DAC 910.


The compression controller 950 controls the gains of the VGAs 240 and 340, to enable the amplitude of the sounds represented by data output by the summing node 230 and the ADC 310, respectively, to be reduced in response to actual instances or indications of upcoming instances of clipping and/or other undesirable audio artifacts being detected by the compression controller 950. The gains of the VGAs 240 and 340 may be controlled in a coordinated manner, or may be controlled entirely independently of each other.



FIG. 4
f depicts another possible signal processing topology 2500f for which the ANR circuit 2000 may be structured and/or programmed. Where the ANR circuit 2000 adopts the signal processing topology 2500f, the ANR circuit 2000 incorporates at least the DAC 910; the audio amplifier 960; the ADCs 210 and 310; the summing nodes 230, 270 and 370; the filter blocks 250, 350 and 450; the compressor 950; and the VGAs 125 and 135. The ANR circuit 2000 may further incorporate one or both of the ADCs 410 and 955. The signal processing topologies 2500e and 2500f are similar in numerous ways. However, a substantial difference between the signal processing topologies 2500e and 2500f is the replacement of the pair of VGAs 240 and 340 in the signal processing topology 2500e for the VGAs 125 and 135 in the signal processing topology 2500f.


The VGAs 125 and 135 positioned at the analog inputs to the ADCs 210 and 310, respectively, are analog VGAs, unlike the VGAs 240 and 340 of the signal processing topology 2500e. This enables the compression controller 950 to respond to actual occurrences and/or indications of soon-to-occur instances of clipping and/or other audio artifacts in driving the acoustic driver 190 by reducing the amplitude of one or both of the analog signals representing feedback and feedforward reference sounds. This may be deemed desirable where it is possible for the analog signals provided to the ADCs 210 and 310 to be at too great an amplitude such that clipping at the point of driving the acoustic driver 190 might be more readily caused to occur. The provision of the ability to reduce the amplitude of these analog signals (and perhaps also including the analog signal provided to the ADC 410 via the VGA 145 depicted elsewhere) may be deemed desirable to enable balancing of amplitudes between these analog signals, and/or to limit the numeric values of the digital data produced by one or more of the ADCs 210, 310 and 410 to lesser magnitudes to reduce storage and/or transmission bandwidth requirements.



FIG. 4
g depicts another possible signal processing topology 2500g for which the ANR circuit 2000 may be programmed or otherwise structured. Where the ANR circuit 2000 adopts the signal processing topology 2500g, the ANR circuit 2000 incorporates at least the compression controller 950, the DAC 910, the audio amplifier 960, the ADCs 210 and 310, a pair of VGAs 220 and 320, the summing nodes 230 and 270, the filter blocks 250 and 350, another pair of VGAs 355 and 360, and the VGA 280. The ANR circuit 2000 may further incorporate one or more of the ADC 410, the filter block 450, still another VGA 460, the summing node 290, and the ADC 955.


The ADC 210 receives an analog signal from the feedback microphone 120 and digitizes it, before providing corresponding feedback reference data to the VGA 220. The VGA 220 outputs the feedback reference data, possibly after modifying its amplitude, to the summing node 230. Similarly, the ADC 310 receives an analog signal from the feedforward microphone 130 and digitizes it, before providing corresponding feedforward reference data to the VGA 320. The VGA 320 outputs the feedforward reference data, possibly after modifying its amplitude, to the filter block 350. One or more digital filters within the filter block 350 are employed to modify the feedforward reference data to derive feedforward anti-noise data representing feedforward anti-noise sounds, and the filter block 350 provides the feedforward anti-noise data to both of the VGAs 355 and 360. In various implementations, the gains of the VGAs 355 and 360 are dynamically selectable and can be operated in a coordinated manner like a three-way switch to enable the feedforward anti-noise data to be selectively provided to either of the summing nodes 230 and 270. Thus, where the feedforward anti-noise data is combined with data related to feedback ANR within the signal processing topology 2500g is made selectable.


Therefore, depending on the gains selected for the VGAs 355 and 360, the feedforward anti-noise data from the filter block 350 may be combined with the feedback reference data from the ADC 210 at the summing node 230, or may be combined with feedback anti-noise data derived by the filter block 250 from the feedback reference data at the summing node 270. If the feedforward anti-noise data is combined with the feedback reference data at the summing node 230, then the filter block 250 derives data representing a combination of feedback anti-noise sounds and further-modified feedforward anti-noise sounds, and this data is provided to the VGA 280 through the summing node 270 at which no combining of data occurs. Alternatively, if the feedforward anti-noise data is combined with the feedback anti-noise data at the summing node 270, then the feedback anti-noise data will have been derived by the filter block 250 from the feedback reference data received through the summing node 230 at which no combining of data occurs, and the data resulting from the combining at the summing node 270 is provided to the VGA 280. With or without an alteration in amplitude, the VGA 280 provides whichever form of combined data is received from the summing node 270 to the DAC 910 to create an analog signal. This provision of this combined data by the VGA 280 may be through the summing node 290 where the provision of pass-through audio is also supported.


Where the provision of pass-through audio is supported, the audio source 9400 may provide an analog signal representing pass-through audio to be acoustically output to a user, and the ADC 410 digitizes the analog signal and provides pass-through audio data corresponding to the analog signal to the filter block 450. Alternatively, where the audio source 9400 provides digital data representing pass-through audio, such digital data may be provided directly to the filter block 450. One or more digital filters within the filter block 450 may be employed to modify the digital data representing the pass-through audio to derive a modified variant of the pass-through audio data that may be re-equalized and/or enhanced in other ways. The filter block 450 provides the modified pass-through audio data to the VGA 460, and either with or without altering the amplitude of the pass-through audio sounds represented by the modified pass-through audio data, the VGA 460 provides the modified pass-through audio data to the DAC 910 through the summing node 290.


The compression controller 950 controls the gain of the VGA 280 to enable the amplitude of whatever combined form of feedback and feedforward anti-noise sounds are received by the VGA 280 to be reduced under the control of the compression controller 950 in response to actual occurrences and/or indications of impending instances of clipping and/or other audio artifacts.



FIGS. 5
a through 5e depict some possible filter block topologies that may be employed in creating one or more blocks of filters (such as filter blocks 250, 350 and 450) within signal processing topologies adopted by the ANR circuit 2000 (such as the signal processing topologies 2500a-g). It should be noted that the designation of a multitude of digital filters as a “filter block” is an arbitrary construct meant to simplify the earlier presentation of signal processing topologies. In truth, the selection and positioning of one or more digital filters at any point along any of the pathways (such as the pathways 200, 300 and 400) of any signal processing topology may be accomplished in a manner identical to the selection and positioning of VGAs and summing nodes. Therefore, it is entirely possible for various digital filters to be positioned along a pathway for the movement of data in a manner in which those digital filters are interspersed among VGAs and/or summing nodes such that no distinguishable block of filters is created. Or, as will be illustrated, it is entirely possible for a filter block to incorporate a summing node or other component as part of the manner in which the filters of a filter block are coupled as part of the filter topology of a filter block.


However, as previously discussed, multiple lower-order digital filters may be combined in various ways to perform the equivalent function of one or more higher-order digital filters. Thus, although the creation of distinct filter blocks is not necessary in defining a pathway having multiple digital filters, it can be desirable in numerous situations. Further, the creation of a block of filters at a single point along a pathway can more easily enable alterations in the characteristics of filtering performed in that pathway. By way of example, multiple lower-order digital filters connected with no other components interposed between them can be dynamically configured to cooperate to perform any of a variety of higher-order filter functions by simply changing their coefficients and/or changing the manner in which they are interconnected. Also, in some implementations, such close interconnection of digital filters may ease the task of dynamically configuring a pathway to add or remove digital filters with a minimum of changes to the interconnections that define that pathway.


It should be noted that the selections of types of filters, quantities of filters, interconnections of filters and filter topologies depicted in each of FIGS. 5a through 5e are meant to serve as examples to facilitate understanding, and should not be taken as limiting the scope of what is described or the scope of what is claimed herein.



FIG. 5
a depicts a possible filter block topology 3500a for which the ANR circuit 2000 may be structured and/or programmed to define a filter block, such as one of the filter blocks 250, 350 and 450. The filter block topology 3500a is made up of a serial chain of digital filters with a downsampling filter 652 at its input; biquad filters 654, 655 and 656; and a FIR filter 658 at its output.


As more explicitly depicted in FIG. 5a, in some implementations, the ANR circuit 2000 employs the internal architecture 2200a such that the ANR circuit 2000 incorporates the filter bank 550 incorporating multitudes of the downsampling filters 552, the biquad filters 554, and the FIR filters 558. One or more of each of the downsampling filters 552, biquad filters 554 and FIR filters 558 may be interconnected in any of a number of ways via the switch array 540, including in a way that defines the filter block topology 3500a. More specifically, the downsampling filter 652 is one of the downsampling filters 552; the biquad filters 654, 655 and 656 are each one of the biquad filters 554; and the FIR filter 658 is one of the FIR filters 558.


Alternatively, and as also more explicitly depicted in FIG. 5a, in other implementations, the ANR circuit 2000 employs the internal architecture 2200b such that the ANR circuit 2000 incorporates a storage 520 in which is stored the downsampling filter routine 553, the biquad filter routine 555 and the FIR filter routine 559. Varying quantities of downsampling, biquad and/or FIR filters may be instantiated within available storage locations of the storage 520 with any of a variety of interconnections defined between them, including quantities of filters and interconnections that define the filter block topology 3500a. More specifically, the downsampling filter 652 is an instance of the downsampling filter routine 553; the biquad filters 654, 655 and 656 are each instances of the biquad filter routine 555; and the FIR filter 658 is an instance of the FIR filter routine 559.


As previously discussed, power conservation and/or other benefits may be realized by employing different data transfer rates along different pathways of digital data representing sounds in a signal processing topology. In support of converting between different data transfer rates, including where one pathway operating at one data transfer rate is coupled to another pathway operating at another data transfer rate, different data transfer clocks may be provided to different ones of the digital filters within a filter block, and/or one or more digital filters within a filter block may be provided with multiple data transfer clocks.


By way of example, FIG. 5a depicts a possible combination of different data transfer rates that may be employed within the filter block topology 3500a to support digital data being received at one data transfer rate, digital data being transferred among these digital filters at another data transfer rate, and digital data being output at still another data transfer rate. More specifically, the downsampling filter 652 receives digital data representing a sound at a data transfer rate 672, and at least downsamples that digital data to a lower data transfer rate 675. The lower data transfer rate 675 is employed in transferring digital data among the downsampling filter 652, the biquad filters 654-656, and the FIR filter 658. The FIR filter 658 at least upsamples the digital data that it receives from the lower data transfer rate 675 to a higher data transfer rate 678 as that digital data is output by the filter block to which the digital filters in the filter block topology 3500a belong. Many other possible examples of the use of more than one data transfer rate within a filter block and the possible corresponding need to employ multiple data transfer clocks within a filter block will be clear to those skilled in the art.



FIG. 5
b depicts a possible filter block topology 3500b that is substantially similar to the filter block topology 3500a, but in which the FIR filter 658 of the filter block topology 3500a has been replaced with an interpolating filter 657. Where the internal architecture 2200a is employed, such a change from the filter block topology 3500a to the filter block topology 3500b entails at least altering the configuration of the switch array 540 to exchange one of the FIR filters 558 with one of the interpolating filters 556. Where the internal architecture 2200b is employed, such a change entails at least replacing the instantiation of the FIR filter routine 559 that provides the FIR filter 658 with an instantiation of the interpolating filter routine 557 to provide the interpolating filter 657



FIG. 5
c depicts a possible filter block topology 3500c that is made up of the same digital filters as the filter block topology 3500b, but in which the interconnections between these digital filters have been reconfigured into a branching topology to provide two outputs, whereas the filter block topology 3500b had only one. Where the internal architecture 2200a is employed, such a change from the filter block topology 3500b to the filter block topology 3500c entails at least altering the configuration of the switch array 540 to disconnect the input to the biquad filter 656 from the output of the biquad filter 655, and to connect that input to the output of the downsampling filter 652, instead. Where the internal architecture 2200b is employed, such a change entails at least altering the instantiation of biquad filter routine 555 that provides the biquad filter 656 to receive its input from the instantiation of the downsampling filter routine 553 that provides the downsampling filter 652. The filter block topology 3500c may be employed where it is desired that a filter block be capable of providing two different outputs in which data representing audio provided at the input is altered in different ways to create two different modified versions of that data, such as in the case of the filter block 450 in each of the signal processing topologies 2500b-f.



FIG. 5
d depicts another possible filter block topology 3500d that is substantially similar to the filter block topology 3500a, but in which the biquad filters 655 and 656 have been removed to shorten the chain of digital filters from the quantity of five in the filter block topology 3500a to a quantity of three.



FIG. 5
e depicts another possible filter block topology 3500e that is made up of the same digital filters as the filter block topology 3500b, but in which the interconnections between these digital filters have been reconfigured to put the biquad filters 654, 655 and 656 in a parallel configuration, whereas these same filters were in a serial chain configuration in the filter block topology 3500b. As depicted, the output of the downsampling filter 652 is coupled to the inputs of all three of the biquad filters 654, 655 and 656, and the outputs of all three of these biquad filters are coupled to the input of the interpolating filter 657 through an additionally incorporated summing node 659.


Taken together, the FIGS. 5a through 5e depict the manner in which a given filter block topology of a filter block is dynamically configurable to so as to allow the types of filters, quantities of filters and/or interconnections of digital filters to be altered during the operation of a filter block. However, as those skilled in the art will readily recognize, such changes in types, quantities and interconnections of digital filters are likely to require corresponding changes in filter coefficients and/or other settings to be made to achieve the higher-order filter function sought to be achieved with such changes. As will be discussed in greater detail, to avoid or at least mitigate the creation of audible distortions or other undesired audio artifacts arising from making such changes during the operation of the personal ANR device, such changes in interconnections, quantities of components (including digital filters), types of components, filter coefficients and/or VGA gain values are ideally buffered so as to enable their being made in a manner coordinated in time with one or more data transfer rates.


The dynamic configurability of both of the internal architectures 2200a and 2200b, as exemplified throughout the preceding discussion of dynamically configurable signal processing topologies and dynamically configurable filter block topologies, enables numerous approaches to conserving power and to reducing audible artifacts caused by the introduction of microphone self noise, quantization errors and other influences arising from components employed in the personal ANR device 1000. Indeed, there can be a synergy between achieving both goals, since at least some measures taken to reduce audible artifacts generated by the components of the personal ANR device 1000 can also result in reductions in power consumption. Reductions in power consumption can be of considerable importance given that the personal ANR device 1000 is preferably powered from a battery or other portable source of electric power that is likely to be somewhat limited in ability to provide electric power.


In either of the internal architectures 2200a and 2200b, the processing device 510 may be caused by execution of a sequence of instructions of the ANR routine 525 to monitor the availability of power from the power source 180. Alternatively and/or additionally, the processing device 510 may be caused to monitor characteristics of one or more sounds (e.g., feedback reference and/or anti-noise sounds, feedforward reference and/or anti-noise sounds, and/or pass-through audio sounds) and alter the degree of ANR provided in response to the characteristics observed. As those familiar with ANR will readily recognize, it is often the case that providing an increased degree of ANR often requires the implementation of a more complex transfer function, which often requires a greater number of filters and/or more complex types of filters to implement, and this in turn, often leads to greater power consumption. Analogously, a lesser degree of ANR often requires the implementation of a simpler transfer function, which often requires fewer and/or simpler filters, which in turn, often leads to less power consumption.


Further, there can arise situations, such as an environment with relatively low environmental noise levels or with environmental noise sounds occurring within a relatively narrow range of frequencies, where the provision of a greater degree of ANR can actually result in the components used in providing the ANR generating noise sounds greater than the attenuated environmental noise sounds. Still further, and as will be familiar to those skilled in the art of feedback-based ANR, under some circumstances, providing a considerable degree of feedback-based ANR can lead to instability as undesirable audible feedback noises are produced.


In response to either an indication of diminishing availability of electric power or an indication that a lesser degree of ANR is needed (or is possibly more desirable), the processing device 510 may disable one or more functions (including one or both of feedback-based and feedforward-based ANR), lower data transfer rates of one or more pathways, disable branches within pathways, lower data transfer rates between digital filters within a filter block, replace digital filters that consume more power with digital filters that consume less power, reduce the complexity of a transfer function employed in providing ANR, reduce the overall quantity of digital filters within a filter block, and/or reduce the gain to which one or more sounds are subjected by reducing VGA gain settings and/or altering filter coefficients. However, in taking one or more of these or other similar actions, the processing device 510 may be further caused by the ANR routine 525 to estimate a degree of reduction in the provision of ANR that balances one or both of the goals of reducing power consumption and avoiding the provision of too great a degree of ANR with one or both of the goals of maintaining a predetermined desired degree of quality of sound and quality of ANR provided to a user of the personal ANR device 1000. A minimum data transfer rate, a maximum signal-to-noise ratio or other measure may be used as the predetermined degree of quality or ANR and/or sound.


As an example, and referring back to the signal processing topology 2500a of FIG. 4a in which the pathways 200, 300 and 400 are explicitly depicted, a reduction in the degree of ANR provided and/or in the consumption of power may be realized through turning off one or more of the feedback-based ANR, feedforward-based ANR and pass-through audio functions. This would result in at least some of the components along one or more of the pathways 200, 300 and 400 either being operated to enter a low power state in which operations involving digital data would cease within those components, or being substantially disconnected from the power source 180. A reduction in power consumption and/or degree of ANR provided may also be realized through lowering the data transfer rate(s) of at least portions of one or more of the pathways 200, 300 and 400, as previously discussed in relation to FIG. 4a.


As another example, and referring back to the signal processing topology 2500b of FIG. 4b in which the pathways 200, 300 and 400 are also explicitly depicted, a reduction in power consumption and/or in the complexity of transfer functions employed may be realized through turning off the flow of data through one of the branches of the split in the pathway 400. More specifically, and as previously discussed in relation to FIG. 4b, the crossover frequency employed by the digital filters within the filter block 450 to separate the modified pass-through audio into higher frequency and lower frequency sounds may be selected to cause the entirety of the modified pass-through audio to be directed towards only one of the branches of the pathway 400. This would result in discontinuing of the transfer of modified pass-through audio data through one or the other of the summing nodes 230 and 370, thereby enabling a reduction in power consumption and/or in the introduction of noise sounds from components by allowing the combining function of one or the other of these summing nodes to be disabled or at least to not be utilized. Similarly, and referring back to the signal processing topology 2500d of FIG. 4d (despite the lack of explicit marking of its pathways), either the crossover frequency employed by the filter block 450 or the gain settings of the VGAs 445, 455 and 460 may be selected to direct the entirety of the modified pass-through audio data down a single one of the three possible pathway branches into which each of these VGAs lead. Thus, a reduction in power consumption and/or in the introduction of noise sounds would be enabled by allowing the combining function of one or the other of the summing nodes 230 and 290 to be disabled or at least not be utilized. Still further, one or more of the VGAs 445, 455 and 460 through which modified pass-through audio data is not being transferred may be disabled.


As still another example, and referring back to the filter block topology 3500a of FIG. 5a in which the allocation of three data transfer rates 672, 675 and 678 are explicitly depicted, a reduction in the degree of ANR provided and/or in power consumption may be realized through lowering one or more of these data transfer rates. More specifically, within a filter block adopting the filter block topology 3500a, the data transfer rate 675 at which digital data is transferred among the digital filters 652, 654-656 and 658 may be reduced. Such a change in a data transfer rate may also be accompanied by exchanging one or more of the digital filters for variations of the same type of digital filter that are better optimized for lower bandwidth calculations. As will be familiar to those skilled in the art of digital signal processing, the level of calculation precision required to maintain a desired predetermined degree of quality of sound and/or quality of ANR in digital processing changes as sampling rate changes. Therefore, as the data transfer rate 675 is reduced, one or more of the biquad filters 654-656 which may have been optimized to maintain a desired degree of quality of sound and/or desired degree of quality of ANR at the original data transfer rate may be replaced with other variants of biquad filter that are optimized to maintain substantially the same quality of sound and/or ANR at the new lower data transfer rate with a reduced level of calculation precision that also reduces power consumption. This may entail the provision of different variants of one or more of the different types of digital filter that employ coefficient values of differing bit widths and/or incorporate differing quantities of taps.


As still other examples, and referring back to the filter block topologies 3500c and 3500d of FIGS. 5c and 5d, respectively, as well as to the filter block topology 3500a, a reduction in the degree of ANR provided and/or in power consumption may be realized through reducing the overall quantity of digital filters employed in a filter block. More specifically, the overall quantity of five digital filters in the serial chain of the filter block topology 3500a may be reduced to the overall quantity of three digital filters in the shorter serial chain of the filter block topology 3500d. As those skilled in the art would readily recognize, such a change in the overall quantity of digital filters would likely need to be accompanied by a change in the coefficients provided to the one or more of the digital filters that remain, since it is likely that the transfer function(s) performed by the original five digital filters would have to be altered or replaced by transfer function(s) that are able to be performed with the three digital filters that remain. Also more specifically, the overall quantity of five digital filters in the branching topology of the filter block topology 3500c may be reduced to an overall quantity of three digital filters by removing or otherwise deactivating the filters of one of the branches (e.g., the biquad filter 656 and the interpolating filter 657 of one branch that provides one of the two outputs). This may be done in concert with selecting a crossover frequency for a filter block providing a crossover function to effectively direct all frequencies of a sound represented by digital data to only one of the two outputs, and/or in concert with operating one or more VGAs external to a filter block to remove or otherwise cease the transfer of digital data through a branch of a signal processing topology.


Reductions in data transfer rates may be carried out in various ways in either of the internal architectures 2200a and 2200b. By way of example in the internal architecture 2200a, various ones of the data transfer clocks provided by the clock bank 570 may be directed through the switch array 540 to differing ones of the digital filters, VGAs and summing nodes of a signal processing topology and/or filter block topology to enable the use of multiple data transfer rates and/or conversions between different data transfer rates by one or more of those components. By way of example in the internal architecture 2200b, the processing device 510 may be caused to execute the sequences of instructions of the various instantiations of digital filters, VGAs and summing nodes of a signal processing topology and/or filter block topology at intervals of differing lengths of time. Thus, the sequences of instructions for one instantiation of a given component are executed at more frequent intervals to support a higher data transfer rate than the sequences of instructions for another instantiation of the same component where a lower data transfer rate is supported.


As yet another example, and referring back to any of the earlier-depicted signal processing topologies and/or filter block topologies, a reduction in the degree of ANR provided and/or in power consumption may be realized through the reduction of the gain to which one or more sounds associated with the provision of ANR (e.g., feedback reference and/or anti-noise sounds, or feedforward reference and/or anti-noise sounds). Where a VGA is incorporated into at least one of a feedback-based ANR pathway and a feedforward-based ANR pathway, the gain setting of that VGA may be reduced. Alternatively and/or additionally, and depending on the transfer function implemented by a given digital filter, one or more coefficients of that digital filter may be altered to reduce the gain imparted to whatever sounds are represented by the digital data output by that digital filter. As will be familiar to those skilled in the art, reducing a gain in a pathway can reduce the perceptibility of noise sounds generated by components. In a situation where there is relatively little in the way of environmental noise sounds, noise sounds generated by components can become more prevalent, and thus, reducing the noise sounds generated by the components can become more important than generating anti-noise sounds to attenuate what little in the way of environmental noise sounds may be present. In some implementations, such reduction(s) in gain in response to relatively low environmental noise sound levels may enable the use of lower cost microphones.


In some implementations, performing such a reduction in gain at some point along a feedback-based ANR pathway may prove more useful than along a feedforward-based ANR pathway, since environmental noise sounds tend to be more attenuated by the PNR provided by the personal ANR device before ever reaching the feedback microphone 120. As a result of the feedback microphone 120 tending to be provided with weaker variants of environmental noise sounds than the feedforward microphone 130, the feedback-based ANR function may be more easily susceptible to a situation in which noise sounds introduced by components become more prevalent than environmental noise sounds at times when there is relatively little in the way of environmental noise sounds. A VGA may be incorporated into a feedback-based ANR pathway to perform this function by normally employing a gain value of 1 which would then be reduced to ½ or to some other preselected lower value in response to the processing device 510 and/or another processing device external to the ANR circuit 2000 and to which the ANR circuit 2000 is coupled determining that environmental noise levels are low enough that noise sounds generated by components in the feedback-based ANR pathway are likely to be significant enough that such a gain reduction is more advantageous than the production of feedback anti-noise sounds.


The monitoring of characteristics of environmental noise sounds as part of determining whether or not changes in ANR settings are to be made may entail any of a number of approaches to measuring the strength, frequencies and/or other characteristics of the environmental noise sounds. In some implementations, a simple sound pressure level (SPL) or other signal energy measurement without weighting may be taken of environmental noise sounds as detected by the feedback microphone 120 and/or the feedforward microphone 130 within a preselected range of frequencies. Alternatively, the frequencies within the preselected range of frequencies of a SPL or other signal energy measurement may subjected to the widely known and used “A-weighted” frequency weighting curve developed to reflect the relative sensitivities of the average human ear to different audible frequencies.



FIGS. 6
a through 6c depict aspects and possible implementations of triple-buffering both to enable synchronized ANR setting changes and to enable a failsafe response to an occurrence and/or to indications of a likely upcoming occurrence of an out-of-bound condition, including and not limited to, clipping and/or excessive amplitude of acoustically output sounds, production of a sound within a specific range of frequencies that is associated with a malfunction, instability of at least feedback-based ANR, or other condition that may generate undesired or uncomfortable acoustic output. Each of these variations of triple-buffering incorporate at least a trio of buffers 620a, 620b and 620c. In each depicted variation of triple-buffering, two of the buffers 620a and 620b are alternately employed during normal operation of the ANR circuit 2000 to synchronously update desired ANR settings “on the fly,” including and not limited to, topology interconnections, data clock settings, data width settings, VGA gain settings, and filter coefficient settings. Also, in each depicted variation of triple-buffering, the third buffer 620c maintains a set of ANR settings deemed to be “conservative” or “failsafe” settings that may be resorted to bring the ANR circuit 2000 back into stable operation and/or back to safe acoustic output levels in response to an out-of-bound condition being detected.


As will be familiar to those skilled in the art of controlling digital signal processing for audio signals, it is often necessary to coordinate the updating of various audio processing settings to occur during intervals between the processing of pieces of audio data, and it is often necessary to cause the updating of at least some of those settings to be made during the same interval. Failing to do so can result in the incomplete programming of filter coefficients, an incomplete or malformed definition of a transfer function, or other mismatched configuration issue that can result in undesirable sounds being created and ultimately acoustically output, including and not limited to, sudden popping or booming noises that can surprise or frighten a listener, sudden increases in volume that are unpleasant and can be harmful to a listener, or howling feedback sounds in the case of updating feedback-based ANR settings that can also be harmful.


In some implementations, the buffers 620a-c of any of FIGS. 6a-c are dedicated hardware-implemented registers, the contents of which are able to be clocked into registers within the VGAs, the digital filters, the summing nodes, the clocks of the clock bank 570 (if present), switch array 540 (if present), the DMA device 541 (if present) and/or other components. In other implementations, the buffers 620a-c of FIGS. 6a-c are assigned locations within the storage 520, the contents of which are able to be retrieved by the processing device 510 and written by the processing device 510 into other locations within the storage 520 associated with instantiations of the VGAs, digital filters, and summing nodes, and/or written by the processing device 510 into registers within the clocks of the clock bank 570 (if present), the switch array 540 (if present), the DMA device 541 (if present) and/or other components.



FIG. 6
a depicts the triple-buffering of VGA settings, including gain values, employing variants of the buffers 620a-c that each store differing ones of VGA settings 626. An example of a use of such triple-buffering of VGA gain values may be the compression controller 950 operating one or more VGAs to reduce the amplitude of sounds represented by digital data in response to detecting occurrences and/or indications of impending occurrences of clipping and/or other audible artifacts in the acoustic output of the acoustic driver 190. In some implementations, the compression controller 950 stores new VGA settings into a selected one of the buffers 620a and 620b. At a subsequent time that is synchronized to the flow of pieces of digital data through one or more of the VGAs, the settings stored in the selected one of the buffers 620a and 620b are provided to those VGAs, thereby avoiding the generation of audible artifacts. As those skilled in the art will readily recognize, the compression controller 950 may repeatedly update the gain settings of VGAs over a period of time to “ramp down” the amplitude of one or more sounds to a desired level of amplitude, rather than to immediately reduce the amplitude to that desired level. In such a situation, the compression controller 950 would alternate between storing updated gain settings to the buffer 620a and storing updated gain settings to the buffer 620b, thereby enabling the decoupling of the times at which each of the buffers 620a and 620b are each written to by the compression controller 950 and the times at which each of the buffers provide their stored VGA settings to the VGAs. However, a set of more conservatively selected VGA settings is stored in the buffer 620c, and these failsafe settings may be provided to the VGAs in response to an out-of-bound condition being detected. Such provision of the VGA settings stored in the buffer 620c overrides the provision of any VGA settings stored in either of the buffers 620a and 620b.



FIG. 6
b depicts the triple-buffering of filter settings, including filter coefficients, employing variants of the buffers 620a-c that each store differing ones of filter settings 625. An example of a use of such triple-buffering of filter coefficients may be adjusting the range of frequencies and/or the degree of attenuation of noise sounds that are reduced in the feedback-based ANR provided by the personal ANR device 1000. In some implementations, processing device 510 is caused by the ANR routine 525 to store new filter coefficients into a selected one of the buffers 620a and 620b. At a subsequent time that is synchronized to the flow of pieces of digital data through one or more of the digital filters, the settings stored in the selected one of the buffers 620a and 620b are provided to those digital filters, thereby avoiding the generation of audible artifacts. Another example of a use of such triple-buffering of filter coefficients may be adjusting the crossover frequency employed by the digital filters within the filter block 450 in some of the above signal processing topologies to divide the sounds of the modified pass-through audio into lower and higher frequency sounds. At a time synchronized to at least the flow of pieces of digital data associated with pass-through audio through the digital filters of the filter block 450, filter settings stored in one or the other of the buffers 620a and 620b are provided to at least some of the digital filters.



FIG. 6
c depicts the triple-buffering of either all or a selectable subset of clock, VGA, filter and topology settings, employing variants of the buffers 620a-c that each store differing ones of topology settings 622, filter settings 625, VGA settings 626 and clock settings 627. An example of a use of triple-buffering of all of these settings may be changing from one signal processing topology to another in response to a user of the personal ANR device 1000 operating a control to activate a “talk-through” feature in which the ANR provided by the personal ANR device 1000 is altered to enable the user to more easily hear the voice of another person without having to remove the personal ANR device 1000 or completely turn off the ANR function. The processing device 510 may be caused to store the settings required to specify a new signal processing topology in which voice sounds are more readily able to pass to the acoustic driver 190 from the feedforward microphone 130, and the various settings of the VGAs, digital filters, data clocks and/or other components of the new signal processing topology within one or the other of the buffers 620a and 620b. Then, at a time synchronized to the flow of at least some pieces of digital data representing sounds through at least one component (e.g., an ADC, a VGA, a digital filter, a summing node, or a DAC), the settings are used to create the interconnections for the new signal processing topology (by being provided to the switch array 540, if present) and are provided to the components that are to be used in the new signal processing topology.


However, some variants of the triple-buffering depicted in FIG. 6c may further incorporate a mask 640 providing the ability to determine which settings are actually updated as either of the buffers 620a and 620b provide their stored contents to one or more components. In some embodiments, bit locations within the mask are selectively set to either 1 or 0 to selectively enable the contents of different ones of the settings corresponding to each of the bit locations to be provided to one or more components when the contents of one or the other of the buffers 620a and 620b are to provide updated settings to the components. The granularity of the mask 640 may be such that each individual setting may be selectively enabled for updating, or may be such that the entirety of each of the topology settings 622, the filter settings 625, the VGA setting 626 and the clock setting 627 are able to be selected for updating through the topology settings mask 642, the filter settings mask 645, the VGA settings mask 646 and the clock settings mask 647, respectively.



FIGS. 7
a and 7b each depict variations of a number of possible additions to the internal architectures 2200a and 2200b, respectively, of the ANR circuit 2000. Therefore, it should be noted that for sake of simplicity of discussion, only portions of the internal architectures 2200a and 2200b associated with these possible additions are depicted. Some of these possible additions rely on the use of the interface 530 coupling the ANR circuit 2000 to other devices via at least one bus 535. Others of these possible additions rely on the use of the interface 530 to receive a signal from at least one manually-operable control.


More particularly, in executing a sequence of instructions of the loading routine 522 to possibly retrieve at least some of the contents of the ANR settings 527 from an external storage device (e.g., the storage device 170), the processing device 510 may be caused to configure the ANR circuit 2000 to accept those contents from an external processing device 9100, instead. Also, to better enable the use of adaptive algorithms in providing feedback-based and/or feedforward-based ANR functions, the external processing device 9100 may be coupled to the ANR circuit 2000 to augment the functionality of the ANR circuit 2000 with analysis of statistical information concerning feedback reference sounds, feedforward reference sounds and/or pass-through audio, where side-chain information is provided from downsampling and/or other filters either built into or otherwise connected to one or more of the ADCs 210, 310 and 410. Further, to enable cooperation between two of the ANR circuits 2000 to achieve a form of binaural feedforward-based ANR, each one of the ANR circuits 2000 may transmit copies of feedforward reference data to the other. Still further, one or more of the ANR circuit 2000 and/or the external processing device 9100 may monitor a manually-operable talk-through control 9300 for instances of being manually operated by a user to make use of a talk-through function.


The ANR circuit 2000 may accept an input from the talk-through control 9300 coupled to the ANR circuit 2000 directly, through another ANR circuit 2000 (if present), or through the external processing device 9100 (if present). Where the personal ANR device 1000 incorporates two of the ANR circuit 2000, the talk-through control 9300 may be directly coupled to the interface 530 of each one of the ANR circuit 2000, or may be coupled to a single one of the external processing device 9100 (if present) that is coupled to both of the ANR circuits 2000, or may be coupled to a pair of the external processing devices 9100 (if present) where each one of the processing devices 9100 is separately coupled to a separate one of each of the ANR circuits 2000.


Regardless of the exact manner in which the talk-through control 9300 is coupled to other component(s), upon the talk-through control 9300 being detected as having been manually operated, the provision of at least feedforward-based ANR is altered such that attenuation of sounds in the human speech band detected by the feedforward microphone 130 is reduced. In this way, sounds in the human speech band detected by the feedforward microphone 130 are actually conveyed through at least a pathway for digital data associated with feedforward-based ANR to be acoustically output by the acoustic driver 190, while other sounds detected by the feedforward microphone 130 continue to be attenuated through feedforward-based ANR. In this way, a user of the personal ANR device 1000 is still able to have the benefits of at least some degree of feedforward-based ANR to counter environmental noise sounds, while also being able to hear the voice of someone talking nearby.


As will be familiar to those skilled in the art, there is some variation in what range of frequencies is generally accepted as defining the human speech band from ranges as wide as 300 Hz to 4 KHz to ranges as narrow as 1 KHz to 3 KHz. In some implementations, the processing device 510 and/or the external processing device 9100 (if present) is caused to respond to the user operating the talk-through control 9300 by altering ANR settings for at least the filters in the pathway for feedforward-based ANR to reduce the range of frequencies of environmental noise sounds attenuated through feedforward-based ANR such that the feedforward-based ANR function is substantially restricted to attenuating frequencies below whatever range of frequencies is selected to define the human speech band for the personal ANR device 1000. Alternatively, the ANR settings for at least those filters are altered to create a “notch” for a form of the human speech band amidst the range of frequencies of environmental noise sounds attenuated by feedforward-based ANR, such that feedforward-based ANR attenuates environmental noise sounds occurring in frequencies below that human speech band and above that human speech band to a considerably greater degree than sounds detected by the feedforward microphone 130 that are within that human speech band. Either way, at least one or more filter coefficients are altered to reduce attenuation of sounds in the human speech band. Further, the quantity and/or types of filters employed in the pathway for feedforward-based ANR may be altered, and/or the pathway for feedforward-based ANR itself may be altered.


Although not specifically depicted, an alternative approach to providing a form of talk-through function that is more amenable to the use of analog filters would be to implement a pair of parallel sets of analog filters that are each able to support the provision of feedforward-based ANR functionality, and to provide a form of manually-operable talk-through control that causes one or more analog signals representing feedforward-based ANR to be routed to and/or from one or the other of the parallel sets of analog filters. One of the parallel sets of analog filters is configured to provide feedforward-based ANR without accommodating talk-through functionality, while the other of the parallel sets of filters is configured to provide feedforward-based ANR in which sounds within a form of the human speech band are attenuated to a lesser degree. Something of a similar approach could be implemented within the internal architecture 2200a as yet another alternative, in which a form of manually-operable talk-through control directly operates at least some of the switching devices within the switch array 540 to switch the flow of digital data between two parallel sets of digital filters.



FIG. 8 is a flowchart of an implementation of a possible loading sequence by which at least some of the contents of the ANR settings 527 to be stored in the storage 520 may be provided across the bus 535 from either the external storage device 170 or the processing device 9100. This loading sequence is intended to allow the ANR circuit 2000 to be flexible enough to accommodate any of a variety of scenarios without alteration, including and not limited to, only one of the storage device 170 and the processing device 9100 being present on the bus 535, and one or the other of the storage device 170 and the processing device 9100 not providing such contents despite both of them being present on the bus. The bus 535 may be either a serial or parallel digital electronic bus, and different devices coupled to the bus 535 may serve as a bus master at least coordinating data transfers.


Upon being powered up and/or reset, the processing device 510 accesses the storage 520 to retrieve and execute a sequence of instructions of the loading routine 522. Upon executing the sequence of instructions, at 632, the processing device 510 is caused to operate the interface 530 to cause the ANR circuit 2000 to enter master mode in which the ANR circuit 2000 becomes a bus master on the bus 535, and then the processing device 510 further operates the interface 530 to attempt to retrieve data (such as part of the contents of the ANR settings 527) from a storage device also coupled to the bus 535, such as the storage device 170. If, at 633, the attempt to retrieve data from a storage device succeeds, then the processing device 510 is caused to operate the interface 530 to cause the ANR circuit 2000 to enter a slave mode on the bus 535 to enable another processing device on the bus 535 (such as the processing device 9100) to transmit data to the ANR circuit 2000 (including at least part of the contents of the ANR settings 527) at 634.


However, if at 633, the attempt to retrieve data from a storage device fails, then the processing device 510 is caused to operate the interface 530 to cause the ANR circuit 2000 to enter a slave mode on the bus 535 to enable receipt of data from an external processing device (such as the external processing device 9100) at 635. At 636, the processing device 510 is further caused to await the receipt of such data from another processing device for a selected period of time. If, at 637, such data is received from another processing device, then the processing device 510 is caused to operate the interface 530 to cause the ANR circuit 2000 to remain in a slave mode on the bus 535 to enable the other processing device on the bus 535 to transmit further data to the ANR circuit 2000 at 638. However, if at 637, no such data is received from another processing device, then the processing device 510 is caused to operate the interface 530 to cause the ANR circuit 2000 to return to being a bus master on the bus 535 and to again attempt to retrieve such data from a storage device at 632.



FIGS. 9
a and 9b each depict a manner in which either of the internal architectures 2200a and 2200b may support the provision of side-chain data to the external processing device 9100, possibly to enable the processing device 9100 to add adaptive features to feedback-based and/or feedforward-based ANR functions performed by the ANR circuit 2000. In essence, while the ANR circuit 2000 performs the filtering and other aspects of deriving feedback and feedforward anti-noise sounds, as well as combining those anti-noise sounds with pass-through audio, the processing device 9100 performs analyses of various characteristics of feedback and/or feedforward reference sounds detected by the microphones 120 and/or 130. Where the processing device 9100 determines that there is a need to alter the signal processing topology of the ANR circuit 2000 (including altering a filter block topology of one of the filter blocks 250, 350 and 450), alter VGA gain values, alter filter coefficients, alter clock timings by which data is transferred, etc., the processing device 9100 provides new ANR settings to the ANR circuit 2000 via the bus 535. As previously discussed, those new ANR settings may be stored in one or the other of the buffers 620a and 620b in preparation for those new ANR settings to be provided to components within the ANR circuit 2000 with a timing synchronized to one or more data transfer rates at which pieces of digital data representing sounds are conveyed between components within the ANR circuit 2000. Indeed, in this way, the provision of ANR by the ANR circuit 2000 can also be made adaptive.


In supporting such cooperation between the ANR circuit 2000 and the external processing device 9100, it may be deemed desirable to provide copies of the feedback reference data, the feedforward reference data and/or the pass-through audio data to the processing device 9100 without modification. However, it is contemplated that such data may be sampled at high clock frequencies, possibly on the order of 1 MHz for each of the feedback reference data, the feedforward reference data and the pass-through audio data. Thus, providing copies of all of such data at such high sampling rates through the bus 535 to the processing device 9100 may place undesirably high burdens on the ANR circuit 2000, as well as undesirably increase the power consumption requirements of the ANR circuit 2000. Further, at least some of the processing that may be performed by the processing device 9100 as part of such cooperation with the ANR circuit 2000 may not require access to such complete copies of such data. Therefore, implementations of the ANR circuit 2000 employing either of the internal architectures 2200a and 2200b may support the provision of lower speed side-chain data made up of such data at lower sampling rates and/or various metrics concerning such data to the processing device 9100.



FIG. 9
a depicts an example variant of the ADC 310 having the ability to output both feedforward reference data representative of the feedforward reference analog signal received by the ADC 310 from the feedforward microphone 130 and corresponding side-chain data. This variant of the ADC 310 incorporates a sigma-delta block 322, a primary downsampling block 323, a secondary downsampling block 325, a bandpass filter 326 and a RMS block 327. The sigma-delta block 322 performs at least a portion of a typical sigma-delta analog-to-digital conversion of the analog signal received by the ADC 310, and provides the feedforward reference data at a relatively high sampling rate to the primary downsampling block 323. The primary downsampling block 323 employs any of a variety of possible downsampling (and/or decimation) algorithms to derive a variant of the feedforward reference data at a more desirable sampling rate to whatever combination of VGAs, digital filters and/or summing nodes is employed in deriving feedforward anti-noise data representing anti-noise sounds to be acoustically output by the acoustic driver 190. However, the primary downsampling block 323 also provides a copy of the feedforward reference data to the secondary downsampling block 325 to derive a further downsampled (and/or decimated) variant of the feedforward reference data. The secondary downsampling block 325 then provides the further downsampled variant of the feedforward reference data to the bandpass filter 326 where a subset of the sounds represented by the further downsampled feedforward reference data that are within a selected range of frequencies are allowed to be passed on to the RMS block 327. The RMS block 327 calculates RMS values of the further downsampled feedforward reference data within the selected range of frequencies of the bandpass filter 326, and then provides those RMS values to the interface 530 for transmission via the bus 535 to the processing device 9100.


It should be noted that although the above example involved the ADC 310 and digital data associated with the provision of feedforward-based ANR, similar variations of either of the ADCs 210 and 410 involving either of the feedback-based ANR and pass-through audio, respectively, are possible. Also possible are alternate variations of the ADC 310 (or of either of the ADCs 210 and 410) that do not incorporate the secondary downsampling block 325 such that further downsampling (and/or decimating) is not performed before data is provided to the bandpass filter 326, alternate variations that employ an A-weighted or B-weighted filter in place of or in addition to the bandpass filter 326, alternate variations that replace the RMS block 327 with another block performing a different form of signal strength calculation (e.g., an absolute value calculation), and alternate variations not incorporating the bandpass filter 326 and/or the RMS block 327 such that the downsampled (and/or decimated) output of the secondary downsampling block 325 is more conveyed to the interface with less or substantially no modification.



FIG. 9
b depicts an example variant of the filter block 350 having the ability to output both feedforward anti-noise data and side-chain data corresponding to the feedforward reference data received by the filter block 350. As has been previously discussed at length, the quantity, type and interconnections of filters within the filter blocks 250, 350 and 450 (i.e., their filter block topologies) are each able to be dynamically selected as part of the dynamic configuration capabilities of either of the internal architectures 2200a and 2200b. Therefore, this variant of the filter block 350 may be configured with any of a variety of possible filter block topologies in which both of the functions of deriving feedforward anti-noise data and side-chain data are performed.



FIGS. 10
a and 10b each depict a manner in which either of the internal architectures 2200a and 2200b may support binaural feedforward-based ANR in which feedforward reference data is shared between a pair of the ANR circuits 2000 (with each incarnation of the ANR circuit 2000 providing feedforward-based ANR to a separate one of a pair of the earpieces 100). In some implementations of the personal ANR device 1000 having a pair of the earpieces 100, feedforward reference data representing sounds detected by separate feedforward microphones 130 associated with each of the earpieces 100 is provided to both of the separate ANR circuits 2000 associated with each of the earpieces. This is accomplished through an exchange of feedforward reference data across a bus connecting the pair of ANR circuits 2000.



FIG. 10
a depicts an example addition to a signal processing topology (perhaps, any one of the signal processing topologies previously presented in detail) that includes a variant of the filter block 350 having the ability to accept the input of feedforward reference data from two different feedforward microphones 130. More specifically, the filter block 350 is coupled to the ADC 310 to more directly receive feedforward reference data from the feedforward microphone 130 that is associated with the same one of the earpieces to which the one of the ANR circuits 2000 in which the filter block 350 resides is also associated. This coupling between the ADC 310 and the filter block 350 is made in one of the ways previously discussed with regard to the internal architectures 2200a and 2200b. However, the filter block 350 is also coupled to the interface 530 to receive other feedforward reference data from the feedforward microphone 130 that is associated with the other of the earpieces 100 through the interface 530 from the ANR circuit 2000 that is also associated with the other of the earpieces 100. Correspondingly, the output of the ADC 310 by which feedforward reference data is provided to the filter block 350 is also coupled to the interface 530 to transmit its feedforward reference data to the ANR circuit 2000 associated with the other one of the earpieces 100 through the interface 530. The ANR circuit 2000 associated with the other one of the earpieces 100 employs this same addition to its signal processing topology with the same variant of its filter block 350, and these two incarnations of the ANR circuit 2000 exchange feedforward reference data through their respective ones of the interface 530 across the bus 535 to which both incarnations of the ANR circuit 2000 are coupled.



FIG. 10
b depicts another example addition to a signal processing topology that includes a variant of the filter block 350. However, this variant of the filter block 350 is involved in the transmission of feedforward reference data to the ANR circuit 2000 associated with the other one of the earpieces 100, in addition to being involved in the reception of feedforward reference data from that other incarnation of the ANR circuit 2000. Such additional functionality may be incorporated into the filter block 350 in implementations in which it is desired to in some way filter or otherwise process feedforward reference data before it is transmitted to the other incarnation of the ANR circuit 2000.



FIG. 11 depicts signal processing topology aspects of a coordinated compression of feedback and feedforward reference sounds in response to occurrences of excessively high environmental noise sound levels. In situations where environmental noise sounds reach sufficiently high levels of acoustic energy, one or both of feedback-based and feedforward-based ANR may be overloaded to the extent that the provision of ANR is compromised, and possibly to the extent that acoustic noise is actually generated. FIG. 11 presents a simplified depiction of additions and/or modifications that may be made to some signal processing topologies (such as the signal processing topologies 2500a through 2500g of FIGS. 4a through 4g, respectively) to perform such coordinated compression in such situations.


Regarding feedforward-based ANR, the diaphragm of the feedforward microphone 130 may be vibrated by such high environmental noise sound levels to such an extent that the voltage levels of the electrical signal output by the feedforward microphone 130 that is meant to represent the feedforward reference sounds may cease to have a linear relationship with the physical movement of its diaphragm, possibly to the extent that clipping occurs in that electrical signal. If such a clipped non-linear electrical signal is then used as a representation of feedforward reference sounds, then a clipped form of feedforward anti-noise sounds will be created that will be incapable of providing effective feedforward-based ANR. Further, the result may also be the generation of feedforward anti-noise sounds that actually include additional noise that effectively bring about a resulting amplification of environmental noise sounds as those clipped feedforward anti-noise sounds are acoustically output by the acoustic driver 190.


Further, regardless of whether or not feedforward anti-noise sounds are generated from a distorted electrical signal that is meant to represent feedforward reference noise sounds, such high environmental noise levels can cause the generation of feedforward and/or feedback anti-noise sounds having an amplitude sufficient that clipping occurs in the acoustic output of one or both of those anti-noise sounds as a result of limitations in the audio amplifier 960 and/or the acoustic driver 190 being reached. As those skilled in the art will readily recognize, occurrences of clipping (or other acoustic artifacts) in the acoustic output of sounds can cause those output sounds to be distorted. Where this happens to anti-noise sounds, the result can be a reduction in the degree of ANR provided, and possibly the generation of additional noise sounds.


As has been previously discussed, both generally and more specifically in reference to the signal processing topologies 2500f-g depicted in FIGS. 4f-g, respectively, the compression controller 950 may respond to any of a number of events by operating the VGAs 125 and 135 (if present), the VGAs 220 and 320 (if present) and/or other VGAs that may be present to reduce the gain to which the feedback reference sounds and feedforward reference sounds, respectively, are subjected prior to being provided to various filters for the generation of anti-noise sounds (e.g., filter blocks 250 and 350). As has also been previously discussed, a pair of VGAs, such as the pair of analog VGAs 125 and 135 or the pair of digital VGAs 220 and 320, may be controlled in a coordinated manner, possibly to balance the relative amplitudes of analog signals representing the feedback and feedforward reference sounds, and/or possibly to limit the numeric values of digital data conveyed with digital signals representing the feedback and feedforward reference sounds. In other words, a pair of VGAs, such as the pair of analog VGAs 125 and 135 or the pair of digital VGAs 220 and 320, may be controlled in a coordinated manner balance the relative amplitudes of feedback and feedforward reference sounds (whether represented in analog or digital form).


More specifically and as is depicted in FIG. 11, the compression controller 950 may operate either the pair of VGAs 125 and 135 or the pair of VGAs 220 and 320 to reduce the gains to which signals representing feedback reference sounds and feedforward reference sounds are subjected in a coordinated manner in response to receiving an indication that environmental noise sounds (such as those emanating from the acoustic noise source 9900) have reached at least one predetermined level of acoustic energy (e.g., a predetermined sound pressure level). This may be done by directly monitoring the amplitude of feedforward reference sounds as detected by the feedforward microphone 130 (as specifically depicted in FIG. 11). In some embodiments, that indication may be an occurrence of an acoustic artifact or an amplitude exceeding a predetermined level detected in signals conveying feedforward reference sounds from the feedforward microphone 130. In other embodiments, that indication may be an occurrence of an acoustic artifact (e.g., clipping) or an amplitude of a sound exceeding a predetermined level detected by the compression controller 950 in a signal conveying at least an anti-noise sound to be acoustically output by the acoustic driver 190 (as specifically depicted in FIG. 11). In still other embodiments, that indication may be an occurrence of an acoustic artifact or an amplitude of a sound exceeding a predetermined level detected by the compression controller 950 anywhere along the feedback-based ANR pathway 200 and/or the feedforward-based ANR pathway 300. In yet other embodiments, that indication may be an external control signal received from another device (not shown), where that other device may have in some way determined that the acoustic level of an environmental noise sound has reached a predetermined level.


Attenuating both the feedforward and feedback reference sounds in a coordinated manner serves to avoid situations in which relative differences in strengths of the resulting feedforward and feedback anti-noise sounds are allowed to differ too greatly. For example, if feedforward reference sounds are not attenuated as feedback reference sounds are attenuated such that the strength of the feedforward reference sounds is allowed to far exceed that of the feedback reference sounds, saturation of the compression of the feedback reference sounds may occur. As those skilled in the art of combining feedforward-based and feedback-based ANR will readily recognize, where the feedforward ANR anti-noise sound is summed towards the feedback loop output, the strength of feedforward anti-noise sounds is reduced by the desensitivity of the loop that is formed in implementing feedback-based ANR, and the strength of feedforward anti-noise sounds will then increase as gain in the loop of the feedback-based ANR is decreased by compressor action. In some embodiments, this increase in the strength of the feedforward anti-noise sounds can, if allowed to become too great relative to the strength of the feedback anti-noise sounds, actually induce further compression in the feedback-based ANR loop to the point of compression saturation such that the strength of feedback anti-noise sounds is actually reduced to a degree that the provision of feedback-based ANR is fully lost. Further, the resulting absence of feedback-based ANR can induce still further increases in the strength of the feedforward anti-noise sounds in an effort to compensate for the absence of feedback-based ANR. Under these conditions, the feedforward anti-noise sounds could be supplied to the audio amplifier 960 and/or the acoustic driver 190 with such strength that clipping of the feedforward anti-noise sounds occurs as a result of limitations in the audio amplifier 960 to amplify audio and/or in the acoustic driver 190 to acoustically output audio being reached or exceeded, thereby further compromising the provision of ANR.


As is also more specifically depicted in FIG. 11, the compression controller 950 may operate a pair of VGAs to compress signals representing feedforward reference sounds with a steeper slope of attenuation than signals representing feedback reference sounds. In other words, the compression controller 950 may operate the pair of VGAs to compress the amplitude of the feedforward reference sounds to a greater degree than the feedback reference sounds. This may be done in an effort to avoid occurrences of the aforedescribed scenario of saturation of compression in the loop of the feedback-based ANR. It may also be deemed desirable to do this in recognition of the more direct and greater effect that environmental noise sounds are likely to have on the feedforward microphone 130 than on the feedback microphone 120.


Variable degrees of compression may be employed in embodiments in which the compression controller 950 is provided with indications of amplitudes, voltage levels and/or magnitudes of data values of signals conveying either feedforward reference sounds or anti-noise sounds for acoustic output, wherein the variable degrees of attenuation of the feedforward and feedback reference noise sounds are derived in relation to such amplitudes, voltage levels and/or magnitudes. It should be noted that although FIG. 11 depicts substantially linear slopes of attenuation as being employed by the compression controller in operating a pair of VGAs, non-linear curves representing any of a variety of linear and/or non-linear relations between the degrees of attenuation that may be employed and one or more of amplitudes, voltage levels, magnitudes and/or signal time histories.


As if further more specifically depicted in FIG. 11, the compression of at least the feedforward reference sound may level off after reaching a certain degree of compression. Given that the degree of compression of the feedforward reference sound may, in some embodiments, be increased at a greater rate than the degree of compression of the feedback reference sound (again, as indicated by the depicted steeper slope), it may be that this leveling off of the compression of the feedforward reference sound is a result of the maximum possible compression of the feedforward reference sound being reached before the maximum possible compression of the feedback reference sound is reached. In other words, whatever VGA is employed in compressing the feedforward reference sound may be operated such that the feedforward reference sound is compressed to the extent that its amplitude is reduced to close to zero (possibly reduced fully to zero) while the feedback reference sound is not. Alternatively, limitations in whatever VGA or other component is involved in compressing the feedforward reference sound may set a maximum degree of compression of the feedforward reference sound that cannot be exceed. Alternatively and/or additionally, other design considerations may result in it being deemed in some way desirable that the degree of compression of the feedforward reference sound never be allowed to reach the extent that its amplitude is reduced close to zero (or reduced fully to zero).



FIGS. 12
a and 12b each depict variations of a number of possible additions to the internal architectures 2200a and 2200b, respectively, of the ANR circuit 2000. Therefore, it should be noted that for sake of simplicity of discussion, only portions of the internal architectures 2200a and 2200b associated with these possible additions are depicted, while other portions (e.g., portions related to pass-through audio that may be present) are omitted. Some of these possible additions rely on the use of the interface 530 coupling the ANR circuit 2000 to other devices via at least one bus 535.


More particularly, in preparation for operating either the pair of VGAs 125 and 135 (if present) or the pair of VGAs 220 and 320 (wherein the VGAs 220 and 320 are either selected from the VGA bank 560 or instantiated from the VGA routine 561), the processing device 510 may be caused (perhaps by the loading routine 522) to configure the ANR circuit 2000 to accept data specifying coordinated gain values from the storage device 170, another ANR circuit 2000 and/or a processing device 9100. In some embodiments, the data specifying coordinated gain values may be made up of one or more pairs of gain values to be provided to either the pair of VGAs 125 and 135 or the pair of VGAs 220 and 320 in response to an occurrence of the acoustic energy (e.g., sound pressure level) of environmental noise sounds reaching at least one predetermined level. In such embodiments, the one or more pairs of gain values may be stored in the storage 520 as part of the ANR settings 527, and/or may be provided in real time from one or both of the other ANR circuit 2000 and the processing device 9100 during normal operation of the personal ANR device 1000. In other embodiments, the data specifying coordinated gain values may be data specifying mathematic or other relationships by which coordinated gain values may be mathematically (or in some other way) derived from an amplitude, voltage level, magnitude or signal time history by the processing device 510 as part of executing the ANR routine 525.


Where coordinated gain values are received by the ANR circuit 2000 through the interface 530 from another device, and where that other device is the other ANR circuit 2000, the coordinated gain values may be provided in response to a feedforward microphone (not shown) of the other ANR circuit 2000 encountering environmental noise sounds having an energy level that reached at least one predetermined level. This may occur where a feedforward microphone of the other ANR circuit 2000 encounters such environmental noise sounds in a situation where the feedforward microphone 130 does not, or where the feedforward microphone of the other ANR circuit 2000 encounters such environmental noise sounds sooner than the feedforward microphone 130. Such conveyance of coordinated gain values between the ANR circuit 2000 and the other ANR circuit 2000 may occur as part of the provision of binaural feedforward-based ANR as previously described.


Where coordinated gain values are received by the ANR circuit 2000 through the interface 530 from another device, and where that other device is the processing device 9100, the coordinated gain values may be provided in response to one or both of the feedforward microphone 130 and another feedforward microphone (not shown) of the other ANR circuit 2000 encountering environmental noise sounds having an energy level that reaches a predetermined level. The processing device 9100 may normally be employed to execute a sequence of instructions that causes the processing device 9100 to perform one or more forms of analysis on at least feedforward reference sounds detected by the feedforward microphone 130 and/or the other feedforward microphone, but may also be further employed to function as a form of compression controller to provide the coordinated gain values to the ANR circuit 2000.


Regardless of the manner in which the coordinated gain values for a pair of VGAs are either received or derived, the manner in which they are provided to a pair of VGAs may entail the use of triple-buffering as previously described. In some embodiments, the buffers 620a and 620b (see FIGS. 6a through 6c) are employed in making timing-coordinated changes of at least the gain settings of at least the pair of VGAs 125 and 135 (if present) or the VGAs 220 and 320 (if present), while the buffer 620c holds coordinated gain values deemed to be conservative enough to be a “failsafe” pair of gain values to be used in instances where instability in the provision of ANR is detected.


Turning to FIG. 12a and as has been previously described, in the internal architecture 2200a, the compression controller 950 may be implemented as distinct circuitry within the ANR circuit 2000. Turning to FIG. 12b and has also been previously described, in the internal architecture 2200b, the compression controller 950 may be caused to be implemented by the processing device 510 as a result of executing a sequence of instructions of the ANR routine 525. Either implementation of the compression controller 950 may monitor characteristics of anti-noise sounds to be acoustically output by the acoustic driver 190 either by receiving the digital data provided to the DAC 910 or by receiving digital data generated by the ADC 955 (if present) from the analog signal output by the audio amplifier 960. This may be done in addition to monitoring characteristics of feedforward reference noise sounds detected by the feedforward microphone 130, as has been described at length. Again, despite such specific depictions of the manner in which the compression controller 950 (whether implemented with distinct circuitry or as a sequence of instructions executed by a processing device) monitors sounds being acoustically output, as previously discussed, the compression controller 950 may more directly monitor feedforward reference sounds as detected by the feedforward microphone 130 and/or may monitor sounds at other locations along one or both of the feedback-based ANR pathway 200 and the feedforward-based ANR pathway 300.


It should be noted again that although implementations of the ANR circuit 2000 employing at least some digital circuitry have been depicted and discussed at length herein, those skilled in the art will readily recognize that each of the many embodiments of signal processing topologies and portions of signal processing topologies depicted and discussed herein may be implemented, either partially or entirely, using analog circuitry. Thus and more specifically, the modifications and/or portions of signal processing topologies depicted in FIG. 11 to implement the coordinated compression of feedforward and feedback reference sounds may be implemented entirely using analog circuitry.



FIG. 13 more clearly depicts an example of coordinated compression of both feedforward and feedback reference sounds with differing slopes, as previously discussed. FIG. 13 also depicts an example of using different predetermined threshold levels of acoustic energy in triggering the start of compression of feedforward reference sounds versus the start of compression of feedback reference sounds, and further depicts an example of using threshold levels that are dependent on frequency characteristics of the environmental noise sounds detected by the feedforward microphone 130.


It should be noted that although a linear rise in the acoustic energy of environmental noise sounds over a period of time is depicted, such a depiction should not be taken as limiting the scope of what is described or what is claimed herein to responding only to such an orderly and steady change in acoustic energy of environmental noise sounds, and should not be taken as reflecting a belief that such behavior of environmental noise sounds is in any way expected in real world conditions. It is to be understood that this very simplistic depiction of such an orderly and steady change in acoustic energy of environmental noise sounds is presented only to enable a greater understanding of the manner in which different levels of acoustic energy of environmental noise sounds may be responded to by what is described and what is claimed herein.


As depicted, as the level of acoustic energy of the environmental noise sounds (such as those emanating from the acoustic noise source 9900) increases, a predetermined threshold level of acoustic energy is reached at either T1 or T2 that serves as a trigger for causing the compression of feedforward reference sounds to begin. As the level of acoustic energy of the environmental noise sounds continues to increase, the degree of compression of feedforward reference sounds increases. As the level of acoustic energy of the environmental noise sounds still continues to increase, another predetermined threshold level of acoustic energy is reached at either T3 or T4 that serves as a trigger for causing the compression of feedback reference sounds to begin. As the level of acoustic energy of the environmental noise sounds yet continues to increase, the degree of compression of feedback reference sounds increases, as does also the degree of compression of feedforward reference sounds, although as is also depicted, the increases in compression of feedforward reference sounds occur at a greater rate following a steeper slope than the increases in compression of feedback reference sounds.


As also depicted, in some embodiments, the threshold levels of acoustic energy of environmental noise sounds may change depending on frequency characteristics of the environmental noise sounds. By way of example, the threshold level of acoustic energy at which compression of feedforward reference sounds is triggered may be changed such that it's reached either at T1 or T2, depending on whether the predominant frequencies of the environmental noise sounds are lower frequencies (such that the threshold is reached at T1) or higher frequencies (such that the threshold is reached at T2). Similarly, the threshold level of acoustic energy at which compression of feedback reference sounds is triggered may be changed between being reached at T3 or T4, depending on whether the predominant frequencies of the environmental noise sounds are lower frequencies (such that the threshold is reached at T3) or higher frequencies (such that the threshold is reached at T4).


This dependency of thresholds on frequency characteristics of environmental noise sounds may be employed in recognition of the different ranges of frequencies at which each form of noise reduction typically functions. Typically, the PNR provided by casing 110, ear coupling 115 and/or other physical features of the personal ANR device 1000 reduces environmental noise sounds to a greater degree at higher frequencies, the feedforward-based ANR acts to reduce environmental sounds at lower frequencies, and the feedback-based ANR acts to reduce environmental sounds at still lower frequencies. Thus, the feedforward-based and feedback-based ANR are more likely to be adversely affected by environmental noise sounds having very high acoustic energy levels at lower frequencies such that compression of feedforward and/or feedback reference sounds may provide greater benefits at lower frequencies. Therefore, where environmental noise sounds are made up of predominantly lower frequency sounds, the threshold(s) at which compression of feedforward and/or feedback reference sounds may be lowered such that compression of feedforward reference sounds is triggered at T1 (instead of at T2) and/or compression of feedback reference sounds is triggered at T3 (instead of T4 ).


Alternatively and/or additionally, this dependency of thresholds on frequency characteristics of environmental noise sounds may be employed in recognition of possible limitations of the acoustic driver 190 in acoustically outputting sounds of certain audible frequencies and/or ranges of audible frequencies. As will be familiar to those skilled in the art, it is common for acoustic drivers to acoustically output a sound of one audible frequency with greater acoustic energy than another sound of a different audible frequency despite such acoustic drivers being driven by an audio amplifier with equal electrical energy to acoustically output both sounds. Given that the earlier-described feedback-based ANR loop includes the acoustic driver 190, which may be subject to such limitations, it may be deemed desirable to select the thresholds by which the compression of feedforward reference sounds and the compression of feedback reference sounds are each triggered by environmental noise sounds of predominantly higher frequencies and of predominantly lower frequencies at least partly in recognition of those limitations.


The compression controller 950 may incorporate one or more filters to separate the feedforward reference sounds represented by signals provided to the compression controller 950 from the feedforward microphone 130 into sounds within two or more ranges of frequencies, and/or to determine the relative acoustic energies of the sounds within those two or more ranges of frequencies. Alternatively and/or additionally, filters of one or more of the filter blocks 250, 350 and 450 may be employed, perhaps in a manner in which the compression controller 950 receives the feedforward reference sounds in a form that is already separated into those two or more ranges of frequencies In the internal architecture 2200a, those filters may be provided from the filter bank 550. In the internal architecture 2200b, those filters may be instantiated and implemented by the processing device 510 through execution of one or more of the filter routines 553, 555, 557 and 559.



FIG. 14 depicts signal processing topology aspects of a more sophisticated form of frequency-dependent control of the compression of one or both of feedback and feedforward reference sounds. Whatever audio is selected to be used as an input to the compression controller 950 to enable triggering of compression is routed through a filter 952 that imposes a transform on that audio before it is provided to the compression controller 950 to vary the sensitivity of the compression controller 950 to different frequencies of that audio. In this way, the compression controller is caused to more or less aggressively compress one or both of the feedback and feedforward reference sounds depending on the magnitudes of different frequencies of sound present in that audio. FIG. 14 presents a simplified depiction of such additions and/or modifications that may be made to a signal processing topology (such as the signal processing topologies 2500a through 2500g of FIGS. 4a through 4g, respectively) to perform such frequency-dependent compression. It should be understood that in an effort to reduce visual clutter, the specific manner in which the filter blocks 250 and 350 are coupled to derive and combine feedback and feedforward anti-noise sounds from feedback and feedforward reference noise sounds is not specifically shown. In other words, portions of the signal processing topology involving the manner in which the filter blocks 250 and 350 are coupled are not specifically depicted.


As has been previously discussed, the need to compress one or both of feedback and feedforward reference sounds may arise in response to any of a number of events, including an occurrence of a noise sound having excessive acoustic energy such that the functionality of one or both of feedback-based and feedforward-based ANR is undesirably compromised without such compression. More generally, and has also been discussed at length, the need may arise to employ such compression where the amplitude of the analog signal representing the sound to be acoustically output by the acoustic driver 190 is sufficiently high that clipping may be caused by that amplitude exceeding limitations imposed by characteristics of the audio amplifier 960 and/or of the acoustic driver 190. Compression of one or both of feedback and feedforward reference sounds reduces the amplitude of sounds on which the derivation of anti-noise sounds is based, thereby reducing the amplitude of those anti-noise sounds so as to prevent clipping. Although this resulting reduction in amplitude of anti-noise sounds, in turn, results in a reduced provision of ANR, a temporary application of such compression is deemed to be much less objectionable than the audible results of allowing clipping to occur in the acoustic output of anti-noise sounds.


Alternatively and/or additionally, the need to compress one or both of the feedback and feedforward reference sounds may arise from a need to drive the acoustic driver 190 to acoustically output anti-noise sounds with greater acoustic energy at some frequencies while avoiding exceeding limits imposed by characteristics of the audio amplifier 960 and/or of the acoustic driver 190 where those limits may be more constraining at other frequencies. This need may arise where a personal ANR device (such as the personal ANR device 1000) is to be employed to counteract environmental noise sounds in an especially noisy environment, e.g., the interior of certain military vehicles, an engine room of a boat, a construction or mining site with loud machinery, etc.


The filter 952 may be any of a variety of types of filter configured to impose any of a variety of types of transform on whatever audio is employed as an input to the compression controller 950. The transform may be selected to define at least one lower limit to the amplitude at which at least one sound having one frequency may be driven before compression is applied by the compression controller 950, and at least one higher limit to the amplitude at which at least one other sound having a different frequency may be driven before compression is applied by the compression controller 950. The various limits in amplitude that are set by the choice of transform for which the filter 952 is configured may be chosen to avoid various undesirable situations that could arise at different frequencies as a result of achieving too high an amplitude, such as clipping, exceeding mechanical limits, etc.


By way of one example (not specifically depicted) in which an acoustic driver is operated in an open-air environment (i.e., not encumbered by being enclosed within a cavity of a casing, etc.) such that a diaphragm of the acoustic driver is able to freely move in the surrounding air, it may be deemed desirable to cause compression to be more aggressively applied at lower frequencies. More specifically, as those skilled in the operation of acoustic drivers will readily recognize, the mechanical impedance exerted by the surrounding air on a diaphragm of any acoustic driver is frequency-dependent. At lower frequencies (on the order of 100 Hz or less), the surrounding air and various mechanical aspects of an acoustic driver exert relatively little in the way of resistance against movements of its diaphragm such that it is easier for a sufficiently powerful audio amplifier to cause its diaphragm to move too far such that a component of an acoustic driver (e.g., the diaphragm, a magnet, a flexible electric conductor, a flexible support of that diaphragm, etc.) is moved too close to an undesirable limit in its range of movement. Indeed, it may be possible to damage one or more components of an acoustic driver under such circumstances. In contrast, at higher frequencies, surrounding air exerts significant resistance against movement of a diaphragm that it tends to be sufficiently restricted in its movement that such an undesirable reaching of such a limit tends not to occur (presuming that both of the lower and higher frequencies are driven at the same level). Thus, it is generally possible to safely drive an acoustic driver to output higher frequency sounds (sounds at frequencies generally greater than 100 Hz) with high acoustic energy with a lesser risk of mechanical damage to an acoustic driver component, but such risks become more prevalent at lower frequencies.


Thus, in this example, it may be deemed desirable to cause some form of compression to be more aggressively applied at the lower frequencies to prevent such mechanical damage to components of the acoustic driver, while causing compression to be less aggressively applied at higher frequencies where the risk of mechanical damage is considerably less. In other words, it may be deemed desirable to define a lower limit to the amplitude at which the lower frequencies may be acoustically output before compression is applied and a higher limit to the amplitude at which the higher frequencies may be acoustically output before compression is applied.


Returning to FIG. 14 and the example operation of the acoustic driver 190 within the casing 110 of one of the earpieces 100, configuring the filter 952 to cause the application of compression of feedback and/or feedforward reference noise sounds to be frequency-dependent may involve somewhat different transforms depending on whether the cavity 119 (best seen in FIG. 1) is or is not acoustically coupled in some way to the environment external to the casing 110. Where the cavity 119 is not so coupled, where it is desired to acoustic output anti-noise sounds of considerable amplitude so as to counteract noise sounds of considerable amplitude, and where the audio amplifier 960 is sufficiently powerful, the concerns that may make the use of frequency-dependent compression desirable are rather similar to those in the earlier example of an open-air acoustic driver.


More specifically, the mechanical impedance exerted on a diaphragm of the acoustic driver 190 at higher frequencies (e.g., frequencies generally above 100 Hz) is significant, just as was the case with the earlier open-air acoustic driver example. Indeed, unless the cavity 119 is very small in relation to the size of the diaphragm of the acoustic driver 190, the significant mechanical impedance at higher frequencies of the earlier example of the open-air acoustic driver may be quite similar to the acoustic driver 190 within the casing 110 where the cavity 119 is not coupled to the external environment. Thus, at higher frequencies, it may again be desirable to cause the application of compression to be less aggressive, and therefore, the filter 952 may be configured to implement a transform that causes the compression controller 950 to be less sensitive to high amplitudes at higher frequencies. As a result, a higher threshold of amplitude is defined at higher frequencies such that a higher frequency sound would have to have an amplitude that reaches that higher threshold before the compression controller 950 would apply compression. However, the lack of acoustic coupling of the cavity 119 to the environment external to the casing 110 makes more of difference in the operation of the acoustic driver 190 as compared to the earlier example of open-air operation of an acoustic driver at lower frequencies (e.g., frequencies on the order 100 Hz and less). As those skilled in the art will readily recognize, there is a considerable increase in the mechanical impedance exerted on the diaphragm of the acoustic driver 190 at lower frequencies with the cavity 119 not be coupled to the external environment. As a result, at such lower frequencies, the audio amplifier 960 would have to operate the acoustic driver 190 with considerably more electrical energy to cause a mechanical limit of a component of the acoustic driver 190 to be reached than would be required if the acoustic driver 190 were operated in an open-air environment. Therefore, at lower frequencies, although reaching a mechanical limit of the acoustic driver 190 from moving its diaphragm is still a concern, but to a lesser degree. Thus, at lower frequencies, it may again be desirable to cause the application of compression to be more aggressive, and therefore, the filter 952 may be configured to implement a transform that causes the compression controller 950 to be more sensitive to high amplitudes at lower frequencies. As a result, a lower threshold of amplitude is still defined at lower frequencies such that a lower frequency sound would have to have an amplitude that reaches only that lower threshold before the compression controller 950 would apply compression. However, the lower threshold may be set somewhat higher than it would otherwise be set if the acoustic driver 190 were operated in an open-air environment.



FIG. 15 depicts another example in which it may be desired to cause the compression controller 950 to apply compression in a frequency-dependent manner. More specifically, FIG. 15 depicts an alternate variant of the example just described in which the acoustic driver 190 is enclosed by the casing 110, but in this example, the cavity 119 is coupled to the environment external to the casing 110. Although this was earlier depicted in FIG. 1 with a rather simple depiction of a single acoustic port, it was presented as possible that more than one acoustic port may provide such a coupling, and FIG. 15 depicts such a more complex coupling through a resistive port 195 and a mass port 198. The resistive port 195 may be formed with a piece of acoustically resistive material 196 positioned within the resistive port 195, as depicted, or with a piece of resistive material overlying the resistive port 195 either where the resistive port 195 opens to the environment external to the casing 110 or where it opens into the cavity 119. The mass port 198 may be formed as an opening between the cavity 119 and the environment external to the casing 110 having dimensions and/or a shape that tunes the resonance of the mass port 198 with the compliance of the cavity 119 to effectively acoustically couple the cavity 119 to the environment external to the casing 110 below a selected tuning frequency while acoustically isolating the cavity 119 from the environment external to the casing 110 above the tuning frequency. The provision of one or both of the resistive port 195 and the mass port 198 may be done to enhance characteristics of the acoustic output of sounds by the acoustic driver 190 (e.g., in acoustically outputting lower frequencies) and/or to enable the cavity 119 to be made smaller, as described in greater detail in U.S. Pat. No. 6,831,984 issued Dec. 14, 2004, to Roman Sapiejewski, assigned to Bose Corporation of Framingham, Massachusetts, and hereby incorporated by reference.


Beyond the possibility of one or more acoustic ports coupling the cavity 119 to the external environment (e.g., the resistive port 195 and the mass port 198), other variations of an earpiece 100 are possible in which one or more acoustic ports may be formed in the casing 110 to couple the cavity 112 to environment external to the casing 110. Such coupling of the cavity 112 to the external environment may be done for any of a number of reasons, including the provision of some degree of predictable and constant leak between the cavity 112 and the external environment as an aid to stabilizing the provision of ANR as described in greater detail in U.S. patent application Ser. No. 12/719,903 filed Mar. 9, 2010 by Jason Harlow et al, assigned to Bose Corporation of Framingham, Massachusetts, and hereby incorporated by reference.


Such couplings between the external environment and one or both of the cavities 112 and 119 may have a “tuned” characteristic in which such couplings take on a behavior of acting like openings to the external environment at some frequencies, while also acting as if they are closed to the external environment at other frequencies. As a result, a diaphragm of the acoustic driver 190 may encounter less mechanical impedance exerted by surrounding air at some frequencies due to such ports acting like openings at those frequencies (allowing air within one or more cavities to freely move through those ports), but encounter greater mechanical impedance from the surrounding air at other frequencies where those ports act as if they are closed at those other frequencies. At those frequencies where less mechanical impedance is encountered, a diaphragm of the acoustic driver 190 may be free enough to move that there is a risk of that diaphragm traveling too far such that a component of the acoustic driver 190 is moved too close to an undesirable limit in its range of movement.


In the example depicted in FIG. 15, the combination of the resistive port 195 and the mass port 198 is tuned such that the cavity 119 is coupled to the environment external to the casing 110 at frequencies of about 40 Hz and below, and is relatively closed to that external environment at frequencies of about 100 Hz and above, with a transition between being open and closed between 40 Hz and 100 Hz. Thus, in a manner somewhat similar to the previous example of an open-air acoustic driver and the previous example of the acoustic driver 190 within the casing 110 with no ports coupling the cavity 119 to the external environment, a diaphragm of the acoustic driver 190 encounters less resistance to movement from the surrounding generally at frequencies of 100 Hz or less, and encounters significant resistance to movement at frequencies above 100 Hz. This presents a risk of a mechanical limit of the acoustic driver 190 being reached at lower frequencies that is greater than where the cavity 119 is not coupled to the external environment, and indeed, this risk may be similar to what it would be if the acoustic driver 190 were operated in an open-air environment. Thus, again, especially where it is desired to drive the diaphragm with enough energy to provide ANR to attenuate rather loud noise sounds, it may again be desired to configure the filter 952 to implement a transform that causes the compression controller 950 to more aggressively compress the feedback and/or feedforward reference noise sounds at lower frequencies and to less aggressively do so at higher frequencies.



FIG. 15 specifically depicts such a transform. In essence, the filter 952 is configured to function as a shelf filter. Sounds having frequencies up to 40 Hz pass through the filter 952 with greater amplitude such that the compression controller is made more sensitive to their amplitude, sounds having frequencies greater than 100 Hz pass through the filter 952 with a lesser amplitude such that the compression controller is less sensitive to their amplitude, and sounds in the 40-100 Hz range of frequencies pass through the filter 952 with decreasing amplitude as the frequency increases within that range. Thus, a sound having a frequency of 100 Hz or greater is allowed to reach a higher amplitude before the compression controller 950 begins applying compression, while a sound having a frequency of 40 Hz or lower cannot reach as high an amplitude before the compression controller 950 begins applying compression. Again, the amplitude that lower frequency sounds are permitted to reach before the compression controller 950 is caused to apply compression is selected to at least prevent the diaphragm of the acoustic driver 190 from being moved too far, and the amplitude that higher frequency sounds are permitted to reach before the compression controller 950 is caused to apply compression is selected to at least prevent clipping in the output of the amplifier 960 that drives the acoustic driver 190.



FIG. 15 also depicts a way in which the filter 952 may be employed to compensate for the presence of a resonant frequency. As those skilled in the art will recognize, various electronic and/or acoustic components of a personal ANR device (e.g., components of an earpiece 100 of the personal ANR device 1000) may tend to resonate at one or more frequencies, and at these resonant frequencies, a diaphragm of the acoustic driver 190 may be able to move to a substantially greater degree due to interactions of reactive portions of impedances of that diaphragm and surrounding structure (e.g., portions of the casing 110 defining one or both of the cavities 112 and 119). Thus, at such resonant frequencies, it becomes easier for the diaphragm to be moved to a greater degree with less electrical energy output by the audio amplifier 960, and therefore, more likely that the diaphragm to be moved too far to the extent that mechanical damage to the acoustic driver 190 results. To counteract this, and as shown in dotted lines in FIG. 15, the transform that the filter 952 is configured to implement may include a high-order “peak” that is centered about a resonant frequency to increase the sensitivity of the compression controller 950 to sounds occurring at or close to that resonant frequency so that the compression controller 950 more aggressively applies compression in response to such sounds at a lower amplitude than sounds occurring at frequencies above or below.


Regardless of the exact nature of the purpose for incorporating such a frequency-dependent form of compression, the exact nature of its implementation may take any of a variety of forms. By way of example, where the compression controller 950 is a distinct circuit capable of directly receiving an analog audio signal, and where the audio to be provided to the compression controller 950 to trigger compression is represented with an analog signal (e.g., an analog signal output of feedback microphone 120 or the feedforward microphone 130, or an analog signal input to audio amplifier 960 or the acoustic driver 190), the filter 952 may be implemented entirely with analog circuitry. By way of another example, where the compression controller 950 is either a distinct digital circuit or is implemented as a sequence of instructions executed by a processing device (e.g., the processing device 510) in which the audio to be provided to the compression controller 950 to trigger compression must be represented with digital data (e.g., must be an output of one of the ADCs 210, 310, 410 or 955), the filter 952 may be a distinct digital circuit (e.g., one of the filters selected from the filter bank 550) or may be implemented as a sequence of instructions (e.g., an instantiation of one of the downsampling filter routine 553, the biquad filter routine 555, the interpolating filter routine 557, or the FIR filter routine 559) executed by a processing device.


Although FIG. 15 specifically depicts a simple shelf filter transform being implemented by the filter 952, it should be noted that any of a variety of transforms may be implemented by the filter 952. It should also be noted that although the use of the single filter 952 to impose a transform on audio provided to the compression controller 950 has been depicted and described, other variations are possible in which more than one filter is employed in series and/or in parallel to implement a more complex transform. The transform implemented by the filter 952 (whether it is a single filter or actually multiple filters) may be derived by a processing device (e.g., the processing device 510 or the processing device 9100) during operation of the ANR circuit 2000 based on characteristics of audio detected within the cavity 112 or elsewhere, or may be selected from a multitude of transforms stored in the storage 520 and/or the storage device 170.


Further, where the filter 952 is a portion of the ANR circuit 2000 of the personal ANR device 1000 in which a variety of aspects of operation are dynamically configurable during normal operation, the type of filter used in implementing the filter 952 may be dynamically selected either from the filter bank 550 or from among multiple filter routines stored within the storage 520, and/or the transform implemented by the filter 952 may be dynamically alterable, perhaps through use of the earlier-described buffers 620a-c. Indeed, it may be deemed desirable to enable one or both of these aspects of the filter 952 to be changeable along with types of filters incorporated into the filter blocks 250, 350 and/or 450, along with their coefficients. Indeed, it may be deemed desirable for there to be a “failsafe” selection of a type of filter to be used in implementing the filter 952 and a “failsafe” set of coefficients with which to program the filter 952 included with other failsafe values.


As has been depicted and discussed in considerable detail, a response to an instance of instability, an instance of a sound having an excessive amplitude, an occurrence of an audio artifact, an impending instance of clipping in an analog signal representing a sound to be acoustically output, etc., is to compress one or more sounds (e.g., one or both of the feedback and feedforward reference sounds) in a manner that entails reducing the amplitude of those sounds. As has already been discussed, and as those skilled in the art will readily recognize, providing either feedback-based or feedforward-based ANR entails providing a noise sound that is detected by a microphone as a reference noise sound to one or more filters implementing an ANR transform (sometimes also referred to as an “ANR compensator”) to derive an anti-noise sound that destructively interacts with the noise sound at a predetermined location when the anti-noise sound is acoustically output by an acoustic driver towards that predetermined location (e.g., a location adjacent an ear, in the case of a personal ANR device, such as the personal ANR device 1000). Thus, where a feedback or feedforward reference noise sound is compressed in amplitude, a corresponding reduction in amplitude of an anti-noise sound derived from that reference noise sound results. Although such use of compression of amplitude may be effective in counteracting an instance of instability, an instance of excessive amplitude, an occurrence of an audio artifact or an impending instance of clipping (i.e., as clipping is about to occur so as to prevent it occurring), it typically comes at the cost of reducing the amplitude of the whole range of frequencies anti-noise sounds.



FIG. 16 depicts an application of an alternative to compressing the amplitude of a reference noise sound in which a lower or upper limit of a range of frequencies at which a form of ANR is provided is altered in response to such events as instability, excessive amplitude, audio artifact or an impending instance of clipping. More specifically, FIG. 16 depicts an instance of a lower limit of a range of frequencies at which feedback-based ANR is provided being changed to momentarily reduce the range of frequencies at which feedback-based ANR is provided. As depicted, the lower limit of the range of frequencies at which feedback-based ANR is provided is raised such that the range of frequencies over which feedback-based ANR is provided ceases to include at least some lower frequencies in the range of 10 Hz to 100 Hz. As can be seen, the manner in which the lower limit of the range of frequencies of feedback-based ANR entails a sliding of the cutoff frequency and transition band that define the lower limit. The slope within the transition band is substantially maintained during this raising and lowering of the lower limit such that these changes to the lower limit might be called “sliding” the lower limit, first to a higher frequency, and then returning to its original lower frequency at a later time.


This is done, as depicted, in an example where the provision of feedback-based ANR, feedforward based ANR and PNR are each configured in magnitude and range of frequencies to cooperate to provide a relatively constant magnitude of noise reduction across a wide range of audible frequencies in a personal ANR device (such as the personal ANR device 1000). As will be familiar to those skilled in the art, acoustic and electrical propagation delays through components of a device providing ANR, along with limitations in the range of frequencies supported by electrical and/or acoustic aspects of those components, result in the difficulty in providing anti-noise sounds with a phase aligned closely enough with the phase of noise sounds to enable effective attenuation of noise sounds increasing as frequency increases. Thus, the provision of either feedback-based or feedforward-based ANR is typically only at lower frequencies (e.g., at audible frequencies from about 20 Hz up to perhaps 2 KHz), with PNR typically being largely relied upon to provide attenuation at higher audible frequencies.


Past observations have revealed that at least some events associated with instances of instability or clipping (perhaps allowed to occur or made worse by a leak in an acoustic seal employed in enclosing an environment in which ANR is provided) tend to involve noise sounds at lower frequencies (e.g., frequencies generally around 10-80 Hz). Such events often occur where there is a loss of an acoustic seal that is meant to define an acoustic environment of limited volume in which ANR is meant to be provided such that at least the feedback-based ANR responds by increasing the amplitude of its anti-noise sounds in an effort in vain to attenuate noise sounds in an acoustic environment that extends beyond and is far larger than the originally intended acoustic environment of limited volume. Thus, as an alternative to reducing an amplitude of a reference noise sound provided as input to filters implementing an ANR transform, the ANR transform may be altered so as to raise the lower limit of the frequencies across which anti-noise sounds are provided. In some embodiments, this lower limit is raised in increments to higher and higher frequencies until the event or impending event triggering this raising of the lower limit has been addressed. There may be a predetermined frequency at which beyond which the lower limit is not permitted to be raised, and the fact of this limit being reached (or approached too closely) may serve as a trigger to employ a more conventional compression of an amplitude or other measure. In other embodiments, this lower limit is raised in increments to a predetermined more conservative lower limit chosen to not include noise sounds at such troublesome frequencies. In other words, the ANR transform is altered to cease deriving anti-noise sounds from reference noise sounds at those lower frequencies in order to avoid deriving anti-noise sounds from noise sounds often associated with such events. In carrying out such a raising of the lower limit, the lower limit may be raised relatively quickly (especially if being done in response to detecting an instance of instability), but not so quickly that “pop” or “snap” sounds, or other audible artifacts are created (e.g., perhaps over a period of time on the order of 10 msec). This may then be followed by a gradual lowering of the lower limit at a somewhat slower rate in an effort to gradually return to providing ANR at those lower frequencies (e.g., perhaps over a period of time on the order of 100 msec). This somewhat slower rate at which to gradually return to providing ANR at those lower frequencies may be chosen to ensure that there is time during such lowering to detect an indication that the lower limit cannot yet be returned to the frequency at which it was set before the event triggering the raising of the lower limit occurred. In some embodiments, recurring attempts may be made at a predetermined interval to return the lower limit back to its original setting until it is found that the lower limit can be so returned.


It should be noted that although FIG. 16 depicts only the raising and lowering of the lower limit of frequencies over which feedback-based ANR is provided, it may be deemed desirable to similarly raise and lower the lower limit of frequencies over which feedforward-based ANR is provided, either as an alternative to raising and lowering the lower limit of frequencies of feedback-based ANR, or perhaps in coordination with raising and lowering the lower limit of frequencies of feedback-based ANR. For example, just as it has been previously discussed that it may be desirable to coordinate the compression of amplitudes of reference noise sounds employed in both feedback-based and feedforward-based ANR, it may also be deemed desirable to coordinate the raising and lowering of lower limits of the ranges of frequencies at which both feedback-based and feedforward-based ANR is provided. Further, and although again not specifically depicted, it may be deemed desirable to at least momentarily reduce the range of frequencies over which one or both of feedback-based and feedforward-based ANR is provided by lowering and later raising the upper limit (what might be called a “sliding” of the upper limit, first to a lower frequency, and then to a higher frequency). This may be done to prevent and/or counteract clipping at a higher frequency (i.e., at a frequency at or near the upper limit) or an instance of instability.



FIG. 17 depicts another alternative to compressing the amplitude of a reference noise sound in which the slope at the transition band at one or the other of the lower or upper limit of a range of frequencies a form of ANR is provided is altered in response to such events as instability, excessive amplitude, audio artifact or an impending instance of clipping. More specifically, FIG. 17 depicts examples of the slope at the lower limit or at the upper limit of a range of frequencies at which feedback-based ANR is provided being changed momentarily to become shallower to reduce the magnitude of the provision of feedback-based ANR at the lower or upper limit without reducing the magnitude of the provision of feedback-based ANR across the entire range of frequencies at which feedback-based ANR is provided. Again, as was the case with the sliding of the lower limit depicted in FIG. 16, this changing of the slope to become shallower is reversed at a later time when slope is returned, once again, to its original steepness. It should be noted that, unlike FIG. 16, only the provision of feedback-based ANR is depicted in FIG. 17 for the sake of clarity in this discussion.


In this exemplary depiction of altering one or the other of these slopes, the range of frequencies over which any positive magnitude of feedback-based ANR is provided is not changed, but the changing of the slopes within the transition band at the lower or upper limits changes the range of frequencies covered by that transition band and shifts the associated cutoff frequency. The cutoff frequency is initially shifted inward into the range of frequencies over which feedback-based ANR is provided, and is shifted outward back to its original position at a later time. It may be that changing the slope within the transition band at the lower or upper limit is preferred over sliding the lower or upper limit in response to certain conditions and/or in a certain embodiment to avoid an undesired loss of gain or phase margin that such sliding might cause. Again, as is the case in sliding a lower or upper limit, it is preferred that these changes to slope (initially shallower, and later steeper), be made quickly enough to address the event or impending event that triggered the initial shallowing of slope, but slowly enough to avoid generating “pop” or “snap” sounds. By way of example, the shallowing may be done in increments over a period of time on the order of 10 msec, while the steepening to return to an original slope may be done in increments over a period of time on the order of 100 msec.


Effectuating such a sliding and/or such a change in slope of a lower or upper limit of the range of frequencies at which one or both of feedback-based and/or feedforward-based ANR is provided may be done where analog filters are employed to implement ANR transforms, although currently available technology on which analog filters are currently based may make this prohibitively difficult and/or expensive. Instead, effectuating one or the other of such changes at such lower or upper limits is more easily done where digital filters are employed to implement at least a portion of ANR transforms, as it is likely possible to cause such sliding and/or changing in slope through simple alterations of the coefficients provided to one or more digital filters. Where those digital filters are among those of the ANR circuit 2000 of the personal ANR device 1000, the sliding and/or changing of slope at lower and/or upper limits over a controlled period of time may be carried out through use of one or more of the buffers 620a and 620b to repeatedly reconfigure coefficients of digital filters of the ANR circuit 2000 at timed intervals. In the manner that has been previously discussed, a set of “fail safe” coefficients may be stored in the buffer 620c to be employed where bringing about such changes fails to address an instance of instability and/or where bringing about such changes (e.g., sliding a lower or upper limit) somehow causes an instance of instability.



FIG. 18 depicts signal processing topology aspects of implementing such sliding of lower and/or upper limits of ranges of frequencies at which feedback-based and/or feedforward-based ANR is provided, and/or such changing of a slope at the lower and/or upper limits. More specifically, FIG. 18 presents a simplified depiction of additions and/or modifications that may be made to some signal processing topologies (such as the signal processing topologies 2500a through 2500g of FIGS. 4a through 4g, respectively) to effectuate the making of such changes at the lower and/or upper limits of such ranges of frequencies.


Whichever one of the sounds that may be monitored (whether one or both of the reference noise sounds detected by the feedback microphone 120 or the feedforward microphone 130, or sounds to be acoustically output by the acoustic driver 190 before or after amplification by the audio amplifier 960) for indications of instability, excessive amplitude, audio artifacts, etc. is provided to the compression controller 950. As indicated with the filter 952 being depicted in dotted lines, the provision of one or more monitored sounds to the compression controller 950 may be through the filter 952 so as to enable the compression controller 950 to be made more sensitive to certain amplitudes of sounds occurring at some frequencies than at other frequencies in the manner previously discussed. In this way, the use of such sliding of lower and/or upper limits of one or more ranges of frequencies at which ANR is provided may be made dependent on different amplitudes being reached at different frequencies.


Upon determining that a lower limit and/or an upper limit at which one or both of feedback-based and/or feedforward-based ANR is provided is to be momentarily changed, or upon determining that a slope at the lower and/or upper limit is to be momentarily changed, the compression controller 950 causes coefficients of digital filters employed in one or both of the filter blocks 250 and 350 to be repeatedly reconfigured at timed intervals to effectuate one or the other of these changes in steps, as previously discussed, to avoid subjecting a user of the personal ANR device 1000 to the acoustic output of audio artifacts. Where sliding of a limit is to be done, the compression controller 950 first causes a raising of a lower limit or a lowering of an upper limit to reduce a range of frequencies, and later causes a lowering of the lower limit or a raising of the upper limit back towards their original frequencies. Where changing of a slope is to be done, the compression controller 950 first causes a shallowing of the slope of the transition band (thus increasing the transition width and moving the cutoff frequency further within the range of frequencies between the lower and upper limit) at either the lower or upper limit to reduce the magnitude of the provision of ANR in the vicinity of that limit while not lowering the magnitude of the provision of ANR across the entire range of frequencies between the lower and upper limit, and later causes a steepening of the slope within that transition band back towards its original slope (thus returning the transition band to its original width and returning the cutoff frequency to its original frequency).


Where the ANR circuit 2000 employs the internal architecture 2200a (or a similar internal architecture) such that the compression controller 950 is a distinct electronic circuit, the compression controller 950 may cooperate with the processing device 510 to cause the processing device 510 to carry out the repeated reconfiguring of coefficients of one or more of the downsampling filters 552, biquad filters 554, interpolating filters 556 or FIR filters 558 that are employed in implementing whatever ANR transform within one or both of the filter blocks 250 and 350 that is to be so altered. Where the ANR circuit 2000 employs the internal architecture 2200b (or a similar internal architecture) such that the function of the compression controller 950 is caused by the ANR routine 525 stored within the storage 520 to be carried out by the processing device 510 in lieu of the compression controller 950 being a distinct electronic circuit. Thus, the processing device 510 may be caused by a sequence of instructions of the ANR routine 525 that implement that compression controller 950 to repeatedly reconfigure the coefficients of one or more of the instances of the downsampling filter routine 553, biquad filter routine 555, interpolating filter routine 557 and FIR filter routine 559 that are employed in implementing whatever ANR transform within one or both of the filter blocks 250 and 350 that is to be so altered.


Where a sliding of the lower limit of the provision of a form of ANR to a predetermined higher frequency is being carried out, the predetermined higher frequency may be selected at a time prior to any use of the personal ANR device 1000, perhaps during an initial configuration of the personal ANR device 1000. The predetermined higher frequency may be selected based on an average of acoustic characteristics expected to be encountered during the use of multiple ones of the personal ANR device 1000 by many different users, and may include some additional frequency margin to ensure that a sliding of the lower limit higher to the predetermined frequency will be highly likely to successfully counteract the event that triggered the sliding of the lower limit. Alternatively, the predetermined higher frequency may be selected based on acoustic characteristics found to be likely to occur based on tests of the personal ANR device 1000 with a specific user as part of customizing the personal ANR device 1000 for that user.


It should be noted that although the sliding of a lower or upper limit of a range of frequencies at which a form of ANR is provided, and the changing of a slope at the lower or upper limit have each been presented and discussed as alternatives to compressing an amplitude of a reference noise sound, in some embodiments, it may be that a combination of such sliding of limits, such changing of slopes and such compression of amplitude is employed, at least in response to some events. Similarly, it should be noted that it may also be that the compression controller 950 selectively employs one or more of sliding of limits, changing slopes and compressing amplitudes, depending on the nature of the event detected. This possible combined capability is indicated in FIG. 18 with the dotted line couplings of the compression controller 950 to one or more of VGAs 125, 135, 220 and/or 320 to make clear that in some embodiments, the compression controller 950 may also be capable of operating one or more of these VGAs to effectuate compression of amplitude of feedback and/or feedforward noise reference sounds in addition to or in lieu of effectuating such sliding of such lower and upper limits and/or changing of slopes at such lower and upper limits.


Other implementations are within the scope of the following claims and other claims to which the applicant may be entitled.

Claims
  • 1. A personal active noise reduction (ANR) device comprising: an acoustic driver;an ANR circuit coupled to the acoustic driver to operate the acoustic driver to acoustically output ANR anti-noise sounds to provide ANR at a location adjacent an ear of a user of the personal ANR device across a range of frequencies having a lower limit and an upper limit; andat least one digital filter of the ANR circuit, wherein: the at least one digital filter is configurable with a plurality of coefficients to implement an ANR transform to derive the ANR anti-noise sounds from ANR reference noise sounds;the ANR circuit is configured to repeatedly reconfigure the at least one digital filter with different pluralities of coefficient values at a first recurring interval to reduce the magnitude of the provision of ANR at one of the lower limit or the upper limit without reducing a magnitude of the provision of ANR across the entire range of frequencies in response to an event adversely affecting the provision of ANR at the one of the lower limit and the upper limit; andthe ANR circuit is configured to repeatedly reconfigure the at least one digital filter with different pluralities of coefficient values at a second recurring interval to reverse the reduction in the provision of ANR at the one of the lower limit and the upper limit in response to the event adversely affecting the provision of ANR at the one of the lower limit and the upper limit having ceased.
  • 2. The personal ANR device of claim 1, wherein: the first recurring interval is shorter than the second recurring interval; andthe first recurring interval is selected to enable the reduction in the provision of the ANR at the one of the lower limit and the upper limit quickly enough to minimize audible artifacts arising from the event, while avoiding generating an audible artifact arising from repeatedly reconfiguring the at least one digital filter.
  • 3. The personal ANR device of claim 1, wherein the event is selected from a set of events consisting of an instance of clipping in the acoustic outputting of the anti-noise sounds, an instance of instability in providing ANR, an instance of a sound having an excessive amplitude, and an occurrence of an audio artifact.
  • 4. The personal ANR device of claim 1, wherein the first recurring interval is on the order of 10 msec and the second recurring interval is on the order of 100 msec.
  • 5. The personal ANR device of claim 1, wherein the provision of the ANR at the one of the lower limit and the upper limit is reduced by moving the one of the lower limit and the upper limit in steps with each of the first recurring intervals to reduce the range of frequencies, wherein a slope at the one of the lower limit and the upper limit is substantially maintained as the one of the lower limit and the upper limit is moved.
  • 6. The personal ANR device of claim 5, wherein the reduction in provision of the ANR at the one of the lower limit and the upper limit is reversed by moving the one of the lower limit and the upper limit in steps with each of the second recurring intervals to return the range of frequencies to what the range of frequencies was before the reduction in provision of the ANR at the one of the lower limit and the upper limit, wherein the slope at the one of the lower limit and the upper limit is substantially maintained as the one of the lower limit and the upper limit is moved.
  • 7. The personal ANR device of claim 1, wherein the provision of the ANR at the one of the lower limit and the upper limit is reduced by changing a slope at the one of the lower limit and the upper limit to make the slope more shallow in steps with each of the first recurring intervals, wherein a transition bandwidth occupied by the slope widens as a cutoff frequency associated with the slope is moved inward into the range of frequencies in steps with each of the first recurring intervals.
  • 8. The personal ANR device of claim 7, wherein the reduction in provision of the ANR at the one of the lower limit and the upper limit is reversed by changing the slope at the one of the lower limit and the upper limit to make the slope more steep in steps with each of the second recurring intervals, wherein the transition bandwidth occupied by the slope narrows as a cutoff frequency associated with the slope is moved outward in steps with each of the first recurring intervals back to what the cutoff frequency was before the reduction in provision of the ANR.
  • 9. The personal ANR device of claim 1, wherein the ANR comprises feedback-based ANR provided across a first range of frequencies having a lower limit and an upper limit, and feedforward-based ANR provided across a second range of frequencies having a lower limit and an upper limit;the personal ANR device comprises a feedback microphone detecting feedback reference noise sounds to enable provision of the feedback-based ANR and a feedforward microphone detecting feedforward reference noise sounds to enable provision of the feedforward-based ANR; andreducing provision of the ANR at the one of the lower limit and the upper limit comprises reducing provision of both the feedback-based ANR and the feedforward-based ANR at one of the lower limits and the upper limits of both the feedback-based and feedforward-based ANR in steps at the first recurring interval.
  • 10. The personal ANR device of claim 1, further comprising a first buffer of the ANR circuit and a second buffer of the ANR circuit, wherein the ANR circuit alternately employs the first and second buffers to repeatedly reconfigure the at least one digital filter with different pluralities of coefficient values at the first recurring intervals and at the second recurring intervals.
  • 11. A method comprising: repeatedly reconfiguring at least one digital filter with different pluralities of coefficient values at a first recurring interval to reduce the magnitude of a provision of active noise reduction (ANR) by the at least one digital filter at one of the lower limit or the upper limit of a range of frequencies without reducing a magnitude of the provision of ANR across the entire range of frequencies in response to an event adversely affecting the provision of ANR at the one of the lower limit and the upper limit; andrepeatedly reconfiguring the at least one digital filter with different pluralities of coefficient values at a second recurring interval to reverse the reduction in the provision of ANR at the one of the lower limit and the upper limit in response to the event adversely affecting the provision of ANR at the one of the lower limit and the upper limit having ceased.
  • 12. The method of claim 11, wherein: the first recurring interval is shorter than the second recurring interval; andthe first recurring interval is selected to enable the reduction in the provision of the ANR at the one of the lower limit and the upper limit quickly enough to minimize audible artifacts arising from the event, while avoiding generating an audible artifact arising from repeatedly reconfiguring the at least one digital filter.
  • 13. The method of claim 11, wherein the event is selected from a set of events consisting of an instance of clipping in the acoustic outputting of the anti-noise sounds, an instance of instability in providing ANR, an instance of a sound having an excessive amplitude, and an occurrence of an audio artifact.
  • 14. The method of claim 11, wherein the first recurring interval is on the order of 10 msec and the second recurring interval is on the order of 100 msec.
  • 15. The method of claim 11, wherein reducing the provision of the ANR at the one of the lower limit and the upper limit comprises moving the one of the lower limit and the upper limit in steps with each of the first recurring intervals to reduce the range of frequencies, wherein a slope at the one of the lower limit and the upper limit is substantially maintained as the one of the lower limit and the upper limit is moved.
  • 16. The method of claim 15, wherein reversing the reduction in provision of the ANR at the one of the lower limit and the upper limit comprises moving the one of the lower limit and the upper limit in steps with each of the second recurring intervals to return the range of frequencies to what the range of frequencies was before the reduction in provision of the ANR at the one of the lower limit and the upper limit, wherein the slope at the one of the lower limit and the upper limit is substantially maintained as the one of the lower limit and the upper limit is moved.
  • 17. The method of claim 11, wherein reducing the provision of the ANR at the one of the lower limit and the upper limit comprises changing a slope at the one of the lower limit and the upper limit to make the slope more shallow in steps with each of the first recurring intervals, wherein a transition bandwidth occupied by the slope widens as a cutoff frequency associated with the slope is moved inward into the range of frequencies in steps with each of the first recurring intervals.
  • 18. The method of claim 17, wherein reversing the reduction in provision of the ANR at the one of the lower limit and the upper limit comprises changing the slope at the one of the lower limit and the upper limit to make the slope more steep in steps with each of the second recurring intervals, wherein the transition bandwidth occupied by the slope narrows as a cutoff frequency associated with the slope is moved outward in steps with each of the first recurring intervals back to what the cutoff frequency was before the reduction in provision of the ANR.
  • 19. The method of claim 11, wherein the ANR comprises feedback-based ANR provided across a first range of frequencies having a lower limit and an upper limit, and feedforward-based ANR provided across a second range of frequencies having a lower limit and an upper limit; andreducing provision of the ANR at the one of the lower limit and the upper limit comprises reducing provision of both the feedback-based ANR and the feedforward-based ANR at one of the lower limits and the upper limits of both the feedback-based and feedforward-based ANR in steps at the first recurring interval.
CROSS-REFERENCE TO RELATED APPLICATION

The present application is a continuation-in-part of application Ser. No. 12/749,935 filed Mar. 30, 2010 by Pericles N. Bakalos and Ricardo F. Carreras, the disclosure of which is incorporated herein by reference.

US Referenced Citations (45)
Number Name Date Kind
5255325 Ishimitsu et al. Oct 1993 A
5337366 Eguchi et al. Aug 1994 A
5699436 Claybaugh et al. Dec 1997 A
5724433 Engebretson et al. Mar 1998 A
5815582 Claybaugh et al. Sep 1998 A
6094489 Ishige et al. Jul 2000 A
6118878 Jones Sep 2000 A
6160893 Saunders et al. Dec 2000 A
6418228 Terai et al. Jul 2002 B1
6522753 Matsuzawa et al. Feb 2003 B1
6567524 Svean et al. May 2003 B1
6717537 Fang et al. Apr 2004 B1
6744882 Gupta et al. Jun 2004 B1
7039195 Svean et al. May 2006 B1
7260209 Harvey et al. Aug 2007 B2
7292973 Johnston et al. Nov 2007 B1
7433481 Armstrong et al. Oct 2008 B2
7627127 Aida et al. Dec 2009 B2
7706550 Amada et al. Apr 2010 B2
20030053636 Goldberg et al. Mar 2003 A1
20040138769 Akiho Jul 2004 A1
20040240677 Onishi et al. Dec 2004 A1
20050117754 Sakawaki Jun 2005 A1
20070003078 Escott et al. Jan 2007 A1
20070076896 Hosaka et al. Apr 2007 A1
20070223715 Barath et al. Sep 2007 A1
20080025530 Romesburg Jan 2008 A1
20080095383 Pan et al. Apr 2008 A1
20080107282 Asada May 2008 A1
20080162072 Copley et al. Jul 2008 A1
20080192957 Kubo Aug 2008 A1
20080292113 Tian Nov 2008 A1
20080310652 Gustavsson Dec 2008 A1
20090034748 Sibbald Feb 2009 A1
20090161889 Magrath Jun 2009 A1
20100272275 Carreras et al. Oct 2010 A1
20100272276 Carreras Oct 2010 A1
20100272277 Joho et al. Oct 2010 A1
20100272278 Joho et al. Oct 2010 A1
20100272279 Joho et al. Oct 2010 A1
20100272280 Joho et al. Oct 2010 A1
20100272281 Carreras et al. Oct 2010 A1
20100272283 Carreras et al. Oct 2010 A1
20100272284 Joho et al. Oct 2010 A1
20110188665 Burge et al. Aug 2011 A1
Foreign Referenced Citations (8)
Number Date Country
2254898 Oct 1990 JP
5341792 Dec 1993 JP
8006571 Jan 1996 JP
2005257720 Sep 2005 JP
2007536877 Dec 2007 JP
2008216375 Sep 2008 JP
9205538 Apr 1992 WO
2009041012 Apr 2009 WO
Non-Patent Literature Citations (4)
Entry
Invitation to Pay Additional Fees dated Aug. 3, 2010 for PCT/US2010/032557.
International Search Report and Written Opinion dated Sep. 16, 2010 for PCT/US10/032557.
European Office Action dated Nov. 7, 2012 for Application No. 10715648.1-2213.
Japanese Office Action dated Mar. 19, 2013 for Appication No. 2012-508587.
Related Publications (1)
Number Date Country
20110243345 A1 Oct 2011 US
Continuation in Parts (1)
Number Date Country
Parent 12749935 Mar 2010 US
Child 12766914 US