This disclosure relates to audio signal processing. More specifically, this disclosure relates to three-dimensional sound compression and over-the-air transmission during a call.
As technology advances, we see the distinguishable growth of network speed and storage, which already supports not only text, but also multimedia data. In real-time cellular communication systems, the ability to capture, compress, and transmit three-dimensional (3-D) audio is not presently available. One of the challenges is the capturing of three-dimensional audio signals. Therefore, a benefit may be realized by capturing and reproducing three-dimensional audio for more realistic and immersive exchange of individual aural experiences.
A method for encoding three dimensional audio by a wireless communication device is described. The method includes detecting an indication of a spatial direction of a plurality of localizable audio sources. The method also includes recording a plurality of audio signals associated with the plurality of localizable audio sources. The method further includes encoding the plurality of audio signals. The indication of the spatial direction of the localizable audio source may be based on received input.
The method may include determining a number of localizable audio sources. The method may also include estimating a direction of arrival of each localizable audio source. The method may include encoding a multichannel signal according to a three dimensional audio encoding scheme.
The method may include applying a beam in a first end-fire direction to obtain a first filtered signal. The method may also include applying a beam in a second end-fire direction to obtain a second filtered signal. The method may combine the first filtered signal with a delayed version of the second filtered signal. Each of the first and second filtered signals may have at least two channels. One of the filtered signals may be delayed relative to the other filtered signal. The method may delay a first channel of the first filtered signal relative to a second channel of the first filtered signal and delay a first channel of the second filtered signal relative to a second channel of the second filtered signal. The method may delay a first channel of the combined signal relative to a second channel of the combined signal.
The method may apply a filter having a beam in a first direction to a signal produced by a first pair of microphones to obtain a first spatially filtered signal and may apply a filter having a beam in a second direction to a signal produced by a second pair of microphones to obtain a second spatially filtered signal. The method may then combine the first and second spatially filtered signals to obtain an output signal.
The method may include recording, for each of a plurality of microphones in an array, a corresponding input channel. The method may also include applying, for each of a plurality of look directions, a corresponding multichannel filter to a plurality of the recorded input channels to obtain a corresponding output channel. Each of the multichannel filters may apply a beam in the corresponding look direction and a null beam in the other look directions. The method may include processing the plurality of output channels to produce a binaural recording. The method may include applying the beam to frequencies between a low threshold and a high threshold. At least one of the low and high thresholds is based on a distance between microphones.
A method for selecting a codec by a wireless communication device is described. The method includes determining an energy profile of a plurality of audio signals. The method also includes displaying the energy profile of each of the plurality of audio signals. The method also includes detecting an input that selects an energy profile. The method also includes associating a codec with the input. The method further includes compressing the plurality of audio signals based on the codec to generate a packet. The method may include transmitting the packet over the air. The method may include transmitting a channel identification.
A method for increasing bit allocation by a wireless communication device is described. The method includes determining an energy profile of a plurality of audio signals. The method also includes displaying the energy profile of each of the plurality of audio signals. The method also includes detecting an input that selects an energy profile. The method also includes associating a codec with the input. The method further includes increasing bit allocation to the codec used to compress audio signals based on the input. Compression of the audio signals may result in four packets being transmitted over the air.
A wireless communication device for encoding three dimensional audio by a wireless communication device is described. The wireless communication device includes spatial direction circuitry that detects an indication of a spatial direction of a plurality of localizable audio sources. The wireless communication device also includes recording circuitry coupled to the spatial direction circuitry. The recording circuitry records a plurality of audio signals associated with the plurality of localizable audio sources. The wireless communication device also includes an encoder coupled to the recording circuitry. The encoder encodes the plurality of audio signals.
A wireless communication device for selecting a codec by a wireless communication device is described. The wireless communication device includes energy profile circuitry that determines an energy profile of a plurality of audio signals. The wireless communication device includes a display coupled to the energy profile circuitry. The display displays the energy profile of each of the plurality of audio signals. The wireless communication device includes input detection circuitry coupled to the display. The input detection circuitry detects an input that selects an energy profile. The wireless communication device includes association circuitry coupled to the input detection circuitry. The association circuitry associates a codec with the input. The wireless communication device includes compression circuitry coupled to the association circuitry. The compression circuitry compresses the plurality of audio signals based on the codec to generate a packet.
A wireless communication device for increasing bit allocation by a wireless communication device is described. The wireless communication device includes energy profile circuitry that determines an energy profile of a plurality of audio signals. The wireless communication device includes a display coupled to the energy profile circuitry. The display displays the energy profile of each of the plurality of audio signals. The wireless communication device includes input detection circuitry coupled to the display. The input detection circuitry detects an input that selects an energy profile. The wireless communication device includes association circuitry coupled to the input detection circuitry. The association circuitry associates a codec with the input. The wireless communication device includes bit allocation circuitry coupled to the association circuitry. The bit allocation circuitry increases bit allocation to the codec used to compress audio signals based on the input.
A computer-program product for encoding three dimensional audio is described. The computer-program product includes a non-transitory tangible computer-readable medium having instructions thereon. The instructions include code for causing a wireless communication device to detect an indication of a spatial direction of a plurality of localizable audio sources. The instructions include code for causing the wireless communication device to record a plurality of audio signals associated with the plurality of localizable audio sources. The instructions include code for causing the wireless communication device to encode the plurality of audio signals.
A computer-program product for selecting a codec is described. The computer-program product includes a non-transitory tangible computer-readable medium having instructions thereon. The instructions include code for causing a wireless communication device to determine an energy profile of a plurality of audio signals. The instructions include code for causing a wireless communication device to display the energy profile of each of the plurality of audio signals. The instructions include code for causing a wireless communication device to detect an input that selects an energy profile. The method also includes associating a codec with the input. The instructions include code for causing a wireless communication device to compress the plurality of audio signals based on the codec to generate a packet.
A computer-program product for increasing bit allocation is described. The computer-program product includes a non-transitory tangible computer-readable medium having instructions thereon. The instructions include code for causing a wireless communication device to determine an energy profile of a plurality of audio signals. The instructions include code for causing a wireless communication device to display the energy profile of each of the plurality of audio signals. The instructions include code for causing a wireless communication device to detect an input that selects an energy profile. The method also includes associating a codec with the input. The instructions include code for causing a wireless communication device to increase bit allocation to the codec used to compress audio signals based on the input.
Examples of communication devices include cellular telephone base stations or nodes, access points, wireless gateways and wireless routers. A communication device may operate in accordance with certain industry standards, such as Third Generation Partnership Project (3GPP) Long Term Evolution (LTE) standards. Other examples of standards that a communication device may comply with include Institute of Electrical and Electronics Engineers (IEEE) 802.11a, 802.11b, 802.11g, 802.11n and/or 802.11ac (e.g., Wireless Fidelity or “Wi-Fi”) standards, IEEE 802.16 (e.g., Worldwide Interoperability for Microwave Access or “WiMAX”) standard and others. In some standards, a communication device may be referred to as a Node B, evolved Node B, etc. While some of the systems and methods disclosed herein may be described in terms of one or more standards, this should not limit the scope of the disclosure, as the systems and methods may be applicable to many systems and/or standards.
Some communication devices (e.g., access terminals, client devices, client stations, etc.) may wirelessly communicate with other communication devices. Some communication devices (e.g., wireless communication devices) may be referred to as mobile devices, mobile stations, subscriber stations, clients, client stations, user equipment (UEs), remote stations, access terminals, mobile terminals, terminals, user terminals, subscriber units, etc. Additional examples of communication devices include laptop or desktop computers, cellular phones, smart phones, wireless modems, e-readers, tablet devices, gaming systems, etc. Some of these communication devices may operate in accordance with one or more industry standards as described above. Thus, the general term “communication device” may include communication devices described with varying nomenclatures according to industry standards (e.g., access terminal, user equipment, remote terminal, access point, base station, Node B, evolved Node B, etc.).
Some communication devices may be capable of providing access to a communications network. Examples of communications networks include, but are not limited to, a telephone network (e.g., a “land-line” network such as the Public-Switched Telephone Network (PSTN) or cellular phone network), the Internet, a Local Area Network (LAN), a Wide Area Network (WAN), a Metropolitan Area Network (MAN), etc.
Unless expressly limited by its context, the term “signal” is used herein to indicate any of its ordinary meanings, including a state of a memory location (or set of memory locations) as expressed on a wire, bus, or other transmission medium. Unless expressly limited by its context, the term “generating” is used herein to indicate any of its ordinary meanings, such as computing or otherwise producing. Unless expressly limited by its context, the term “calculating” is used herein to indicate any of its ordinary meanings, such as computing, evaluating, smoothing and/or selecting from a plurality of values. Unless expressly limited by its context, the term “obtaining” is used to indicate any of its ordinary meanings, such as calculating, deriving, receiving (e.g., from an external device), and/or retrieving (e.g., from an array of storage elements). Unless expressly limited by its context, the term “selecting” is used to indicate any of its ordinary meanings, such as identifying, indicating, applying, and/or using at least one, and fewer than all, of a set of two or more. Where the term “comprising” is used in the present description and claims, it does not exclude other elements or operations. The term “based on” (as in “A is based on B”) is used to indicate any of its ordinary meanings, including the cases (i) “derived from” (e.g., “B is a precursor of A”), (ii) “based on at least” (e.g., “A is based on at least B”) and, if appropriate in the particular context, (iii) “equal to” (e.g., “A is equal to B”). Similarly, the term “in response to” is used to indicate any of its ordinary meanings, including “in response to at least.”
References to a “location” of a microphone of a multi-microphone audio sensing device indicate the location of the center of an acoustically sensitive face of the microphone, unless otherwise indicated by the context. The term “channel” is used at times to indicate a signal path and at other times to indicate a signal carried by such a path, according to the particular context. Unless otherwise indicated, the term “series” is used to indicate a sequence of two or more items. The term “logarithm” is used to indicate the base-ten logarithm, although extensions of such an operation to other bases are within the scope of this disclosure. The term “frequency component” is used to indicate one among a set of frequencies or frequency bands of a signal, such as a sample of a frequency domain representation of the signal (e.g., as produced by a fast Fourier transform) or a subband of the signal (e.g., a Bark scale or mel scale subband).
Unless indicated otherwise, any disclosure of an operation of an apparatus having a particular feature is also expressly intended to disclose a method having an analogous feature (and vice versa), and any disclosure of an operation of an apparatus according to a particular configuration is also expressly intended to disclose a method according to an analogous configuration (and vice versa). The term “configuration” may be used in reference to a method, apparatus and/or system as indicated by its particular context. The terms “method,” “process,” “procedure,” and “technique” are used generically and interchangeably unless otherwise indicated by the particular context. The terms “apparatus” and “device” are also used generically and interchangeably unless otherwise indicated by the particular context. The terms “element” and “module” are typically used to indicate a portion of a greater configuration. Unless expressly limited by its context, the term “system” is used herein to indicate any of its ordinary meanings, including “a group of elements that interact to serve a common purpose.” Any incorporation by reference of a portion of a document shall also be understood to incorporate definitions of terms or variables that are referenced within the portion, where such definitions appear elsewhere in the document, as well as any figures referenced in the incorporated portion.
A method as described herein may be configured to process the captured signal as a series of segments. Typical segment lengths range from about five or ten milliseconds to about forty or fifty milliseconds, and the segments may be overlapping (e.g., with adjacent segments overlapping by 25% or 50%) or nonoverlapping. In one particular example, the signal is divided into a series of nonoverlapping segments or “frames”, each having a length of ten milliseconds. A segment as processed by such a method may also be a segment (i.e., a “subframe”) of a larger segment as processed by a different operation, or vice versa. Nowadays we are experiencing prompt exchange of individual information through rapidly growing social network services such as Facebook, Twitter, etc. At the same time, we also see the distinguishable growth of network speed and storage, which already supports not only text, but also multimedia data. In this environment, we see an important need for capturing and reproducing three-dimensional (3D) audio for more realistic and immersive exchange of individual aural experiences. In real-time cellular communication systems the ability to capture, compress, and transmit 3-D audio is not presently available. One of the challenges is the capturing of 3-D audio signals. Some of the techniques described in U.S. patent application Ser. No. 13/280,303, Attorney Docket No. 102978U2, entitled “THREE-DIMENSIONAL SOUND CAPTURING AND REPRODUCING WITH MULTI-MICROPHONES” filed on Oct. 24, 2011 may be also used herein, to describe how 3-D audio information is captured, and how it may be recorded. However, this application extends the capability previously disclosed, by describing how 3-D audio may be combined with speech codecs found in real-time cellular communication systems.
First, the capture of 3-D audio is described. In some implementations, the audible information may be recorded. The audible information described herein may also be compressed by one or more independent speech codecs and transmitted in one or more over-the-air channels.
Different beamformer databanks may be computed offline for various microphone 104a-e combinations given a range of design methods (i.e., minimum variance distortionless response (MVDR), linearly constrained minimum variance (LCMV), phased arrays, etc.). During use, a desired one of these beamformers may be selected through a menu in the user interface depending on current use case requirements.
Three-dimensional audio capturing may also be performed with specialized microphone setups, such as a three-microphone 504a-c arrangement as shown in
It is generally assumed that a far-end user listens to recorded spatial sound using a stereo headset (e.g., an adaptive noise cancellation or ANC headset). In other applications, however, a multi-loudspeaker array capable of reproducing more than two spatial directions may be available at the far end. To support such a use case, it may be desirable to enable more than one microphone/beamformer combination at the same time during recording, or capturing of the 3-D audio signal to be used to compress and transmit 3-D audio.
A multi-microphone array may be used with a spatially selective filter to produce a monophonic sound for each of one or more source directions. However, such an array may also be used to support spatial audio encoding in two or three dimensions. Examples of spatial audio encoding methods that may be supported with a multi-microphone array as described herein include 5.1 surround, 7.1 surround, Dolby Surround, Dolby Pro-Logic, or any other phase-amplitude matrix stereo format; Dolby Digital, DTS or any discrete multi-channel format; and wavefield synthesis. One example of a five-channel encoding includes Left, Right, Center, Left surround, and Right surround channels.
In order to convey an immersive sound experience to the user, surround sound recordings may be stand-alone or in conjunction with videotaping. Surround sound recording may use a separate microphone setup using uni-directional microphones 604a-d. In this example, the one or more uni-directional microphones 604a-d may be clipped on separately. In this disclosure, an alternative scheme based on multiple omnidirectional microphones 604a-d combined with spatial filtering is presented. In an example of this configuration, one or more omnidirectional microphones 604a-d embedded on the smartphone or tablet may support multiple sound recording applications. For example, two microphones 604a-d may be used for wide stereo, and at least three omnidirectional microphones 604a-d, with appropriate microphone 604a-d axes, may be used for surround sound, may be used to record multiple sound channels on the smartphone or tablet device. These channels may in turn be processed in pairs or filtered at the same time with filters designed to have specific spatial pickup patterns in desired look directions. Due to spatial aliasing, the inter-microphone distances may be chosen so the patterns are effective in the most relevant frequency bands. The generated stereo or 5.1 output channels may be played back in a surround sound setup to generate the immersive sound experience.
When the device is in an end-fire holding position, the recording may provide a wide stereo effect. In this case, spatial filtering (e.g., using a null beamformer or a BSS solution, such as ICA or IVA) may enhance the effect slightly.
In a dual-microphone case, a stereo recorded file may be enhanced through spatial filtering (e.g., to increase separation of the user's voice and the recorded scene) as described above. It may be desirable to generate several different directional channels from the captured stereo signal (e.g., for surround sound), such as to upmix the signal to more than two channels. For example, it may be desirable to upmix the signal to five channels (for a 5.1 surround sound scheme, for example) such that it may be played back using a different one of an array of five speakers for each channel. Such an approach may include applying spatial filtering in corresponding directions to obtain the upmixed channels. Such an approach may also include applying a multichannel encoding scheme to the upmixed channels (e.g., a version of Dolby Surround).
For a case in which more than two microphones 704a-d are used for recording, it may be possible to record in multiple directions (e.g., five directions, according to a 5.1 standard) using spatial filtering and different microphone 704a-d combinations, then to play back the recorded signal (e.g., using five loudspeakers). Such processing may be performed without upmixing.
The audio signals associated with the four different directions (FR 1184, BR 1188, BL 1186, FL 1182) may be compressed using speech codecs on a wireless communication device 702. At the receiver side, the center sound that a user playing/or decoding the four reconstructed audio signals associated with the different directional sounds may be generated by the combination of the FR 1184, BR 1188, BL 1186, FL 1182 channels. These audio signals associated with different directions may be compressed and transmitted in real-time using a wireless communication device 702. Each of the four independent sources may be compressed and transmitted from a certain low band frequency (LB) frequency up to a certain upper band frequency (UB).
The effectiveness of a spatial filtering technique may be limited to a bandpass range depending on factors such as small inter-microphone spacing, spatial aliasing and scattering at high frequencies. In one example, the signal may be lowpass-filtered (e.g., with a cutoff frequency of 8 kHz) before spatial filtering.
For a case in which sound from a single point source is being captured, complementing such beamforming with masking of signals arriving from other directions may lead to strong attenuation of non-direct-path signals and/or audible distortion at the level of aggressiveness needed to achieve the desired masking effect. Such artifacts may be undesirable for high-definition (HD) audio. In one example, HD audio may be recorded at a sampling rate of 48 kHz. To mitigate such artifacts, instead of using the aggressively spatially filtered signal, it may be desirable to use only the energy profile of the processed signal for each channel and to apply a gain panning rule according to the energy profile for each channel on the original input signals or spatially processed output before masking. Note that as sound events may be sparse in the time-frequency map, it may be possible to use such a post-gain-panning method even with multiple-source cases.
For a dual-mic-pair case, it may be desirable to design at least one beam for one pair and at least two beams in different directions for the other pair. The beams may be designed or learned (e.g., with a blind source separation approach, such as independent component analysis or independent vector analysis). Each of these beams may be used to obtain a different channel of the recording (e.g., for a surround sound recording).
Some of the channels may be produced by combining two of more of the beams.
Because of spatial aliasing, depending on the inter-microphone distances it may be desirable to apply the beams to less than the entire frequency range of the captured signals (e.g., to the range of from 0 to 8 kHz as noted above). After the low-frequency content is spatially filtered, the high-frequency content may be added back, with some adjustment for spatial delay, processing delay and/or gain matching. In some cases (e.g., handheld device form factors), it may also be desirable to filter only a middle range of frequencies (e.g., only down to 200 or 500 Hz), as some loss of directivity may be expected anyway due to microphone spacing limitations.
If some kind of non-linear phase distortion exists, then a standard beam/null-forming technique that is based on the same delay for all frequencies according to the same direction of arrival (DOA) may perform poorly, due to differential delay on some frequencies as caused by the non-linear phase distortion. A method based on independent vector analysis as described herein operates on a basis of source separation, however, and such a method may therefore be expected to produce good results even in the presence of differential delay for the same direction of arrival. Such robustness may be a potential advantage of using independent vector analysis for obtaining surround processing coefficients.
For a case in which no spatial filtering is done above some cutoff frequency (e.g., 8 kHz), providing the final high-definition signal may include high-pass filtering the original front/back channels and adding back the band of from 8 to 24 kHz. Such an operation may include adjusting for spatial and high-pass filtering delays. It may also be desirable to adjust the gain of the 8-24-kHz band (e.g., so as not to confuse the spatial separation effect). The examples illustrated in
In one example of such a learning process, an independent sound source is positioned at each of four designated locations (e.g., the four corner locations FL, FR, BL and BR) around the four-microphone 1604a-d array, and the array is used to capture a four-channel signal. Note that each of the captured four-channel outputs is a mixture of all four sources. A blind source separation technique (e.g., independent vector analysis) may then be applied to separate the four independent sources. After convergence, the separated four independent sources as well as a converged filter set, which is essentially beaming toward the target corner and nulling toward the other three corners, may be obtained.
The beam pattern may vary depending on the acquired mixture data.
The process of training a four-microphone filter using independent vector analysis may include beaming toward the desired direction, but also nulling the interference directions. For example, the filter for the front left (FL) direction is converged to a solution that includes a beam toward the front left (FL) direction and nulls in the front right (FR), back left (BL) and back right (BR) directions. Such a training operation may be done deterministically if the exact microphone array geometry is already known. Alternatively, the independent vector analysis process may be performed with rich training data, in which one or more audio sources (e.g., speech, a musical instrument, etc.) are located at each corner and captured by the four-microphone array. In this case, the training process may be performed once regardless of microphone configuration (i.e., without the necessity of information regarding microphone geometry), and the filter may be fixed for a particular array configuration at a later time. As long as the array includes four microphones in a projected two-dimensional (x-y) plane, the results of this learning processing may be applied to produce an appropriate set of four corner filters. If the microphones of the array are arranged in two orthogonal or nearly orthogonal axes (e.g., within 15 degrees of orthogonal), such a trained filter may be used to record a surround sound image without the constraint of a particular microphone array configuration. For example, a three-microphone array may be sufficient if the two axes are very close to orthogonal, and the ratio between the separations between the microphones on each axis is not important.
As noted above, a high definition signal may be obtained by spatially processing the low frequency and passing the high frequency terms. However, processing of the entire frequency region may be performed instead, if the increase in computational complexity is not a significant concern for the particular design. Because the four-microphone independent vector analysis approach focuses more on nulling than beaming, the effect of aliasing in the high-frequency terms may reduced. Null aliasing may happen at rare frequencies in the beaming direction, such that most of the frequency region in the beaming direction may remain unaffected by the null aliasing, especially for small inter-microphone distances. For larger inter-microphone distances, the nulling may actually become randomized, such that the effect is similar to the case of just passing unprocessed high-frequency terms.
For a small form factor (e.g., a handheld device 102), it may be desirable to avoid performing spatial filtering at low frequencies, as the microphone spacing may be too small to support a good result, and performance in higher frequencies may be compromised. Likewise, it may be desirable to avoid performing spatial filtering at high frequencies, as such frequencies are typically directional already and filtering may be ineffective for frequencies above the spatial aliasing frequency.
If fewer than four microphones are used, it may be difficult to form nulls at the three other corners (e.g., due to insufficient degrees of freedom). In this case, it may be desirable to use an alternative, such as end-fire pairing as discussed with reference to
This description includes disclosures of providing a 5.1-channel recording from a signal recorded using multiple omnidirectional microphones 2504a-d. It may be desirable to create a binaural recording from a signal captured using multiple omnidirectional microphones 2504a-d. If there is no 5.1 channel surround system from the user side, for example, it may be desirable to downmix the 5.1 channels to a stereo binaural recording so that the user can have experience of being in an actual acoustic space with the surround sound system. Also, this capability can provide an option wherein the user may monitor the surround recording while they are recording the scene on the spot and/or play back the recorded video and surround sound on his mobile device using a stereo headset instead of a home theater system.
The systems and methods described herein may provide for directional sound sources from the array of omnidirectional microphones 2504a-d, which are intended to be played through loudspeakers located at the designated locations (FL, FR, C, BL (or surround left), and BR (or surround right)) in a living room space. One method of reproducing this situation with headphones may include an offline process of measuring binaural impulse responses (BIRs) (e.g., binaural transfer functions) from each loudspeaker to a microphone 2504a-d located inside of each ear in the desired acoustic space. The binaural impulse responses may encode the acoustic path information, including the direct path as well as the reflection paths from each loudspeaker, for every source-receiver pair among the array of loudspeakers and the two ears. Small microphones 2504a-d may be located inside of real human ears, or use a dummy head such as a Head and Torso Simulator (e.g., HATS, Bruel and Kjaer, D K) with silicone ears.
For binaural reproduction, the measured binaural impulse responses may be convolved with each directional sound source for the designated loudspeaker location. After convolving all the directional sources with the binaural impulse responses, the results may be summed for each ear recording. In this case two channels (e.g., left and right) that replicate the left and right signals captured by human ears may be played though a headphone. Note that 5.1 surround generation from the array of omnidirectional microphones 2504a-d may be used as a via-point from the array to binaural reproduction. Therefore, this scheme may be generalized depending on how the via-point is generated. For example, more directional sources are created from the signals captured by the array, they may be used as a via-point with appropriately measured binaural impulse responses from the desired loudspeaker location to the ears.
It may be desirable to perform a method as described herein within a portable audio sensing device that has an array of two or more microphones 2504a-d configured to receive acoustic signals. Examples of a portable audio sensing device that may be implemented to include such an array and may be used for audio recording and/or voice communications applications include a telephone handset (e.g., a cellular telephone handset); a wired or wireless headset (e.g., a Bluetooth headset); a handheld audio and/or video recorder; a personal media player configured to record audio and/or video content; a personal digital assistant (PDA) or other handheld computing device; and a notebook computer, laptop computer, netbook computer, tablet computer, or other portable computing device. The class of portable computing devices currently includes devices having names such as laptop computers, notebook computers, netbook computers, ultra-portable computers, tablet computers, mobile Internet devices, smartbooks and smartphones. Such a device may have a top panel that includes a display screen and a bottom panel that may include a keyboard, wherein the two panels may be connected in a clamshell or other hinged relationship. Such a device may be similarly implemented as a tablet computer that includes a touchscreen display on a top surface. Other examples of audio sensing devices that may be constructed to perform such a method and to include instances of array and may be used for audio recording and/or voice communications applications include set-top boxes and audio- and/or video-conferencing devices.
Each microphone of the array 2630 may have a response that is omnidirectional, bidirectional, or unidirectional (e.g., cardioid). The various types of microphones that may be used in the array 2630 may include (without limitation) piezoelectric microphones, dynamic microphones, and electret microphones. In a device for portable voice communications, such as a handset or headset, the center-to-center spacing between adjacent microphones of the array 2630 may be in the range of from about 1.5 cm to about 4.5 cm, although a larger spacing (e.g., up to 10 or 15 cm) may also be possible in a device such as a handset or smartphone, and even larger spacings (e.g., up to 20, 25 or 30 cm or more) may be possible in a device such as a tablet computer. The microphones of the array 2630 may be arranged along a line (with uniform or non-uniform microphone spacing) or, alternatively, such that their centers lie at the vertices of a two-dimensional (e.g., triangular) or three-dimensional shape.
It is expressly noted that the microphones may be implemented more generally as transducers sensitive to radiations or emissions other than sound. In one such example, the microphone pair may be implemented as a pair of ultrasonic transducers (e.g., transducers sensitive to acoustic frequencies greater than fifteen, twenty, twenty-five, thirty, forty or fifty kilohertz or more).
During the operation of a multi-microphone audio sensing device 2628, the array may 2630 produce a multichannel signal in which each channel is based on the response of a corresponding one of the microphones to the acoustic environment. One microphone may receive a particular sound more directly than another microphone, such that the corresponding channels differ from one another to provide collectively a more complete representation of the acoustic environment than can be captured using a single microphone. In some implementations, the chipset 2634 may be coupled to one or more microphones 2604a-b, a loudspeaker 2610, one or more antennas 2603a-b, a display 2605 and/or a keypad 2607.
It may be desirable for the array 2730 to produce the multichannel signal as a digital signal, that is to say, as a sequence of samples. The array 2730, for example, may include analog-to-digital converters (ADCs) 2740a and 2740b that are each arranged to sample the corresponding analog channel. Typical sampling rates for acoustic applications may include 8 kHz, 12 kHz, 16 kHz, and other frequencies in the range of from about 8 to about 16 kHz, although sampling rates as high as about 44 kHz may also be used. In this particular example, the array 2730 may also include digital preprocessing stages 2742a and 2742b that are each configured to perform one or more preprocessing operations (e.g., echo cancellation, noise reduction, and/or spectral shaping) on the corresponding digitized channel to produce the corresponding channels MCS-1, MCS-2 of multichannel signal MCS. Although
Current formats for immersive audio reproduction include (a) binaural 3D, (b) transaural 3D, and (c) 5.1/7.1 surround sound. Both for binaural and transaural 3D typically just stereo channels/signals are transmitted. For surround sound more than just stereo signals may be transmitted. This disclosure proposes a coding scheme used in mobile devices for transmitting more than stereo for surround sound.
Current systems may transmit “B-format audio” as illustrated in FIG. 1, from the Journal of Audio Eng. Soci. Vol. 57, No. 9, 2009 September. The B-format audio has 1 via-point with 4 channels and requires a special recording setup. Other systems, are focused on broadcasting, not voice-communication.
The present systems and methods have four via points used in a real-time communication system, where a via point may exist at each of four corners (e.g., front left, front right, back left and back right) of a surround sound system. Transmitting the sounds of these four corners may be done together or independently. In these configurations the four audio signals may be compressed using any number of speech codecs. In some cases, there may be no need for a recording setup (e.g., such as that used in the B-format audio). The z-axis can be omitted. Doing so does not degrade the signal as the information can still be discerned by the human ears.
The new coding scheme is able to provide compression with distortion, primarily limited to that inherent by the speech codecs. The final audio output may be interpolated for possible loudspeaker placement. In addition, it can be compatible with other formats, such as B-format (except for the z-axis, and binaural recording). Moreover, the new coding scheme may benefit by the use of echo cancellers that work in tandem with the speech codecs, located in the audio path of most mobile devices, as the four audio signals may be largely uncorrelated.
The present systems and methods may address the issue of real-time communication. In some examples, frequency bands from a certain lower band (LB) frequency up to a certain upper band (UB) frequency (e.g., [LB, UB]) may be transmitted as individual channels. Above the certain upper band (UB) frequency to the Nyquist frequency (e.g., [UB, NF]) different channels may be transmitted depending on the available channel capacity. For example, if four channels are available, four audio channels may be transmitted. If two channels are available, the front and back channels may be transmitted after averaging the front two and back two channels. If one channel is available, the average of all microphone inputs may be transmitted. In some configurations, no channels are transmitted and the high band (e.g., [UB, NF]) may be generated from the low band (e.g., [LB, UB]) using a technique similar to spectral band replication. For those bands below the lower band frequency (LB), (e.g., [0, LB]), the average of all microphone inputs may be transmitted.
In some examples, the encoding of audio signals may include selective encoding. For example, if a user wants to send one specific directional source, (e.g., the user's voice), the wireless communication device can allocate coding bit resources more for that direction, by minimizing dynamic range of the other channels as well as decreasing the energy of the other directions. Additionally or alternatively, the wireless communication device can transmit one or two channels if the user is interested in a specific directional source (e.g., the user's voice).
According to some configurations, an audio signal 2844a-d may be divided into one or more bands. For example, a front left audio signal 2844a may be divided into band 1A 2846a, band 1B 2876a, band 2A 2878a, band 2B 2880a and band 2C 2882a. The other audio signals 2844b-d may be divided similarly. As used herein the term “band 1B” may refer to the frequency bands that fall between a certain low band frequency (LB) and a certain upper band frequency (UB) (e.g., [LB, UB]). The bands of an audio signal 2844a-d may include one or more types of bands. For example, an audio signal 2844a may include one or more narrowband signals. In some implementations, a narrowband signal may include band 1A 2846a-d and a portion of band 1B 2876a-d (e.g., the portion of band 1B 2876a-d that is less than 4 kHz). In other words, if the certain upper band frequency (UB) is greater than 4 kHz, band 1B 2876a-d may be larger than a narrowband signal. In other implementations, a narrowband signal may include band 1A 2846a-d, band 1B 2876a-d, and a portion of band 2A 2878a-d (e.g., the portion of band 2A 2878a-d that is less than 4 kHz). The audio signal 2844a may also include one or more non-narrowband signals (e.g., a portion of band 2A 2878a (the portion greater than 4 kHz), band 2B 2880a and band 2C 2882a). As used herein, the term “non-narrowband” refers to any signal that is not a narrowband signal (e.g., a wideband signal, a superwideband signal and a fullband signal).
The ranges of the bands may be as follows: band 1A 2846a-d may span from 0-200 Hz. In some implementations the upper range of band 1A 2846a-d may be up to approximately 500 Hz. Band 1B 2876a-d may span from the maximum frequency of band 1A 2846a-d (e.g., 200 Hz or 500 Hz) up to approximately 6.4 kHz. Band 2A 2878a-d may span from the maximum range of band 1B 2876a-d (e.g., 6.4 kHz) and approximately 8 kHz. Band 2B 2880a-d may span from the maximum range of band 2A 2878a-d (e.g. 8 kHz) up to approximately 16 kHz. Band 2C 2882a-d may span from the maximum range of band 2B 2880a-d (e.g., approximately 16 kHz) up to approximately 24 kHz.
In some implementations, the upper range of band 1B 2876a-d may depend on one or more factors including, but not limited to, the geometric placement of the microphones and the mechanical design of the microphones (e.g., unidirectional microphones vs. omnidirectional microphones). For example, the upper range of band 1B 2876a-d may be different when the microphones are positioned closer together than when the microphones are positioned farther apart. In this implementation, the other bands (e.g., bands 2A-C 2878a-d, 2880a-d, 2882a-d) may be derived from band 1B 2876a-d.
The frequency ranges up to the upper boundary of band 1B 2876a-d may be a narrowband signal (e.g., up to 4 kHz) or slightly higher than a narrowband limit (e.g., 6.4 KHz). As described above, if the upper boundary of band 1B 2876a-d is less than a narrowband signal (e.g., 4 kHz), a portion of band 2A 2878a-d may include a narrowband signal. By comparison, if the upper boundary of band 1B 2876a-d is greater than a narrowband signal (e.g., 4 kHz), band 2A 2878a-d may not include a narrowband signal. A portion of the frequency ranges up to the upper boundary of band 2A 2878a-d (e.g., 8 kHz) may be a wideband signal (e.g., the portion greater than 4 kHz). The frequency ranges up to the upper boundary of band 2B 2880a-d (e.g., 16 kHz) may be a superwideband signal. The frequency ranges up to the upper boundary of band 2C 2882a-d (e.g., 24 kHz) may be a fullband signal.
Depending on the availability of the network, and availability of speech codecs available in the mobile device 102, different configurations of codecs may be used. Where compression is involved, a distinction is sometimes made between audio codecs and speech codecs. Speech codecs may be referred to as voice codecs. Audio codecs and speech codecs have different compression schemes and the amount of compression may vary widely between the two. Audio codecs may have better fidelity, but may require more bits when compressing an audio signal 2844a-d. Thus, the compression ratio (i.e., the number of bits of the input signal in the codec to the number of bits of the output signal of the codec) may be lower for audio codecs than speech codecs. Consequently, because of over-the-air bandwidth constraints in a cell (an area covered by multiple base stations), audio codecs were not used in older 2G (Second Generation) and 3G (Third Generation) communication systems, to transmit voice, as the number of bits required to transmit a speech packet was undesirable. As a result, speech codecs were and have been used in 2G and 3 G communication systems to transmit compressed speech over-the air in a voice channel from one mobile device to another mobile device.
Although audio codecs exist in mobile devices, the transmission of audio packets, i.e., the description for the compression of audio by an audio codec, has been done over the air data channel. Examples of audio codecs include MPEG-2/AAC Stereo, MPEG-4 BSAC Stereo, Real Audio, SBC Bluetooth, WMA and WMA 10 Pro. It should be noted that these audio codecs may be found in mobile devices in 3G systems, but the compressed audio signals were not transmitted over the air, in real-time, over a traffic channel or voice channel. Speech codecs are used to compress audio signals and transmit over the air, in real time. Examples of speech codecs include AMR Narrowband Speech Codec (5.15 kbp), AMR Wideband Speech Codec (8.85 Kbps), G.729AB Speech Codec (8 kbps), GSM-EFR Speech Codec (12.2 kbps), GSM-FR Speech Codec (13 kbps), GSM-HR speech Codec (5.6 kpbs), EVRC-NB, EVRC-WB. Compressed speech (or audio) is packaged in a vocoder packet and sent over the air in a traffic channel. The speech codec is sometimes called a vocoder. Before being sent over the air, the vocoder packet is inserted into a larger packet. In 2G and 3 G communications voice is transmitted in voice-channels, although voice can also be transmitted in data channels using VoIP (voice-over-IP).
Depending on the over-the air bandwidth, various codec schemes may be used for encoding the signals between the upper band (UB) frequency and the Nyquist Frequency (NF). Examples of these schemes are presented in
In this example, each audio signal 2944a-d may use a fullband codec 2948a-d for compression and transmission of the various bands of the audio signal 2944a-d. For example, those bands of each audio signal 2944a-d that fall within the frequency range defined by a certain low band frequency (LB) and a certain upper band frequency (UB) (e.g., including band 1B 2976a-d) may be filtered. According to this configuration, for bands that include frequencies greater than the certain upper band frequency (UB) and less than the Nyquist Frequency (e.g., bands 2A-2C 2984a-d), the original audio signal captured at the nearest microphone to the desired corner location 2944a-d may be encoded. Similarly, for bands that include frequencies less than the certain low band frequency (LB) (e.g., band 1A 2946a-d), the original audio signal captured at the nearest microphone to the desired corner location 2944a-d may be encoded. In some configurations, encoding the original audio signal captured at the nearest microphone to the desired corner location 2944a-d may denote a designated direction for bands 2A-2C 2984a-d since it captures natural delay and gain difference among the microphone channels. In some examples, the difference between capturing the nearest microphone to the desired location and the filtered range is that the effect of the directionality is not so much compared with the filtered frequency region.
In this example, those bands of each audio signal 2944a-d that fall within the frequency range defined by a certain low band frequency (LB) and a certain upper band frequency (UB) (e.g., including band 1B 2976a-d) may be filtered. According to this configuration, for bands that include frequencies greater than the certain upper band frequency (UB) and less than the Nyquist Frequency (e.g., bands 2A-2B 2986a-d), the original audio signal captured at the nearest microphone to the desired corner location 2944a-d may be encoded. Similarly, for bands that include frequencies less than the certain low band frequency (LB) (e.g., band 1A 2946a-d), the original audio signal captured at the nearest microphone to the desired corner location 2944a-d may be encoded.
In this example, those bands of each audio signal 2944a-d that fall within the frequency range defined by a certain low band frequency (LB) and a certain upper band frequency (UB) (e.g., including band 1B 2976a-d) may be filtered. According to this configuration, for bands that include frequencies greater than the certain upper band frequency (UB) and less than the Nyquist Frequency (e.g., band 2A 2978a-d), the original audio signal captured at the nearest microphone to the desired corner location 2944a-d may be encoded. Similarly, for bands that include frequencies less than the certain low band frequency (LB) (e.g., band 1A 2946a-d), the original audio signal captured at the nearest microphone to the desired corner location 2944a-d may be encoded.
In this configuration, the fullband codecs 3094a, 3094b may average one or more audio signals 3044a-d for the frequency range above a certain upper boundary of the front right audio signal 3044c and the back right audio signal 3044d. For example, the fullband codecs 3094a, 3094b may average the audio signal bands that include frequencies greater than the certain upper band frequency (UB) (e.g., band 2A-2C 3092a, 3092b). Audio signals 3044a-d originating from the same general direction may be averaged together. For example, a front left audio signal 3044a and a front right audio signal 3044c may be averaged together, and a back left audio signal 3044b and a back right audio signal 3044d may be averaged together.
An example of averaging audio signals 3044a-d is given as follows. A front left audio signal 3044a and a back left audio signal 3044b may use fullband codecs 3094a, 3094b. In this example, a front right audio signal 3044c and a back right audio signal 3044d may use narrowband codecs 3094c, 3094d. In this example, the fullband codecs 3094a, 3094b may include those filtered bands between the certain low band frequency (LB) and the certain upper band frequency (UB) (e.g., band 1B 3076a-b) for the respective audio signals (e.g., front left audio signal 3044a and back left audio signal 3044b). The fullband codecs 3094a, 3094b may also average the audio signal bands containing frequencies above the certain upper band frequency (UB) (e.g., band 2A-2C 3092a-b) of similarly directed audio signals (e.g., front audio signals 3044a, 3044c, and back audio signals 3044b, 3044d). Similarly, the fullband codecs 3094a, 3094b may include bands below the certain low band frequency (LB) (e.g., band 1A 3046a-b).
Further, in this example, the narrowband codecs 3094c, 3094d may include those filtered bands containing frequencies between the certain low band frequency (LB) and the maximum of 4 kHz and the certain upper band frequency (UB) (e.g., band 1B 3076c, 3076d) for the respective audio signals (e.g., front right audio signal 3044c, back right audio signal 3044d). The narrowband codecs 3094c, 3094d may also include bands below the certain low band frequency (LB) for the respective audio signals (e.g., front right audio signal 3044c, back right audio signal 3044d). In this example, if the certain upper band frequency (UB) is less than 4 kHz, the original audio signal captured at the nearest microphone to the desired corner location 3044a-d may be encoded.
As described above, while
In this example, the fullband codecs 3094a, 3094b may include bands 1A 3046a-b, band 1B 3076a-b, band 2A 3078a-b, and an averaged band 2B, 2C 3092a-b. The wideband codecs 3094e, 3094f may include those filtered bands containing frequencies between the certain low band frequency (LB) and the certain upper band frequency (UB) (e.g., band 1B 3076c-d) for the respective audio signals (e.g., front right audio signal 3044c and back right audio signal 3044d). The wideband codecs 3094e, 3094f may also include the original audio signal captured at the nearest microphone signal for band 2A 3078c-d. By encoding the nearest microphone signal, the directionality may still be encoded by intrinsic time and level differences among the microphone channels (although not as dramatic as spatial processing of frequencies between the certain lower band frequency (LB) and the certain upper band frequency (UB). The wideband codecs 3094e, 3094f may also include bands below the certain low band frequency (LB) (e.g., band 1A 3046c-d) for the respective audio signals (e.g., front right audio signal 3044c and back right audio signal 3044d).
In this example, the fullband codec 3198a may include those filtered bands containing frequencies between the certain low band frequency (LB) and the certain upper band frequency (UB) (band 1B 3176a) for the audio signal 3144a. The fullband codec 3198a may also average the audio signal bands containing frequencies above the certain upper band frequency (UB) (e.g., band 2A-2C 3192a) of the audio signals 3144a-d. Similarly, the fullband codec 3198a may include bands below the certain low band frequency (LB) (e.g., band 1A 3146a).
The narrowband codecs 3198b-d may include those filtered bands including frequencies between the certain low band frequency (LB) and the maximum of 4 kHz and the certain upper band frequency (UB) (e.g., band 1B 3176b-d) for the respective audio signals (e.g., 3144b-d). The narrowband codecs 3198b-d may also include bands containing frequencies below the certain low band frequency (LB) (e.g., band 1A 3146b-d) for the respective audio signals (e.g., 3144b-d).
In this example, the fullband codec 3198a may include band 1A 3146a, band 1B 3176a, band 2A 3178a and band 2B-2C 3192a. The wideband codecs 3198e-g may include those filtered bands including frequencies between the certain low band frequency (LB) and the certain upper band frequency (UB) (e.g., band 1B 3176b-d) for the respective audio signals (e.g., 3144b-d). The wideband codecs 3198e-g may also include the original audio signal captured at the nearest microphone to the desired corner location for frequencies above the certain upper band frequency (UB) (e.g., band 2A 3178b-d). The wideband codecs 3198e-g may also include bands containing frequencies below the certain low band frequency (LB) (e.g., band 1A 3146b-d) for the respective audio signals (e.g., 3144b-d).
The wireless communication device 102 may then generate 3304 the audio signal packets 3376. In some implementations, generating 3304 the audio signal packets 3376 may include generating one or more audio channels. For example, given the codec configuration of
Generating 3304 the audio signal packets 3376 may also include applying one or more non-narrowband codecs to the audio channels. According to some configurations, the wireless communication device 102 may use one or more of the first configuration of codecs as depicted in
With the audio signal packets 3376 generated, the wireless communication device 102 may transmit 3306 the audio signal packets 3376 to a decoder. The decoder may be included in audio output device, such as a wireless communication device 102. In some implementations, the audio signal packets 3376 may be transmitted over-the-air.
The decoder may receive 3308 the audio signal packets 3376. In some implementations, receiving 3308 the audio signal packets 3376 may include decoding the received audio signal packets 3376. The decoder may do so according to the first configuration. Drawing from the above example, the decoder may decode the audio channels using a fullband codec for each audio channel. Alternatively, the decoder may use superwideband codecs 2988a-d or wideband codecs 2990a-d, depending on how the transmission packets 3376 were generated.
In some configurations, receiving 3308 the audio signal packets 3376 may include reconstructing a front center channel. For example, a receiving audio output device may combine the front left audio channel and the front right audio channel to generate a front center audio channel.
Receiving 3308 the audio signal packets 3376 may also include reconstructing a subwoofer channel. This may include passing one or more of the audio signals 2944a-d through a low pass filter.
The received audio signal may then be played 3310 back on an audio output device. In some cases this may include playing the audio signal back in a surround sound format. In other cases, the audio signal may be downmixed and played back in a stereo format.
In some implementations, four low band channels (e.g., corresponding to the four audio signals 3044a-d illustrated in
Generating 3404 the audio signal packets 3476 may also include applying one or more codecs 3094a-f to the audio channels. According to some configurations, the wireless communication device 102 may use one or more of the second configuration of codecs 3094a-f as depicted in
For example, given the codecs as depicted in
With the audio signal information generated, the wireless communication device 102 may transmit 3406 the audio signal information. In some implementations, this may be done as described in connection with
The decoder may receive 3408 the audio signal information. In some implementations, receiving 3408 the audio signal information may include decoding the received audio signal information. In some implementations this may be done as described in connection with
In some configurations, receiving 3408 the audio signal information may include reconstructing a front center channel. In some implementations this may be done as described in connection with
Receiving 3408 the audio signal information may also include reconstructing a subwoofer signal. In some implementations, this may be done as described in connection with
The received audio signal may then be played 3410 back on an audio output device. In some implementations, this may be done as described in connection with
The wireless communication device 102 may then generate 3504 the audio signal packets 3576. In some implementations, generating 3504 the audio signal packets 3576 may include generating one or more audio channels. For example, the bands of an audio signal 3144 that fall within a certain low band frequency (LB) and a certain upper band frequency (UB) (e.g., band 1B 3176a-d) may be filtered. In some implementations, this may be done as described in
In some implementations, four low band channels, corresponding to the four audio signals 3144, may be generated. In some implementations, this may be done as described in
Generating 3504 the audio signal packets 3576 may also include applying one or more codecs 3198a-g to the audio channels. According to some configurations, the wireless communication device 102 may use one or more of the third configuration of codecs 3198a-g as depicted in
For the packet 3576 corresponding to the audio signal 3144a using a fullband codec 3198a, the packet 3576 may include the low band channels of that audio signal 3144a and the high band channel up to twenty four kHz (e.g., the maximum frequency allowed by a fullband codec 3198a) of the averaged audio signals 3144a-d. For the audio signal packets 3576 corresponding to the audio signals 3144a-d using wideband codecs 3198e-g (e.g., audio signals 3144b-d), the audio signal packet 3576 may include the low band channels of that audio signal 3144a-d (e.g., audio signals 3144b-d) and the original audio signal greater than the certain upper band frequency (UB) up to 8 kHz.
With the audio signal information generated, the wireless communication device 102 may transmit 3506 the audio signal information. In some implementations, this may be done as described in connection with
The decoder may receive 3508 the audio signal information. In some implementations, receiving 3508 the audio signal information may include decoding the received audio signal information. In some implementations this may be done as described in connection with
In some configurations, receiving 3508 the audio signal information may include reconstructing a front center channel. In some implementations this may be done as described in connection with
Receiving 3508 the audio signal information may also include reconstructing a subwoofer signal. In some implementations, this may be done as described in connection with
The received audio signal may then be played 3510 back on an audio output device. In some implementations, this may be done as described in connection with
The wireless communication device 102 may then generate 3604 the audio signal packets 3676. Generating 3604 the audio signal packets 3676 may include generating one or more audio channels. In some implementations, this may be done as described in
Generating 3604 the audio signal packets 3676 may also include applying one or more non-narrowband codecs, as depicted in
With the audio signal packets 3676 generated, the wireless communication device 102 may transmit 3606 the audio signal packets 3676 to a decoder. In some implementations, this may be done as described in
The decoder may receive 3608 the audio signal packets 3676. In some implementations, receiving 3608 the audio signal packets 3676 may include decoding the received audio signal packets 3676. The decoder may use one or more wideband codecs or one or more narrowband codecs to decode the audio signal packets 3676. The audio output device may also reconstruct the [8, 24] kHz. range of the audio channels based on the received audio signal packets 3676 using bandwidth extension of the wideband channels. In this example no transmission from the upper band frequency (UB) to the Nyquist Frequency is necessary. This range may be generated from the low band frequency to the upper band frequency (UB) range using techniques similar to spectral band replication (SBR). Bands below the low band frequency (LB) may be transmitted, for example, by averaging the microphone inputs.
In some configurations, receiving 3608 the audio signal packets 3676 may include reconstructing a front center channel. In some implementations, this may be done as described in
Receiving 3608 the audio signal packets 3676 may also include reconstructing a subwoofer channel. In some implementations, this may be done as described in
Coding bits may be assigned, or distributed, based on a specific direction. This direction may be selected by the user. For example, the direction where the user's voice is coming from may have more bits assigned to it. This may be performed by minimizing the dynamic range of other channels, as well as, decreasing the energy of the other directions. In addition, in a different configurations, the visualization of the energy distribution of the four corners of the surround sound may be generated. The user selection of which directional sound should have more bits allocated, i.e., sound better, or have a better desired sound direction may be selected based on the visualization of the energy distribution. In this configuration, one or two channels are encoded with more bits, but one or more channels are transmitted.
The method 3700 may include recording 3702 one or more audio signals 2944. In some implementations, this may be done as described in connection with
Generating 3704 the audio signal packets 3776 may also include generating a visualization of the energy distribution of the four corners (e.g., the four audio signals 2944a-d). From this visualization a user may select which directional sound should have more bits allocated (e.g., where the user's voice is coming from). Based on the user selection (e.g., an indication of spatial direction 3878), the wireless communication device 102 may apply more bits to one or two of the codecs of the first configuration of codecs (e.g., the codecs depicted in
With the audio signal packets 3776 generated, the wireless communication device 102 may transmit 3706 the audio signal packets 3776 to a decoder. In some implementations, this may be done as described in connection with
The received audio signal may then be played 3710 back on an audio output device. In some implementations, this may be done as described in connection with
The wireless communication device 102 may then generate 3804 the audio signal packets 3876. Generating 3804 the audio signal packets 3876 may include generating one or more audio channels. In some implementations, this may be done as described in
With the audio signal information generated, the wireless communication device 102 may transmit 3806 the audio signal packet 3876 to a decoder. In some implementations, this may be done as described in connection with
The decoder may receive 3808 the audio signal information. In some implementations, this may be done as described in connection with
The received audio signal may then be played 3810 back on an audio output device. In some implementations, the received audio signal may be played 3810 back as described in connection with
The wireless communication device 3902 may include memory 3950 coupled to the microphone array 3930. The memory 3950 may receive audio signals provided by the microphone array 3930. For example, the memory 3950 may include one or more data sets pertaining to the four recorded directions. In other words, the memory 3950 may include data for the front left microphone 3904a audio signal, the front right microphone 3904b audio signal, the back right microphone 3904c audio signal and the back left microphone 3904d audio signal.
The wireless communication device 3902 may also include a controller 3952 that receives processing information. For example, the controller 3952 may receive user information input into a user interface. More specifically, a user may indicate a desired recording direction. In other examples, a user may indicate one or more audio channels to allocate more processing bits to, or a user may indicate which audio channels to encode and transmit. The controller 3952 may also receive a bandwidth information. For example, the bandwidth information may indicate to the controller 3952 the bandwidth allocated (e.g., fullband, superwideband, wideband and narrowband) to the wireless communication device 3902 for transmission of the audio signal information.
Based on the information from the controller 3952, (e.g., user input and bandwidth information) and the information stored in the memory 3950, the communication device 3902 may select from one or more codec configurations 3974a-d, a particular configuration to apply to the audio channels. In some implementations, the codec configurations 3974a-d present on the wireless communication device may include the first configurations of
The wireless communication device 102 may generate 4404 a plurality of audio signal packets 3376. In some configurations, the audio signal packets 3376 may be based on the plurality of audio signals. The plurality of audio signal packets 3376 may include an averaged signal. As described above generating 4404 a plurality of audio signal packets 3376 may include generating a plurality of audio channels. For example, a portion of the plurality of directional audio signals may be compressed and transmitted as a plurality of audio channels over the air. In some cases, the number of directional audio signals that are compressed may not equal the number of audio channels that are transmitted. For example, if four directional audio signals are compressed, the number of audio channels that are transmitted may equal three. The audio channels may correspond to the one or more directional audio signals. In other words, the wireless communication device 102 may generate a front left audio channel that corresponds to the front left audio signal. The plurality of audio channels may include a filtered range of frequencies (e.g., band 1B) and an unfiltered range of frequencies (e.g., bands 1A, 2A, 2B and/or 2C).
Generating 4404 the plurality of audio signal packets 3376 may also include applying codecs to the audio channels. For example, the wireless communication device 102 may apply one or more of a fullband codec, a wideband codec, a superwideband codec or a narrowband codec to the plurality of audio signals. More specifically, the wireless communication device 102 may compress at least one directional audio signal in a low band, and may compress a different directional audio signal in a high band.
In some implementations, generating 4404 the plurality of audio signal packets 3376 may be based on received input. For example, the wireless communication device 102 may receive input from a user to determine bit allocation of the codecs. In some cases, the bit allocation may be based on a visualization of the energy of the directions to be compressed. A wireless communication device 102 may also receive input associated with compressing the directional audio signals. For example, a wireless communication device 102 may receive input from a user on which directional audio signals to compress (and transmit over the air). In some cases, the input may indicate which directional audio signal should have better audio quality. In these examples, the input may be based on by a gesture of a user's hand, for example by touching a display of a wireless communication device. Similarly, the input may be based on a movement of the wireless communication device.
With the audio signal packets 3376 generated, the wireless communication device 102 may transmit 4406 the plurality of audio signal packets 3376 to a decoder. The wireless communication device 102 may transmit 4406 the plurality of audio signal packets 3376 over the air. In some configurations, the decoder is included in a wireless communication device 102 such as an audio sensing device.
In some implementations, decomposing 4504 the auditory scene may include partitioning the audio signals into one or more frequency ranges. For example, the wireless communication device may partition the audio signals into a first set of narrowband frequency ranges and a second set of wideband frequency ranges. Additionally, the wireless communication device may compress audio samples that are associated with a first frequency band that is in the set of narrowband frequency ranges. With the audio samples compressed, the wireless communication device may transmit the compressed audio samples.
The wireless communication device 102 may also apply a beam in a first end-fire direction to obtain a first filtered signal. Similarly, a second beam in a second end-fire direction may generate a second filtered signal. In some cases, the beam may be applied to frequencies that are between a low threshold and a high threshold. In these cases, one of the thresholds (e.g., the low threshold or the high threshold) may be based on a distance between the microphones.
The wireless communication device may combine the first filtered signal with a delayed version of the second filtered signal. In some cases, the first and second filtered signals may each have two channels. In some cases one channel of a filtered signal (e.g., the first filtered signal and the second filtered signal) may be delayed relative to the other channel. Similarly, the combined signal (e.g., the combination of the first filtered signal and the second filtered signal) may have two channels that may be delayed relative to one another.
The wireless communication device 102 may include generating a first spatially filtered signal. For example, the wireless communication device 102 may apply a filter having a beam in a first direction to a signal produced by a first pair of microphones. In a similar fashion, the wireless communication device 102 may generate a second spatially filtered signal. In some cases, the axis of the first pair of microphones (e.g., those used to generate the first spatially filtered signal) may be at least substantially orthogonal to the axis of a second pair of microphones (e.g., those used to generate the second spatially filtered signal). The wireless communication device 102 may then combine the first spatially filtered signal and the second spatially filtered signal to generate an output signal. The output signal may correspond to a direction that is different than the direction of the first spatially filtered signal and the second spatially filtered signal.
The wireless communication device may also record an input channel. In some implementations, the input channel may correspond to each of a plurality of microphones in an array. For example, an input channel may correspond to the input of four microphones. A plurality of multichannel filters may be applied to the input channels to obtain an output channel. In some cases, the multichannel filters may correspond to a plurality of look directions. For example four multichannel filters may correspond to four look directions. Applying a multichannel filter in one look direction may include applying a null beam in other look directions. In some implementations, the axis of a first pair of the plurality of microphones may be less than fifteen degrees from orthogonal to the axis of a second pair of the plurality of microphones.
As described above, applying a plurality of multichannel filters may generate an output channel. In some cases, the wireless communication device 102 may process the output channel to produce a binaural recording that is based on a sum of binaural signals. For example, the wireless communication device 102 may apply a binaural impulse response to the output channel. This may result in a binaural signal which may be used to produce a binaural recording.
The wireless communication device 102 may then record 4604 a plurality of audio signals associated with the localizable audio sources. For example, one or more microphones located on the wireless communication device 102 may record 4604 an audio signal coming from a front left, a front right, a back left and/or a back right direction.
The wireless communication device 102 may encode 4606 the plurality of audio signals. As described above, the wireless communication device 102 may use any number of codecs to encode the signal. For example, the wireless communication device 102 may encode 4606 a front left and back left audio signals using a fullband codec and may encode 4606 a front right and back right audio signals using a wideband codec. In some cases, the wireless communication device 102 may encode a multichannel signal according to a three dimensional audio encoding scheme. For example, the wireless communication device 102 may use any of the configuration schemes described in connection with
The wireless communication device 102 may also apply a beam in a first end-fire direction to obtain a first filtered signal. Similarly, a second beam in a second end-fire direction may generate a second filtered signal. In some cases, the beam may be applied to frequencies that are between a low threshold and a high threshold. In these cases, one of the thresholds (e.g., the low threshold or the high threshold) may be based on a distance between the microphones.
The wireless communication device may combine the first filtered signal with a delayed version of the second filtered signal. In some cases, the first and second filtered signals may each have two channels. In some cases one channel of a filtered signal (e.g., the first filtered signal and the second filtered signal) may be delayed relative to the other channel. Similarly, the combined signal (e.g., the combination of the first filtered signal and the second filtered signal) may have two channels that may be delayed relative to one another.
The wireless communication device 102 may include generating a first spatially filtered signal. For example, the wireless communication device 102 may apply a filter having a beam in a first direction to a signal produced by a first pair of microphones. In a similar fashion, the wireless communication device 102 may generate a second spatially filtered signal. In some cases, the axis of the first pair of microphones (e.g., those used to generate the first spatially filtered signal) may be at least substantially orthogonal to the axis of a second pair of microphones (e.g., those used to generate the second spatially filtered signal). The wireless communication device 102 may then combine the first spatially filtered signal and the second spatially filtered signal to generate an output signal. The output signal may correspond to a direction that is different than the direction of the first spatially filtered signal and the second spatially filtered signal.
The wireless communication device may also record an input channel. In some implementations, the input channel may correspond to each of a plurality of microphones in an array. For example, an input channel may correspond to the input of four microphones. A plurality of multichannel filters may be applied to the input channels to obtain an output channel. In some cases, the multichannel filters may correspond to a plurality of look directions. For example four multichannel filters may correspond to four look directions. Applying a multichannel filter in one look direction may include applying a null beam in other look directions. In some implementations, the axis of a first pair of the plurality of microphones may be less than fifteen degrees from orthogonal to the axis of a second pair of the plurality of microphones.
As described above, applying a plurality of multichannel filters may generate an output channel. In some cases, the wireless communication device 102 may process the output channel to produce a binaural recording that is based on a sum of binaural signals. For example, the wireless communication device 102 may apply a binaural impulse response to the output channel. This may result in a binaural signal which may be used to produce a binaural recording.
The wireless communication device 102 may associate 4708 a codec associated with the input. For example, the wireless communication device 102 may associate 4708 a codec to produce better audio quality for a directional audio signal selected by the user. The wireless communication device 102 may then compress 4710 the plurality of audio signals based on the codec to generate an audio signal packet. As described above, the packet may then be transmitted over the air. In some implementations, the wireless communication device may also transmit a channel identification.
The wireless communication device 102 may associate 4808 a codec associated with the input. For example, the wireless communication device 102 may associate 4808 a codec to produce better audio quality for a directional audio signal selected by the user. The wireless communication device 102 may then increase 4810 bit allocation to the codec used to compress audio signals based on the input. As described above, the packet may then be transmitted over the air.
The wireless communication device 4902 includes a processor 4958. The processor 4958 may be a general purpose single- or multi-chip microprocessor (e.g., an ARM), a special purpose microprocessor (e.g., a digital signal processor (DSP)), a microcontroller, a programmable gate array, etc. The processor 4958 may be referred to as a central processing unit (CPU). Although just a single processor 4958 is shown in the wireless communication device 4902 of
The wireless communication device 4958 also includes memory 4956 in electronic communication with the processor 4958 (i.e., the processor 4958 can read information from and/or write information to the memory 4956). The memory 4956 may be any electronic component capable of storing electronic information. The memory 4956 may be random access memory (RAM), read-only memory (ROM), magnetic disk storage media, optical storage media, flash memory devices in RAM, on-board memory included with the processor 4958, programmable read-only memory (PROM), erasable programmable read-only memory (EPROM), electrically erasable PROM (EEPROM), registers, and so forth, including combinations thereof.
Data 4960 and instructions 4962 may be stored in the memory 4956. The instructions 4962 may include one or more programs, routines, sub-routines, functions, procedures, code, etc. The instructions 4962 may include a single computer-readable statement or many computer-readable statements. The instructions 4962 may be executable by the processor 4958 to implement one or more of the methods described above. Executing the instructions 4962 may involve the use of the data 4960 that is stored in the memory 4956.
The wireless communication device 4902 may also include a transmitter 4964 and a receiver 4966 to allow transmission and reception of signals between the wireless communication device 4902 and a remote location (e.g., a communication device, base station, etc.). The transmitter 4964 and receiver 4966 may be collectively referred to as a transceiver 4968. An antenna 4970 may be electrically coupled to the transceiver 4968. The wireless communication device 4902 may also include (not shown) multiple transmitters 4964, multiple receivers 4966, multiple transceivers 4968 and/or multiple antennas 4970.
In some configurations, the wireless communication device 4902 may include one or more microphones for capturing acoustic signals. In one configuration, a microphone may be a transducer that converts acoustic signals (e.g., voice, speech) into electrical or electronic signals. Additionally or alternatively, the wireless communication device 4902 may include one or more speakers. In one configuration, a speaker may be a transducer that converts electrical or electronic signals into acoustic signals.
The various components of the wireless communication device 4902 may be coupled together by one or more buses, which may include a power bus, a control signal bus, a status signal bus, a data bus, etc. For simplicity, the various buses are illustrated in
The methods and apparatus disclosed herein may be applied generally in any transceiving and/or audio sensing application, especially mobile or otherwise portable instances of such applications. For example, the range of configurations disclosed herein includes communications devices that reside in a wireless telephony communication system configured to employ a code-division multiple-access (CDMA) over-the-air interface. Nevertheless, it would be understood by those skilled in the art that a method and apparatus having features as described herein may reside in any of the various communication systems employing a wide range of technologies known to those of skill in the art, such as systems employing Voice over IP (VoIP) over wired and/or wireless (e.g., CDMA, TDMA, FDMA, and/or TD-SCDMA) transmission channels.
It is expressly contemplated and hereby disclosed that communications devices disclosed herein may be adapted for use in networks that are packet-switched (for example, wired and/or wireless networks arranged to carry audio transmissions according to protocols such as VoIP) and/or circuit-switched. It is also expressly contemplated and hereby disclosed that communications devices disclosed herein may be adapted for use in narrowband coding systems (e.g., systems that encode an audio frequency range of about four or five kilohertz) and/or for use in wideband coding systems (e.g., systems that encode audio frequencies greater than five kilohertz), including whole-band wideband coding systems and split-band wideband coding systems.
The foregoing presentation of the described configurations is provided to enable any person skilled in the art to make or use the methods and other structures disclosed herein. The flowcharts, block diagrams, and other structures shown and described herein are examples only, and other variants of these structures are also within the scope of the disclosure. Various modifications to these configurations are possible, and the generic principles presented herein may be applied to other configurations as well. Thus, the present disclosure is not intended to be limited to the configurations shown above but rather is to be accorded the widest scope consistent with the principles and novel features disclosed in any fashion herein, including in the attached claims as filed, which form a part of the original disclosure.
Those of skill in the art will understand that information and signals may be represented using any of a variety of different technologies and techniques. For example, data, instructions, commands, information, signals, bits and symbols that may be referenced throughout the above description may be represented by voltages, currents, electromagnetic waves, magnetic fields or particles, optical fields or particles, or any combination thereof.
Important design requirements for implementation of a configuration as disclosed herein may include minimizing processing delay and/or computational complexity (typically measured in millions of instructions per second or MIPS), especially for computation-intensive applications, such as playback of compressed audio or audiovisual information (e.g., a file or stream encoded according to a compression format, such as one of the examples identified herein) or applications for wideband communications (e.g., voice communications at sampling rates higher than eight kilohertz, such as 12, 16, or 44 kHz).
Goals of a multi-microphone processing system may include achieving ten to twelve dB in overall noise reduction, preserving voice level and color during movement of a desired speaker, obtaining a perception that the noise has been moved into the background instead of an aggressive noise removal, dereverberation of speech, and/or enabling the option of post-processing for more aggressive noise reduction.
The various elements of an implementation of an apparatus as disclosed herein may be embodied in any combination of hardware with software, and/or with firmware, that is deemed suitable for the intended application. For example, such elements may be fabricated as electronic and/or optical devices residing, for example, on the same chip or among two or more chips in a chipset. One example of such a device is a fixed or programmable array of logic elements, such as transistors or logic gates, and any of these elements may be implemented as one or more such arrays. Any two or more, or even all, of these elements may be implemented within the same array or arrays. Such an array or arrays may be implemented within one or more chips (for example, within a chipset including two or more chips).
One or more elements of the various implementations of the apparatus disclosed herein may also be implemented in whole or in part as one or more sets of instructions arranged to execute on one or more fixed or programmable arrays of logic elements, such as microprocessors, embedded processors, IP cores, digital signal processors, FPGAs (field-programmable gate arrays), ASSPs (application-specific standard products), and ASICs (application-specific integrated circuits). Any of the various elements of an implementation of an apparatus as disclosed herein may also be embodied as one or more computers (e.g., machines including one or more arrays programmed to execute one or more sets or sequences of instructions, also called “processors”), and any two or more, or even all, of these elements may be implemented within the same such computer or computers.
A processor or other means for processing as disclosed herein may be fabricated as one or more electronic and/or optical devices residing, for example, on the same chip or among two or more chips in a chipset. One example of such a device is a fixed or programmable array of logic elements, such as transistors or logic gates, and any of these elements may be implemented as one or more such arrays. Such an array or arrays may be implemented within one or more chips (for example, within a chipset including two or more chips). Examples of such arrays include fixed or programmable arrays of logic elements, such as microprocessors, embedded processors, IP cores, DSPs, FPGAs, ASSPs and ASICs. A processor or other means for processing as disclosed herein may also be embodied as one or more computers (e.g., machines including one or more arrays programmed to execute one or more sets or sequences of instructions) or other processors. It is possible for a processor as described herein to be used to perform tasks or execute other sets of instructions that are not directly related to a directional encoding procedure, such as a task relating to another operation of a device or system in which the processor is embedded (e.g., an audio sensing device). It is also possible for part of a method as disclosed herein to be performed by a processor of the audio sensing device and for another part of the method to be performed under the control of one or more other processors.
Those of skill will appreciate that the various illustrative modules, logical blocks, circuits, and tests and other operations described in connection with the configurations disclosed herein may be implemented as electronic hardware, computer software or combinations of both. Such modules, logical blocks, circuits, and operations may be implemented or performed with a general purpose processor, a digital signal processor (DSP), an ASIC or ASSP, an FPGA or other programmable logic device, discrete gate or transistor logic, discrete hardware components, or any combination thereof designed to produce the configuration as disclosed herein. For example, such a configuration may be implemented at least in part as a hard-wired circuit, as a circuit configuration fabricated into an application-specific integrated circuit, or as a firmware program loaded into non-volatile storage or a software program loaded from or into a data storage medium as machine-readable code, such code being instructions executable by an array of logic elements such as a general purpose processor or other digital signal processing unit. A general purpose processor may be a microprocessor, but in the alternative, the processor may be any conventional processor, controller, microcontroller or state machine. A processor may also be implemented as a combination of computing devices, e.g., a combination of a DSP and a microprocessor, a plurality of microprocessors, one or more microprocessors in conjunction with a DSP core, or any other such configuration. A software module may reside in RAM (random-access memory), ROM (read-only memory), nonvolatile RAM (NVRAM) such as flash RAM, erasable programmable ROM (EPROM), electrically erasable programmable ROM (EEPROM), registers, hard disk, a removable disk, a CD-ROM or any other form of storage medium known in the art. An illustrative storage medium is coupled to the processor such the processor can read information from, and write information to, the storage medium. In the alternative, the storage medium may be integral to the processor. The processor and the storage medium may reside in an ASIC. The ASIC may reside in a user terminal. In the alternative, the processor and the storage medium may reside as discrete components in a user terminal.
It is noted that the various methods disclosed herein may be performed by an array of logic elements such as a processor, and that the various elements of an apparatus as described herein may be implemented as modules designed to execute on such an array. As used herein, the term “module” or “sub-module” can refer to any method, apparatus, device, unit or computer-readable data storage medium that includes computer instructions (e.g., logical expressions) in software, hardware or firmware form. It is to be understood that multiple modules or systems can be combined into one module or system and one module or system can be separated into multiple modules or systems to perform the same functions. When implemented in software or other computer-executable instructions, the elements of a process are essentially the code segments to perform the related tasks, such as with routines, programs, objects, components, data structures, and the like. The term “software” should be understood to include source code, assembly language code, machine code, binary code, firmware, macrocode, microcode, any one or more sets or sequences of instructions executable by an array of logic elements, and any combination of such examples. The program or code segments can be stored in a processor readable medium or transmitted by a computer data signal embodied in a carrier wave over a transmission medium or communication link.
The implementations of methods, schemes, and techniques disclosed herein may also be tangibly embodied (for example, in one or more computer-readable media as listed herein) as one or more sets of instructions readable and/or executable by a machine including an array of logic elements (e.g., a processor, microprocessor, microcontroller, or other finite state machine). The term “computer-readable medium” may include any medium that can store or transfer information, including volatile, nonvolatile, removable and non-removable media. Examples of a computer-readable medium include an electronic circuit, a semiconductor memory device, a ROM, a flash memory, an erasable ROM (EROM), a floppy diskette or other magnetic storage, a CD-ROM/DVD or other optical storage, a hard disk, a fiber optic medium, a radio frequency (RF) link, or any other medium which can be used to store the desired information and which can be accessed. The computer data signal may include any signal that can propagate over a transmission medium such as electronic network channels, optical fibers, air, electromagnetic, RF links, etc. The code segments may be downloaded via computer networks such as the Internet or an intranet. In any case, the scope of the present disclosure should not be construed as limited by such configurations.
Each of the tasks of the methods described herein may be embodied directly in hardware, in a software module executed by a processor, or in a combination of the two. In a typical application of an implementation of a method as disclosed herein, an array of logic elements (e.g., logic gates) is configured to perform one, more than one or even all of the various tasks of the method. One or more (possibly all) of the tasks may also be implemented as code (e.g., one or more sets of instructions), embodied in a computer program product (e.g., one or more data storage media such as disks, flash or other nonvolatile memory cards, semiconductor memory chips, etc.), that is readable and/or executable by a machine (e.g., a computer) including an array of logic elements (e.g., a processor, microprocessor, microcontroller, or other finite state machine). The tasks of an implementation of a method as disclosed herein may also be performed by more than one such array or machine. In these or other implementations, the tasks may be performed within a device for wireless communications such as a cellular telephone or other device having such communications capability. Such a device may be configured to communicate with circuit-switched and/or packet-switched networks (e.g., using one or more protocols such as VoIP). For example, such a device may include RF circuitry configured to receive and/or transmit encoded frames.
It is expressly disclosed that the various methods disclosed herein may be performed by a portable communications device such as a handset, headset, or portable digital assistant (PDA), and that the various apparatus described herein may be included within such a device. A typical real-time (e.g., online) application is a telephone conversation conducted using such a mobile device.
In one or more exemplary configurations, the operations described herein may be implemented in hardware, software, firmware or any combination thereof. If implemented in software, such operations may be stored on or transmitted over a computer-readable medium as one or more instructions or code. The term “computer-readable media” includes both computer storage media and communication media, including any medium that facilitates transfer of a computer program from one place to another. A storage media may be any available media that can be accessed by a computer. By way of example, and not limitation, such computer-readable media can comprise an array of storage elements, such as semiconductor memory (which may include without limitation dynamic or static RAM, ROM, EEPROM, and/or flash RAM), or ferroelectric, magnetoresistive, ovonic, polymeric, or phase-change memory; CD-ROM or other optical disk storage, magnetic disk storage or other magnetic storage devices, or any other medium that can be used to store desired program code, in the form of instructions or data structures, in tangible structures that can be accessed by a computer. Also, any connection is properly termed a computer-readable medium. For example, if the software is transmitted from a website, server, or other remote source using a coaxial cable, fiber optic cable, twisted pair, digital subscriber line (DSL), or wireless technology such as infrared, radio, and/or microwave, then the coaxial cable, fiber optic cable, twisted pair, DSL, or wireless technology such as infrared, radio, and/or microwave are included in the definition of medium. Disk and disc, as used herein, includes compact disc (CD), laser disc, optical disc, digital versatile disc (DVD), floppy disk and Blu-ray Disc™ (Blu-Ray Disc Association, Universal City, Calif.), where disks usually reproduce data magnetically, while discs reproduce data optically with lasers. Combinations of the above should also be included within the scope of computer-readable media.
An acoustic signal processing apparatus as described herein may be incorporated into an electronic device that accepts speech input in order to control certain operations, or may otherwise benefit from separation of desired noises from background noises, such as communications devices. Many applications may benefit from enhancing or separating clear desired sound from background sounds originating from multiple directions. Such applications may include human-machine interfaces in electronic or computing devices which incorporate capabilities such as voice recognition and detection, speech enhancement and separation, voice-activated control, and the like. It may be desirable to implement such an acoustic signal processing apparatus to be suitable in devices that only provide limited processing capabilities.
The elements of the various implementations of the modules, elements and devices described herein may be fabricated as electronic and/or optical devices residing, for example, on the same chip or among two or more chips in a chipset. One example of such a device is a fixed or programmable array of logic elements, such as transistors or gates. One or more elements of the various implementations of the apparatus described herein may also be implemented in whole or in part as one or more sets of instructions arranged to execute on one or more fixed or programmable arrays of logic elements such as microprocessors, embedded processors, IP cores, digital signal processors, FPGAs, ASSPs and ASICs.
It is possible for one or more elements of an implementation of an apparatus as described herein to be used to perform tasks or execute other sets of instructions that are not directly related to an operation of the apparatus, such as a task relating to another operation of a device or system in which the apparatus is embedded. It is also possible for one or more elements of an implementation of such an apparatus to have structure in common (e.g., a processor used to execute portions of code corresponding to different elements at different times, a set of instructions executed to perform tasks corresponding to different elements at different times, or an arrangement of electronic and/or optical devices performing operations for different elements at different times).
In the above description, reference numbers have sometimes been used in connection with various terms. Where a term is used in connection with a reference number, this may be meant to refer to a specific element that is shown in one or more of the Figures. Where a term is used without a reference number, this may be meant to refer generally to the term without limitation to any particular Figure.
In accordance with the present disclosure, a circuit in a mobile device may be adapted to receive signal conversion commands and accompanying data in relation to multiple types of compressed audio bitstreams. The same circuit, a different circuit or a second section of the same or different circuit may be adapted to perform a transform as part of signal conversion for the multiple types of compressed audio bitstreams. The second section may advantageously be coupled to the first section, or it may be embodied in the same circuit as the first section. In addition, the same circuit, a different circuit, or a third section of the same or different circuit may be adapted to perform complementary processing as part of the signal conversion for the multiple types of compressed audio bitstreams. The third section may advantageously be coupled to the first and second sections, or it may be embodied in the same circuit as the first and second sections. In addition, the same circuit, a different circuit, or a fourth section of the same or different circuit may be adapted to control the configuration of the circuit(s) or section(s) of circuit(s) that provide the functionality described above.
The term “determining” encompasses a wide variety of actions and, therefore, “determining” can include calculating, computing, processing, deriving, investigating, looking up (e.g., looking up in a table, a database or another data structure), ascertaining and the like. Also, “determining” can include receiving (e.g., receiving information), accessing (e.g., accessing data in a memory) and the like. Also, “determining” can include resolving, selecting, choosing, establishing and the like.
This application is related to and claims priority from U.S. Provisional Patent Application Ser. No. 61/651,185 filed May 24, 2012, for “THREE-DIMENSIONAL SOUND COMPRESSION AND OVER-THE-AIR TRANSMISSION DURING A CALL.”
Number | Date | Country | |
---|---|---|---|
61651185 | May 2012 | US |