The present disclosure relates generally to audio signal processing, and in a specific example embodiment, to automatic equalization of coloration in speech recordings.
In typical speaking environments, a speaker does not provide a constant level of speech. For example, people tend to move when they speak. If the speaker moves his head or turns away from the microphone, sound will be different than when the speaker is speaking directly into the microphone. Additionally, when multiple speakers are in the same environment, one speaker will be closer to a microphone and thus provide louder or clearer speech than the speaker that is further away. As such, speech may not be at a constant loudness or clarity.
Various ones of the appended drawings merely illustrate example embodiments of the present invention and cannot be considered as limiting its scope.
The description that follows includes systems, methods, techniques, instruction sequences, and computing machine program products that embody illustrative embodiments of the present invention. In the following description, for purposes of explanation, numerous specific details are set forth in order to provide an understanding of various embodiments of the inventive subject matter. It will be evident, however, to those skilled in the art that embodiments of the inventive subject matter may be practiced without these specific details. In general, well-known instruction instances, protocols, structures, and techniques have not been shown in detail. As used herein, the term “or” may be construed in either an inclusive or exclusive sense.
Systems and methods to provide automatic equalization of coloration in speech records are provided. In example embodiments, a reference spectral shape based on a reference signal is determined. The reference signal comprises any audio signal that may be used as a reference for equalizing the input signal.
An estimated spectral shape for an input signal is derived. In example embodiments, a plurality of averagers are used to measure the input signal. The plurality of averagers may each comprise a different time constant. For example, the plurality of averagers may include a short time constant averager, a mid time constant averager, and a long time constant averager. By using averagers having different time constants, short time changes in the input signal may be identified while also obtaining a good approximation of the input spectral shape over a longer time period. The values of the plurality of averagers may be combined to derive the estimated spectral shape of the input signal.
Using the estimated spectral shape and the reference spectral shape a comparison is performed to determine gain settings. The gain settings may comprise a gain value for each filter of a filter system. Using gain values associated with the gain setting, automatic equalization is performed on the input signal.
With reference to
The equalization system 102 further receives a reference signal from a reference signal device 106. The reference signal may be any audio stream that is used for comparison to the input signal. In one embodiment, the reference signal is a recorded signal. Based on the reference signal, the equalization system 102 automatically equalizes the input signal. The equalization system 102 and its processes will be discussed in more detail below.
The result of the equalization system 102 is improved audio which is then passed onto a signal output device 108. The signal output device 108 may comprise, for example, a speaker, a recorder (e.g., for recording the output signal), or any other device configured to utilize the output signal. It should be noted that while audio is improved using example embodiments of the present subject matter, the input and output signals may comprise more than audio. For example, the input and output signals may be a combination of audio and video. Using example embodiments, the audio portion of the input signals are automatically equalized to improve sound quality. Furthermore, additional devices may be coupled along the signal path for audio or video latency compensation. This ensures audio/video synchronization.
The FFT/IFFT module 202 transforms signals between the time domain and the frequency domain. In some embodiments, an input signal may be converted into the frequency domain for processing by the equalization system 102. Once an equalized signal is generated by the equalization system 102, the equalized signal may be converted back to the time domain for output to the signal output device 108.
The reference model module 204 defines spectral shapes for the reference signal. In some embodiments, the reference signal may be a flat response such as a neutral sound. In other embodiments, the reference signal may be any arbitrary sound which may or may not be in the same environment as the input signal. For example, the reference signal may be from an anchorperson talking into a microphone while the input signal may be a live interview from outside a studio. In this example, the recorded sound from the anchorperson speaking in the studio is the reference signal that the reference model module 204 uses to define the reference spectral shape.
The measurement system 206 measures an input spectral shape. The measurement system 206 includes a normalizer 214 to normalize the input signal to a certain average level (rms). In a time domain, the measured (input) sounds may be lifted to a level similar to the reference sound. Alternatively in the spectral domain, the input spectral shape may be lifted to a level of the reference spectral shape in the spectral domain. The normalizing process may be arbitrary complex. For example, in the absence of a useful signal, the normalizer 214 may boost the ambience noise too much. In this situation, the normalizer 214 gain may be limited. Additional preprocessing steps may also be considered (e.g., noise gate, denoiser). A graphical example of the normalization process is shown in
In some embodiments, the measurement system 206 includes a plurality of averagers 216, each with a different time or integration constant. For instance, the measurement system 206 may include three averagers 216 with an averager 216 having a short time constant (e.g., one second), an averager 216 having a mid time constant (e.g., three seconds), and an averager 216 having a long time constant (e.g., ten seconds). By using averagers 216 having different time constants, short time changes in the input signal may be identified while a good approximation of the input spectral shape (e.g., over an average spectrum over a longer time period) may be obtained. While three averagers 216 are provided in the example, it is contemplated that any number of averages 216 having any type of time constant may be used.
The outputs of the averagers 216 are spectral estimates that then are used to derive a measured output by an input model module 218. Each individual band (bin) is compared. If a bin of the spectral estimate of the short or mid time averager 216 exceeds a value of the long time averager 216, the value of the short or mid time averager 216 becomes current to the long time averager 216 otherwise the bin value decays linearly or exponentially. In alternative embodiments, an average of the values from the averagers 216 may be the measured output. In yet other embodiment, some smoothing and/or averaging over a bin and its neighbor bins may be used to determine the measure output. The resulting measured output is a modelled estimated spectral shape for the input signal.
As such, the automatic control of the equalization process is based on a difference between short time average which immediately catches a change in the audio (e.g., a person turns their head away from the microphone) and a long time average. This difference may be used to control and amplify certain frequencies in order to improve the audio signal.
The comparison module 208 compares the difference between the estimated spectral shape and the reference spectral shape. The difference defines gain settings for the filter system 212. In example embodiments, the comparison module 208 combines and weights the spectral bins to get a wide band response and suppress estimation errors (e.g., averaged out). The resulting value defines a gain change for each filter node of the filter system 212.
The gain controller 210 analyzes the gain change output of the comparison module 208 and determines if the gain value satisfies a maximum or minimum gain value. Thus, the gain controller 210 may truncate a gain value that exceeds a maximum gain. This truncation is performed in order to alleviate perceptible audio changes produced by applying too much gain to the input signal.
For example, if the difference between the estimated spectral shape and the reference spectral shape is 30-40 dB, the gain controller 210 will reduce the gain value to, for example, 6 dB. This lower gain value will provide sound improvement without adding any drastic effects to the input signal. Thus, the gain controller 210 controls the amount of gain applied to the input signal.
The filter system 212 comprises a plurality of filters that automatically apply the calculated gain value from the gain controller 210 to the input signal. In some embodiments, the filter system 212 comprises multiple second order filters. The amount of filters may vary depending on the complexity of the coloration. For each filter, a side chain signal may be extracted upon which an envelope follower is computed. If an envelope follower signal falls below or rises above a given threshold, the filter gain may be swept from 0 dB to maximum gain. In some embodiments, the envelope follower operates in the frequency domain on a set of weighted bins of the normalized input spectrum that gives a spectral power threshold, which is compared with the reference spectral shape. As such, a relative gain shift may be computed. The gain may be updated for each FFT update.
Each of the averagers 216 fetches the input signal in parallel. Thus, each of the averagers 216 gets the same input spectrum of a current time for analysis. In the current example, the long averager 216a has a long time constant of twenty seconds, the short averager 216b has a short time constant of one second, and the mid averager 216c has a mid time constant of ten seconds.
The outputs of the averagers 216 are used to derive a measured output by the input model module 218. In some embodiments, each individual band (bin) is compared to determine a measured output. The resulting measured output is a modelled estimated spectral shape for the input signal.
The comparison module 208 compares the difference between the estimated spectral shape received from the input model module 218 and the reference spectral shape from the reference model module 204 (not shown in
According to some embodiments, the gain may be computed as follows. X(n, f) is a spectra based on averager n and frequency f (fft bin). The frequencies may be grouped into bands such that G(n, k) represents a frequency group k of averager n. A maximum gain, Gmax(k) may be determined whereby for each band k, max=0 and for each averager n, if G(n, k)>max then max=G(n, k). Thus, Gmax(k)=max.
In alterative embodiments, the max gain computation for each frequency band may be represented by weighted_gain=0.2*G(n, k−1)+0.6*G(n,k)+0.2*G(n,k+1) for example. If weighted_gain>max, then max=weighted_gain. Because gains are calculated per bands rather than individual gains per frequency, the gains per frequency could be computed by a linear interpolation from one to another band. A similar approach can be used to compute the gain of one frequency band.
The gain controller 210 analyzes the gain value, G(f), of the comparison module 208 and determines if the gain value satisfies a maximum or minimum gain threshold. For example, the gain controller 210 may truncate a gain value that exceeds a maximum gain. The output transfer function, G′(f), of the gain controller 210 is provided to the filter system 212 which automatically applies the modified gain value to the input signal. The resulting equalized spectra, Y(f) may be converted back into the time domain (e.g., y(t)) for output via the signal output device 108. It should be noted that the filter system 212 may perform the equalization in frequency or time domain. If the equalization is performed in the time domain, the transfer function is mapped to a set of time domain filters.
In operation 504, a reference spectral shape is defined. In example embodiments, a reference signal is received by the equalization system 102. The reference model module 204 defines the reference spectral shapes using the reference signal. In some embodiments, the reference signal may be a flat response such as a neutral sound. In other embodiments, the reference signal may be any arbitrary sound which may or may not be in the same environment as the input signal.
The input signal is normalized in operation 506. A normalizer 214 of the measurement system 206 normalizes the input signal to a certain average level (e.g., to a normalization threshold). In various embodiments, the measured (input) sounds of the input spectral shape may be lifted to a level the normalization threshold. In some embodiment, the normalization threshold may be the reference spectral shape in the spectral domain.
In operation 508, the spectral shape of the input signal is derived. In some embodiments, the measurement system 206 includes a plurality of averagers 216, each with a different time or integration constant. The averagers may include a short time constant averager 216b, a mid time constant averager 216c, and a long time constant averager 216a. By using these averagers 216 having different time constants, short time changes in the input signal may be identified while a good approximation of the overall input spectral shape (e.g., over an average spectrum over a longer time period) may also be obtained.
The outputs of the averagers are spectral estimates that then are used to derive a measured output by an input model module 218. The resulting measured output is a modelled estimated spectral shape for the input signal.
In operation 510, a difference between the estimated spectral shape and the reference spectral shape is determined. The comparison module 208 compares the difference between the estimated spectral shape and the reference spectral shape. The difference defines gain settings for the filter system 212. In example embodiments, the comparison module 208 combines and weights the spectral bins to get a wide band response and suppress estimation errors (e.g., averaged out). The resulting value defines a gain value for each filter node of the filter system 212.
Automatic equalization is then performed in operation 512. Operation 512 will be discussed in more detail in connection with
Referring now to
In operation 604, the gain values may be modified. The gain controller 210 analyzes the gain settings from the comparison module 208 and determines if each gain value satisfies a maximum or minimum gain value. Thus, the gain controller 210 may truncate a gain value that exceeds a maximum gain. This truncation is performed in order to alleviate perceptual audio changes produced by applying too much gain to the input signal. Thus, the gain controller 210 controls the amount of gain applied to the input signal.
In operation 606, the gain values are automatically applied to the input signal. In example embodiment, a plurality of filters of the filter system 212 automatically apply the calculated gain from the gain controller 210 to the input signal. In some embodiments, the filter system 212 comprises multiple second order filters.
The equalized signal is then output in operation 608. The equalized output signal is provided to the signal output device 108 for output. The output may comprise presenting the audio (e.g., through a speaker) or recording of the audio (e.g., into storage for later playback).
Modules, Components, and Logic
Certain embodiments described herein may be implemented as logic or a number of modules, engines, components, or mechanisms. A module, engine, logic, component, or mechanism (collectively referred to as a “module”) may be a tangible unit capable of performing certain operations and configured or arranged in a certain manner. In certain exemplary embodiments, one or more computer systems (e.g., a standalone, client, or server computer system) or one or more components of a computer system (e.g., a processor or a group of processors) may be configured by software (e.g., an application or application portion) or firmware (note that software and firmware can generally be used interchangeably herein, as is known by a skilled artisan) as a module that operates to perform certain operations described herein.
In various embodiments, a module may be implemented mechanically or electronically. For example, a module may comprise dedicated circuitry or logic that is permanently configured (e.g., within a special-purpose processor, application specific integrated circuit (ASIC), or array) to perform certain operations. A module may also comprise programmable logic or circuitry (e.g., as encompassed within a general-purpose processor or other programmable processor) that is temporarily configured by software or firmware to perform certain operations. It will be appreciated that a decision to implement a module mechanically, in the dedicated and permanently configured circuitry, or in temporarily configured circuitry (e.g., configured by software) may be driven by, for example, cost, time, energy-usage, and package size considerations.
Accordingly, the term “module” should be understood to encompass a tangible entity, be that an entity that is physically constructed, permanently configured (e.g., hardwired), or temporarily configured (e.g., programmed) to operate in a certain manner or to perform certain operations described herein. Considering embodiments in which modules or components are temporarily configured (e.g., programmed), each of the modules or components need not be configured or instantiated at any one instance in time. For example, where the modules or components comprise a general-purpose processor configured using software, the general-purpose processor may be configured as respective different modules at different times. Software may accordingly configure the processor to constitute a particular module at one instance of time and to constitute a different module at a different instance of time.
Modules can provide information to, and receive information from, other modules. Accordingly, the described modules may be regarded as being communicatively coupled. Where multiples of such modules exist contemporaneously, communications may be achieved through signal transmission (e.g., over appropriate circuits and buses) that connect the modules. In embodiments in which multiple modules are configured or instantiated at different times, communications between such modules may be achieved, for example, through the storage and retrieval of information in memory structures to which the multiple modules have access. For example, one module may perform an operation and store the output of that operation in a memory device to which it is communicatively coupled. A further module may then, at a later time, access the memory device to retrieve and process the stored output. Modules may also initiate communications with input or output devices and can operate on a resource (e.g., a collection of information).
Example Machine Architecture and Machine-Readable Medium
With reference to
The exemplary computer system 700 may include a processor 702 (e.g., a central processing unit (CPU), a graphics processing unit (GPU) or both), a main memory 704 and a static memory 706, which communicate with each other via a bus 708. The computer system 700 may further include a video display unit 710 (e.g., a liquid crystal display (LCD) or a cathode ray tube (CRT)). In exemplary embodiments, the computer system 700 also includes one or more of an alpha-numeric input device 712 (e.g., a keyboard), a user interface (UI) navigation device or cursor control device 714 (e.g., a mouse), a disk drive unit 716, a signal generation device 718 (e.g., a speaker), and a network interface device 720.
Machine-Readable Storage Medium
The disk drive unit 716 includes a machine-readable storage medium 722 on which is stored one or more sets of instructions 724 and data structures (e.g., software instructions) embodying or used by any one or more of the methodologies or functions described herein. The instructions 724 may also reside, completely or at least partially, within the main memory 704 or within the processor 702 during execution thereof by the computer system 700, the main memory 704 and the processor 702 also constituting machine-readable media.
While the machine-readable storage medium 722 is shown in an exemplary embodiment to be a single medium, the term “machine-readable storage medium” may include a single medium or multiple media (e.g., a centralized or distributed database, or associated caches and servers) that store the one or more instructions. The term “machine-readable storage medium” shall also be taken to include any tangible medium that is capable of storing, encoding, or carrying instructions for execution by the machine and that cause the machine to perform any one or more of the methodologies of embodiments of the present invention, or that is capable of storing, encoding, or carrying data structures used by or associated with such instructions. The term “machine-readable storage medium” shall accordingly be taken to include, but not be limited to, solid-state memories and optical and magnetic media. Specific examples of machine-readable storage media include non-volatile memory, including by way of example semiconductor memory devices (e.g., Erasable Programmable Read-Only Memory (EPROM), Electrically Erasable Programmable Read-Only Memory (EEPROM), and flash memory devices); magnetic disks such as internal hard disks and removable disks; magneto-optical disks; and CD-ROM and DVD-ROM disks.
Transmission Medium
The instructions 724 may further be transmitted or received over a communications network 726 using a transmission medium via the network interface device 720 and utilizing any one of a number of well-known transfer protocols (e.g., HyperText Transfer Protocol (HTTP)). Examples of communication networks include a local area network (LAN), a wide area network (WAN), the Internet, mobile telephone networks, Plain Old Telephone (POTS) networks, and wireless data networks (e.g., WiFi and WiMax networks). The term “transmission medium” shall be taken to include any intangible medium that is capable of storing, encoding, or carrying instructions for execution by the machine, and includes digital or analog communications signals or other intangible media to facilitate communication of such software.
Although an overview of the inventive subject matter has been described with reference to specific exemplary embodiments, various modifications and changes may be made to these embodiments without departing from the broader spirit and scope of embodiments of the present invention. Such embodiments of the inventive subject matter may be referred to herein, individually or collectively, by the term “invention” merely for convenience and without intending to voluntarily limit the scope of this application to any single invention or inventive concept if more than one is, in fact, disclosed.
The embodiments illustrated herein are described in sufficient detail to enable those skilled in the art to practice the teachings disclosed. Other embodiments may be used and derived therefrom, such that structural and logical substitutions and changes may be made without departing from the scope of this disclosure. The Detailed Description, therefore, is not to be taken in a limiting sense, and the scope of various embodiments is defined only by the appended claims, along with the full range of equivalents to which such claims are entitled.
Moreover, plural instances may be provided for resources, operations, or structures described herein as a single instance. Additionally, boundaries between various resources, operations, modules, engines, and data stores are somewhat arbitrary, and particular operations are illustrated in a context of specific illustrative configurations. Other allocations of functionality are envisioned and may fall within a scope of various embodiments of the present invention. In general, structures and functionality presented as separate resources in the example configurations may be implemented as a combined structure or resource. Similarly, structures and functionality presented as a single resource may be implemented as separate resources. These and other variations, modifications, additions, and improvements fall within a scope of embodiments of the present invention as represented by the appended claims. The specification and drawings are, accordingly, to be regarded in an illustrative rather than a restrictive sense.
Number | Name | Date | Kind |
---|---|---|---|
5812972 | Juang et al. | Sep 1998 | A |
5937377 | Hardiman et al. | Aug 1999 | A |
6411927 | Morin et al. | Jun 2002 | B1 |
7254535 | Kushner et al. | Aug 2007 | B2 |
7292974 | Kemp | Nov 2007 | B2 |
7333618 | Shuttleworth et al. | Feb 2008 | B2 |
7336793 | Horbach et al. | Feb 2008 | B2 |
7623572 | Li | Nov 2009 | B2 |
7742592 | Faller | Jun 2010 | B2 |
8090120 | Seefeldt | Jan 2012 | B2 |
8094826 | Pedersen | Jan 2012 | B2 |
8229125 | Short | Jul 2012 | B2 |
8489393 | Alves et al. | Jul 2013 | B2 |
8761408 | Yoneda et al. | Jun 2014 | B2 |
20060126865 | Blamey et al. | Jun 2006 | A1 |
20060291681 | Klinkby et al. | Dec 2006 | A1 |
20090034747 | Christoph | Feb 2009 | A1 |
20090080666 | Uhle et al. | Mar 2009 | A1 |
20090110218 | Swain | Apr 2009 | A1 |
20090147975 | Horbach et al. | Jun 2009 | A1 |
20090225980 | Schmidt et al. | Sep 2009 | A1 |
20100111330 | Baumgarte | May 2010 | A1 |
20100215194 | Bhattacharya | Aug 2010 | A1 |
20110228951 | Sekiya et al. | Sep 2011 | A1 |
20130010982 | Elko et al. | Jan 2013 | A1 |
Number | Date | Country | |
---|---|---|---|
20120239391 A1 | Sep 2012 | US |