Field of the Disclosed Embodiments
The disclosed embodiments relate generally to signal processing and, more specifically, to techniques for tuning the distortion response of a loudspeaker.
Description of the Related Art
A conventional loudspeaker is a physical device that generates acoustic signals based on electrical input signals. Loudspeakers may have a wide range of physical structures, although typically a loudspeaker includes one or more magnets, one or more voice coils, and one or more speaker cones. The magnet(s), voice coil(s), and speaker cone(s) associated with a given loudspeaker dictate the linear and non-linear response characteristics of the loudspeaker.
The non-linear response characteristics of a loudspeaker give rise to an acoustic effect known in the art as “distortion.” Distortion may be undesirable in some cases, although in other cases, distortion may be perceived as adding desirable “texture” to the acoustic signal generated by the loudspeaker. For example, a guitar amplifier typically includes one or more distortion filters that amplify certain non-linear characteristics of a received guitar signal, thereby producing a distorted guitar signal that some listeners find acoustically pleasing.
One drawback associated with conventional loudspeakers is that the distortion associated with a given loudspeaker is dependent on the physical structure of that loudspeaker. Thus, the characteristics of the distortion usually cannot be changed without altering the physical structure the loudspeaker. Consequently, any distortion added by a loudspeaker typically comprises a portion of the acoustic output of the loudspeaker.
As the foregoing illustrates, more effective techniques for adjusting the distortion response of a loudspeaker would be useful.
One or more embodiments set forth include a computer-implemented method for generating a desired response for a loudspeaker, including tuning an audio signal to augment one or more desired distortion characteristics associated with a first output device to produce a tuned audio signal, correcting the tuned audio signal to attenuate one or more undesired distortion characteristics associated with a second output device to produce a corrected audio signal, outputting a final signal, via the second output device, that is based on the corrected audio signal, where the final signal includes the one or more desired distortion characteristics associated with the first output device.
At least one advantage of the disclosed embodiments is that unwanted distortion characteristics associated with a loudspeaker can be mitigated, while desired distortion characteristics associated with another loudspeaker can be incorporated into an audio signal.
So that the manner in which the recited features of the one more embodiments set forth above can be understood in detail, a more particular description of the one or more embodiments, briefly summarized above, may be had by reference to certain specific embodiments, some of which are illustrated in the appended drawings. It is to be noted, however, that the appended drawings illustrate only typical embodiments and are therefore not to be considered limiting of its scope in any manner, for the scope of the disclosed embodiments subsumes other embodiments as well.
In the following description, numerous specific details are set forth to provide a more thorough understanding of certain specific embodiments. However, it will be apparent to one of skill in the art that other embodiments may be practiced without one or more of these specific details or with additional specific details.
During operation of signal chain 100, signal source 110 generates an audio signal 112 and then transmits that audio signal to tuning filter 120. Tuning filter 120 processes audio signal 112, based on tuning parameters 122, and generates tuned signal 124. Tuning filter 120 transmits tuned signal 124 to corrector 130. Corrector 130 processes tuned signal 124, based on loudspeaker parameters 132, to generate pre-corrected signal 134. Corrector 130 transmits pre-corrected signal 134 to amplifier 140. Amplifier 140 amplifies pre-corrected signal 134 to generate amplified signal 142. Amplifier 140 transmits amplified signal 142 to loudspeaker 150. Loudspeaker 150 generates acoustic signal 152 based on amplified signal 142 and then outputs acoustic signal 152.
Signal source 110 may be any technically feasible source of electrical audio signals, including, for example and without limitation, a microphone, an electric guitar pickup, a digital signal generator, and so forth. Audio signal 112 is an electrical signal that may represent an acoustic signal transduced by signal source 110 or a purely virtual signal generated by signal source 110.
Tuning filter 120 is an analog or digital filter configured to perform a signal processing operation with audio signal 112 to incorporate desired linear and/or non-linear characteristics into that signal, including desired distortion characteristics. Those distortion characteristics are defined by tuning parameters 122. Tuning parameters 122 define different sets of distortion characteristics that may correspond to different loudspeakers which loudspeaker 150 can be configured to emulate via the various stages of signal chain 100.
Tuning filter 120 and tuning parameters 122 may be generated via a wide variety of different types of processes, including, for example and without limitation, physical system modeling, Hammerstein models, and Volterra kernels, among others. An exemplary approach for generating tuning filter 120 and tuning parameters 122 is described in greater detail below in conjunction with
Corrector 130 is an analog or digital filter configured to perform a signal processing operation with tuned signal 124 to compensate for certain linear and/or non-linear characteristics, including unwanted distortion characteristics that may be subsequently induced by loudspeaker 150. Those distortion characteristics are defined by loudspeaker parameters 132. Loudspeaker parameters 132 represent a model of loudspeaker 150, and may be used by corrector 130 as an inverse transfer function of loudspeaker 150. Thus, corrector 130 “pre-corrects” tuned signal 124 to pre-emptively mitigate unwanted distortive effects of loudspeaker 150.
Corrector 130 and loudspeaker parameters 132 may be generated via a wide variety of different types of processes, including, for example and without limitation, physical system modeling, Hammerstein models, and Volterra kernels, among others. An exemplary approach for generating corrector 130 and loudspeaker parameters 132 is described in greater detail below in conjunction with
Amplifier 140 is a signal processing element configured to amplify the magnitude of pre-corrected signal 134. In doing so, amplifier 140 generates amplified signal 142. Loudspeaker 150 receives amplified signal 142, and then generates acoustic signal 152. Because tuning filter 120 incorporates desired distortion characteristics into audio signal 112, as described, and corrector 130 compensates for unwanted distortion characteristics within the loudspeaker 150, acoustic signal 152 can be specifically designed to have precise characteristics. Thus, signal chain 100, as a whole, converts audio signal 112 into acoustic signal 152 with specifically designed linear and/or non-linear characteristics. Signal chain 100 may be implemented in many different ways, as mentioned.
Computing device 210 includes a processor 212, input/output (I/O) devices 214, and a memory 216. Memory 216 includes an emulation application 218. Emulation application 218 includes tuning filter 120, tuning parameters 122, corrector 130, and loudspeaker parameters 132.
Processor 212 may be any technically feasible hardware for processing data and executing applications, including, for example and without limitation, a central processing unit (CPU), an application specific integrated circuit (ASIC), a field-programmable gate array (FPGA), among others. I/O devices 214 may include devices for receiving input, such as a keyboard, mouse, or microphone, for example and without limitation, devices for providing output, such as a display screen or a speaker, for example and without limitation, and devices for receiving input and providing output, such as a touchscreen, for example and without limitation.
Memory 216 may be any technically feasible medium configured to store data, including, for example and without limitation, a hard disk, a random access memory (RAM), a read-only memory (ROM), and so forth. Emulation application 218 includes program code that, when executed by processor 212, performs the various operations of tuning filter 120 and corrector 130 previously described in conjunction with
Amplification system 220 includes amplifier 140 and loudspeaker 150. Amplification system 220 could be, for example, and without limitation, a musical instrument amplifier or a public address (PA) system, among other possibilities. In one embodiment, amplification system 220 is a simulated device.
Again, signal chain 100 may be implemented in any technically feasible manner. Implementation 200 is provided here for illustrative purposes only, and is not meant to be limiting. The operation of signal chain 100 is described in greater detail below in conjunction with
As shown in
As shown in
As shown in
As shown in
Referring generally to
As shown in
As shown in
As shown in
As shown in
Referring generally to
As shown in
As shown in
As shown in
As shown in
Referring generally to
As shown in
As shown in
As shown in
As shown in
Referring generally to
Persons skilled in the art will recognize that the different graphs shown in
As shown, a method 700 begins at step 702, where tuning filter 120 receives audio signal 112 from audio source 110. Signal source 110 may be any technically feasible source of electrical audio signals, including, for example and without limitation, a microphone, an electric guitar pickup, a digital signal generator, and so forth. Audio signal 112 is an electrical signal that may represent an acoustic signal transduced by signal source 110 or a purely virtual signal generated by signal source 110.
At step 704, tuning filter transforms audio signal 112 to augment desired distortion characteristics. In doing so, tuning filter 120 generates tuned signal 124. Tuning filter 120 is an analog or digital filter configured to perform a signal processing operation with audio signal 112 to incorporate desired linear and/or non-linear characteristics into that signal, including desired distortion characteristics. Those distortion characteristics are defined by tuning parameters 122. Tuning parameters 122 define different sets of distortion characteristics that may correspond to different loudspeakers which loudspeaker 150 can be configured to emulate via the various stages of signal chain 100.
At step 706, corrector transforms tuned signal 124 to attenuate unwanted distortion characteristics potentially introduced by loudspeaker 150. In doing so, corrector 130 generates pre-corrected signal 134. Corrector 130 is an analog or digital filter configured to perform a signal processing operation with tuned signal 124 to compensate for certain linear and/or non-linear characteristics, including unwanted distortion characteristics that may be subsequently induced by loudspeaker 150. Those distortion characteristics are defined by loudspeaker parameters 132. Loudspeaker parameters 132 represent a model of loudspeaker 150, and may be used by corrector 130 as an inverse transfer function of loudspeaker 150. Thus, corrector 130 “pre-corrects” tuned signal 124 to pre-emptively mitigate unwanted distortive effects of loudspeaker 150.
At step 708, amplifier 140 amplifies pre-corrected signal 134 to produce amplified signal 142. Amplified signal 142 represents an amplified version of pre-corrected signal 142 having larger amplitude. At step 710, loudspeaker 150 outputs acoustic signal 152 with desired distortion characteristics introduced by tuning filter 120 but without unwanted distortion characteristics nominally associated with loudspeaker 150. Because tuning filter 120 incorporates desired distortion characteristics into audio signal 112, as described, and corrector 130 compensates for unwanted distortion characteristics within tuned signal 124, acoustic signal 152 can be specifically designed to have precise characteristics. Thus, signal chain 100, as a whole, converts audio signal 112 into acoustic signal 152 with specifically designed linear and/or non-linear characteristics.
As mentioned above, tuning filter 120 and/or tuning parameters 122 and corrector 130 and/or loudspeaker parameters 132 may be generated via a number of different technically feasible approaches. Exemplary approaches for generating these elements are described in greater detail below in conjunction with
As shown in
A sensor array 806 is coupled to loudspeaker 150 and configured to measure various time-varying physical quantities 808 associated with loudspeaker 150 when loudspeaker 150 responds to test inputs 802. Those quantities include output pressure P of loudspeaker, displacement D of a voice coil associated with loudspeaker 150, and voice coil current I that drives loudspeaker 150 in response to test signals 802. An adaptive algorithm 810 is configured to receive physical attributes 808, well as output 804, and to then generate lumped parameters model 812.
Lumped parameters model 812 is a physical model of loudspeaker 150 that includes loudspeaker parameters 132. Lumped parameter model 812 may be defined by a set of differential equations that, in conjunction with the numerical values of loudspeaker parameters 132, define the dynamic response of loudspeaker 150. Adaptive algorithm 810 may employ a gradient descent algorithm in order to estimate values for loudspeaker parameters 132. Based on these loudspeaker parameters 132, the above-mentioned differential equations may then be evaluated. The differential equations and loudspeaker parameters 132 are set forth below in conjunction with Equations 1-4 and Table 1.
Given the input (voltage) stimulus u(t), the voice coil current I(t) can be calculated using Equation 1:
The displacement x(t) can be computed using Equation 2:
The reluctance force is calculated using Equation 3:
The output pressure p(t) can be calculated using Equation 4:
The output of the lumped parameter model is p(t), which defines pressure as a function of time based on loudspeaker parameters 132. These loudspeaker parameters, some of which are referenced above in Equations 1-4, are tabulated below in conjunction with Table 1:
Based on lumped parameters model 812 and loudspeaker parameters 132, a model inverse function 814 may compute an inverse transfer function 816 for loudspeaker 150. This inverse transfer function may provide the response curve for corrector 130 in embodiments where that corrector is generated via signal chain 800. Tuning filter 120 may be generated via a similar approach, as described in conjunction with
As shown in
A sensor array 826 is coupled to loudspeaker 850 and configured to measure various time-varying physical quantities 828 associated with loudspeaker 850 when loudspeaker 850 responds to test inputs 822. Those quantities include output pressure P of loudspeaker 850, displacement D of a voice coil associated with loudspeaker 850, and voice coil current I that drives loudspeaker 850 in response to test signals 822. An adaptive algorithm 830 is configured to receive physical attributes 828, well as output 824, and to then generate lumped parameters model 832.
Lumped parameters model 832 is a physical model of loudspeaker 850 that includes tuning parameters 122 associated with loudspeaker 850. Lumped parameter model 832 may be defined by a set of differential equations that, in conjunction with the numerical values of tuning parameters 122, define the dynamic response of loudspeaker 850. Adaptive algorithm 830 may employ a gradient descent algorithm in order to estimate values for tuning parameters 122. The above-mentioned differential equations may then be evaluated using those tuning parameters. The differential equations and tuning parameters 122 may be substantially similar to those set forth in Equations 1-4 and Table 1.
Referring generally to
As mentioned, any technically feasible approach to modeling physical systems can be implemented in order to generate tuning filter 120, corrector 130, and corresponding parameters. A generic, stepwise approach is described in greater detail below in conjunction with
As shown, a method 900 begins at step 902, emulation application 218 of
At step 904, emulation application 218 configures corrector 130 based on loudspeaker parameters 132 generated at step 902. In doing so, emulation application may compute an inverse of a lumped parameter model of loudspeaker 150, in like fashion as described above in conjunction with
At step 906, emulation application 218 analyzes the response of loudspeaker 850 to generate tuning parameters 122. In one embodiment, emulation application 218 implements adaptive algorithm 822 to compute lumped parameters model 832, which incorporate those parameters, as discussed above in conjunction with
At step 908, emulation application 218 configures the tuning filter 120 based on tuning parameters 122 generated at step 906. In doing so, emulation application 218 may rely on a gradient descent algorithm to estimate tuning parameters 122, as described above in conjunction with
By implementing the generic approach set forth above in conjunction with
In sum, a corrector is configured to transform audio signals to compensate for unwanted distortion characteristics of a loudspeaker. A tuning filter is configured to transform audio signals to incorporate desired distortion characteristics associated with a target loudspeaker. By chaining together the tuning filter and the corrector, an audio signal can be modified so that the loudspeaker, when outputting the audio signal, has response characteristics of the target loudspeaker.
At least one advantage of the disclosed techniques is that unwanted distortion characteristics associated with the loudspeaker can be mitigated, while desired distortion characteristics associated with the other loudspeaker can be incorporated into the audio signal. Accordingly, the loudspeaker can be configured to emulate the sound of the target loudspeaker. More generally, without changing the physical construction of the loudspeaker, the response of the loudspeaker can be tuned to have any desired response.
The descriptions of the various embodiments have been presented for purposes of illustration, but are not intended to be exhaustive or limited to the embodiments disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art without departing from the scope and spirit of the described embodiments.
Aspects of the present embodiments may be embodied as a system, method or computer program product. Accordingly, aspects of the present disclosure may take the form of an entirely hardware embodiment, an entirely software embodiment (including firmware, resident software, micro-code, etc.) or an embodiment combining software and hardware aspects that may all generally be referred to herein as a “circuit,” “module” or “system.” Furthermore, aspects of the present disclosure may take the form of a computer program product embodied in one or more computer readable medium(s) having computer readable program code embodied thereon.
Any combination of one or more computer readable medium(s) may be utilized. The computer readable medium may be a computer readable signal medium or a computer readable storage medium. A computer readable storage medium may be, for example, but not limited to, an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system, apparatus, or device, or any suitable combination of the foregoing. More specific examples (a non-exhaustive list) of the computer readable storage medium would include the following: an electrical connection having one or more wires, a portable computer diskette, a hard disk, a random access memory (RAM), a read-only memory (ROM), an erasable programmable read-only memory (EPROM or Flash memory), an optical fiber, a portable compact disc read-only memory (CD-ROM), an optical storage device, a magnetic storage device, or any suitable combination of the foregoing. In the context of this document, a computer readable storage medium may be any tangible medium that can contain, or store a program for use by or in connection with an instruction execution system, apparatus, or device.
Aspects of the present disclosure are described above with reference to flowchart illustrations and/or block diagrams of methods, apparatus (systems) and computer program products according to embodiments of the disclosure. It will be understood that each block of the flowchart illustrations and/or block diagrams, and combinations of blocks in the flowchart illustrations and/or block diagrams, can be implemented by computer program instructions. These computer program instructions may be provided to a processor of a general purpose computer, special purpose computer, or other programmable data processing apparatus to produce a machine, such that the instructions, which execute via the processor of the computer or other programmable data processing apparatus, enable the implementation of the functions/acts specified in the flowchart and/or block diagram block or blocks. Such processors may be, without limitation, general purpose processors, special-purpose processors, application-specific processors, or field-programmable processors.
The flowchart and block diagrams in the figures illustrate the architecture, functionality, and operation of possible implementations of systems, methods and computer program products according to various embodiments of the present disclosure. In this regard, each block in the flowchart or block diagrams may represent a module, segment, or portion of code, which comprises one or more executable instructions for implementing the specified logical function(s). It should also be noted that, in some alternative implementations, the functions noted in the block may occur out of the order noted in the figures. For example, two blocks shown in succession may, in fact, be executed substantially concurrently, or the blocks may sometimes be executed in the reverse order, depending upon the functionality involved. It will also be noted that each block of the block diagrams and/or flowchart illustration, and combinations of blocks in the block diagrams and/or flowchart illustration, can be implemented by special purpose hardware-based systems that perform the specified functions or acts, or combinations of special purpose hardware and computer instructions.
While the preceding is directed to embodiments of the present disclosure, other and further embodiments of the disclosure may be devised without departing from the basic scope thereof, and the scope thereof is determined by the claims that follow.