1. Technical Field of the Invention
The present invention relates to a technology for processing an impulse response used to impart reverberation.
2. Description of the Related Art
A technology for changing a time length during which reverberation continues (which will be referred to as a “reverberation time”) in an apparatus for imparting reverberation to a sound signal through convolution of an impulse response has been suggested. For example, Japanese Patent Application Publication No. 2004-294712 describes a technology in which a new impulse response having a desired reverberation time is generated by summing (i.e., linearly combining) two types of impulse responses after multiplying each of the impulse responses by an exponential function.
However, in the technology of Japanese Patent Application Publication No. 2004-294712, the magnitude of noise such as background noise superimposed on the impulse response is also amplified since the magnitude of the impulse response is increased through multiplication by the exponential function. Accordingly, the prior art technology has a problem in that the sound quality of the reverberant sound added to the sound signal is degraded.
The invention has been made in view of these circumstances, and it is an object of the invention to change the reverberation time while maintaining the sound quality of the reverberant sound.
In order to achieve the above object, an impulse response processing apparatus according to the invention includes a waveform dividing part that divides an impulse response into a plurality of base blocks on a time axis, a time adjustment part that increases a time difference between each two adjacent ones of the plurality of the base blocks, an interpolation processing part that generates an interpolation block, and a waveform synthesis part that generates a new impulse response by arranging the interpolation block between the two adjacent base blocks generated through adjustment of the time adjustment part.
In this configuration, since the reverberation time is extended by increasing the time difference between each two adjacent base blocks generated through division of the impulse response, it is possible to generate a new impulse response of a reverberant sound with high quality in which noise is suppressed, compared to a configuration wherein the reverberation time is extended by increasing the amplitude of the impulse response. In addition, since the interpolation block is disposed between each adjacent two base blocks, it is possible to generate a new impulse response of a reverberant sound that is aurally natural, compared to the case where a new impulse response is generated by simply increasing the interval between each adjacent two base blocks.
In a preferable embodiment of the invention, the interpolation processing part includes an averaging part that calculates an interpolation block by averaging or summing each two adjacent ones of the base blocks, and the waveform synthesis part generates the new impulse response by arranging the interpolation block calculated by the averaging part between the two adjacent ones of the base blocks that the averaging part has used to calculate the interpolation block. In this embodiment, since the interpolation block is generated by obtaining the average or sum (including a weighted sum) of each two adjacent ones of the plurality of base blocks, it is possible to generate a natural new impulse response in which the base blocks and interpolation blocks have similar acoustic characteristics, compared to the case where the interpolation block is generated independently of the base blocks.
If acoustic characteristics such as frequency characteristics of base and interpolation blocks that are adjacent are excessively similar, a reverberant sound generated according to the new impulse response may be perceived to be aurally unnatural. Therefore, in a preferable embodiment of the invention, the interpolation processing part includes a waveform processing part that modifies a waveform represented by an interpolation block (for example, the interpolation block generated by the averaging part), and the waveform synthesis part generates the new impulse response using an interpolation block generated through modifying of the waveform processing part.
In this embodiment, it is possible to generate a new impulse response of a reverberant sound that is aurally natural since it is possible to cause the acoustic characteristics of the interpolation and base blocks to be moderately different. As a specific configuration for modifying the waveform of the interpolation block, it is preferable to employ a configuration wherein the waveform represented by the interpolation block is reversed in the direction of the time axis, or a configuration wherein the phase in the frequency domain of the waveform represented by the interpolation block is rotated.
In a preferable embodiment of the invention, the interpolation processing part includes an amplitude adjustment part that adjusts an amplitude of each interpolation block so that an amplitude of the interpolation block disposed between each two adjacent base blocks generated through adjustment of the time adjustment part increases as the time difference between each two adjacent base blocks generated through adjustment of the time adjustment part increases, and the waveform synthesis part generates the new impulse response using the interpolation block generated through adjustment of the amplitude adjustment part. In this configuration, it is possible to generate a new impulse response of a reverberant sound that is aurally natural since the amplitudes of both the base and interpolation blocks of the new impulse response are made uniform.
The impulse response processing apparatus according to a preferable embodiment of the invention further includes a first windowing part (for example, a windowing part 34 in
In this embodiment, there is an advantage in that it is possible to generate a new impulse response of a natural reverberant sound in which the base and interpolation blocks are smoothly connected since base blocks that partially overlap are used to generate the new impulse response after each of the base blocks is multiplied by a window function.
In another preferable embodiment of the invention, the interpolation processing part includes a second windowing part (for example, a windowing part 56 in
In a preferable embodiment of the invention, the waveform synthesis part generates the new impulse response by arranging a plurality of interpolation blocks between each two adjacent ones of the plurality of base blocks. In this embodiment, it is possible to generate a new impulse response with a reverberation time increased by a high scaling factor since a plurality of interpolation blocks are arranged between adjacent two base blocks.
A reverberation imparting apparatus according to the invention includes an impulse response processing apparatus according to each of the above embodiments, and a reverberation imparting part that performs convolution of a sound signal and a new impulse response generated by the impulse response processing apparatus. The reverberation imparting apparatus achieves the same operations and advantages as those of the impulse response processing apparatus according to each of the above embodiments.
The impulse response processing apparatus according to each of the embodiments may not only be implemented by hardware (electronic circuitry) such as a Digital Signal Processor (DSP) dedicated to impulse response processing but may also be implemented through cooperation of a general arithmetic processing unit such as a Central Processing Unit (CPU) with a computer program. A program according to the invention causes a computer to perform a waveform dividing process to divide an impulse response into a plurality of base blocks on a time axis, a time adjustment process to increase a time difference between each two adjacent ones of the plurality of the base blocks, an interpolation processing process to generate an interpolation block, and a waveform synthesis process to generate a new impulse response by arranging the interpolation block between the two adjacent base blocks generated through the time adjustment process. The program achieves the same operations and advantages as those of the impulse response processing apparatus according to each of the above embodiments. The program of the invention may be provided to a user through a computer readable recording medium storing the program and then be installed on a computer and may also be provided from a server device to a user through distribution over a communication network and then be installed on a computer.
As shown in
The arithmetic processor 12 functions as a plurality of elements including an impulse response processor 22 and a reverberation imparting unit 24 by executing the program stored in the storage device 14. The elements of the arithmetic processor 12 may each be mounted in a distributed manner on a plurality of devices such as integrated circuits or may each be implemented by an electronic circuit (DSP) dedicated to processing the sound signal S.
The impulse response processor 22 processes the impulse response H stored in the storage device 14 and generates a sample sequence representing the waveform of a new impulse response HNEW which has different characteristics such as reverberation time from those of the impulse response H. The new impulse response HNEW is a signal representing a waveform obtained by extending the reverberation time to be R times longer than that of the impulse response H (1<R=2). The reverberation imparting unit 24 generates a reverberant sound signal SR by performing a filtering process such as convolution on the sound signal S using the new impulse response HNEW generated by the impulse response processor 22. The reverberation imparting unit 24 may use any known technology to generate the reverberant sound signal SR.
The input device 16 includes an operating unit that the user operates to input instructions for the reverberation imparting apparatus 100. The user can adjust the scaling factor R of the reverberation time by operating the input device 16.
The waveform divider 32 divides the impulse response H stored in the storage device 14 into a plurality of sections (which will be referred to as “base blocks”) Ba (Ba[1], Ba[2], . . . ) on the time axis. As shown in
The windowing part 34 in
W(n)=0.5−0.5 cos(nπ/N) (1)
The time adjuster 36 in
The interpolation processor 42 in
The waveform synthesizer 44 in
For each base block Bb and each interpolation block P that are arranged on the time axis as described above, the waveform synthesizer 44 sums the values of samples, which correspond to the same time point, of the base block Bb and the interpolation block P for each time point. The new impulse response HNEW illustrated in
The following is a description of a detailed example of the interpolation processor 42 with reference to
The waveform synthesizer 44 may use the interpolation block Pa[i] generated by the averager 52 as the interpolation block P[i] to generate the new impulse response HNEW. However, a waveform represented by the interpolation block Pa[i] is very similar to waveforms represented by the base block Ba[i] and the base block Ba[i+1] used to generate the interpolation block Pa[i]. Thus, similar waveforms will be repeatedly arranged in the new impulse response HNEW generated by arranging the interpolation block Pa[i] between the base block Bb[i] and the base block Bb[i+1]. This may cause the listener to perceive aural incongruity (or aural abnormalities) such as undulation in the reproduced sound of the reverberant sound signal SR. On the other hand, the interpolation block P[i] may also be generated independently of the base block Ba[i] and the base block Ba[i+1]. However, this may cause the listener to perceive aural incongruity in the reproduced sound of the reverberant sound signal SR due to the difference between acoustic characteristics such as frequency characteristics of each base block Bb and each interpolation block P.
Thus, the waveform processor 54 of this embodiment modifies the waveform represented by the interpolation block Pa[i] generated by the averager 52 to generate a modified interpolation block Pb[i]. As shown in
The windowing part 56 in
The amplitude (i.e., the value of each sample) of the interpolation block Pc[i] generated through the processing of the windowing part 56 is the product of the window function w2 and the average of the amplitudes of the base block Bb[i] and the base block Bb[i+1]. Therefore, for example in the case where the interpolation block Pc[i] is used as the interpolation block P[i] to generate the new impulse response HNEW, the amplitude of the new impulse response HNEW is excessive at a portion where the interpolation block Pc[i] is inserted, thereby causing the listener to perceive aural incongruity in the reproduced sound of the reverberant sound signal SR. Accordingly, the amplitude adjuster 58 in
As shown in
In
A configuration wherein the reverberation time is extended by multiplying the impulse response H by an exponential function a(t) is described below as an example for comparison with this embodiment. In this comparative example, the new impulse response Has is generated by multiplying the impulse response H by the exponential function a(t), for example as represented in the following Equation (2). In the configuration of the comparative example, the amplification ratio of the amplitude (strength) of the new impulse response HNEW to the amplitude of the impulse response H exponentially increases toward the rear end of the impulse response H as shown in
In contrast to the comparative example, this embodiment overcomes the problem that the magnitude of noise of the impulse response H emerges in the new impulse response HNEW since, in this embodiment, the impulse response H is not amplified according to the scaling factor R but instead the new impulse response HNEW is generated by increasing the time difference between each of the plurality of base blocks Ba (Bb) into which the impulse response H is divided (i.e., by extending the impulse response H in the direction of the time axis). Accordingly, this embodiment can extend the reverberation time while maintaining the sound quality of the reverberant sound. This embodiment can also generate a reverberant sound which is aurally natural, compared to the case where the new impulse response HNEW is generated by simply increasing the interval between each base block Bb (i.e., between each two adjacent base blocks Bb), since the interpolation block P is arranged between each base block Bb in this embodiment.
Further, the base blocks Bb and the interpolation blocks P generated through multiplication by the window functions w1 and w2 are continuously connected on the time axis since the sample value of each of the base blocks Bb and the interpolation blocks P decreases toward both ends. Accordingly, this embodiment has an advantage in that it is possible to generate a new impulse response HNEW capable of generating a reverberant sound which is aurally natural compared to the case where the envelope is discontinuous at the connection portion of each base block Bb or each interpolation block P.
A description will now be given of the second embodiment of the invention. In the first embodiment, the waveform processor 54 reverses the waveform of the interpolation block Pa[i] generated by the averager 52 in the direction of the time axis. The waveform processor 54 of this embodiment generates an interpolation block Pb[i] by rotating the phase of the interpolation block Pa[i] generated by the averager 52. Elements in each of the following embodiments which are shared with the first embodiment are denoted by the same reference numerals and a detailed description thereof is appropriately omitted.
The waveform processor 54 of this embodiment configured as described above generates an interpolation block Pb[i] having frequency characteristics which are moderately similar to (i.e., which are neither excessively similar to or excessively different from) those of the base block Bb[i] or the base block Bb[i+1]. Accordingly, similar to the first embodiment, this embodiment can generate a new impulse response HNEW capable of generating a reverberant sound which is aurally natural, compared to the configuration wherein the interpolation block Pa[i] is used as the final interpolation block P[i] or the configuration wherein the interpolation block P[i] is generated independently of the base block Bb[i] and the base block Bb[i+1].
The following is a description of the third embodiment of the invention. In the first embodiment, it is assumed that the scaling factor R of the reverberation time is equal to or less than 2. One purpose of this embodiment is to extend the reverberation time by a scaling factor R of greater than 2. In the case where the scaling factor R is less than or equal to 2 in this embodiment, the reverberation time is extended through the same procedure as the first or second embodiment.
The interpolation block P[i]_1 in
The windowing part 56 in
Although two interpolation blocks P[i] are disposed between the base block Bb[i] and the base block Bb[i+1] in
Various modifications can be made to each of the above embodiments. The following are specific examples of such modifications. It is also possible to freely select and combine two or more from the following modifications.
Where or when multiplication by the window function w1 is performed is appropriately changed. For example, in the embodiment of
In addition, while the amplitude adjuster 58 adjusts the amplitude of the interpolation block Pc[i] generated through multiplication by the window function w2 in each of the above embodiments, it is also preferable to employ a configuration wherein the windowing part 56 multiplies the interpolation block Pb[i] by the window function w2, the amplitude of which has been adjusted according to the time difference between the base block Bb[i] and the base block Bb[i+1], to generate the interpolation block P[i].
Details of the window function w1 or the window function w2 are optional and any known window function (a Hanning or triangular window) can be freely used as the window function w1 or the window function w2. However, it is not essential to use the window function w1 or the window function w2 in the invention. For example, it is possible to employ a configuration wherein the time adjuster 36 extends the interval between each base block Ba generated through division of the waveform divider 32 and the waveform synthesizer 44 then inserts an interpolation block P into the interval between each base block Ba to generate a new impulse response HNEW. Accordingly, partial overlapping of each base block Ba is also not essential in the invention. However, in the configuration wherein no window function is used, for example in the configuration wherein base blocks Ba do not overlap, a reverberant sound may be discontinuous in boundaries between base blocks Ba and interpolation blocks P, thereby causing a reduction in sound quality. Accordingly, taking into consideration the need to naturally connect base blocks Ba and interpolation blocks P, it is important to use the window function w1 or the window function w2 after setting each base block Ba so as to partially overlap, and it is especially preferable to use a window function whose value decreases toward both ends.
The method for generating the interpolation block P is diverse in the invention. While the initial interpolation block Pa[i] is generated by averaging the base block Ba[i] and the base block Ba[i+1] in the above embodiments, it is also possible to employ a configuration wherein the averager 52 calculates the sum (including a weighted sum) of the base block Ba[i] and the base block Ba[i+1] as the interpolation block Pa[i]. In addition, the bases for calculating the interpolation block Pa[i] are not limited to the base block Ba[i] and the base block Ba[i+1]. For example, it is possible to employ a configuration wherein one base block Ba[i] (or one base block Ba[i+1]) is used as the interpolation block Pa[i] or a configuration wherein three or more consecutive base blocks Ba are summed or averaged to calculate the interpolation block Pa[i]. However, the configuration wherein base blocks Ba extracted from the impulse response H are used to generate interpolation blocks P is not essential in the invention. For example, it is possible to employ a configuration wherein interpolation blocks Pa previously created independently of the impulse response H (i.e., independently of the base blocks Ba) (for example, blocks created through division of a different impulse response having characteristics similar to those of the impulse response H) are used to generate interpolation blocks P[i].
In
The method for causing the frequency characteristics of the plurality of interpolation blocks P[i] (P[i]_1, P[i]_2, . . . ) generated by the interpolation processor 42 to be different in the third embodiment is not limited to the method of changing the rotation angle θ of the phase of each interpolation block P[i]. For example, it is also possible to employ a configuration wherein odd-numbered interpolation blocks Pb are generated by reversing the waveform of the interpolation block Pa on the time axis as illustrated in
While the reverberation imparting apparatus 100 including the impulse response processor 22 and the reverberation imparting unit 24 is illustrated in the above embodiments, an impulse response processing apparatus (i.e., the impulse response processor 22) constructed by removing the reverberation imparting unit 24 from the reverberation imparting apparatus 100 of
Number | Date | Country | Kind |
---|---|---|---|
2008-143509 | May 2008 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5272274 | Kimura | Dec 1993 | A |
5553150 | Kozuki | Sep 1996 | A |
5619579 | Ando et al. | Apr 1997 | A |
5689571 | Kitamura | Nov 1997 | A |
5880390 | Hagiwara | Mar 1999 | A |
6483922 | Limacher | Nov 2002 | B1 |
6782105 | Sahara et al. | Aug 2004 | B1 |
6978027 | Dahl et al. | Dec 2005 | B1 |
Number | Date | Country |
---|---|---|
1 463 030 | Sep 2004 | EP |
1 463 030 | Sep 2004 | EP |
09-146549 | Jun 1997 | JP |
2004-294712 | Oct 2004 | JP |
WO-9917277 | Apr 1999 | WO |
Number | Date | Country | |
---|---|---|---|
20090296962 A1 | Dec 2009 | US |