This application is based on Japanese Patent Application 2002-052006, filed on Feb. 27, 2002, the entire contents of which are incorporated herein by reference.
A) Field of the Invention
This invention relates to a singing voice synthesizing method, a singing voice synthesizing apparatus and a storage medium by using a phase vocoder technique.
B) Description of the Related Art
Conventionally, as a singing voice synthesizing technique, a singing voice synthesizing using a well-known Spectral Modeling Synthesis (SMS) technique according to U.S. Pat. No. 5,029,509 is well known. (For example, refer to Japanese Patent No. 2906970.)
In the SMS analyzing process, the input voice signal is divided into a series of time frames, and one set of a magnitude spectrum data is generated in each frame by Fast Fourier Transform (FFT) and the like, and a linear spectrum corresponding to plurality of peaks from one set of magnitude spectrum data by each frame. A data representing an amplitude value and frequency of these linear spectrums are called a Deterministic Component. Next, a spectrum of the deterministic component is subtracted from a spectrum of an input voice waveform to obtain a remaining difference spectrum. This remaining difference spectrum is called Stochastic Component.
In the section logging process, the deterministic component data and the stochastic data obtained in the SMS analyzing process are divided corresponding to a voice synthesis unit. The voice synthesis unit is a structural element of lyrics. For example, a voice synthesis unit is consisted of a single phoneme such as [a] or [i] or, a phonemic chain (a chain of a plurality of phonemes) such as [a—i] or [a—p].
In a voice synthesis unit database DB, a deterministic component data and stochastic component data are stored for every voice synthesis unit.
In the singing voice synthesizing, at Step S3, lyrics data and melody data are input. Then, at Step S4, a phonemic series/voice synthesis unit conversion process is executed on the phonemic series that the lyrics data represents to divide the phonemic series into a voice synthesis unit. Then, the deterministic component data and the stochastic component data are read from the database DB as a voice synthesis unit data for every voice synthesis unit.
At Step S5, a voice synthesis unit connecting process is executed on the voice synthesis unit data (the deterministic component data and the stochastic component data) read from the database DB to connect voice synthesis unit data in an order of pronunciations. At Step S6, new deterministic component data adapting to the musical note pitch is generated based on the musical note pitch that the deterministic component data and the melody data indicate for every voice synthesis unit. At this time, if a spectrum intensity is adjusted to be a form of a spectrum envelope that the deterministic component data processed at Step S5 is taken over, a musical tone of the voice signal input at Step S1 can be reproduced with the new deterministic component data.
At Step S7, the deterministic component data generated at Step S6 is added to the stochastic component data executed the process at Step S5 in every voice synthesis unit. Then, at Step S8, the data to which the adding process is executed at Step S7 is converted to a synthesized voice signal of time region by a reverse FFT and the like in each voice synthesis unit.
For example, to synthesizing a singing voice [saita], voice syntheses units corresponding to voice synthesis units [#s], [s—a], [a], [a—i], [l], [i—t], [a], and [a#] (# represents a silence) are read from the database DB, and they are connected each other at Step S5. Then, at Step S6, a deterministic component data that has a pitch corresponding to the input musical note pitch is generated in each voice synthesis unit. After the adding process at Step S7 and the converting process at Step S8, a singing voice signal of [saita] can be obtained.
According to the above-described prior art, there is a tendency that a sense of unity between the deterministic component and the stochastic component is not satisfactory. That is, there is a tendency that the singing voice is caught as an artificial voice because the voice signal pitch input at Step S1 is converted corresponding to the input musical note pitch at Step S6 and the stochastic component data is added to the deterministic component data with the converted pitch at Step S7. For example, the stochastic component data is sounded being split in a section of a long sound such as [i] in singing [saita].
In order to deal with this kind of tendencies, the inventors of the present invention suggested that an amplitude spectrum distribution in a lower region that the stochastic component data represents is adjusted corresponding to the input musical note pitch before (refer to Japanese Patent Application No. 2000-401041). However, if the stochastic component data is adjusted as above, it is not easy to control splitting and resounding of the stochastic component completely.
Also, in the SMS technique, analysis of a voiced fricative or plosive sound is difficult, and it is a problem that the synthesizing voice will be very artificial sound. The SMS technique is on the assumption that a voice signal is consisted of a deterministic component and a stochastic component, and it is a fundamental problem that the voice signal cannot be split into the deterministic component and the stochastic component as the SMS technique.
On the other hand, the phase vocoder technique is explained in a specification of the U.S. Pat. No. 3,360,610. In the phase vocoder technique, a signal was represented by a filter bank before and recently has been represented by a frequency region as a result of the FFT of input signal. Recently, the phase vocoder technique is widely used for a time-stretch (stretching or shortening of a time axis without changing the original pitch), a pitch-shift (changing a pitch without changing the time length) and the like. As this kind of pitch changing technique, the result of FFT of the input signal is not used as it is. It is well known that the pitch shift is executed by moving the spectrum distribution on a frequency axis in each spectrum distribution region after dividing the FFT spectrum into a plurality of spectrum distribution regions centered at a local peak. (For example, refer to J. Laroche and M. Dolson, “New Phase-Vocoder Techniques for Real-Time Pitch Shifting, Chourusing, Harmonizing, and Other Exotic Audio Modifications” J. Audio Eng. Soc., Vol. 47, No. 11, 1999). However, relevancy between the pitch shifting technique and the singing voice synthesizing technique is not clear.
It is an object of the present invention to provide a new singing voice synthesizing method or apparatus that enable a natural and high-quality voice synthesizing by using a phase vocoder technique, and a storage medium.
According to one aspect of the present invention, there is provided a singing voice synthesizing method, comprising the steps of: (a) detecting a frequency spectrum by analyzing a frequency of a voice waveform corresponding to voice synthesis unit of a voice to be synthesized; (b) detecting a plurality of local peaks of a spectrum intensity on the frequency spectrum; (c) designating, for each of the plurality of the local peaks, a spectrum distribution region including the local peak and spectrums therebefore and thereafter on the frequency spectrum and generating amplitude spectrum data representing an amplitude spectrum distribution depending on a frequency axis for each spectrum distribution region; (d) generating phase spectrum data representing a phase spectrum distribution depending on the frequency axis for each spectrum distribution region; (e) designating a pitch for the voice to be synthesized; (f) adjusting, for each spectrum distribution regions, the amplitude spectrum data for moving the amplitude spectrum distribution represented by the amplitude spectrum data along the frequency axis in accordance with the pitch; (g) adjusting, for each spectrum distribution regions, the phase spectrum distribution represented by the phase spectrum data in accordance with the adjustment of the amplitude spectrum data; and (h) converting the adjusted amplitude spectrum data and the adjusted phase spectrum data into a synthesized voice signal of a time region.
According to the first singing voice synthesizing method, a voice waveform corresponding to a voice synthesis unit (a phoneme or a phonemic chain) is executed a frequency analysis, and a frequency spectrum is detected. Then an amplitude spectrum data and a phase spectrum data are generated based on the frequency spectrum. When a desired pitch is designated, the amplitude spectrum data and the phase spectrum data are adjusted corresponding to the designated pitch, and a synthesized voice signal in a time region is generated based on the adjusted amplitude spectrum data and the adjusted phase spectrum data. Because voice synthesizing is executed without splitting the result of the frequency analysis of the voice waveform into a deterministic component and a stochastic component, the stochastic component may not split and resound. Therefore, a natural synthesized sound can be obtained. Also, a natural synthesized sound can be obtained in a case of a voiced fricative or plosive sound.
According to another aspect of the present invention, there is provided a singing voice synthesizing method, comprising the steps of. (a) obtaining amplitude spectrum data and phase spectrum data corresponding to a voice synthesis unit of a voice to be synthesized, wherein the amplitude spectrum data is data representing an amplitude spectrum distribution depending on a frequency axis for each spectrum distribution region for each of a plurality of local peaks of a spectrum intensity including the local peak and spectrums therebefore and thereafter in a frequency spectrum obtained by a frequency analysis of a voice waveform of the voice synthesis unit, and the phase spectrum data is data representing a phase spectrum distribution depending on the frequency axis for each spectrum distribution region; (b) designating a pitch for the voice to be synthesized; (c) adjusting, for each spectrum distribution regions, the amplitude spectrum data for moving the amplitude spectrum distribution represented by the amplitude spectrum data along the frequency axis in accordance with the pitch; (d) adjusting, for each spectrum distribution regions, the phase spectrum distribution represented by the phase spectrum data in accordance with the adjustment of the amplitude spectrum data; and (e) converting the adjusted amplitude spectrum data and the adjusted phase spectrum data into a synthesized voice signal of a time region.
The second singing voice synthesizing method corresponds to the case that the amplitude spectrum data and the phase spectrum data are stored in a database in each voice synthesis unit after executing the processes up to the step of generating the phase spectrum data, or the case that the process up to the step of generating the phase spectrum data is executed with other apparatus. That is, in the second singing voice synthesizing method, in a obtaining step, the amplitude spectrum data and the phase spectrum data corresponding to the voice synthesis unit of the voice to be synthesized are obtained from other apparatus or the database, and a process after the step to designate pitch is executed in the same method as the first singing voice synthesizing method. Therefore, according to the second singing voice synthesizing method, a natural synthesized sound can be obtained as the first singing voice synthesizing method.
According to further aspect of the present invention, there is provided a singing voice synthesizing apparatus, comprising: a designating device that designates a voice synthesis unit and a pitch for a voice to be synthesized; a reading device that reads voice waveform data representing a waveform corresponding to the voice synthesis unit as voice synthesis unit data from a voice synthesis unit database; a first detecting device that detects a frequency spectrum by analyzing a frequency of the voice waveform represented by the voice waveform data; a second detecting device that detects a plurality of local peaks of a spectrum intensity on the frequency spectrum; a first generating device that designates, for each of the plurality of the local peaks, a spectrum distribution region including the local peak and spectrums therebefore and thereafter on the frequency spectrum and generates amplitude spectrum data representing an amplitude spectrum distribution depending on a frequency axis for each spectrum distribution region; a second generating device that generates phase spectrum data representing a phase spectrum distribution depending on the frequency axis for each spectrum distribution region; a first adjusting device that adjusts, for each spectrum distribution regions, the amplitude spectrum data for moving the amplitude spectrum distribution represented by the amplitude spectrum data along the frequency axis in accordance with the pitch; a second adjusting device that adjusts, for each spectrum distribution regions, the phase spectrum distribution represented by the phase spectrum data in accordance with the adjustment of the amplitude spectrum data; and a converting device that converts the adjusted amplitude spectrum data and the adjusted phase spectrum data into a synthesized voice signal of a time region.
According to yet further aspect of the present invention, there is provided a singing voice synthesizing apparatus, comprising: a designating device that designates a voice synthesis unit and a pitch for a voice to be synthesized; a reading device that reads amplitude spectrum data and phase spectrum data corresponding to the voice synthesis unit as voice synthesis unit data from a voice synthesis unit database, wherein the amplitude spectrum data is data representing an amplitude spectrum distribution depending on a frequency axis for each spectrum distribution region for each of a plurality of local peaks of a spectrum intensity including the local peak and spectrums therebefore and thereafter in a frequency spectrum obtained by a frequency analysis of a voice waveform of the voice synthesis unit, and the phase spectrum data is data representing a phase spectrum distribution depending on the frequency axis for each spectrum distribution region; a first adjusting device that adjusts, for each spectrum distribution regions, the amplitude spectrum data for moving the amplitude spectrum distribution represented by the amplitude spectrum data along the frequency axis in accordance with the pitch; a second adjusting device that adjusts, for each spectrum distribution regions, the phase spectrum distribution represented by the phase spectrum data in accordance with the adjustment of the amplitude spectrum data; and a converting device that converts the adjusted amplitude spectrum data and the adjusted phase spectrum data into a synthesized voice signal of a time region.
The first and second singing voice synthesizing apparatuses are to execute the before-described first and second singing voice synthesizing methods by using the voice synthesis unit database, and a natural singing voice synthesized voice can be obtained.
According to yet further aspect of the present invention, there is provided a singing voice synthesizing apparatus, comprising: a designating device that designates a voice synthesis unit and a pitch for each of voices to be sequentially synthesized; a reading device that reads voice waveform data corresponding to each of the voice synthesis unit designated by the designating device from a voice synthesis unit database; a first detecting device that detects a frequency spectrum by analyzing a frequency of the voice waveform corresponding to each voice waveform; a second detecting device that detects a plurality of local peaks of a spectrum intensity on the frequency spectrum corresponding to each voice waveform; a first generating device that designates, for each of the plurality of the local peaks for each voice synthesis unit, a spectrum distribution region including the local peak and spectrums therebefore and thereafter on the frequency spectrum and generates amplitude spectrum data representing an amplitude spectrum distribution depending on a frequency axis for each spectrum distribution region; a second generating device that generates phase spectrum data representing a phase spectrum distribution depending on the frequency axis for each spectrum distribution region of each voice synthesis unit; a first adjusting device that adjusts, for each spectrum distribution regions of each voice synthesis unit, the amplitude spectrum data for moving the amplitude spectrum distribution represented by the amplitude spectrum data along the frequency axis in accordance with the pitch; a second adjusting device that adjusts, for each spectrum distribution regions of each voice synthesis unit, the phase spectrum distribution represented by the phase spectrum data in accordance with the adjustment of the amplitude spectrum data; a first connecting device that connects the adjusted amplitude spectrum data to connect sequential voice synthesis units respectively corresponding to the voices to be sequentially synthesized in a pronunciation order, wherein the spectrum intensities are adjusted to be agreed or approximately agreed with each another at connection points of the sequential voice synthesis units; a second connecting device that connects the adjusted phase spectrum data to connect sequential voice synthesis units respectively corresponding to the voices to be sequentially synthesized in a pronunciation order, wherein the phases are adjusted to be agreed or approximately agreed with each another at connection points of the sequential voice synthesis units; and a converting device that converts the connected amplitude spectrum data and the connected phase spectrum data into a synthesized voice signal of a time region.
According to yet further aspect of the present invention, there is provided a singing voice synthesizing apparatus, comprising: a designating device that designates a voice synthesis unit and a pitch for each of voices to be sequentially synthesized; a reading device that reads voice waveform data corresponding to each of the voice synthesis unit designated by the designating device from a voice synthesis unit database, wherein the amplitude spectrum data is data representing an amplitude spectrum distribution depending on a frequency axis for each spectrum distribution region for each of a plurality of local peaks of a spectrum intensity including the local peak and spectrums therebefore and thereafter in a frequency spectrum obtained by a frequency analysis of a voice waveform of the voice synthesis unit, and the phase spectrum data is data representing a phase spectrum distribution depending on the frequency axis for each spectrum distribution region; a first adjusting device that adjusts, for each spectrum distribution regions of each voice synthesis unit, the amplitude spectrum data for moving the amplitude spectrum distribution represented by the amplitude spectrum data along the frequency axis in accordance with the pitch; a second adjusting device that adjusts, for each spectrum distribution regions of each voice synthesis unit, the phase spectrum distribution represented by the phase spectrum data in accordance with the adjustment of the amplitude spectrum data; a first connecting device that connects the adjusted amplitude spectrum data to connect sequential voice synthesis units respectively corresponding to the voices to be sequentially synthesized in a pronunciation order, wherein the spectrum intensities are adjusted to be agreed or approximately agreed with each another at connection points of the sequential voice synthesis units; a second connecting device that connects the adjusted phase spectrum data to connect sequential voice synthesis units respectively corresponding to the voices to be sequentially synthesized in a pronunciation order, wherein the phases are adjusted to be agreed or approximately agreed with each another at connection points of the sequential voice synthesis units; and a converting device that converts the connected amplitude spectrum data and the connected phase spectrum data into a synthesized voice signal of a time region.
The third and the fourth singing voice synthesizing apparatuses are to execute the before described first or second singing voice synthesizing methods by using the voice synthesis unit database, and can obtain a natural singing voice synthesized sound. Moreover, spectral intensities and phases at a connecting part of the sequential voice synthesis units are adjusted to be the same or approximately the same to each other at the time of connecting the amplitude spectral data and the phase spectral data to be modified for connecting the voice synthesis units in the order of the pronunciation; therefore, it is prevented to generate noise at the time of generating the synthesized voice.
According to the present invention, amplitude spectrum data and phase spectrum data are generated based on a result of a frequency analyzing of a voice waveform corresponding to a voice synthesis unit, and the amplitude spectrum data and the phase spectrum data are adjusted corresponding to a designated pitch. Then, since a synthesized voice signal in a time region is generated based on the adjusted amplitude spectrum data and the adjusted phase spectrum data, a situation that the stochastic component splits and resounds as the conventional example that the result of the frequency analysis is split into the deterministic component and the stochastic component will not occur principally, and an effect that enables a natural or high-quality singing voice synthesizing can be obtained.
A central processing unit (CPU) 12, a read only memory (ROM) 14, a random access memory (RAM) 16, a singing voice input unit 17, a lyrics/melody input unit 18, a control parameter input unit 20, an external storage unit 22, a displaying unit 24, a timer 26, a digital/analogue (D/A) conversion unit 28, a musical instrument digital interface (MIDI) interface 30, a communication interface 32 and the like are connected to a bus 11.
The CPU executes various kinds of processes related to the singing voice synthesizing and the like according to a program stored in the ROM 14. The processes related to the singing voice synthesizing are explained later referring
The RAM 16 includes various kinds of storing regions such as a working region at a time of various processes in the CPU 12. As the storing regions according to the embodiment of the present invention, for example, inputting data storing regions are respectively corresponding to the input units 17, 18 and 20. The details will be explained later.
The singing voice input unit 17 has a microphone, a voice inputting terminal and the like for inputting a singing voice signal, and equips an analog/digital (A/D) conversion device that converts the input singing voice signal to a digital waveform data. The digital waveform data to be input is stored in a predetermined region in the RAM 16.
The lyrics/melody input unit 18 includes a keyboard that can input letters and numbers, and a reading device that can read scores. It can input a melody data that represents a series of musical notes (including rest) and a lyrics data and melody that represents a phonemic series that consists of the lyrics of a desired singing voice. The lyrics data and the melody data to be input are stored in a predetermined region in the RAM 16.
The lyrics/melody input unit 18 equips a keyboard that can input letters and numbers, and a reading device that can read scores. It can input a melody data that represents a series of musical notes (including rest) that consists a lyrics data and melody that represents a phonemic series that consists the lyrics of a desired singing voice. The lyrics data and the melody data to be input are stored in a predetermined region in the RAM 16.
The control parameter input unit 20 equips parameter setting devices such as a switch, a volume and the like, and can set a control parameter for controlling a musical expression of the singing voice synthesized voice. A musical tone, a pitch classification (high, middle, low, etc.), a pitch throb (a pitch bend, vibrato, etc.), dynamics classification (high, middle, low, etc. of a volume level), a tempo classification (fast, middle, slow, etc. tempo) and the like can be set as the control parameter. The control parameter data that represents a control parameter to be set is stored in a predetermined region in the RAM 16.
The external storage unit 22 includes one or plural kinds of removable storing mediums such as a flexible disk (FD), a compact disk (CD), a digital versatile disk (DVD), a magneto optical disk (MO) and the like. Data can be transmitted from the storing medium to the RAM 16 in a state that a desired storing medium is loaded into the external storage unit 22. If a loaded medium is writable such as HD and FD, data in the RAM 16 can transmit to the storing medium.
As a program storing unit, a storing medium of the external storage unit can be used instead of the ROM 14. In this case, the program stored in the storing medium is transmitted from the external storage unit 22 to the RAM 16. Then, the CPU is executed operations according to the program stored in the RAM 16. By doing this, a program addition, version-up, etc. can easily be executed.
The displaying unit 24 includes a displaying device such as a liquid crystal displaying device, and can display various kids of information such as the above-described results of the frequency analysis and the like.
The timer 26 generates a tempo clock signal TCL in a cycle corresponding to a tempo that a tempo data TM designates, and the tempo clock signal TCL is provided to the CPU 12. The CPU 12 executes a signal outputting process to the D/A conversion unit 28 based on the tempo clock signal TCL. A tempo that the tempo data TM designates can be set flexibly by a tempo setting device in an input unit 20.
The D/A conversion unit 28 converts a synthesized digital voice signal to an analog voice signal. The analogue voice signal transmitted from the D/A conversion unit 28 is converted to audio sound by a sound system 34 including an amplifier, a speaker, etc.
The MIDI interface 30 is provided for executing a MIDI communication to a MIDI device 36 that is separate from this singing voice synthesizing apparatus, and is used for receiving data for singing voice synthesizing from the MIDI device 36 in the present invention. As a data for singing voice synthesizing, a lyrics data and a melody data corresponding to a desired singing voice, a control parameter data for controlling a musical expression and the like can be received. These data for singing voice synthesizing are formed according to what is called a MIDI format, and the MIDI format may preferably be adapted for the lyrics data and the melody data input from the input unit 18 and the control parameter data input from the input unit 20.
As for the lyrics data, the melody data and the control parameter data received via the MIDI interface 30, a MIDI system exclusive data, which a manufacturer can define on its own form will be preferable for enabling the data to be read before other data. Also, as for one kind of data of the control parameter data input from the input unit 20 and the control parameter data received via the MIDI interface 30, a singer (or a musical tone) designating data may be used in a case that the voice synthesis unit data is stored in a later-described database by each singer (or each musical tone). In this case, as for the singer (or musical tone) designating data, program change data of MIDI can be used.
The communication interface 32 is provided for data communication to other computer 38 via the communication network (for example, local area network (LAN), the Internet, and a telephone line) 37. The programs and various kinds of data necessary for executing the present invention (for example, the lyrics data, the melody data, the voice synthesis unit data, etc.) may be loaded from the computer 38 to the RAM 16 or the external storage unit 22 via the communication network 37 and the communication interface 32 according to a downloading demand.
Next, an example of the singing voice analyzing process is explained referring to
At Step 42, a section waveform is logged at each section corresponding to each voice synthesis unit (phoneme or phonemic chain) for the digital waveform data to be stored (the digital waveform data is divided). As for the voice synthesis unit, there are a vowel phoneme, a phonemic chain of vowel and consonant or consonant and vowel, phonemic chain of consonant and consonant, phonemic chain of vowel and vowel, a phonemic chain of silence and consonant or vowel, a phonemic chain of vowel or consonant and silence and the like. As for a vowel phoneme, there is a long sound phoneme that is sung by lengthening a vowel. As an example, as for a singing voice of [saita], a section waveform is logged corresponding to each of [#s], [s—a], [a], [a—i], [l], [i—t], [t—a], [a] and [a#].
At Step 44, one or a plurality of time frame(s) is fixed by each section waveform, a frequency spectrum (an amplitude spectrum and a phase spectrum) are detected by executing the frequency analysis for each frame by the FFT and the like. Then, the data that represents the frequency spectrum is stored in a predetermined region in the RAM 16. A frame length may be a certain length or a flexible length. To make the frame length a flexible length, after the frequency analysis of one frame as a fixed length, a pitch is detected from the result of the frequency analysis, and a frame length corresponding to the detected pitch is set, and the frequency analysis can be executed on the frame again. In another case, after the frequency analysis of one frame as a fixed length, a pitch is detected from the result of the frequency analysis, a next frame length is set corresponding to the detected pitch, and the frequency analysis of the next frame can be executed. The number of frames will be one frame or a plurality of frames for a single phoneme consisted of only vowel, and will be a plurality of frames for the phonemic chain. In
Next, at Step 46, a pitch is detected based on the amplitude spectrum by voice synthesis unit, and a pitch data that represents a detected pitch is generated to store in a predetermined region in the RAM 16. The pitch detection can be executed by an averaging method of all frames of the pitches obtained by each frame.
At Step 48, plurality of local peaks of a spectrum intensity (amplitude) on the amplitude spectrum are detected by each frame. In order to detect the local peaks, a method wherein a peak whose amplitude value is the maximum is detected from the next plurality (for example, 4) peaks can be used. In
At Step 50, a spectrum distribution region corresponding to each local peak by each frame on the amplitude spectrum is designated, and an amplitude spectrum data represents the amplitude spectrum distribution in the region depending on the frequency axis to store in a predetermined region in the RAM 16. As a method for designating the spectrum distribution region, there are a method wherein each half of the frequency axes cut between two adjacent local peaks are assigned to a spectral distribution region including the local peak closer to the half and a method wherein the bottom where the amplitude is the lowest is found between the adjacent two local peaks, and the frequency of the bottom is used as a boundary of the adjacent spectrum distribution regions.
At Step 52, a phase spectrum data that represents the phase spectrum distribution in each spectrum distribution depending on the frequency axis by each frames based on the phase spectrum is generated, and it is stored in a predetermined region in the RAM 16. In
At Step 54, a pitch data, an amplitude spectrum data and a phase spectrum data are stored in a voice synthesis unit database by each voice synthesis unit. The RAM 16 or the external storage device 22 can be used as a voice synthesis unit database.
At a time of storing the voice synthesis unit data, by storing the voice synthesis unit data, each having difference in a singer (a musical tone), the pitch classification, the dynamics classification, the tempo classification and the like from other voice synthesis units, a natural (or high quality) singing voice can be synthesized. For example, for voice synthesis unit [a], voice synthesis unit data M1, M2 and M3 respectively corresponding to the tempo classifications “slow”, “middle”, and “fast” while the pitch classification is “low” and the dynamics classification is “small” are recorded by having a singer A sing in all the combination of the tempo classifications “slow”, “middle”, “fast”, the pitch classifications “high”, “middle”, “low” and the dynamics classifications “large”, “middle”, “small”. The voice synthesis unit data corresponding to the other combinations are recorded in the same way. The pitch data generated at Step 46 is used when it is judged to which of “low”, “middle” and “high” of the pitch classification the voice synthesis unit data is belonging.
As for a singer B who has a different voice from the singer A, a multiplicity of the voice synthesis units are recorded in the database DBS with different pitch classifications, dynamics classifications and pitch classifications by having the singer B sing similar to the above described singer A. Also, voice synthesis units other than [a] are recorded in the same manner as described above.
Although the voice synthesis unit data are generated in accordance with the singing voice signal input from the input unit 17 in the above-described example, the singing voice signal can be input via the interface 30 or 32, and the voice synthesis unit data can be generated in accordance with the input voice signal. Moreover, the database DBS can be stored not only in the RAM 16 or the external storage unit 22 but also in the ROM14, a storage unit of the MIDI device 36, a storage unit of the computer 38, etc.
At Step 62, a phoneme series corresponding to the input lyrics data is converted into individual voice synthesis units. Thereafter, at Step 64, voice synthesis unit data (pitch data, amplitude spectrum data and phase data) corresponding to each voice synthesis units are read from the database DBS. At Step 64, a tone color, a pitch classification, a dynamics classification, a tempo classification, etc. may be input from the input unit 20 as control parameters, and voice synthesis unit data corresponding to the control parameters directed by the data.
By the way, duration of the pronunciation of the voice synthesis unit is corresponding to the number of the voice synthesis unit data. That is, when the voice synthesizing is executed by using the voice synthesis unit data to be stored without changing, the duration of the pronunciation corresponding to the number of the voice synthesis unit data can be obtained. However, the duration of the pronunciation may be inappropriate depending on a duration of the musical note (an input musical note length), a set tempo and the like, and changing the duration of pronunciation will be necessary. In order to satisfy this necessity, the number of read frames of the voice synthesis unit data may be controlled corresponding to the input note length, the set tempo and the like.
For example, in order to shortening the duration of the pronunciation of the voice synthesis unit, the voice synthesis unit data is read skipping a part of frames. Also, in order to lengthening the duration of the pronunciation of the voice synthesis unit, voice synthesis unit data is read repeatedly. Moreover, when a long sound of a single phoneme such as is synthesized, the duration of the pronunciation tends to be changed. Synthesizing the long sound is explained later with reference to
At Step 66, the amplitude spectrum data of each frame is adjusted corresponding to a pitch of the input musical note corresponding to each voice synthesis unit. That is, the amplitude spectrum distribution that the amplitude spectrum data represents by each spectrum distribution region is moved on the frequency axis to be a pitch corresponding to the input musical note pitch.
In this case, as for the spectrum distribution AM2, the frequency of the local peak is Fi=T,fi, and a pitch conversion ratio is called T=Fi/fi. Also, the lower limit frequency Fi and the upper limit Fu are decided corresponding to each frequency difference “fi−fi” and “fu−fi”.
In the above-described example, however, the spectrum distribution is moved toward the higher pitch side on the frequency axis to rise the pitch, it can be moved toward the lower pitch side on the frequency axis to lower the pitch. In this case, two spectrum distribution regions Ra and Rb are partly overlapped as shown in
In an example in
As described in the above, when the spectrum distribution that includes the local peak is moved on the frequency axis, the spectrum envelope stretches and shortens only by changing the frequency setting, and a problem that the musical tone is different from the input voice waveform arises. In order to reproduce the musical tone of the input voice waveform, it is necessary that the spectrum intensity of local peaks of one or plurality of the spectrum distribution region is adjusted along with the spectrum envelope corresponding to a linked line with the local peaks of a series of spectrum distribution region by each frame.
In
In the above-described example, however, musical tone of the input voice waveform is reproduced, a musical tone that is different from the input voice waveform may be added on the synthesizing voice. By doing this, the spectrum intensity may be adjusted by using the spectrum envelope that the spectrum envelope EV shown in
In order to simplify a process using the spectrum envelope, the spectrum envelope is preferably expressed with a curve or a straight line.
Next, at Step 68 in
When a time interval between the frames is Δt, a local peak frequency is fi, and a pitch conversion ratio is T, a phase interpolation amount Δψ1 related to the spectrum distribution region that contains ith local peak is provided with a following equation A1.
Δψi=2πfi(T−1)Δt (A1)
The interpolation amount Δψi that is obtained by the equation A1 is added to a phase of each phase spectrum in the regions Fi to Fu as shown in
The phase interpolation as described in the above is executed for each spectrum distribution region. For example, in one frame, in the case that the frequency of the local peak is perfectly in a harmonic relation (the harmonic frequency is an absolute integral multiple of the fundamental frequency), the fundamental frequency of the input voice (that is, the pitch that the pitch data in the voice synthesis unit data represents) is fo. When numbers of the spectrum distribution region are k=1, 2, 3, . . . , the phase interpolation amount Δωi is provided with a following equation A2.
Δψi=2πfok(T−1)Δt (A2)
At Step 70, a reproduction starting time is decided corresponding to the set tempo and the like by each voice synthesis unit. The reproduction starting time depends on the set tempo and the input musical note length and can be represented with a clock count of the tempo clock signal TCL. As an example, in the case of the singing voice [saita], the reproduction starting time of the voice synthesis unit [s—a] is set in order to start [a] other than [s] at a note-on time that is decided by the input musical note length and the set tempo. At Step 60, the lyrics data and the melody are input on real time base. When the singing voice synthesizing is executed on real time base, the lyrics data and the melody data are input before the note-on time in order to be possible to set the reproduction starting time described in the above.
At Step 72, a spectrum intensity level can be adjusted between the voice synthesis units. This level adjustment process is executed for both of the amplitude spectrum data and the phase spectrum data, and it is executed for preventing a noise generated at a time of a synthesizing voice generation with a data connection at a next Step 74. There are a smoothing process, a level adjustment process and the like as a level adjustment process, and these processes are explained later referring to
At Step 74, the amplitude spectrum data are connected to each another, and the phase spectrum data are connected to each another. Then, at Step 76, the amplitude spectrum data and the phase spectrum data are converted to a synthesized voice signal (a digital waveform data) of the time region by each voice synthesis unit.
At Step 78, the synthesized voice signal is output to the D/A converting unit 28 referring to the reproduction starting time decided at Step 78. As a result, the singing voice is generated to be synthesized from the sound system 34.
At Step 82, a section waveform is logged by each section corresponding to the voice synthesis unit for the digital waveform data to be stored as same way as that is described before with reference to Step 42.
At Step 84, a section waveform data (the voice synthesis unit data) that represents the section waveform by each voice synthesis unit is stored in the voice synthesis unit database. The RAM 16 and the external storage unit 22 can be used as the voice synthesis unit database, and The ROM 14, a storing device in the MIDI device 36 and the storing device in the computer 38 may be used depending on a request. At a time of storing the voice synthesis unit data, section waveform data m1, m2, m3 . . . which are different in the singer (the musical tone), the pitch classification, the dynamics classification and the tempo classification by each voice synthesis unit can be stored in the voice synthesis unit database DBS as same way as that is described before with reference to
Next, another example of the singing voice synthesizing process is explained referring to
At Step 92, the phonemic series that the lyrics data represents is converted to individual voice synthesis unit as same way as that is described before with reference to Step 62. Then at Step 94, the section waveform data (the voice synthesis unit data) corresponding to each voice synthesis unit is read from the database that is executed the storing process at Step 84. In this case, data such as the musical tone, the pitch classification, the dynamics classification and the tempo classification are input as a control parameter from the input unit 20, and the section waveform data corresponding to the control parameter that the data instructs may be read. Also, the duration of pronunciation of the voice synthesis unit may be changed corresponding to the input musical note length and the set tempo as same way as that is described before with reference to Step 64. For doing this, when the voice waveform is read, reading the voice waveform may be continued only for a desired duration of pronunciation by omitting a part of the voice waveform or repeating a part or whole of the voice waveform.
At Step 96, one or plurality of time frames are decided for the section waveform by each section waveform data to be read, and the frequency analysis is executed by each frame by the FFT and the like to detect the frequency spectrum (the amplitude spectrum and the phase spectrum). Then data that represents the frequency spectrum is stored in a predetermined region in the RAM 16.
At Step 98, the same processes as Steps 46 to 52 in
The singing voice synthesizing process in
At Step 110, the pitch changing process that is the same as the process at Step 66 is executed on an amplitude spectrum data FSP that is resulted from a long sound voice synthesis unit data SD. That is, the spectrum distribution is moved where a pitch corresponds to the input musical note pitch that the input musical note pitch data PT shows on the frequency axis by each spectrum distribution region of each frame related to amplitude spectrum data FSP.
In the case that the long sound whose duration of the pronunciation is longer than the time length of the voice synthesis unit data SD is required, after reading the voice synthesis unit data SD to the end, the process returns to the start to read again. As doing this, a method to repeat the reading in a time sequential order can be adapted depending on a necessity. As another method, the voice synthesis unit data SD is read from the end to the start after it is read to the end, and a method to repeat the reading in a time sequential order and the reading in a time reverse order depending on the necessity may be adapted. In this method, a reading starting point at a time of the reading in a time reverse order may be set randomly.
In the database DBS shown in
At Step 114, a musical tone adjustment process is executed on an amplitude spectrum data FSP′ that is executed the pitch changing process at Step 110. This process is to set the musical tone of the synthesized voice adjusting the spectrum intensity according to the spectrum envelope by each frame as described before with reference to
At Step 116, the spectrum envelope data corresponding to the voice synthesis unit of the long sound is read from the database DBS. Then at Step 118, a spectrum envelope setting process is executed based on the spectrum envelope data to be read. That is, the spectrum envelope is set by adjusting the spectrum intensity in order to be along with the spectrum envelope indicated by the spectrum envelope data for each amplitude spectrum data of each frame of plurality of n frames amplitude spectrum data FRi to FRn in a frame group FR of long sounds. As a result, an appropriate musical tone can be added on the long sound.
In the spectrum envelope setting process at Step 118, for example, for example, a spectrum envelope throb data that represents a time sequential spectrum envelope change is stored corresponding to each of a long voice synthesis unit data such as M1 (or m1), M2 (or m2) and M3 (or m3) in the database DBS shown in
At Step 120, the spectrum envelope is extracted from an amplitude spectrum data PFR of a last frame of a former note, and the spectrum envelope is extracted from am amplitude spectrum data NFR of a first frame of the latter note. Then two spectrum envelopes to be extracted execute a time interpolation, and a spectrum envelope data that represents a spectrum envelope for a long sound is formed.
At Step 122, the spectrum envelope is set by adjusting the spectrum intensity in order to be along with the spectrum envelope that the spectrum envelope data to be formed at Step 120 indicates for each amplitude spectrum data of each frame of plurality of n frames amplitude spectrum data FRi to FRn. As a result, an appropriate musical tone can be added on the long sound between the phonemic chains.
Also, at Step 122, the spectrum envelope setting can be controlled by reading the spectrum envelope throb data VE from the database DBS corresponding to the control parameter such as musical tone and the like as same as the before-described process with reference to Step 118. By doing this, a natural synthesized voice can be obtained.
Next, an example of the smoothing process (corresponding to Step 72) is explained referring to
As an example, two voice synthesis units [a—i] and [i—a] as shown in
For example, in order to cross fade parameters for harmonic components, as shown in
The cross fading can be executed also on parameters such as other harmonic components and slope components as same as the above.
In this case, the level adjustment is executed in order to be almost the same amplitudes before and after the connecting point of voice synthesis units instead of cross fading. The level adjustment can be executed by multiplying a certain or a transitional coefficient to the amplitude of the voice synthesis unit.
In this example, it is explained that gains of slope components of two voice synthesis units are joined. First, as shown in
Next, typical samples (the slope components and each parameter of the harmonic component) for each of phonemes [a] and [i] are calculated. As the typical samples, the amplitude spectrum data of the first and the last frames of [a—l] can be calculated.
In accordance with the typical samples of [a] and [i], as indicated by the broken line shown in
At the above described Step 72, the above described smoothing process or level adjustment process is applied not only to the amplitude spectrum data but also to the phase spectrum data for adjustment of phase. As a result, production of noise can be prevented, and high quality singing voice synthesizing can be achieved. Further, in the smoothing process or level adjustment process, although the spectrum intensities are completely agreed at the connecting point, the spectrum intensities can be approximately agreed.
The present invention has been described in connection with the preferred embodiments. The invention is not limited only to the above embodiments. It is apparent that various modifications, improvements, combinations, and the like can be made by those skilled in the art.
Number | Date | Country | Kind |
---|---|---|---|
2002-052006 | Feb 2002 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
5536902 | Serra et al. | Jul 1996 | A |
5712437 | Kageyama | Jan 1998 | A |
5744742 | Lindemann et al. | Apr 1998 | A |
5750912 | Matsumoto | May 1998 | A |
6101469 | Curtin | Aug 2000 | A |
6836761 | Kawashima et al. | Dec 2004 | B1 |
Number | Date | Country | |
---|---|---|---|
20030221542 A1 | Dec 2003 | US |