The present invention relates to an electronic musical instrument, an electronic musical instrument control method, and a program for outputting a voice sound by driving a trained acoustic model in response to an operation on an operation element such as a keyboard.
In electronic musical instruments, in order to supplement expressive power of a singing voice sound and a live musical instrument, which are weak points of the expressive power of a pulse code modulation (PCM) method of the related art, a technology of training an acoustic model, in which a human vocalization mechanism and a sound generation mechanism of a musical instrument are modeled by digital signal processing, by machine learning based on a singing operation and a performance operation and inferring and outputting sound waveform data of a singing voice or musical sound by driving the trained acoustic model, based on an actual performance operation is devised and put into practical use (for example, Patent Literature 1).
When generating a singing voice waveform or musical sound waveform by machine learning, for example, the generated waveform often changes depending on changes in performance tempo, phrase-singing way, and performance style. For example, a sound generation time length of consonant portions in vocal voices, a sound generation time length of blowing sounds in wind instruments, and a time length for noise components when starting playing strings of a bowed string instrument are long in slow performances with few notes, and therefore, results in highly expressive and lively sounds, and are short in performances with many notes and a fast tempo, and therefore, results in articulated sounds.
However, when a user gives a performance in real time on a keyboard, etc., there is no way to convey a performance speed between notes that changes in response to change in score division of each note or difference in performance phrase in a sound source device, so that the acoustic model cannot infer an appropriate sound waveform corresponding to the change in performance speed between notes. As a result, for example, for a slow performance, the expressive power lacks, or conversely, the rising of the sound waveform generated for a fast-tempo performance is slow, making it difficult to give a performance.
Therefore, an object of the present invention is to enable inference of an appropriate sound waveform matched to a change in performance speed between notes that changes in real time.
An electronic musical instrument as an example of an aspect includes a pitch designation unit configured to output performance time pitch data designated at a time of a performance, a performance style output unit configured to output performance time performance style data indicating a performance style at the time of the performance, and a sound generation model unit configured, based on an acoustic model parameter inferred by inputting the performance time pitch data and the performance time performance style data to a trained acoustic model, to synthesize and output musical sound data corresponding to the performance time pitch data and the performance time performance style data, at the time of the performance.
An electronic musical instrument as another example of the aspect includes a lyric output unit configured to output performance time lyric data indicating lyrics at a time of a performance, a pitch designation unit configured to output performance time pitch data designated in tune with an output of lyrics at the time of the performance, a performance style output unit configured to output performance time performance style data indicating a performance style at the time of the performance, and a vocalization model unit configured, based on an acoustic model parameter inferred by inputting the performance time lyric data, the performance time pitch data and the performance time performance style data to a trained acoustic model, to synthesize and output singing voice sound data corresponding to the performance time lyric data, the performance time pitch data and the performance time performance style data, at the time of the performance.
According to the present invention, it is possible to enable inference of an appropriate voice sound waveform matched to a change in performance speed between notes that changes in real time.
Hereinafter, embodiments of the present invention will be described in detail with reference to the drawings.
The CPU 201 is configured to execute a control operation of the electronic keyboard musical instrument 100 shown in
The timer 210 that is used in the present embodiment is implemented on the CPU 201, and is configured to count progression of automatic performance in the electronic keyboard musical instrument 100, for example.
The sound source LSI 204 is configured to read out musical sound waveform data from a waveform ROM (which is not particularly shown), for example, and to output the same to the D/A converter 211, as musical sound data 218, in response to sound generation control data 216 from the CPU 201. The sound source LSI 204 is capable of 256-voice polyphony.
When the voice synthesis LSI 205 is given, as performance time singing voice data 215, text data of lyrics (performance time lyric data), data (performance time pitch data) designating each pitch corresponding to each lyric, and data relating to how to sing (performance time performance style data) from the CPU 201, the voice synthesis LSI synthesize singing voice sound data 217 corresponding to the data, and outputs the singing voice sound data to the D/A converter 212.
The key scanner 206 is configured to regularly scan pressed/released states of the keys on the keyboard 101 shown in
The LCD controller 208 is an IC (integrated circuit) configured to control a display state of the LCD 104.
The voice synthesis section 302 synthesizes and outputs singing voice sound data 217 by inputting the performance time singing voice data 215 including lyrics, a pitch and information relating to how to sing instructed from the CPU 201 via the key scanner 206 in
For example, as shown in
The voice training section 301 and the voice synthesis section 302 shown in
(Non-Patent Literature 1) Kei Hashimoto and Shinji Takaki, “Statistical parametric speech synthesis based on deep learning”, Journal of the Acoustical Society of Japan, vol. 73, no. 1 (2017), pp. 55-62
The voice training section 301 in
The voice training section 301 uses, for example, voice sounds that were recorded when a certain singer sang a plurality of songs in an appropriate genre, as training singing voice sound data 312. In addition, text data (training lyric data) of lyrics of each song, data (training pitch data) designating each pitch corresponding to each lyric, and data (training performance style data) indicating the singing way of the training singing voice sound data 312 are prepared as training singing voice data 311. As the training performance style data, time intervals at which the training pitch data is sequentially designated are sequentially measured, and each data indicating the sequentially measured time intervals is designated.
The training singing voice data 311 including training lyric data, training pitch data and training performance style data is input to the training singing voice analysis unit 303. The training singing voice analysis unit 303 analyzes the input data. As a result, the training singing voice analysis unit 303 estimates and outputs a training linguistic feature sequence 313, which is a discrete numerical sequence representing a phoneme, a pitch, and a singing way corresponding to the training singing voice data 311.
In response to the input of the training singing voice data 311, the training acoustic feature extraction unit 304 receives and analyzes the training singing voice sound data 312 that has been recorded via a microphone or the like when a certain singer sang lyrics corresponding to the training singing voice data 311. As a result, the training acoustic feature extraction unit 304 extracts a training acoustic feature sequence 314 representing a feature of a voice sound corresponding to the training singing voice sound data 312, and outputs the same, as teacher data.
The training linguistic feature sequence 313 is represented by a following symbol.
ι [expression 1]
The acoustic model is represented by a following symbol.
λ [expression 2]
The training acoustic feature sequence 314 is represented by a following symbol.
o [expression 3]
A probability that the training acoustic feature sequence 314 will be generated is represented by a following symbol.
P(o|ι,λ) [expression 4]
An acoustic model that maximizes the probability that the training acoustic feature sequence 314 will be generated is represented by a following symbol.
{circumflex over (λ)} [expression 5]
The model training unit 305 estimates an acoustic model, which maximizes a probability that the training acoustic feature sequence 314 will be generated, by machine learning, from the training linguistic feature sequence 314 and the acoustic model, according to a following equation (1). That is, a relationship between a linguistic feature sequence, which is a text, and an acoustic feature sequence, which is a voice sound, is expressed by a statistical model called an acoustic model.
Here, a following symbol indicates a computation of calculating a value of the argument underneath the symbol, which gives the greatest value for the function to the right of the symbol.
arg max [expression 7]
The model training unit 305 outputs training result data 315 expressing an acoustic model that is calculated as a result of machine learning by the computation shown in the equation (1). The calculated acoustic model is represented by a following symbol.
{circumflex over (λ)} [expression 8]
As shown in
The voice synthesis section 302 that is a function to be executed by the voice synthesis LSI 205 includes a performance time singing voice analysis unit 307, an acoustic model unit 306, and a vocalization model unit 308. The voice synthesis section 302 executes statistical voice synthesis processing of sequentially synthesizing and outputting the singing voice sound data 217, which corresponds to the performance time singing voice data 215 sequentially input at a time of a performance, by making predictions using the statistical model referred to as the acoustic model set in the acoustic model unit 306.
As a result of a performance of a user in tune with an automatic performance, the performance time singing voice data 215, which includes information about performance time lyric data (phonemes of lyrics corresponding to a lyric text), performance time pitch data and performance time performance style data (data about how to sing) designated from the CPU 201 in
In response to an input of the performance time linguistic feature sequence 316, the acoustic model unit 306 estimates and outputs, a performance time acoustic feature sequence 317, which is an acoustic model parameter corresponding to the input performance time linguistic feature sequence. The performance time linguistic feature sequence 316 input from the performance time singing voice analysis unit 307 is represented by a following symbol.
ι [expression 9]
An acoustic model set as the training result data 315 by machine learning in the model training unit 305 is represented by a following symbol.
{circumflex over (λ)} [expression 10]
The performance time acoustic feature sequence 317 is represented by a following symbol.
o [expression 11]
A probability that the performance time acoustic feature sequence 317 will be generated is represented by a following symbol.
P(o|ι,{circumflex over (λ)}) [expression 12]
An estimation value of the performance time acoustic feature sequence 317, which is an acoustic model parameter that maximizes the probability that the performance time acoustic feature sequence 317 will be generated, is represented by a following symbol.
ô [expression 13]
The acoustic model unit 306 estimates an estimation value of the performance time acoustic feature sequence 317, which is an acoustic model parameter that maximizes the probability that the performance time acoustic feature sequence 317 will be generated, based on the performance time linguistic feature sequence 316 input from the performance time singing voice analysis unit 307 and the acoustic model set as the training result data 315 by machine learning in the model training unit 305, in accordance with a following equation (2).
In response to an input of the acoustic feature sequence 317, the vocalization model unit 308 synthesizes and outputs the singing voice sound data 217 corresponding to the performance time singing voice data 215 designated from the CPU 201. This singing voice sound data 217 is output from the D/A converter 212 in
The acoustic feature represented by the training acoustic feature sequence 314 or the performance time acoustic feature sequence 317 includes spectral information modeling a human vocal tract and sound source information modeling human vocal cords. As the spectral information (parameter), for example, mel-cepstrum, line spectral pairs (LSP) or the like may be employed. As the sound source information, a power value and a fundamental frequency (FO) indicating a pitch frequency of human voice can be employed. The vocalization model unit 308 includes a sound source generation unit 309 and a synthesis filter unit 310. The sound source generation unit 309 is a unit that models human vocal cords, and, in response to a sequence of the sound source information 319 being sequentially input from the acoustic model unit 306, generates sound source signal data consisting of pulse sequence data (in the case of a voiced sound phoneme) that periodically repeats with the fundamental frequency (FO) and the power value included in the sound source information 319, white noise data (in the case of an unvoiced sound phoneme) having the power value included in the sound source information 319 or a mixed data thereof, for example. The synthesis filter unit 310 is a unit that models the human vocal tract, and forms a digital filter modeling the vocal tract, based on a sequence of the spectral information 318 sequentially input from the acoustic model unit 306, and generates and outputs the singing voice sound data 321, which is digital signal data, by using the sound source data input from the sound source generation unit 309, as an excitation source signal data.
The sampling frequency for the training singing voice sound data 312 and the singing voice sound data 217 is, for example, 16 KHz (kilohertz). When a mel-cepstrum parameter obtained by mel-cepstrum analysis processing, for example, is employed for the spectral parameter included in the training acoustic feature sequence 314 and the performance time acoustic feature sequence 317, a frame update period thereof is, for example, 6 msec (milliseconds). In addition, when mel-cepstrum analysis processing is performed, an analysis window length is 25 msec, a window function is Blackman window function, and an analysis order is a twenty-four order.
As specific processing of statistical voice synthesis processing that is performed by the voice training section 301 and the voice synthesis section 302 in
Through the statistical voice synthesis processing that is performed by the voice training section 301 and the voice synthesis section 302 shown in
Here, in the singing voice, it is normal that there is a difference in singing way between a melody of a fast passage and a melody of a slow passage.
In order to reflect the difference in performance tempo as described above to the change in singing voice sound data, in the statistical voice synthesis processing that is performed by the voice training section 301 and the voice synthesis section 302 shown in
On the other hand, in the voice synthesis section 302 including the acoustic model unit 306 in which the trained acoustic model is set as described above, performance time performance style data indicating a singing way is added to performance time lyric data indicating lyrics and performance time pitch data indicating pitch in the performance time singing voice data 215, and the information about the performance tempo can be included in the performance time performance style data. The performance time singing voice analysis unit 307 in the voice synthesis section 302 analyzes the performance time singing voice data 215 to generate the performance time linguistic feature sequence 316. Then, the acoustic model unit 306 in the voice synthesis section 302 outputs the corresponding spectral information 318 and sound source information 319 by inputting the performance time linguistic feature sequence 316 to the trained acoustic model, and supplies the spectral information and the sound source information to the synthesis filter unit 310 and the sound source generation unit 309 in the vocalization model unit 308, respectively. As a result, the vocalization model unit 308 can output the singing voice sound data 217 in which changes in the length of consonants or the like as shown in
The lyric output unit 601 outputs each performance time lyric data 609 indicating lyrics at the time of a performance, with including the same in each performance time singing voice data 215 that is output to the voice synthesis LSI 205 in
The pitch designation unit 602 outputs each performance time pitch data 610 indicating each pitch designated in tune with an output of each lyric at the time of a performance, with including the same in each performance time singing voice data 215 that is output to the voice synthesis LSI 205 in
The performance style output unit 603 outputs performance time performance style data 611 indicating a singing way that is a performance style at the time of a performance, with including the same in each performance time singing voice data 215 that is output to the voice synthesis LSI 205 in
Specifically, when a user sets a performance tempo mode to a free mode on the first switch panel 102 in
On the other hand, when the user does not set the performance tempo mode to the free mode on the first switch panel 102 in
In addition, when the user sets the performance tempo mode to a performance tempo adjustment mode for intentionally changing a performance tempo mode on the first switch panel 102 in
In this way, each function of the lyric output unit 601, the pitch designation unit 602, and the performance style output unit 603 that are executed by the CPU 201 in
An operation of the embodiment of the electronic keyboard musical instrument 100 in
The header chunk consists of four values: ChunkID, ChunkSize, Format Type, NumberOfTrack, and TimeDivision. ChunkID is a 4-byte ASCII code “4D 54 68 64” (numbers are hexadecimal) corresponding to the four half-width characters “MThd”, which indicates that the chunk is a header chunk. ChunkSize is 4-byte data indicating a data length of FormatType, NumberOfTrack and TimeDivision parts of the header chunk, excluding ChunkID and ChunkSize. The data length is fixed to six bytes “00 00 00 06” (numbers are hexadecimal). FormatType is 2-byte data “00 01” (numbers are hexadecimal) meaning that the format type is format 1, in which multiple tracks are used, in the case of the present embodiment. NumberOfTrack is 2-byte data “00 02” (numbers are hexadecimal) indicating that two tracks corresponding to the lyric part and the accompaniment part are used, in the case of the present embodiment. TimeDivision is data indicating a timebase value, which indicates a resolution per quarter note, and in the case of the present embodiment, is 2-byte data “01 E0” (numbers are hexadecimal) indicating 480 in decimal notation.
The first track chunk indicates the lyric part, corresponds to the musical piece data 604 in
Each ChunkID in the first and second track chunks is a 4-byte ASCII code “4D 54 72 6B” (numbers are hexadecimal) corresponding to 4 half-width characters “MTrk”, which indicates that the chunk is a track chunk. Each ChunkSize in the first and second track chunks is 4-byte data indicating a data length of each track chunk, excluding ChunkID and ChunkSize.
DeltaTime_1[i], which is the timing data 605 in
Event_1[i], which is the event data 606 in
In each performance data pair DeltaTime_[i] and Event_1[i] of the first track chunk/lyric part, Event_1[i], which is the event data 606, is executed after a wait of DeltaTime_1[i], which is the timing data 605, from the execution time of Event_1[i−1], which is the event data 606 immediately prior thereto. Thereby, the progression of song playback is realized. On the other hand, in each performance data pair DeltaTime_2[i] and Event 2[i] of the second track chunk/accompaniment part, Event_2[i], which is the event data, is executed after a wait of DeltaTime_2[i], which is the timing data, from the execution time of Event_2[i−1], which is the event data immediately prior thereto. Thereby, the progression of automatic accompaniment is realized.
After first executing initialization processing (step S801), the CPU 201 repeatedly executes the series of processing from step S802 to step S808.
In this repeating processing, the CPU 201 first executes switch processing (step S802). Here, the CPU 201 executes processing corresponding to a switch operation on the first switch panel 102 or the second switch panel 103 in
Next, the CPU 201 executes keyboard processing of determining whether any one key of the keyboard 101 in
Next, the CPU 201 processes data, which is to be displayed on the LCD 104 in
Next, the CPU 201 executes song playback processing (step S805). In the song playback processing, the CPU 201 generates and issues to the voice synthesis LSI 205 performance time singing voice data 215, which includes lyrics, vocalization pitch, and performance tempo for operating the voice synthesis LSI 205 based on song playback. The song playback processing will be described in detail later with reference to a flowchart in
Subsequently, the CPU 201 executes sound source processing (step S806). In the sound source processing, the CPU 201 executes control processing such as processing for controlling the envelope of musical sounds being generated in the sound source LSI 204.
Subsequently, the CPU 201 executes voice synthesis processing (step S807). In the voice synthesis processing, the CPU 201 controls execution of voice synthesis by the voice synthesis LSI 205.
Finally, the CPU 201 determines whether the user has pressed a power-off switch (not particularly shown) to turn off the power (step S808). When the determination in step S808 is NO, the CPU 201 returns to the processing of step S802. When the determination in step S808 is YES, the CPU 201 ends the control processing shown in the flowchart of
First, in
[expression 15]
TickTime [sec]=60/Tempo/TimeDivision (3)
Therefore, in the initialization processing shown in the flowchart of
Next, the CPU 201 sets a timer interrupt for the timer 210 in
Subsequently, the CPU 201 executes additional initialization processing, such as that for initializing the RAM 203 in
The flowcharts in
The CPU 201 first determines whether the tempo of lyric progression and automatic performance has been changed by a tempo-changing switch on the first switch panel 102 (step S1001). When the determination is YES, the CPU 201 executes tempo-changing processing (step S1002). This processing will be described in detail later with reference to
Next, the CPU 201 determines whether any one song has been selected with the second switch panel 103 in
Subsequently, the CPU 201 determines whether a song-starting switch has been operated on the first switch panel 102 in
Subsequently, the CPU 201 determines whether a free mode switch has been operated on the first switch panel 102 in
Subsequently, the CPU 201 determines whether a performance tempo adjustment switch has been operated on the first switch panel 102 in
Finally, the CPU 201 determines whether other switches have been operated on the first switch panel 102 or the second switch panel 103 in
First, similarly to step S901 in
Next, similarly to step S902 in
First, with respect to the progression of automatic performance, the CPU 201 initializes the values of both a timing data variable DeltaT_1 (first track chunk) and a timing data variable DeltaT_2 (second track chunk) on the RAM 203 for counting, in units of TickTime, relative time since the last event to 0. Next, the CPU 201 initializes the respective values of a variable AutoIndex_1 on the RAM 203 for designating an i value (1≤i≤L−1) for a performance data pair DeltaTime_1[i] and Event_1[i] in the first track chunk of the musical piece data shown in
Next, the CPU 201 initializes a value of a variable SongIndex on the RAM 203, which designates a current song position, to a null value (step S922). The null value is usually defined as 0 in many cases. However, since there is a case where the index number is 0, the null value is defined as −1 in the present embodiment.
The CPU 201 also initializes a value of a variable SongStart on the RAM 203, which indicates whether to advance (=1) or not to advance (=0) the lyrics and accompaniment, to 1 (advance) (step S923).
Then, the CPU 201 determines whether the user has made a setting to reproduce the accompaniment in tune with the playback of lyrics by using the first switch panel 102 in
When the determination in step S924 is YES, the CPU 201 sets a value of a variable Bansou on the RAM 203 to 1 (there is an accompaniment) (step S925). On the other hand, when the determination in step S924 is NO, the CPU 201 sets the value of the variable Bansou to 0 (there is no accompaniment) (step S926). After the processing of step S925 or S926, the CPU 201 ends the song-starting processing of step S1006 in
When the determination in step S1101 is NO, the CPU 201 ends the keyboard processing of step S803 in
When the determination in step S1101 is YES, the CPU 201 determines whether a key pressing operation or a key releasing operation has been performed (step S1102).
When it is determined in the determination in step S1102 that the key releasing operation has been performed, the CPU 201 instructs the voice synthesis LSI 205 to cancel the vocalization of the singing voice sound data 217 corresponding to the key-released pitch (or key number) (step S1113). In response to this instruction, the voice synthesis section 302 in
When it is determined in the determination in step S1102 that the key pressing operation has been performed, the CPU 201 determines a value of the variable FreeMode on the RAM 203 (step S1103). The value of the variable FreeMode is set in step S1008 in
When it is determined in step 1103 that the value of the variable FreeMode is 0 and the free mode setting has been canceled, the CPU 201, as described above with respect to the performance style output unit 603 in
In the equation (4), the predetermined coefficient is TimeDivision value of musical piece data×60 in the present embodiment. That is, if the TimeDivision value is 480, PlayTempo becomes 60 (corresponding to normal tempo 60) when DeltaTime_1[AutoIndex_1] is 480. When DeltaTime_1 [AutoIndex_1] is 240, PlayTempo becomes 120 (equivalent to normal tempo 120).
When the free mode setting has been canceled, the performance tempo is set in synchronization with the timing information relating to song playback.
When it is determined in step 1103 that the value of the variable FreeMode is 1, the CPU 201 further determines whether a value of a variable NoteOnTime on the RAM 203 is a null value (step S1104). At the start of song playback, for example, in step S903 in
At the time of the start of song playback and when the determination in step S1104 is YES, the performance tempo cannot be determined from the user's key pressing operation. Therefore, the CPU 201 sets a value calculated by the arithmetic processing shown in the equation (4) using DeltaTime_1 [AutoIndex_1], which is the timing data 605 on the RAM 203, to the variable PlayTempo on the RAM 203 (step S1109). In this way, at the start of song playback, the performance tempo is tentatively set in synchronization with the timing information relating to song playback.
After the start of song playback and when the determination in step S1104 is NO, the CPU 201 first sets a difference time, which is obtained by subtracting the value of the variable NoteOnTime on RAM 203 indicating the last key pressing time from the current time indicated by the timer 210 in
Next, the CPU 201 determines whether the value of the variable DeltaTime, which indicates the difference time from the last key pressing time to the current key pressing time, is smaller than a predetermined maximum time for regarding as a simultaneous key pressing by chord performance (chord) (step S1106).
When the determination in step S1106 is YES and it is determined that the current key pressing is the simultaneous key pressing by chord performance (chord), the CPU 201 does not execute the processing for determining a performance tempo, and proceeds to step S1110, which will be described later.
When the determination in step S1106 is NO and it is determined that the current key pressing is not the simultaneous key pressing by chord performance (chord), the CPU 201 further determines whether the value of the variable DeltaTime, which indicates the difference time from the last key pressing to the current key pressing, is greater than a minimum time for regarding that the performance has been interrupted in the middle (step S1107).
When the determination in step S1107 is YES and it is determined that the key pressing is a key pressing (the beginning of the performance phrase) after the performance has been interrupted for a while, the performance tempo of the performance phrase cannot be determined. Therefore, the CPU 201 sets a value, which is calculated by the arithmetic processing shown in the equation (4) using DeltaTime_1 [AutoIndex_1] that is the timing data 605 on the RAM 203, to the variable PlayTempo on the RAM 203 (step S1109). In this way, in the case of the key pressing (the beginning of the performance phrase) after the performance has been interrupted for a while, the performance tempo is tentatively set in synchronization with the timing information relating to song playback.
When the determination in step S1107 is NO and it is determined that the current key pressing is neither the simultaneous key pressing by chord performance (chord) nor the key pressing at the beginning of the performance phrase, the CPU 201 sets a value obtained by multiplying a predetermined coefficient by a reciprocal of the variable DeltaTime indicating the difference time from the last key pressing to the current key pressing, as shown in a following equation (5), to the variable PlayTempo on the RAM 203 indicating the performance tempo corresponding to the performance time performance style data 611 in
[expression 17]
PlayTempo=(1/DeltaTime)×predetermined coefficient (5)
As a result of the processing in step S1108, when the value of the variable DeltaTime indicating the difference time between the last key pressing and the current key pressing is small, the value of PlayTempo, which is the performance tempo, increases (the performance tempo becomes fast), the performance phrase is regarded as a fast passage, and in the voice synthesis section 302 in the voice synthesis LSI 205, a sound waveform of the singing voice sound data 217 in which the time length of the consonant portion is short as shown in
After the processing of step S1108 described above, after the processing of step S1109 described above, or after the determination in step S1106 described above becomes YES, the CPU 201 sets the current time indicated by the timer 210 in
Finally, the CPU 201 sets a value, which is obtained by adding the value of the variable ShiinAdjust (refer to step S1010 in
Through the processing of step S1111, the user can intentionally adjust the time length of the consonant portion in the singing voice sound data 217 synthesized in the voice synthesis section 302. In some cases, a user may want to adjust the singing way, depending on the song title or taste. For example, for some songs, when the user wants to give a performance with good sound generation by cutting the overall sound short, the user may want the voice sounds to be generated as if a sing were sung with speaking words quickly by shortening the consonants. Conversely, for some songs, when the user wants to give a performance comfortably as a whole, the user may want voice sounds to be generated, which can clearly transfer the breath of consonants as if a sing were sung slowly. Therefore, in the present embodiment, the user may change the value of the variable ShiinAdjust by, for example, operating the performance tempo adjustment switch on the first switch panel 102 in
The performance tempo value set to the variable PlayTempo by the keyboard processing described above is set as a part of the performance time singing voice data 215 in the song playback processing described later (refer to step S1305 in
In the keyboard processing described above, in particular, the processing of steps S1103 to S1109 and step S1111 corresponds to the functions of the performance style output unit 603 in
First, the CPU 201 executes a series of processing (steps S1201 to S1206) corresponding to the first track chunk. First, the CPU 201 determines whether a value of SongStart is 1 (refer to step S1006 in
When it is determined that the progression of lyrics and accompaniment has not been instructed (the determination in step S1201 is NO), the CPU 201 ends the automatic performance interrupt processing shown in the flowchart in
When it is determined that the progression of lyrics and accompaniment has been instructed (the determination in step S1201 is YES), the CPU 201 determines whether the value of the valuable DeltaT_1 on the RAM 203, which indicates the relative time since the last event with respect to the first track chunk, matches DeltaTime_1[AutoIndex_1] on the RAM 203, which is the timing data 605 (
When the determination in step S1202 is NO, the CPU 201 increments the value of the variable DeltaT_1, which indicates the relative time since the last event with respect to the first track chunk, by 1, and allows the time to advance by 1 TickTime unit corresponding to the current interrupt (step S1203). Thereafter, the CPU 201 proceeds to step S1207, which will be described later.
When the determination in step S1202 is YES, the CPU 201 stores the value of the variable AutoIndex_1, which indicates a position of the song event that should be performed next in the first track chunk, in the variable SongIndex on the RAM 203 (step S1204).
Also, the CPU 201 increments the value of the variable AutoIndex_1 for referencing the performance data pairs in the first track chunk by 1 (step S1205).
Further, the CPU 201 resets the value of the variable DeltaT_1, which indicates the relative time since the song event most recently referenced in the first track chunk, to 0 (step S1206). Thereafter, the CPU 201 proceeds to processing of step S1207.
Next, the CPU 201 executes a series of processing (steps S1207 to S1213) corresponding to the second track chunk. First, the CPU 201 determines whether the value of the valuable DeltaT_2 on the RAM 203, which indicates the relative time since the last event with respect to the second track chunk, matches DeltaTime_2[AutoIndex_2] on the RAM 203, which is the timing data of the performance data pair about to be executed indicated by the value of the variable AutoIndex_2 on the RAM 203 (step S1207).
When the determination in step S1207 is NO, the CPU 201 increments the value the variable DeltaT_2, which indicates the relative time since the last event with respect to the second track chunk, by 1, and allows the time to advance by 1 TickTime unit corresponding to the current interrupt (step S1208). Thereafter, the CPU 201 ends the automatic performance interrupt processing shown in the flowchart of
When the determination in step S1207 is YES, the CPU 201 determines whether the value of the variable Bansou on the RAM 203 instructing accompaniment playback is 1 (there is an accompaniment) or not (there is no accompaniment) (step S1209) (refer to steps S924 to S926 in
When the determination in step S1209 is YES, the CPU 201 executes processing indicated by the event data Event_2 [AutoIndex_2] on the RAM 203 relating to the accompaniment of the second track chunk indicated by the value of the variable AutoIndex_2 (step S1210). When the processing indicated by the event data Event_2 [AutoIndex_2] executed here is, for example, a note-on event, the key number and velocity designated by the note-on event are used to issue an instruction to the sound source LSI 204 in
On the other hand, when the determination in step S1209 is NO, the CPU 201 skips step S1210 and proceeds to processing of next step S1211 so as to progress in synchronization with the lyrics without executing the processing indicated by the event data Event_2[AutoIndex_2] relating to the current accompaniment, and executes only control processing that advances events.
After step S1210, or when the determination in step S1209 is NO, the CPU 201 increments the value of the variable AutoIndex_2 for referencing the performance data pairs for accompaniment data on the second track chunk by 1 (step S1211).
Next, the CPU 201 resets the value of the variable DeltaT 2, which indicates the relative time since the event most recently executed with respect to the second track chunk, to 0 (step S1212).
Then, the CPU 201 determines whether the value of the timing data DeltaTime_2[AutoIndex_2] on the RAM 203 of the performance data pair on the second track chunk to be executed next indicated by the value of the variable AutoIndex_2 is 0, i.e., whether this event is to be executed at the same time as the current event (step S1213).
When the determination in step S1213 is NO, the CPU 201 ends the current automatic performance interrupt processing shown in the flowchart in
When the determination in step S1213 is YES, the CPU 201 returns to the processing of step S1209, and repeats the control processing relating to the event data Event_2[AutoIndex_2] on the RAM 203 of the performance data pair to be executed next on the second track chunk indicated by the value of the variable AutoIndex_2. The CPU 201 repeatedly executes the processing of steps S1209 to S1213 by the number of times to be simultaneously executed this time. The above processing sequence is executed when a plurality of note-on events are to generate sound at simultaneous timings, such as a chord.
First, at step S1204 in the automatic performance interrupt processing in
When the determination in step S1301 is YES, i.e., when the present time is a song playback timing, the CPU 201 determines whether a new user key pressing on the keyboard 101 in
When the determination in step S1302 is YES, the CPU 201 sets the pitch designated by the user key pressing, to a register not particularly shown or a variable on the RAM 203, as a vocalization pitch (step S1303).
On the other hand, when it is determined by the determination in step S1301 that the present time is the song playback timing and the determination in step S1302 is NO, i.e., it is determined that no new key pressing has been detected at the present time, the CPU 201 reads out the pitch data (corresponding to the pitch data 607 in the event data 606 in
Subsequently, the CPU 201 reads out the lyric string (corresponding to the lyric data 608 in the event data 606 in
Subsequently, the CPU 201 issues the performance time singing voice data 215 generated in step S1305 to the voice synthesis section 302 in
Finally, the CPU 201 clears the value of the variable SongIndex so as to become a null value and makes subsequent timings non-song playback timings (step S1307). Thereafter, the CPU 201 ends the song playback processing of step S805 in
In the above song playback processing, in particular, the processing of steps S1302 to S1304 corresponds to the function of the pitch designation unit 602 in
According to the embodiment described above, depending on the type of a musical piece to be performed and the performance phrase, the sound generation time length of the consonant portions in the vocal voice is long in performances with few notes of a slow passage and can result in highly expressive and lively sounds, and is short in performances with a fast tempo or many notes and can result in articulated sounds, for example. That is, it is possible to obtain a change in tone color that matches the performance phrase.
The embodiment described above is an embodiment of an electronic musical instrument configured to generate singing voice sound data, but as another embodiment, an embodiment of an electronic musical instrument configured to generate sounds of wind instruments or string instruments can also be implemented. In this case, the acoustic model unit corresponding to the acoustic model unit 306 in
In the embodiment described above, in the case in which the speed of the performance phrase cannot be estimated, such as the first key pressing or the first key pressing of the performance phrase, when singing or striking strongly, the rising portion of the consonant or sound is shortened, and when singing or striking weakly, the rising portion of the consonant or sound is lengthened. By using such a tendency, the intensity with which to play the keyboard (velocity value when pressing a key) may be used as a basis for calculation of a value of the performance tempo.
The voice synthesis method that can be adopted as the vocalization model unit 308 of
In addition, as the voice synthesis method, in addition to the voice synthesis method based on the statistical voice synthesis processing using the HMM acoustic model and the statistical voice synthesis processing using the DNN acoustic model, any voice synthesis method may be employed as long as it is a technology using statistical voice synthesis processing based on machine learning, such as an acoustic model that combines HMM and DNN.
In the embodiment described above, the performance time lyric data 609 is given as the musical piece data 604 stored in advance. However, text data obtained by voice recognition performed on content being sung in real time by a user may be given as lyric information in real time.
Regarding the above embodiment, the following appendixes are further disclosed.
(Appendix 1)
An electronic musical instrument including:
(Appendix 2)
An electronic musical instrument including:
(Appendix 3)
The electronic musical instrument according to Appendix 1 or 2, wherein the performance style output unit is configured to sequentially measure time intervals at which the pitch is designated at the time of the performance, and to sequentially output performance tempo data indicating the sequentially measured time intervals, as the performance time performance style data.
(Appendix 4)
The electronic musical instrument according to Appendix 3, wherein the performance style output unit includes a changing means for allowing a user to intentionally change the performance tempo data obtained sequentially.
(Appendix 5)
An electronic musical instrument control method including causing a processor of an electronic musical instrument to execute processing of:
(Appendix 6)
An electronic musical instrument control method including causing a processor of an electronic musical instrument to execute processing of:
(Appendix 7)
A program for causing a processor of an electronic musical instrument to execute processing of:
(Appendix 8)
A program for causing a processor of an electronic musical instrument to execute processing of:
The present application is based on Japanese Patent Application No. 2020-152926 filed on Sep. 11, 2020, the contents of which are incorporated herein by reference.
Number | Date | Country | Kind |
---|---|---|---|
2020-152926 | Sep 2020 | JP | national |
Filing Document | Filing Date | Country | Kind |
---|---|---|---|
PCT/JP2021/029833 | 8/13/2021 | WO |