The present application is based upon and claims the benefit of priority from the prior Japanese Patent Application No. 2013-051160, filed Mar. 14, 2013, the entire contents of which are incorporated herein by reference.
1. Field of the Invention
The present invention relates to an automatic accompaniment apparatus, a method of automatically playing accompaniment, and a computer readable recording medium with an automatic accompaniment program recorded thereon.
2. Description of the Related Art
In general, when playing musical instruments with a keyboard, such as pianos and organs, or electronic keyboards and electronic pianos, performers play a melody with his/her right hand and an accompaniment with his/her left hand.
But moving the both hands simultaneously to play the musical instrument, the performers are required to do reasonable practice. In particular, it is relatively easy to play a melody with the right hand, but many performers, particularly, beginner performers feel it hard to play accompaniment with the left hand while playing a melody with the right hand. In these situations, electronic musical instruments have been actualized, which automatically produce and play appropriate chords to a melody played by the performer with his/her right hand, whereby the performer is not required to play the chords with his/her left hand. Using the instrument, even such beginner performers can easily enjoy playing the performance.
For example, Japanese Unexamined Patent Publication No. 2011-158855 discloses an electronic musical instrument which can determine appropriate chord names in accordance with weights of melody tones and their succession.
The electronic musical instrument described in Japanese Unexamined Patent Publication No. 2011-158855 uses positions of beats of the melody tone, weights of beats, a melody tone at the leading beat, and chord names to judge chords to be played. A melody progression of general music and chords to be played to a melody vary widely, and particularly in music, chords to be played with melody progression are judged much based on human sense and it has been required to further enhance accuracy in mechanically playing chords to melody tones.
The present invention has been made in consideration of inconvenience involved in conventional techniques, and provides an automatic accompaniment apparatus, a method of automatically playing accompaniment, and a computer readable recording medium with an automatic accompaniment program recorded thereon, which can promptly play appropriate chords with high accuracy based on a melody tone history.
According to one aspect of the invention, there is provided an automatic accompaniment apparatus which comprises a music database having plural pieces of music data recorded therein, the plural pieces of music data corresponding respectively to plural musical pieces, and each piece of music data including melody information and chords corresponding to the melody information, a performance recording unit which records performance information for successively giving an instruction of generating a musical tone in response to operation performed on a performance operating device, a music searching unit which searches for a musical piece having music data including melody information corresponding to the performance information recorded in the performance recording unit through the music database, a chord judging unit which judges a chord based on the performance information recorded in the performance recording unit, a chord selecting unit which selects one of the chord included in the music data of the musical piece found by the music searching unit and the chord judged by the chord judging unit as the chord to be used, and an automatic accompaniment unit which gives an instruction of generating accompaniment in accordance with the chord selected by the chord selecting unit.
According to another aspect of the invention, the above chord selecting unit compares functional harmonies between the chord included in the music data of the musical piece found by the music searching unit and the chord judged by the chord judging unit, and selects the chord based on the result of the comparison of the functional harmonies.
According to other aspect of the invention, the above chord selecting unit selects the chord judged by the chord judging unit, when the both functional harmonies coincide with each other between the chord included in the music data found by the music searching unit and the chord judged by the chord judging unit, and selects the chord included in the music data, when the both functional harmonies do not coincide with each other.
According to still other aspect of the invention, the chords to be played to a melody performed by a performer are determined automatically based on a melody tone history or are read from the music database. Therefore, appropriate chords to be played can promptly be determined with high accuracy.
Now, the preferred embodiments of the present invention will be described with reference to the accompanying drawings in detail.
CPU 21 controls the whole operation of the electronic musical instrument 10, and further performs various processes, such as detecting pressed keys of the keyboard 11, detecting operated switches (for example, 12, 13 in
ROM 22 stores programs for the processes to be performed by CPU 21 such as processes to be performed in accordance with the operated switch or in response to the pressed keys, generating musical tones in response to the pressed keys, deciding the chord names depending on the pitches of the musical tones of the pressed keys, and providing musical accompaniment in accordance with the automated accompaniment patterns and chord names. Further, ROM 22 has a waveform-data area, which stores waveform data for generating various sorts of musical tones such as the pianos, guitars, bass drums, snare drums and cymbals, and an automatic-accompaniment pattern area, which stores data (automatic accompaniment data) indicating various automatic accompaniment patterns.
RAM 23 stores the program read from ROM 23 and data produced in the various processes. Further, RAM 23 stores melody history data which is produced by CPU 21 in response to key-pressing and/or key-releasing operations performed on the keyboard 11. In the present embodiment of the invention, the automated accompaniment pattern contains an automated melody accompaniment pattern including melody tones and obbligato tones, an automated chord accompaniment pattern including chord names and composing tones of each chord, and rhythm patterns including drum sounds. For example, a record of data of automated melody accompaniment pattern contains tone colors, pitches, generation timings, and note values of musical tones. A record of data of automated chord accompaniment pattern includes data indicating chord composing tones in addition to the above information. Further, a record of data of rhythm patterns includes tone colors and generation timings of musical tones.
The sound system 24 comprises a sound source unit 26, an audio circuit 27 and a speaker 28. Upon receipt of information of the pressed key or information of the automated accompaniment patterns from CPU 21, the sound source unit 26 reads predetermined waveform data from the waveform-data area of ROM 22 to generate and output musical-tone data of predetermined pitches. Further, the sound source unit 26 can output waveform data, in particular, waveform data of tone colors of percussion instruments such as the snare drums, buss drums, and cymbals as musical-tone data without any modification, too. The audio circuit 27 converts the musical-tone data into an analog signal, and amplifies the analog signal, whereby the analog signal is output from the speaker 28.
Further, the electronic musical instrument 10 according to the present embodiment of the invention is provided with a music database 30. The music database 30 is used as a dictionary, in which a history of an entered melody is compared with musical pieces registered therein to refer to appropriate chords, as will be described later.
As shown in
Although an example of the music database in which all the musical pieces are recorded in C major is shown in
Further, to the right of the column of “Key/Beats” is the column of “Notes” (Note column), where pitches, intervals from the preceding tone, ST ratios to the opening tone (Step Time) of musical tones of a melody and chords to the melody of each musical piece are recorded.
Again, taking the music “Little Fox” of the music number 1 as an example, a detailed description will be given. The melody of the musical piece is given by “Do Re Mi Fa Sol Sol Sol”, and therefore, the pitches “C D E F G G G” of the melody of the musical piece of music number 1 are successively recorded on the top in the column of Notes, as shown in
On the second line in the column of Note of each musical piece in
As shown in the musical piece of music number 2 and the following musical pieces, when the melody tones are descending, the intervals from the preceding tone are recorded in a negative value. (For example, the fourth tone of “Song of Sparrows” of the music number 2 and the fifth and sixth tones of “Pigeon” of the music number 7 are recorded in a negative value.)
Further, on the third line in the column of Notes of each piece of music in
In the database shown in
Further in
The chord column is referred to determine chords to be played to a melody in a chord selecting process. The chord selecting process will be described later. The chords such as played together with a melody are not always determined as one set of chords but the chords are selected and played by a musician in various ways depending on his/her personality and feeling and on arrangement of music. Meanwhile, in the present embodiments of the invention, from the standpoint of an auxiliary assistance of an automatic chord judgment (automatically playing chords) by a machine in an automatically playing accompaniment, it will be preferable that a table of chords is prepared such that when the chords selected at least from the table are played, no one feels a feeling of strangeness on such chords.
The data format of the musical pieces in the database is not always limited to the one described herein, but data in each item of the database can be calculated from data in MIDI format as follows: “ST ratio to the opening tone” of each note is calculated from a duration of each note of the melody; and pitches of adjacent notes of the melody tones are compared to calculate the “interval” from the just preceding tone to each note. Further, it is possible to prepare chord data containing chords separately. Furthermore, such chord data is practicable too, as recorded on a track separate from a melody track, which chord data contains chord symbols representing chords or plural notes representing chords.
The electronic musical instrument 10 according to the present embodiment of the invention generates musical tones in accordance with the pressed keys of the keyboard 11 in the normal mode. Meanwhile, the electronic musical instrument 10 is switched to the automatic-accompaniment mode, when an automatic accompaniment switch among the various switches 12, 13 shown in
Now, the process to be performed in the electronic musical instrument 10 of the present embodiment of the invention will be described in detail.
As shown in
In the switch process are detected operation of the following switches: a switch of designating a tone color; a switch of designating a sort of the automatic accompaniment pattern; and a switch of designating on/off of the automatic accompaniment pattern (step S302). When the switch of designating the automatic accompaniment pattern is turned on, CPU 21 switches the performance mode to the automatic accompaniment mode. Data indicating the performance mode is designated in a predetermined area of RAM 23. Similarly, data indicating the tone color and data indicating the sort of automatic accompaniment pattern are also stored in a predetermined area of RAM 23.
Then, CPU 21 performs a keyboard process (step S303).
When it is determined YES at S403, that is, when it is determined that the event is a key-on (key-on event), CPU 21 performs a tone generating process in accordance with said key (the key-on event) (step S404). In the tone generating process, CPU 21 reads from RAM 23 tone color data and data indicating a pitch of the key designated by the tone color designating switch, and stores the data temporarily in RAM 23. The data indicating tone color and data indicating pitch are supplied to the sound source unit 26 in a sound-source sound generating process (step S309 in
Thereafter, CPU 21 stores in RAM 23 pitch information (for instance, a key number) of the key-on key and the key-pressed timing at which said key is pressed (for instance, a key-pressed time) (step S405). The key-pressed timing can be counted from the count value of the interrupting counter.
When it is determined NO at step S403, it is determined that the event is a key-off. Then, CPU 21 performs a tone ceasing process in accordance with said key (key-off event) (step S406). In the tone ceasing process, CPU 21 generates data indicating a pitch of a musical tone to be ceased, and stores the data temporarily in RAM 23. In this case, in the sound-source sound generating process (step S309) to be described later, the data indicating tone color of the tone to be ceased and data indicating pitch of the tone to be ceased are supplied to the sound source unit 26. The sound source unit 26 ceases the musical tone in accordance with the supplied data. Thereafter, CPU 21 stores a duration (key-pressed duration) during which the key is kept pressed in RAM 23 (step S407). Further, when a melody history is stored, CPU 21 calculates the ratio of the duration of the present tone (ST ratio to the opening tone) to the opening tone (ST: Step Time), and stores the calculated “ST ratio to the opening tone” together with the melody history information.
CPU 21 judges whether the process has been finished with respect to all the key events (step S408). When it is determined NO at step S408, CPU 21 returns to step S402. When it is determined that the process has been finished with respect to all the key events (YES at step S408), then CPU 21 finishes the keyboard process of
When the keyboard process has finished (step S303 in
In the candidate-music searching process, CPU 21 judges whether a melody has been entered in accordance with the key pressing/releasing operation detected in the keyboard process of
When it is determined that a melody has been entered (YES at step S501), CPU 21 records the entered melody as a melody history in a melody-history recording area of RAM 23 in addition to the melody history previously recorded therein (step S502). An example of a data structure of the melody history recorded in RAM is shown in
In the example shown in
When the melody history is recorded at step S502, it is possible to exclude a tone of an extremely short duration from the tones of the melody history to be recorded, in order to prevent recording a fine touch in error. For example, a tone of a key-pressed duration which is a threshold value or less is not recorded in the melody history recording, and a process of returning from the candidate-music searching process can be performed without performing the processes at step S503 and thereafter.
When the melody-history recording finishes at step S502, CPU 21 judges whether the entered melody tone is the first melody tone (step S503). When it is determined that the entered melody tone is the first melody tone (YES at step S503), CPU 21 performs a process of preparing F-list of musical pieces (step S504).
The F-list of musical pieces prepared in the process of preparing F-list of musical pieces
Since comparison is made between the entered melody and the musical pieces in the database (
In
Then, CPU 21 picks up the musical pieces found at step S602 to prepare F-list of musical pieces (step S603). When plural musical pieces have been found at step S603, CPU 21 uses all the found musical pieces to prepares a list of musical pieces, or CPU 21 selects a predetermined number of musical pieces at random and prepares F-list of these selected musical pieces. On the contrary, when no musical piece has been found, it is possible to send a flag of no music found.
An example of the F-list of musical pieces prepared in the above manner is shown in
The order given to the musical pieces is absolutely one example, and the order shown in
When the F-list of musical pieces (
Meanwhile, when it is determined that the entered melody tone is not the first melody tone (NO at step S503), CPU 21 judges whether a key (tonality) of the entered melody has been established (step S505).
The judgment of whether a key (tonality) of the entered melody has been established (step S505) can be made in a key (tonality) judging process (step S305 in
When it is determined that the key (tonality) of the entered melody has been established (YES step S505), CPU 21 prepares K-list of musical pieces at step S506. A process of preparing K-list of musical pieces is shown in
The K-list of musical pieces to be prepared in the process of preparing K-list of musical pieces of
With the above processes prepared, even if the user plays THE melody in a key arbitrarily transposed by the user, the musical piece can be searched for and specified promptly regardless of the key (tonality) of the musical piece registered in the music database, whereby correct chords will be generated.
In the process of preparing K-list of musical pieces, CPU 21 obtains information of the key of the entered melody, which key is determined to be established, as a variable Key (step S701). Then, CPU 21 compares the established key (variable Key) of the entered melody with the keys (tonalities) of the musical pieces recorded in the music database (
The process of preparing K-list of musical pieces will be described more specifically. For example, assuming that the established Key of the entered melody “F major” has been obtained as the variable Key, when the music “Are you sleeping” of the registered Key “C” of the music number 4 is compared with the entered melody of the variable Key “F”, then the number of semitones between the registered Key “C” and the established Key (variable Key) “F” is calculated. According to the known music theory, the “number of semitones is 5” can be calculated. Each tone of the registered melody of “Are you sleeping” of the music number 4 is subjected to a process of “number of semitones+5” to transpose the key to F major. In the case of the music “Are you sleeping”, the original melody “C D E C C D E” is subjected to modulation of “number of semitones+5”, and will be “F G A F F G A”.
Then, melodies of key-transposed musical pieces in the music database are compared with the previously entered melody history on a tone to tone basis. As a result of the comparison, musical pieces which meet predetermined conditions are picked up at step S702.
Various conditions will be considered for picking up the musical pieces. For instance, a musical piece can be picked up from the music database, whose tones from the initial to the latest tones coincide in pitch with those of the entered melody history. Further, it is possible to pick up a predetermined number of musical pieces in order of decreasing number of coincident tones from among musical pieces including larger number of tones which are continuously coincident from past tones to current tones of the entered melody history. Furthermore, it will also be possible to pick up a predetermined number of musical pieces in order of decreasing number (probability) of coincident tones from among musical pieces including number of coincident tones from the initial tones to the current tones.
Then, CPU 21 judges whether any musical piece has been picked up (step S703). When it is determined that no musical piece has been picked up (NO at step S703), then CPU 21 finished the process of preparing K-list of musical pieces.
When it is determined that musical pieces have been picked up (YES at step S703), “ST ratio to the melody opening tone (the first tone)” of each tone of the entered melody history is calculated. The calculated ST ratios to the melody opening tone (the first tone) of the entered melody history are compared with “ST ratios to the opening tone” of the picked up musical pieces, recorded in the music database, whereby an “accuracy rate” will be calculated (step S704).
To calculate the “accuracy rate” (step S704), various methods will be used.
For instance, the “accuracy rate” will be calculated according to one method, that is, “ST ratio to the melody opening tone” of each tone of the entered melody history is calculated and the accuracy rate of each tone is determined based on difference between the calculated ST ratios of the entered melody and ST ratios registered in the music database, and then average of the determined accuracy rates is calculated. In other words, for instance, concerning “D” of the second tone of the music “Are you sleeping” of the music number 4, “ST ratio”=“1” is recorded in the music data base, which means that “D” of the second tone of the music has the same duration as the opening tone in the music database. But when a duration of the second tone of the melody actually played by the user is 90% or 110% of the melody opening tone, the accurate rate of the second tone will be “90 points” according to the above method.
As described above, the “accurate rate of a musical piece” can be calculated at step S704, which rate corresponds to an index representing “to what extent a musical piece resembles the entered melody history”. A predetermined number of musical pieces are picked up in order of decreasing accurate rate from among musical pieces having a high “accurate rate”, and K-list of picked-up musical pieces is prepared (step S705). Then, the process of preparing K-list of musical pieces finishes.
An example of the K-list of musical pieces prepared in the above manner is shown in
An example of the K-list of musical pieces is shown in
As shown in
The process of preparing K-list of musical pieces (shown in
When the musical pieces including the pitch series have been extracted (YES at step S704), CPU 21 calculates the “accurate rate” P of ST ratio of each of the extracted musical pieces (step S704). Using an ST value: STdb(i) of the i-th note of the extracted musical piece in the music database and an ST value: STin(i) of the i-th note of the entered melody, the “accurate rate” can be calculated from the following formula (1):
As shown in the formula (1), concerning ST value of each tone, an absolute difference between ST value given by data registered in the music database and ST value of the entered melody is divided by the ST value given by data registered in the music database, whereby a ratio is obtained and converted to percentage. An average of the ratios of the second to the latest tones among the entered tones is calculated, and then the calculated average is subtracted from 100 to obtain the “net accurate rate”.
More specifically, when the entered melody shown in
Then, the average of (10, 10, 0) will be about 6.7. [(10+10+0)/3≈6.7] This average is subtracted from 100 to obtain the “accurate rate”=93.3 points.
In the formula (1), the ST ratio of the first tone is not included in the calculation, because the ST ratio of the first tone is used as the reference and the ST ratio of the first tone will be 100% at all times. Therefore, the ST ratio of the first tone is excluded from the operation of the formula (1).
When the accurate rates of the musical pieces including the “pitch series” have been obtained, the musical pieces of the higher accurate rate are picked up in order of decreasing points to prepare K-list of musical pieces (step S705). In the example of the K-list of musical pieces shown in
Once the K-list of musical pieces has been completed (step S506 in
Meanwhile, when it is determined that the key (tonality) of the entered melody has been not established (NO step S505), CPU 21 prepares N-list of musical pieces at step S507. A process of preparing N-list of musical pieces is shown in
N-list of musical pieces is prepared upon comparison of the pitches of the entered melody history with the melody pitch data (data given on the top in the Note column) of each musical piece recorded in the music database (
CPU 21 obtains the melody pitch data of the entered melody history (
Then, CPU 21 compares the obtained pitch-series data of the entered melody with the melody pitch data (data on the top in the Note column) of each musical piece in the music database (
For example, in the case that the entered melody is “C D E” as described above, when the music database (
Then, CPU 21 judges whether any musical piece has been picked up at step S802 (step S803). When it is determined that no musical piece has been picked up (NO at step S803), CPU 21 finishes the process of preparing N-list of musical pieces.
Meanwhile, when it is determined that musical pieces have been picked up (YES at step S803), CPU 21 calculates ST ratio to the melody opening tone (first tone) of each tone of the entered melody history, and compares the calculated ST ratios of the entered melody history with “ST ratios to the opening tone” of the picked up musical pieces recorded the music database on a tone to tone basis to calculate the “accurate rate” of the picked up musical pieces (step S804). The specific method of calculating the “accurate rate” is similar to the method as described at step S704.
Referring to the “accurate rates” of the musical pieces calculated at step 804, CPU 21 picks up a predetermined number of musical pieces in order of decreasing accurate rate from among the musical pieces of the higher “accurate rate” to prepare N-list of musical pieces (step S805), finishing the process.
An example of the N-list of musical pieces prepared in the above manner is shown in
An example of the N-list of musical pieces is shown in
As shown in
When the melody (shown in
Since the musical pieces have been extracted (YES at step S803), CPU 21 calculates the accurate rate of ST ratio: P of each musical piece at step S804. The accurate rate is calculated using the formula (1) in the same manner as at step S704 in the process of preparing K-list of musical pieces.
Taking the music “Kites” of the music number 8 as an example, the calculation of the accurate rate will be described. Since a difference between ST ratio registered in the music database and the ST ratio of the second tone “D” is 0.67, 0.67 is divided by ST ratio registered in the music database (=0.33), whereby about “2” is obtained. (For convenience, 0.33=1/3, and 0.67=2/3.) The value “2” is converted to percentage to obtain “200”. Similarly, the percentage of the difference “200” of the third tone is calculated.
The average, (200+200)/2=200 is calculated, and this average is subtracted from 100, whereby the accurate rate −100 is obtained. (In drawings, a symbol “-” is denoted by ▴.)
When the accurate rate of each musical piece has been calculated, the musical pieces are picked up in order of decreasing the accurate rate to prepare N-list of musical pieces at step S805. An example of the N-list of musical pieces prepared in the above manner is shown in
Once the N-list of musical pieces has been completed (step S507 in
The D-list of musical pieces prepared in the process of
The N-list of musical pieces prepared in
CPU 21 refers to the data of the entered melody history (
For example, assuming that a melody of “F G A” is entered, an interval relationship “2” between the first tone “F” and the second tone “G” will be obtained, and further, an interval relationship “2” between the second tone “G” and the third tone “A” will be obtained.
Then, CPU 21 compares the obtained interval-data of the entered melody with the data of “intervals from the opening/preceding tone” (second line in the Note column) of each musical piece registered in the music database to find musical pieces which coincide in the interval difference with the entered melody (step S902).
The case that the melody of “F G A” is entered will be described as an example. The interval relationship of the entered melody is “2 2” from the first, and concerning the 9 musical pieces registered in the music database (shown in
In consideration of the effect of D-list of musical pieces, “even in the case where a melody which is transposed to a key different from the key registered in the music database, the musical pieces can be searched for through the music database”, the pitch of the opening tone of the entered melody will not be compared with the absolute pitches of the opening tones of musical pieces registered in the music database. When the melody of “F G A” is entered, the pitch “F” of the opening tone of the entered melody and the pitch “C” of the opening tone of each musical piece in the database are different, but in the process of preparing D-list of musical pieces, the pitches of both opening tones are not compared and even if the musical piece has the opening tone of the different pitch, such musical piece will be picked up.
As described above, when the melody of “F G A” is entered, the musical pieces starting with “C D E” will not be picked up in the process of preparing N-list of musical pieces (
Then, CPU 21 judges whether any musical piece has been picked at step S902 (step S903). When it is determined that no musical piece has been picked up (NO at step S903), CPU 21 finishes the process of preparing D-list of musical pieces.
When it is determined that musical pieces have been picked up (YES at step S903), CPU 21 calculates ST ratio to the melody opening tone (first tone) of each tone of the entered melody history, and compares the calculated ST ratios to the melody opening tone (first tone) of the entered melody history with “ST ratios to the opening tone” of each of the picked up musical pieces registered in the music database on a tone to tone basis to calculate the “accurate rate” of each musical piece (step S904). The specific method of calculating the “accurate rate” is similar to that described at step S704.
CPU 21 refers to the calculated “accurate rates” of the musical pieces, and picks up a predetermined number of musical pieces in order of decreasing accurate rate from among the picked up musical pieces to prepare D-list of musical pieces (step S905), finishing the process.
An example of the D-list of musical pieces prepared in the above manner is shown in
An example of the N-list of musical pieces is shown in
As shown in
As described above, when the melody of
When the entered melody described above is subjected to the process of preparing D-list of musical pieces (
In the process of preparing D-list of musical pieces (
For the entered melody of
When the musical pieces have been picked up at step S903 (YES at step S903), then CPU 21 calculates the accurate rate: P of ST ratios of each of the extracted musical pieces at step S904. The accurate rate: P is calculated using the formula (1) in a similar manner to the calculation in K-list of musical pieces at step S704 and in N-list of musical pieces at step S804.
When the accurate rate of each of the extracted musical pieces has been calculated, a predetermined number of musical pieces are selected in order of decreasing accurate rate from among the extracted musical pieces to prepare D-list of musical pieces. An example of the D-list of musical pieces prepared in the above manner is shown in
Once the D-list of musical pieces has been completed (step S508 in
In the process shown in
As the method of combining and putting the musical pieces in order is used a method of putting the musical pieces out of the musical pieces both in the N-list and the D-list in order of decreasing accurate rate of ST ratios calculated at step S804 and step 904.
Further, a method can be used, of putting the musical pieces out of both the N-list and the D-list in order of decreasing number of coincident tones, in the case that when the pitch series or the intervals is compared at step S802 or step 902, the tones of the musical pieces in the music database coincide with the entered melody history in the pitch series or the interval.
Furthermore, upon comprehensively evaluating the result of comparison of the pitch series or interval and the accurate rate of ST ratios, it is possible to use a method of combining the musical pieces of both the N-list and the D-list. In this case, for example, a method can be used, of putting the musical pieces in order of decreasing number of coincident tones among the musical pieces including tones which coincide either in the pitch series or in intervals with those of the entered melody history, and further ranking the musical pieces including even coincident tones in decreasing order of the accurate rate of ST ratios. On the contrary, a method of ranking the musical pieces in decreasing order of the accurate rate of ST ratios on a priority basis can be used, and further a method can be used, of giving a predetermined weights to evaluations of the pitch series and the intervals and summing the weighted evaluations of both items, and then ranking the musical pieces in order of decreasing weighted evaluation.
Once the general list of musical pieces has been created from the N-list of musical pieces and the D-list of musical pieces, CPU 21 searches for a redundant musical piece through the general list of musical pieces (step S1002). This is equivalent to operation of searching for a redundant musical piece through the N-list of musical pieces and the D-list of musical pieces.
When it is determined that a redundant musical piece has been found (YES at step S1002), CPU 21 deletes the redundant musical piece from the general list because such music piece can disturb the following process to be performed. If plural redundant musical pieces should be found, they will be all deleted.
An example of the general list of musical pieces produced from the N-list of musical pieces and the D-list of musical pieces is shown in
As described above, in the candidate music searching process shown in
When the candidate music searching process has finished (step S304 in
In the present embodiment of the invention, CPU 21 stores values in respective items of the diatonic register 2000 every time a melody tone is entered or every time a key is pressed. In the example shown in
In the present embodiment of the invention, CPU 21 stores values of the following items (to described later) of plural melody tones respectively in unit registers 2001 to 2005 of the diatonic register 2000. The unit registers 2001 to 2005 each have items such as a melody tone, duration, assumed key, assumed chord, assumed function, melody tone history, key candidate register and fixed key. The unit register has values stored respectively in these items. In the item of melody tone is stored the tone name of a pressed key. In the item of duration is stored a duration while the key is kept pressed. It is possible to store ST value in the item of duration in conformity with the music database.
When a key (tonality) has been finally fixed, CPU 21 stores the key name of the fixed key in the item of fixed key (for example, in the unit register 2005 in
In the item of melody-tone history are accumulated pitch names of pressed keys from the beginning of a performance or from a predetermined timing. For example, in the item of melody-tone history of the unit register 2001 is stored only “C” of the first pressed key, and in the item of melody-tone history of the unit register 2002 is stored the first pressed key “C” and the following pressed key “D”, in other words, two pressed keys “C” and “D” are stored. In the item of key candidate register is stored one possible key name or more at the time when the key is pressed.
To narrow down from the melody history data to a candidate key (tonality), CPU 21 refers to a diatonic scale table 2100 shown in
In the diatonic scale table 2100, 12 keys, C to B, have key scale notes stored in an easily-discernible manner. For example, for the key “C”, the note names C, D, E, F, G, A, B are stored in the diatonic scale table 2100 (refer to a reference numeral: 2101) and for the key “G”, the note names G, A, B, C, D, E, F♯ are stored therein (refer to a reference numeral: 2102).
CPU 21 compares the melody-tone history of
When the candidate keys (tonality) are limited to one, CPU 21 decides the candidate key as the fixed key (tonality). Meanwhile, when there are two candidate keys or more, CPU 21 selects the candidate key having the least number of key signatures among them as an assumed key and stored the assumed key in the item of assumed key in the unit register. In the case of even number of key signatures, for example in the case of F and G or D and B ♭, a key in major will be selected as the assumed key in priority.
When the key (tonality) judging process has finished as described above (step S305 in
The automatic chord judging process is performed to automatically decide chords which are to be played to the current melody tones, based on the melody tones which have been entered until now. There are various methods of deciding such chords.
For example, using an assumed-chord determining map 2200 shown in
In particular, in the case where a key (tonality) has not yet been established, using this method it is possible to determine chords based on chord database shown in
For example, CPU 21 selects a predetermined number of tones in decreasing order of duration from among tones in a predetermined duration of melody history. It can be previously determined that the predetermined duration of melody history is a melody history consisting of predetermined number of measures or a melody history containing a predetermined number of tones.
CPU 21 compares the predetermined number of tones selected in decreasing order of duration with the chord database 2300 to judge whether any chord is found in the chord database 2300, which chord consists of the chord composing tones including the predetermined number of tones. When it is determined that such chord is found in the chord database 2300, CPU 21 determines that said chord is to be played to the current melody. When it is determined that no chord is found, CPU 21 decreases the number of tones to be selected and refers to the chord database again, and tries to determine a chord again.
Using a chord judging table 2400 shown in
The functions of the chords are tonic (TO), subdominant (SU), and dominant (DO) in Music Theory. The previous chord functions are indicated in the leftmost column of the table shown in
In the chord judging table 2400 shown in
Further, using other methods in the public domain, it is possible to perform the key (tonality) judging process of step 305 and the automatic chord judging process of step S306 in
When the automatic chord judging process has finished as described above (step S306 in
The chord selecting process of
CPU 21 judges whether the general list contains a musical piece including the coincident pitch/interval series of a predetermined number of tones or more (for instance, 10 tones) of (step S1101 in
When no music piece including the coincident pitch/interval series of a predetermined number of tones or more has been located in the general list (NO at step S1101), CPU 21 outputs a chord decided to be played in real time (step S1104), finishing the present chord selecting process. When the musical piece is not located in the F-list of musical pieces, K-list of musical pieces and N-list•D-list of musical pieces at all, and has not been picked up in the general list, it is determined NO at step 1101 and CPU 21 outputs a chord determined to be played in real time at step S1104.
Meanwhile, when music pieces including the coincident pitch/interval series of a predetermined number of tones or more have been located in the general list (YES at step S1101), CPU judges whether the musical pieces which match in sound generating timing 80% or more are included in the located musical pieces (step S1102). More specifically, it is judged at step S1102 whether musical pieces of the “accurate rate” of 80% or more are located in the general list. As described above, the “accurate rate” of 80% or more is an evaluation value concerning a sound-generation timing, decided upon comparison of “ST ratios to the opening tone” between the music database and the entered melody history. Therefore, selecting the musical pieces of a predetermined “accurate rate” or more, it will be possible to determine that the user is now playing the same musical piece as the musical piece registered in the music database and it will make no trouble to select the progression of chords from the music database to play chords for the automatic accompaniment. The “accurate rate” of 80% or more can be changed as needed. It is possible to provide a button (not shown) concerning a “leaning level” and to change the reference for judgment according to the leaning level.
When it is determined that no musical piece which matched in sound generating timing 80% or more is found (NO at step S1102), CPU 21 outputs the chord decided to be played in real time (step 1104), finishing the chord selecting process.
Meanwhile, when it is determined that a musical piece which matched in sound generating timing 80% or more is found (YES at step S1102), CPU 21 refers to the music database (
When the chord decided to be played in the automatic chord judging process (chord decided to be played in real time) match with the chord read from the music database of the applicable musical piece (YES at step S1103), CPU 21 outputs the chord decided to be played in real time (step S1104), finishing the chord selecting process.
Meanwhile, when the chord decided to be played in the automatic chord judging process (chord decided to be played in real time) do not match with the chord read from the music database of the applicable musical piece (NO at step S1103), CPU 21 outputs the chord read from the music database of the applicable musical piece (step S1105), finishing the chord selecting process.
When the chord selecting process has finished as described above (step S307 in
The automatic accompaniment process will be described with reference to a flow chart of
The automatic accompaniment data contains data of musical tones such as melody tones (including obbligato tones), chord tones, and rhythm tones. The data of melody tones and data of chord tones contain a pitch, a generation timing and a duration of each musical tone to be generated. The data of rhythm tones contains a generation timing of each musical tone (rhythm tone) to be generated.
When it is determined YES at step S2502, CPU 21 performs a melody-tone generating/ceasing process (step S2503). In the melody-tone generating/ceasing process, CPU 21 judges whether the event to be processed is a note-on event. When the current time has substantially reached a generation timing of a predetermined tone in the data of melody tones, then it can be determined that the event is a note-on event. Meanwhile, when the current time has substantially reached a time when a duration of a predetermined tone lapsed after the generation timing of the tone in the data of melody tones, then it can be determined that the event is a note-off event.
When the event to be processed is a note-off event, CPU 21 performs a tone ceasing process. Meanwhile, when the event to be processed is a note-on event, CPU 21 performs a tone generating process in accordance with data of melody tones.
Then, CPU 21 refers to the timer (not shown) to judge whether the current time has reached the timing of performing an event of the data of chord tones in the automatic accompaniment data (step S2504). When it is determined YES at step S2504, CPU 21 performs a chord-tone generating/ceasing process (step S2505). In the chord-tone generating/ceasing process, CPU 21 performs a tone generating process of the chord tone, a generation timing of which the current time has reached. Meanwhile, CPU 21 performs a tone ceasing process of the chord tone, a ceasing timing of which the current time has reached.
CPU 21 judges whether the current time has reached a timing of performing an event of the rhythm data in the automatic accompaniment data (step S2506). When it is determined YES at step S2506, CPU 21 performs a rhythm-tone generating process at step S2507. In the rhythm-tone generating process, CPU 21 produces note-on event of a rhythm tone, a generation timing of which the current time has reached.
When the automatic accompaniment process has finished (step S308 in
When the sound-source sound generating process has finished at step S309, CPU 21 performs other processes, such as displaying an image on the displaying unit 15 and turning on/off LED (not shown) at step S310, and returns to step S302.
As described above, in the present embodiment of the invention, the electronic musical instrument for automatically performing accompaniment along with a melody played by a performer is provided with the music data base, and refers to the music database to compare the melody played by the performer with the music pieces recorded in the music database. When music pieces which coincide in some conditions with the melody played by the performer are located in the music database, the chords of such music pieces are read from the music database, whereby an accompaniment is played along with the melody played by the performer.
In the manner described above, it is possible not only to determine chords to be played when the accompaniment is automatically performed in real time along with the melody played by the performer, but also to read the chords appropriate for the melody from the music database, thereby enhancing accuracy in automatically playing the chords to the melody.
In the present embodiment of the invention, in the process of comparing the entered melody with the music database, when the key (tonality) has not yet been established, the N-list of musical pieces is prepared to be used for comparing the pitches of musical tones, and the D-list of musical pieces is also prepared to be use for comparing the intervals to the preceding tones, whereby even if a melody should be played in a key other than the registered keys in the music database, the melody can be compared with the music database. Therefore, even though the performer should play a melody in a key different from the keys registered in the music database, appropriate chords will be played with effective use of the music database.
Further, in the present embodiment of the invention, ST ratio to the opening tone of each melody tone of the melody is registered in the music database. ST ratios to the opening tone of melody tones of the played melody are obtained and compared with ST ratios registered in the music database to calculate the accurate rate of the music pieces. Music pieces are selected in priority in order of decreasing accurate rate from among the musical pieces stored in the music database. Therefore, a flexible system can be constructed, which can extract musical pieces from the music database as far as the musical pieces have coincident features, even if the melody should have been played a little out of the tone generating timing.
The automatic chord judging process is performed in parallel with the process of searching through the music database, and the chords are played in accordance with result of performing the automatic chord judging process, in the case where an appropriate musical piece could not be found in the process of searching through the music database. The appropriate chords are found by two methods: the method of automatically judging chords; and the method of searching for chords through the music database. Therefore, when the appropriate music piece is registered in the music database, the correct chords are determined based on the music database and played immediately. When the appropriate music piece is not registered in the music database or is not distinguishable, chords will be found and played in the automatic chord judging process. As described above, in the present embodiment of the invention, correct chords can be found and automatically played in any event.
Now, the second embodiment of the invention will be described. In the second embodiment of the invention, CPU 21 performs a chord selecting process shown in
In the chord selecting process shown in
In the process at step S2603, CPU 21 compares “functional harmonies” between the chord decided to be played or added to the performed melody in the automatic chord judging process at step S306 and the chord played or added to the melody of musical pieces performed currently, which musical pieces are found in the music database at step S1101 and decided at step S1102 that they satisfy the conditions.
More specifically, as the above “functional harmonies” of the chords in the music database, information of the “functional harmony” added to each melody tone in the music database shown in
For the functional harmonies of chords to be played or provided to the melody performed currently, it is possible to use the functions of the assumed chords stored in the item of assumed function, which was described in relation to the key (tonality) judging process (step S305). It is possible to judge the functions (assumed functions) of chords to be played or added to the melody performed currently, by comparing information of the assumed key or the established key, described in relation to the step S305, with information of the chord added to the melody performed currently.
More specifically, concerning various sorts of chords and functional harmonies of the chords, a table according to the known music theory is prepared. Referring to this table, the functional harmonies of the chords will be obtained. For example, the following chord names for the tonic will be listed as follows: “I Maj”, “I M7”, “III min”, “III m7”, “VI min”, and “VI m7”. The chord names for the subdominant are “II min”, “II m7”, “II m7(−5)”, “IV Maj”, “IV M7”, “IV min”, and “IV mM7”. The chord names for the dominant are “III Maj”, “III7”, “III 7sus4”, “V Maj”, “V 7”, “V 7sus4” and “VII m7(−5)”.
At step S2603, CPU 21 compares the “functional harmonies” between the chord decided to be played to the performed melody in the automatic chord judging process (step S306) and the chord played or added to the melody of musical pieces performed currently, which musical pieces are found in the music database at step S1101 and decided at step S1102 that they coincide with the conditions.
When it is determined that the “functional harmonies” of the both chords share common functions (YES at step S2603), CPU 21 outputs the chord decided to be played or added to the melody performed in real time in the automatic chord judging process (step S1104). Meanwhile, when it is determined that the “functional harmonies” of the both chords do not share common functions (NO at step S2603), CPU 21 reads the chord of the music piece from the music database to output said chord (step S1105).
In the second embodiment of the invention, when the “functional harmonies” of the chords decided to be played or added to the played melody in real time and the “functional harmonies” of the chords read from the music database share common functions, CPU 21 chooses and outputs the chords decided to be played or added to the melody in real time with full respect for them, from among a wide variety of chords sharing the common functions. Meanwhile, when the “functional harmonies” of the chords decided to be played or added to the played melody in real time and the “functional harmonies” of the chords read from the music database do not share common functions, CPU 21 can output the chords read from the music database in order to prevent the chords decided to be played or added in real time from providing functionally impossible harmony. According to the second embodiment of the invention, using both the method of selecting chords from the music database and the method of playing chords decided in real time, it will be possible to select chords from among a variety of chords sharing common function to output the selected chords with full respect for the chords decided to be plated or added to a melody in real time, with decreasing possibility of outputting almost impossible chords.
Although specific embodiments of the invention have been described in the foregoing detailed description, it will be understood that the invention is not limited to the particular embodiments described herein, modifications and rearrangements may be made to the disclosed embodiments while remaining within the scope of the invention as defined by the following claims. It is intended to include all such modifications and rearrangements in the following claims and their equivalents.
The methods described in the embodiments of the present invention can be written as a computer executable program onto recording media, such as magnetic disks (floppy disks, hard-disk drives, etc.), optical disks (CD-ROMs, DVDs, etc.), and semi-conductor memories. The recording media are distributed and installed on various devices. Also, the methods can be transferred through communication media to various devices. A computer for realizing the present instrument reads the program from the recording medium, and operates under control of the program to perform the processes.
In the description, the various processes or steps included in the program written on the recording media are performed in a time-serial order, but are not always required to be performed in the time-serial order and can be performed in parallel or separately from each other.
In the description, terms concerning the system mean a whole apparatus consisting of plural apparatuses and plural methods.
Some of processes shown in
According to the invention described above, since it is possible to creatively use the following two methods to play the chords: the method of automatically playing the chords based on the melody history; and the method of playing the chords in accordance with the music database, more preferable chords can promptly be provided with high accuracy.
In other words, when no appropriate musical piece has been found among the musical pieces registered in the music database, the chords are played to the melody performed by the performer by the method of automatically playing the chords. Therefore, even though the appropriate musical piece has not been found in the music database, a situation can be avoided, where the performer plays a melody with no automatic accompaniment played together.
Meanwhile, when the appropriate musical piece has been found among the musical pieces registered in the music database, using the chords registered in the music database, an accompaniment is automatically played together with the melody performed by the performer. Therefore, when the chords are automatically determined, a situation can be avoided, where chords which are apparently and aurally impossible are played.
According to the invention described above, when an appropriate musical piece has been found among the musical pieces registered in the music database, the “functional harmonies” of the chords output by the method of automatically playing the chords based on the melody history and the “functional harmonies” of the chords output by the method of playing the chords in accordance with the music database are compared to chose the chords to use. Therefore, it is possible to prevent causing an outstanding trouble that the method of automatically providing the chords provides the chords which are impossible and greatly different in functional harmony from the chords recorded in the music database.
Further, when the “functional harmonies” of the chords output by the method of automatically providing the chords based on the melody history and the “functional harmonies” of the chords output by the method of providing the chords in accordance with the music database are compared, and both the “functional harmonies” of the chords are substantially the same, upon confirming that the chords output by the method of automatically providing the chords by no means provide impossible functions, it is possible to chose the chords using an algorithm of the automatically providing the chords with full respect for the algorithm, whereby accompaniment can be performed using more appropriate chords.
Number | Date | Country | Kind |
---|---|---|---|
2013-051160 | Mar 2013 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
4966052 | Shiraki et al. | Oct 1990 | A |
7297859 | Ueki et al. | Nov 2007 | B2 |
8008568 | Kobayashi | Aug 2011 | B2 |
8314320 | Okuda | Nov 2012 | B2 |
20080028919 | Ueki et al. | Feb 2008 | A1 |
20130305907 | Kakishita | Nov 2013 | A1 |
20140238220 | Nakamura | Aug 2014 | A1 |
Number | Date | Country |
---|---|---|
2011-158855 | Aug 2011 | JP |
Number | Date | Country | |
---|---|---|---|
20140260915 A1 | Sep 2014 | US |