This application is based upon and claims the benefit of priority from the prior Japanese Patent Application No. 2014-235233, filed on Nov. 20, 2014, and the entire contents of which are incorporated herein by reference.
1. Field of the Invention
The present invention relates to an automatic composition apparatus, an automatic composition method and a storage medium.
2. Description of the Related Art
There is known a technology for automatically compose music based on a motif melody consisting of a plurality of note data items. In the related art, for example, the following technology is known (for example, a technology disclosed in JP-A-2002-032080). If a certain chord progression is selected from a database retaining chord progressions of a specific key, and a motif is input in a certain key, a motif key is detected from the input motif. Based on the detected motif key, data on the chord progression is transposed into the motif key. Then, in a melody generating block, based on the input motif and the chord progression after the transposition into the motif key, a melody is generated in the motif key. Also, the motif is transposed into the specific key based on the detected motif key, and a melody of the specific key is generated based on the chord progression of the specific key and the transposed motif, and then is transposed into a melody of the motif key.
Also, in the related art, the following technology is known (for example, a technology disclosed in JP-A-H10-105169). Notes having lengths equal to or greater than that of a quarter note are extracted from musical performance data for karaoke and guide melody data which are music data, and the distributions of frequencies of the pitch names (C to B) of the extracted notes are aggregated. The frequency distributions are compared to a major judgment scale and a minor judgment scale. Then, the data is judged to have a key in which the tonic note (scale note) exists at a place where the highest coincidence in distribution shape is attained. Subsequently, based on the result of the key judgment and the guide melody data, harmony data is generated. Then, based on the harmony data, a harmony voice signal is produced.
However, in the above described technologies according to the related art, it is implicitly assumed that a motif melody can be specified in a certain key. For this reason, it is impossible to handle modulation in a motif, mode-like melodies, atonal motifs, and the like. Also, since the key judgment is a method based on the distribution of pitches, sometimes, an accurate correspondence relation may not be obtained. For example, “re, do, si, la, and sol” and “sol, re, la, si, and do” have the same pitch distribution, but should be considered as G major and C major, respectively.
An object of the present invention is to make it possible to select an appropriate chord progression data item, thereby generating natural music.
According to an aspect, an automatic composition apparatus includes a processing unit. The processing unit performs (i) a calculation process of calculating a matching level of each chord progression data item for a motif including a plurality of note data items, with reference to a plurality of note connection rules each of which defines a connection relation of consecutive note types, and (ii) a melody generating process of generating a melody based on the motif and the chord progression data items which matching levels are calculated.
Hereinafter, an embodiment of the present invention will be described in detail with reference to the accompanying drawings.
The motif input unit 101 receives any one of characteristic melody parts to define a tune, such as an A melody, a B melody, and a C melody (a refrain melody), as an input motif 108, from a user. The input motif 108 is any one of a motif A which is the motif of an A melody, a motif B which is the motif of a B melody, and a motif C which is the motif of a C melody, and has, for example, the length of two measures of the beginning of each melody part. The motif input unit 101 includes, for example, one or more means of a keyboard input unit 101-1 for receiving a melody through a keyboard from the user, a voice input unit 101-2 for receiving a melody which the user sings, through a microphone, and a note input unit 101-3 for receiving data on notes constituting a melody through a keyboard or the like from the user. Also, the input unit 101 includes independent operation units for receiving motif types such as “A MELODY”, “B MELODY”, “C MELODY (REFRAIN MELODY)”, and so on.
With respect to each of a plurality of chord progression data items retained in the accompaniment/chord-progression DB 103, the chord-progression selecting unit 102 calculates the matching level representing how much the corresponding chord progression data item is suitable for the input motif 108 input from the motif input unit 101 while referring to the rule DB 104, and outputs, for example, Nos. 0, 1, and 2 chord progression candidate indication data items (each of which is referred to as “CHORD PROGRESSION CANDIDATE” in
The melody generating unit 105 prompts, for example, the user to select one of three chord progression candidates corresponding to Nos. 0, 1, and 2 chord progression candidate indication data items 109 output from the chord-progression selecting unit 102. Alternatively, the melody generating unit 105 may automatically select a chord progression candidate corresponding to any one of Nos. 0, 1, and 2 chord progression candidate indication data items 109, in turns. As a result, the melody generating unit 105 reads a music structure data item corresponding to the selected chord progression candidate, from the accompaniment/chord-progression DB 103. With respect to each of the phrases of measures represented by the read music structure data item, the melody generating unit 105 automatically generates a melody of the corresponding phrase with reference to the input motif 108, phrase sets registered in the phrase set DB 106, and the rule DB 104. The melody generating unit 105 performs an automatic melody generation process with respect to every measure of the whole music, and outputs the automatically generated melody data 110.
The output unit 107 includes a score display unit 107-1 which displays a melody score based on the melody data 110 automatically generated by the melody generating unit 105, and a musical-sound reproducing unit 107-2 which performs reproducing of a melody and accompaniment based on the melody data 110 and MIDI (Musical Instrument Digital Interface) data for accompaniment acquired from the accompaniment/chord-progression DB 103.
Subsequently, the outline of an operation of the automatic composition apparatus 100 having the functional configuration of
In the present embodiment, the user can input, for example, the melody of two measures of the beginning of, for example, an A melody appearing for the first time in a piece of music, as a motif A (which is an example of the input motif 108 of
With respect to this input, the chord-progression selecting unit 102 (see
The melody generating unit 105 of
In one record, the chord progression data item represents a chord progression corresponding to a melody of a piece of music. The chord progression DB shown in
The music structure data item of one record (corresponding to one piece of music) of the accompaniment/chord-progression DB 103 shown in
In the music structure data item shown in
In the music structure data item shown in
Also, in the music structure data item shown in
Also, in the music structure data item shown in
The music structure data item shown in
As described above with reference to
With respect to each of the chord progression data items (hereinafter, referred to as evaluation target chord progression data items) retained in the accompaniment/chord-progression DB 103, the chord-progression selecting unit 102 calculates the matching level representing how much the corresponding evaluation target chord progression data item is suitable for the input motif 108 input from the motif input unit 101.
In the present embodiment, the chord-progression selecting unit calculates the matching level of each evaluation target chord progression data item for the input motif 108, using the available note scale concept of music theory. An available note scale represents notes available for melodies, as a scale, in a case where chord progressions are given. Examples of the types of notes (hereinafter, referred to as “note types”) constituting an available note scale include “CHORD TONE”, “AVAILABLE NOTE”, “SCALE NOTE”, “TENSION NOTE”, and “AVOID NOTE”. A chord tone is a chord constituent note which becomes a scale source, and is a note type in which it is preferable to use one note as a melody. An available note is a note type which is generally usable in melodies. A scale note is a scale constituent note and is a note type which needs to be carefully handled because if the corresponding note is applied as a long sound or the like, it clashes with an original chord sound. A tension note is a note which is superimposed on a chord sound and is used as a tension of a chord, and is a note type in which a tension increases, a feeling of tension of a sound or a sound becomes richer. An avoid note is a note which is not harmonic with a chord, and is a note type in which it is preferable to avoid use of the corresponding note or to use the corresponding note as a short note. In the present embodiment, with respect to each note (each note of
In order to obtain the note type of each note (each note of
In the table of
The pitch class set (hereinafter, referred to as the “chord tone pitch class set”) corresponding to each row of the chord tone table of
With respect to each note (hereinafter, referred to as a “current note”) constituting the input motif 108, the chord-progression selecting unit 102 of
Each pitch class set (hereinafter, referred to as a “tension note pitch class set”) corresponding to one row of the tension note table of
The chord-progression selecting unit 102 of
Each pitch class set (hereinafter, referred to as a “scale note pitch class set”) corresponding to one row of the scale note table of
The chord-progression selecting unit 102 of
In the above described way, the chord-progression selecting unit 102 determines whether any chord tone is included in the chord constituent notes of the chord tone pitch class set corresponding to the chord type described in the chord progression data item which is the evaluation target corresponding to the sound production timing of the current note of the input motif 108. Also, the chord-progression selecting unit 102 determines whether any chord tone is included in the tension notes of the tension note pitch class set of the tension note table exemplified in
Part (a) of
Subsequently, with respect to each of the pitches of the individual notes of the input motif 108, the chord-progression selecting unit 102 calculates semitones (hereinafter, referred to as adjacent tones) between the corresponding pitch and an adjacent pitch. Adjacent tones of Part (b) of
With respect to each chord progression data item which is an evaluation target, the chord-progression selecting unit 102 generates an array variable data item (which is hereinafter denoted by “incon[i]” wherein “i” is an array number) alternately containing note types and adjacent tones calculated as described. Part (c) of
Subsequently, with respect to an array variable data item incon[i] (wherein, “i” is 0, 1, 2, 3 . . . ) containing the note types of the individual notes of the input motif 108 and the adjacent tones calculated in the above described way for a chord progression data item which is a current evaluation target, the chord-progression selecting unit 102 performs a note-connectivity checking process of evaluating a rule of combination of note types and adjacent tones (hereinafter, this rule will be referred to as the note connection rule), sequentially from the array number “0”, for example, for every four sets. In this note-connectivity checking process, the chord-progression selecting unit 102 refers to note connection rules retained in the rule DB 104 of
As note connection rules having the above described data configuration, eighteen rules having j values 0 to 17 as exemplified in
The chord-progression selecting unit 102 performs the note-connectivity checking process using the note connection rules having the above described configuration. Sequentially from the beginning note of the input motif 108 corresponding to two measures and exemplified in
For example, in a case of i=0 shown in
First, in the note connection rule having a j value “0” and exemplified in
Subsequently, in the note connection rule having the j value “1” and exemplified in
Subsequently, in the note connection rule having the j value “2” and exemplified in
If a note connection rule is seen in the above described way, with respect to the subsequent note connection rules of the corresponding note connection rule, evaluation on the set of the note types and the adjacent tones of the first, second, third, and fourth notes of the input motif 108 in the case of i=0 in
If evaluation on the set of the note types and the adjacent tones of the first, second, third, and fourth notes of the input motif 108 in the case of i=0 shown in
If evaluation on the set of the note types and the adjacent tones of the second, third, fourth, and fifth notes of the input motif 108 in the case of i=1 shown in
Thereafter, the same process is performed up to evaluation on the set of the note types and the adjacent tones of the eighth, ninth, and tenth notes of the input motif 108 in a case of i=7 shown in
If the evaluating process on each note of the input motif 108 corresponding to No. 0 chord progression data item which is an evaluation target and is shown in
For example, in a case where a chord progression data item which is an evaluation target is No. 1 or 2 chord progression exemplified in
The chord-progression selecting unit 102 of
Subsequently, the outline of an operation of the melody generating unit 105 of
A phrase set data item corresponding to one record is composed of a plurality of phrase data items, that is, an A melody data item, a B melody data item, a C melody (refrain melody) data item, a first ending data item, and a second ending data item, as shown in
Each of the phrase data items of
If a chord progression candidate is selected from three chord progression candidates corresponding to Nos. 0, 1, and 2 chord progression candidate indication data items 109 output from the chord-progression selecting unit 102 by user's designation or having the highest matching level, the melody generating unit 105 of
In this case, the melody generating unit 105 determines whether the phrase of a measure represented by the music structure data item is a phrase of the input motif 108. In a case where the phase of the measure is the phrase of the input motif 108, the melody generating unit intactly outputs the melody of the input motif 108 as a part of the melody data 110.
In a case where the phrase of the measure represented by the music structure data item is not a phrase of the input motif 108 and is not the beginning phrase of the refrain melody, if a melody for the corresponding phrase has not been generated yet, the melody generating unit 105 extracts a phrase set corresponding to the input motif 108 from the phrase set DB 106, and copies the melody of a corresponding phrase included in the extracted phrase set. Meanwhile, if a melody for the corresponding phase has been generated, the melody generating unit copies the melody from the corresponding phase whose melody has been generated. Thereafter, the melody generating unit 105 performs a melody modifying process (to be described below) of modifying the copied melody, and a melody optimizing process (to be described below) of optimizing the pitch of each note constituting the modified melody, thereby automatically generating the melody of the phrase of the measure represented by the music structure data item, and outputs the generated melody as a part of the melody data 110. Details of the process of copying the melody from the phase having been already generated will be described with respect to a description of
In a case where the phrase of the measure represented by the music structure data item is the beginning phrase of the refrain melody, if a beginning phrase for the corresponding refrain melody has not been generated, the melody generating unit 105 extracts a phrase set corresponding to the input motif 108 from the phrase set DB 106, and copies the melody of the beginning phrase of a corresponding refrain melody (C melody) included in the extracted phrase set, and performs the melody optimizing process of optimizing the pitch of each note constituting the copied melody, thereby automatically generating the melody of the beginning phrase of the refrain melody, and outputs the generated melody as a part of the melody data 110. Meanwhile, if the beginning phrase of the corresponding refrain melody has been generated, the melody generating unit copies a melody from the phrase having been generated, and outputs the copied melody as a part of the melody data 110.
The configuration and operation of the automatic composition apparatus 100 described above will be described in more detail below.
The CPU 1401 executes an automatic-music-composition control program stored in the ROM 1402 while using the RAM 1403 as a work memory, thereby performing a control operation corresponding to each of the functional parts 101 to 107 of
In the ROM 1402, besides the above described automatic-music-composition control program, the accompaniment/chord-progression DB 103 (see
The RAM 1403 temporarily stores the input motif 108 (see
The input unit 1404 corresponds to the function of a part of the motif input unit 101 of
The display unit 1405 implements the function of the score display unit 107-1 of the output unit 107 of
The sound source unit 1406 implements the function of the musical-sound reproducing unit 107-2 of
First, in STEP S1601, the CPU 1401 performs initialization on the RAM 1403 and the sound source unit 1406. Thereafter, the CPU 1401 repeatedly performs a series of processes of STEPS S1602 to S1608.
In this repetitive process, first, in STEP S1602, the CPU 1401 determines whether the user has instructed finishing of the automatic composition process by pressing a power switch (not specifically shown). If finishing has not been instructed (“NO” in the determination of STEP S1602), the CPU 1401 continues the repeating process. Meanwhile, if finishing has been instructed (“YES” in the determination of STEP S1602), the CPU 1401 finishes the automatic composition process exemplified in the flow chart of
In the case where the result of the determination of STEP S1602 is “NO”, in STEP S1603, the CPU 1401 determines whether the user has instructed motif input from the input unit 1404. In a case where the user has instructed motif input (a case where the result of the determination of STEP S1603 is “YES”), in STEP S1606, the CPU 1401 receives motif input of the user from the input unit 1404, and stores the input motif 108 input from the input unit 1404, for example, in the data format of
In a case where the user has not instructed motif input (a case where the result of the determination of STEP S1603 is “NO”), in STEP S1604, the CPU 1401 determines whether the user has instructed automatic composition by a switch (not specifically shown). In a case where the user has instructed automatic composition (a case where the result of the determination of STEP S1604 is “YES”), the CPU 1401 performs a chord-progression selecting process in STEP S1607, and subsequently performs a melody generating process in STEP S1608. The chord-progression selecting process of STEP S1607 implements the function of the chord-progression selecting unit 102 of
In a case where the user has not instructed automatic composition (a case where the result of the determination of STEP S1604 is “NO”), in STEP S1605, the CPU 1401 determines whether the user has instructed reproducing of the automatically composed melody data 110 by a switch (not specifically shown). In a case where the user has instructed reproducing of the melody data 110 (a case where the result of the determination of STEP S1605 is “YES”), the CPU 1401 performs a reproducing process in STEP S1609. This process is the same as the operations of the note input unit 101-3 and the musical-sound reproducing unit 107-2 of the output unit 107 of
In the case where the user has not instructed automatic composition (the case where the result of the determination of STEP S1604 is “NO”), the CPU 1401 returns to the process of STEP S1602.
First, in STEP S1701, the CPU 1401 initializes the variable data items and the array variable data items on the RAM 1403.
Subsequently, the CPU 1401 initializes a variable “n” on the RAM 1403 for controlling a repetitive process on the plurality of chord progression data items retained in the accompaniment/chord-progression DB 103, to “0”. Thereafter, while incrementing the value of the variable “n”, +1 by +1, the CPU performs a series of processes of STEPS S1704 to S1713, as long as it is determined in STEP S1703 that the value of the variable “n” is smaller than the value of a constant data item MAX_CHORD_PROG retained in the ROM 1402. The value of the constant data item MAX_CHORD_PROG is a constant data item representing the number of chord progression data items retained in the accompaniment/chord-progression DB 103. The CPU 1401 repeatedly performs the series of processes of STEPS S1704 to S1713, the same number of times as the number of records of the accompaniment/chord-progression DB 103 shown in
In the repetitive process of STEPS S1703 to S1713, first, in STEP S1703, the CPU 1401 determines whether the value of the variable “n” is smaller than the value of the constant data item MAX_CHORD_PROG.
If the result of the determination of STEP S1703 is “YES”, in STEP S1704, the CPU 1401 loads No. n chord progression data item (see
Subsequently, in STEP S1705, the CPU 1401 determines whether a value which represents the music genre of No. n chord progression data item and has been loaded from the accompaniment/chord-progression DB 103 into an array variable data element iChordAttribute[n][0] for No. n chord progression data item in the RAM 1403 is equal to a value which the user has set in advance by a switch (not specifically shown) and is retained in a variable data item iJunleSelect in the RAM 1403 and represents a music genre. If the result of the determination of STEP S1705 is “NO”, since No. n chord progression data item is not suitable for the music genre which the user desires, the CPU 1401 does not select No. n chord progression data item, and proceeds to STEP S1714.
If the result of the determination of STEP S1705 is “YES”, in STEP S1706, the CPU 1401 determines whether a value which represents the concept of No. n chord progression data item and has been loaded from the accompaniment/chord-progression DB 103 into an array variable data element iChordAttribute[n][1] for No. n chord progression data item in the RAM 1403 is equal to a value which the user has set in advance by a switch (not specifically shown) and is retained in a variable data item iConnceptSelect in the RAM 1403 and represents a music concept. If the result of the determination of STEP S1706 is “NO”, since No. n chord progression data item is not suitable for the music concept which the user desires, the CPU 1401 does not select No. n chord progression data item, and proceeds to STEP S1714.
If the result of the determination of STEP S1706 is “YES”, in STEP S1707, the CPU 1401 performs a chord-design-data generating process. In this process, the CPU 1401 performs a process of storing chord progression information, sequentially designated according to No. n chord progression data item with time, in a chord design data item [k] (to be described below) which is an array variable data item retained in the RAM 1403.
Subsequently, in STEP S1708, the CPU 1401 stores an initial value “0” in a variable data item iKeyShift retained in the RAM 1403. This variable data item iKeyShift designates a key shift value in semitone units for No. n chord progression data item, in a range from the initial value “0” to a value smaller than a constant data item PITCH_CLASS_N retained in the ROM 1402 by 1, in a chromatic scale of one octave. The value of the constant data item PITCH_CLASS_N is generally 12 which is the number of semitones in one octave.
Subsequently, in STEP S1709, the CPU 1401 determines whether the value of the constant data item iKeyShift is smaller than the value of the constant data item PITCH_CLASS_N.
If the result of the determination of STEP S1709 is “YES”, in STEP S1710, the CPU 1401 shifts the key of No. n chord progression data item by the key shift value represented by the variable data item iKeyShift, and then performs a process of checking the matching level on the input motif 108 and No. n chord progression. By this process, the matching level of No. n chord progression for the input motif 108 is obtained in a variable data item doValue retained in the RAM 1403.
Subsequently, in STEP S1711, the CPU 1401 determines whether the value of the variable data item doValue is larger than the value of a variable data item doMaxValue retained in the RAM 1403. The variable data item doMaxValue is a variable for storing the value of the highest matching level at that moment, and is initialized to a value “0” in STEP S1701.
If the result of the determination of STEP S1711 is “YES”, the CPU 1401 replaces the value of the variable data item doMaxValue with the value of the variable data item doValue. Also, the CPU 1401 stores the current value of the variable data item iKeyShift in an array variable data item iBestKeyShift[iBestUpdate] retained in the RAM 1403. Further, the CPU 1401 stores the current value of the variable data item n representing a chord progression data item retained in the accompaniment/chord-progression DB 103, in an array variable data item iBestChordProg[iBestUpdate] retained in the RAM 1403. Thereafter, the CPU 1401 increments a variable data item iBestUpdate retained in the RAM 1403, by +1 (these processes are performed in STEP S1712). The variable data item iBestUpdate is a data item which is initialized to a value “0” in STEP S1701, and is incremented whenever a chord progression data item having the highest matching level at that moment is found. As the value of the variable data item iBestUpdate increases, the matching level becomes higher. The array variable data item iBestKeyShift[iBestUpdate] holds a key shift value corresponding to a ranking represented by the variable data item iBestUpdate. The array variable data item iBestChordProg[iBestUpdate] holds the number of a chord progression corresponding to the ranking represented by the variable data item iBestUpdate and retained in the accompaniment/chord-progression DB 103.
If the result of the determination of STEP S1711 is “NO”, in this time, the CPU 1401 does not select No. n chord progression data item as a chord progression data item for automatic composition relative to the input motif 108 by skipping the process of STEP S1712 described above.
Thereafter, in STEP S1713, the CPU 1401 increments the value of the variable data item iKeyShift by +1. Then, the CPU 1401 returns to the process of STEP S1709.
After the CPU 1401 repeatedly performs the processes of STEPS S1709 to S1713 while incrementing the value of the variable data item iKeyShift, if key shift value designation corresponding to one octave finishes, whereby the result of the determination of STEP S1709 becomes “NO”, the CPU advances the process to STEP S1714. In STEP S1714, the CPU 1401 increments the variable data item n for selecting a chord progression data item retained in the accompaniment/chord-progression DB 103, by +1. Thereafter, the CPU 1401 returns to the process of STEP S1703.
After the CPU 1401 repeatedly performs the series of the processes of STEPS S1703 to S1714 while incrementing the value of the variable data item n, if the process on every chord progression data item retained in the accompaniment/chord-progression DB 103 finishes, whereby the result of the determination of STEP S1703 becomes “NO”, the CPU finishes the process of the flow chart of
First, in STEP S1801, the CPU 1401 sets a variable data item iCDesignCnt representing the number of a chord progression information item, to an initial value “0”.
Subsequently, in STEP S1802, the CPU 1401 stores a pointer to the first meta-event (corresponding to No. 0 chord data item of
Subsequently, while sequentially storing pointers to the subsequent meta-events (Nos. 1, 2, . . . chord data items of
In the above-mentioned repetitive process, first, in STEP S1803, the CPU 1401 determines whether the pointer variable data item “mt” indicates the end.
If the result of the determination of STEP S1803 is “NO”, in STEP S1804, the CPU 1401 attempts to extract a chord root and a chord type (see
In a case where the storing process of STEP S1804 has been successful (a case where the result of the determination of STEP S1805 is “YES”), the CPU 1401 stores a time information item “mt->iTime” (“TIME” data of
In a case where the storing process of STEP S1804 has not been successful (a case where the result of the determination of STEP S1805 is “NO”), in STEP S1807, the CPU 1401 attempts to extract a scale and a key (see
In a case where the storing process of STEP S1807 has been successful (a case where the result of the determination of STEP S1808 is “YES”), the CPU 1401 stores a time information item “mt->iTime” (“TIME” data of
After the CPU 1401 increments the value of the variable data item iCDesignCnt in STEP S1810, or in a case where the storing process of STEP S1807 has not been successful (a case where the result of the determination of STEP S1808 is “NO”), the CPU stores pointers to the subsequent meta-events (Nos. 1, 2, . . . chord data items of
If the CPU 1401 reads the chord data items relative to No. n chord progression data item which is the current target up to the end (see
First, in STEP S1901, the CPU 1401 sets an initial value “0” in the variable data item doValue representing the matching level.
Subsequently, in STEP S1902, the CPU 1401 reads a measure start time data item iPartTime[M] retained in a beginning measure record having an item “PartTime[M]” (see
Subsequently, in STEP S1903, the CPU 1401 sets the value of the variable data item iNoteCnt indicating the order of the notes constituting the input motif 108, to an initial value “0”.
Subsequently, in STEP S1904, the CPU 1401 stores a pointer to the first note data item (corresponding to No. 0 note data item of
Subsequently, while sequentially storing pointers to the subsequent note data items (Nos. 1, 2 . . . note data items of
In the above-mentioned repetitive process, first, in STEP S1905, the CPU 1401 determines whether the pointer variable data item “me” indicates the end.
If the result of the determination of STEP S1905 is “NO”, in STEP S1906, with reference to the “TIME” data “me->iTime” of the note data item (
Subsequently, in STEP S1907, the CPU 1401 stores the value of the pointer variable data item “me” in a note pointer array variable data item note[iNoteCnt] which is an array variable data item having the current value of the variable data item iNoteCnt as its element value.
Thereafter, in STEP S1908, the CPU 1401 increases the value of the variable data item iNoteCnt by +1. Subsequently, the CPU 1401 stores pointers to the subsequent note data items (Nos. 1, 2 . . . note data items of
If the CPU 1401 reads the note data items of the input motif 108 up to the end (see
First, in STEP S2001, the CPU 1401 stores an initial value “0” in a variable “i” which is retained in the RAM 1403 and is for counting the number of notes of the input motif 108. Thereafter, while incrementing the value of the variable “i”, +1 by +1, in STEP S2008, the CPU performs a series of processes of STEPS S2002 to S2008, as long as it is determined in STEP S2002 that the value of the variable “i” is smaller than the value of the variable data item iNoteCnt representing the number of notes of the input motif 108 and finally obtained in the process of
In the repetitive process of STEPS S2002 to S2008, first, in STEP S2002, the CPU 1401 determines whether the value of the variable “i” is smaller than the value of the variable data item iNoteCnt.
If the result of the determination of STEP S2002 is “YES”, in STEP S2003, the CPU 1401 reads a pitch item value “note[i]->iPit” (indicating the value of the “PITCH” item of
Subsequently, in STEP S2004, the CPU 1401 performs a process of obtaining a chord information item corresponding to the timing of the current process target note of the input motif 108. In this process, the chord root, chord type, scale, and key of a chord which should be designated at the sound production timing of the current process target note of the input motif 108 are obtained in the variable data items “root”, “type”, “scale”, and “key”.
Subsequently, in STEP S2005, the CPU 1401 performs a note-type acquiring process. In this process, a note type of a pitch “ipit[i]” corresponding to the i-th note of the input motif 108 which is the current process target and related to No. n chord progression data item which is the current evaluation target is obtained in an array variable data item incon[i×2] (an even-numbered element) of note types and adjacent tones retained in the RAM 1403 and described above with reference to
Subsequently, in STEP S2006, the CPU 1401 determines whether the value of the variable “i” is larger than 0, that is, whether the process target note is a note other than the beginning note.
In a case where the result of the determination of STEP S2006 is “YES”, in STEP S2007, the CPU 1401 subtracts pitch information “ipit[i−1]” corresponding to the (i−1)-th process target note, from the pitch information “ipit[i]” corresponding to the i-th process target note indicated by the variable data item “i”, thereby obtaining an adjacent tone described above with reference to
In a case where the result of the determination of STEP S2006 is “NO” (a case where the process target note is the beginning note), the CPU 1401 skips the process of STEP S2007.
Thereafter, the CPU 1401 increments the value of the variable “i” by +1 in STEP S2008, and proceeds to a process on the next note of the input motif 108, and returns to the determining process of STEP S2002.
After the CPU 1401 repeatedly performs the series of STEPS S2002 to S2008 while incrementing the value of the variable data item “i”, if the process on every note data item constituting the input motif 108 finishes, the result of the determination of STEP S2002 becomes “NO”. Then, the CPU proceeds to the note-connectivity checking process of STEP S2009. At this time, sets of note types and adjacent tones described above with reference to
First, in STEP S2101, the CPU 1401 stores an initial value “0” in a variable “k” which is retained in the RAM 1403 and is for counting the number of information items of a chord design data item. Thereafter, while incrementing the value of the variable “k”, +1 by +1, in STEP S2107, the CPU performs a series of processes of STEPS S2102 to S2107, as long as it is determined in STEP S2102 that the value of the variable “k” is smaller than the value of the variable data item iCDesignCnt representing the number of chord information items constituting No. n chord progression data item which is the current evaluation target and finally obtained in the process of
In the repetitive process of S2102 to S2107, first, in STEP S2102, the CPU 1401 determines whether the value of the variable “k” is smaller than the value of the variable data item iCDesignCnt.
If the result of the determination of STEP S2102 is “YES”, in STEP S2103, the CPU 1401 determines whether a time item value “note[i]->iTime” indicated by a note pointer array variable data item of a note which is the current process target is larger than the value of the time item “cdesign[k]->iTime” of the k-th chord design data item indicated by the variable “k” and is smaller than the value of a time item “cdesign[k+1]->iTime” of the (k+1)-th chord design data item, and each value of the key item “cdesign[k]->iKey” and scale item “cdesign[k]->iScale” of the k-th chord design data item has been set to a significant value equal to or larger than 0 (see STEPS S1806 and S1808 of
If the result of the determination of STEP S2103 is “YES”, it is possible to determine that a chord information item according to the k-th chord design data item cdesign[k] has been designated at the sound production timing of the note “note[i]” which is the current process target of the input motif 108. Therefore, in STEP S2104, the CPU 1401 stores the values of the key item “cdesign[k]->iKey” and the scale item “cdesign[k]->iScale” of the k-th chord design data item in the variable data items “key” and “scale”, respectively.
If the result of the determination of STEP S2103 is “NO”, the CPU 1401 skips the process of STEP S2104.
Subsequently, in STEP S2105, the CPU 1401 determines whether a time item value “note[i]->iTime” indicated by a note pointer array variable data item of a note which is the current process target is larger than the value of the time item “cdesign[k]->iTime” of the k-th chord design data item indicated by the variable “k” and is smaller than the value of a time item “cdesign[k+1]->iTime” of the (k+1)-th chord design data item, and each value of the chord root item “cdesign[k]->iRoot” and the chord type item “cdesign[k]->iType” of the k-th chord design data item has been set to a significant value equal to or larger than 0 (see STEPS S1806 and S1808 of
If the result of the determination of STEP S2105 is “YES”, it is possible to determine that a chord information item according to the k-th chord design data item cdesign[k] has been designated at the sound production timing of the note “note[i]” which is the current process target of the input motif 108. Therefore, in STEP S2106, the CPU 1401 stores the values of the root item “cdesign[k]->iRoot” and the type item “cdesign[k]->iType” of the k-th chord design data item in the variable data items “root” and “type”, respectively.
If the result of the determination of STEP S2105 is “NO”, the CPU 1401 skips the process of STEP S2106.
After the above described process, the CPU 1401 increments the value of the variable “k” by +1 in STEP S2107, and proceeds to a process on the next chord design data item cdesign[k], and returns to the determining process of STEP S2102.
After the CPU 1401 repeatedly performs the series of STEPS S2102 to S2107 while incrementing the value of the variable data item “k”, if the process on every chord design data items finishes, the result of the determination of STEP S2102 becomes “NO”. Then, the CPU finishes the process exemplified in the flow chart of
First, in STEP S2201, the CPU 1401 acquires a chord tone pitch class set corresponding to the chord type “type” calculated in STEP S2004 of
Subsequently, in STEP S2202, the CPU 1401 acquires a tension tone pitch class set corresponding to the above-mentioned chord type “type”, from a tension tone table included in the standard pitch class set table stored in the ROM 1402 and having the data configuration exemplified in
Subsequently, in STEP S2203, the CPU 1401 acquires a scale tone pitch class set corresponding to the scale “scale” obtained in STEP S2004 of
Subsequently, in STEP S2204, the CPU 1401 calculates the tone of the pitch “ipit[i]”, obtained in STEP S2003 of
pc1=(ipit[i]−root+12)mod 12 (1)
Also, “mod 12” means the remainder obtained by dividing a value corresponding to the parentheses on the left of “mod 12” by 12.
Similarly, in STEP S2205, the CPU 1401 calculates the tone of the pitch “ipit[i]”, obtained in STEP S2004 of
pc2=(ipit[i]−key+12)mod 12 (2)
Subsequently, in STEP S2206, the CPU 1401 determines whether the input motif pitch class “pc1” is included in the chord tone pitch class set “pcs1”. This determination calculation process is implemented as a calculation process of taking the logical AND of the pc1-th power of 2 (2pc1) and each pitch of the chord tone pitch class set “pcs1” (see FIG. 7A) and determining whether the obtained result is equal to 2pc1.
If the result of the determination of STEP S2206 is “YES”, in STEP S2207, the CPU 1401 determines that the note type is “CHORD TONE”, and reads the value of the constant data item ci_ChordTone representing “CHORD TONE”, from the ROM 1402, and stores the read value in the location incon[i×2] of the note type element of the array of note types and adjacent tones. Thereafter, the CPU 1401 finishes the process exemplified in the flow chart of
If the result of the determination of the STEP S2206 is “NO”, in STEP S2208, the CPU 1401 determines whether the input motif pitch class “pc1” is included in the tension tone pitch class set “pcs2” and the input motif pitch class “pc2” is included in the scale tone pitch class set “pcs3”. This determination calculation process is implemented as a calculation process of taking the logical AND of the pc1-th power of 2 (2pc1) and each pitch of the tension tone pitch class set “pcs2” (see
If the result of the determination of STEP S2208 is “YES”, in STEP S2209, the CPU 1401 determines that the note type is “AVAILABLE NOTE”, and reads the value of a constant data item ci_AvailableNote representing “AVAILABLE NOTE”, from the ROM 1402, and stores the read value in the location incon[i×2] of the note type element of the array of note types and adjacent tones. Thereafter, the CPU 1401 finishes the process exemplified in the flow chart of
If the result of the determination of the STEP S2208 is “NO”, in STEP S2210, the CPU 1401 determines whether the input motif pitch class “pc2” is included in the scale tone pitch class set “pcs3”. This determination calculation process is implemented as a calculation process of taking the logical AND of the pc2-th power of 2 (2pc2) and each pitch of the scale tone pitch class set “pcs3” (see
If the result of the determination of STEP S2210 is “YES”, in STEP S2211, the CPU 1401 determines that the note type is “SCALE NOTE”, and reads the value of a constant data item ci_ScaleNote representing “SCALE NOTE”, from the ROM 1402, and stores the read value in the location incon[i×2] of the note type element of the array of note types and adjacent tones. Thereafter, the CPU 1401 finishes the process exemplified in the flow chart of
If the result of the determination of the STEP S2210 is “NO”, in STEP S2212, the CPU 1401 determines whether the input motif pitch class “pc1” is included in the tension tone pitch class set “pcs2”. This determination calculation process is implemented as a calculation process of taking the logical AND of the pc1-th power of 2 (2pc1) and each pitch of the tension tone pitch class set “pcs2” (see
If the result of the determination of STEP S2212 is “YES”, in STEP S2213, the CPU 1401 determines that the note type is “TENSION NOTE”, and reads the value of a constant data item ci_TensionNote representing “TENSION NOTE”, from the ROM 1402, and stores the read value in the location incon[i×2] of the note type element of the array of note types and adjacent tones. Thereafter, the CPU 1401 finishes the process exemplified in the flow chart of
Finally, if the result of the determination of STEP S2212 is “NO”, in STEP S2214, the CPU 1401 determines that the note type is “AVOID NOTE”, and reads the value of a constant data item ci_AvoiNote representing “AVOID NOTE”, from the ROM 1402, and stores the read value in the location incon[i×2] of the note type element of the array of note types and adjacent tones. Thereafter, the CPU 1401 finishes the process exemplified in the flow chart of
By the note-type acquiring process of STEP S2005 of
First, in STEP S2301, the CPU 1401 stores an initial value “0” in a variable data item iTotalValue retained in the RAM 1403. This data item holds the total evaluation points for calculating the matching level of No. n chord progression data item (see STEP S1704 of
Subsequently, in STEP S2302, the CPU 1401 stores an initial value “0” in the variable data item “i”. Thereafter, while incrementing the variable data item “i”, +1 by +1, in STEP S2321, the CPU repeatedly performs a series of processes of STEPS S2303 to S2321, as long as the result of the determination of STEP S2303 is “YES”, that is, it is determined that the value of the variable data item “i” is smaller than a value obtained by subtracting 2 from the value of the variable data item iNoteCnt. This repetitive process corresponds to the repetitive process on each note of the input motif 108 of
In a series of processes of STEPS S2304 to S2320 which is performed on each i-th note of the input motif 108, first, in STEP S2304, the CPU 1401 stores an initial value “0” in a variable data item iValue retained in the RAM 1403. Subsequently, in STEP S2306, the CPU 1401 stores an initial value “0” in a variable data item “j”. Thereafter, while incrementing the variable data item “j”, +1 by +1, in STEP S2318, the CPU 1401 repeatedly performs a series of processes of STEPS S2307 to S2319, until the result of the determination of STEP S2307 becomes “YES”, that is, the value of the variable data item “j” reaches its end value. This repetitive process corresponds to the repetitive process of checking each note connection rule of
In a series of processes of STEP S2308 to S2316 to check the j-th note connection rule for each i-th note of the input motif 108, in STEP S2308, the CPU 1401 stores an initial value “0” in a variable data item “k” retained in the RAM 1403. Subsequently, while incrementing the variable data item “k”, +1 by +1, in STEP S2315, the CPU repeatedly performs a series of processes of STEPS S2309 to S2315. By this repetitive process, it is determined whether four note types incon[i×2], incon[i×2+2], incon[i×2+4], and incon[i×2+6] corresponding to four consecutive notes from the i-th note of the input motif 108 coincide with four note types ci_NoteConnect[j][0], ci_NoteConnect[j][2], ci_NoteConnect[j][4], and ci_NoteConnect[j][6] included in the j-th note connection rule exemplified in
After a process of repeatedly performing the series of the processes of STEPS S2309 to S2315 four times while incrementing the value of the variable data item “k” from 0 to 3 is performed as the process of comparing four consecutive notes from the i-th note of the input motif 108 with the j-th note connection rule of
Specifically, in STEP S2310, the CPU 1401 determines whether the note type incon[i×2+k×2] of the (i+k)-th note of the input motif 108 is different from the k-th note type ci_NoteConnect[j][k×2] of the j-th note connection rule. If the result of the determination of STEP S2310 is “YES”, since at least one note type of the corresponding note connection rule does not coincide with at least one of the note types of the four notes starting with the i-th note (the current process target) of the input motif 108, the CPU 1401 proceeds to STEP S2319.
If the result of the determination of STEP S2310 is “NO”, STEPS S2311 and S2312 (to be described below) are performed. When both of the determination results of STEPS S2311 and S2312 are “NO”, if the value of the variable data item “k” is smaller than 3, the result of the determination of STEP S2313 becomes “YES”, and thus the CPU 1401 performs an adjacent tone determining process in STEP S2314. The determination of STEP S2313 is performed for performing the adjacent tone determining process only in a range in which the value of the variable data item “k” is any one of 0 to 2 since there is no adjacent tone from the fourth note (wherein k=3) of the input motif 108. In STEP S2314, the CPU 1401 determines whether an adjacent tone incon[i×2+k×2+1] between the (i+k)-th note and (i+k+1)-th note of the input motif 108 is different from an adjacent tone ci_NoteConnect[j][k×2+1] between the k-th note type and (k+1)-th note type of the j-th note connection rule, and the value of the adjacent tone ci_NoteConnect[j][k×2+1] is different from “99”. The adjacent tone value “99” represents that the corresponding adjacent tone can have any value. If the result of the determination of STEP S2314 is “YES”, since at least one adjacent tone of the corresponding note connection rule does not coincide with at least one of adjacent tones of four notes starting with the i-th note (the current process target) of the input motif 108, and thus the CPU 1401 proceeds to STEP S2319.
In the above described series of processes, if coincidence of the note type incon[i×2+k×2] of the (i+k)-th note of the input motif 108 and the k-th note type ci_NoteConnect[j][k×2] of the j-th note connection rule is detected in STEP S2310, whereby the result of the determination of STEP S2310 becomes “NO”, in STEP S2311, the CPU 1401 determines whether the (k+1)-th note type ci_NoteConnect[j][k×2+2] next to the k-th note type of the j-th note connection rule is “ci_NullNoteType”.
The value “ci_NullNoteType” is set as the note type ci_NoteConnect[j][6] in a case of k=3 in the note connection rules from j=0 to j=8 shown in
Meanwhile, in a case where the result of the determination of STEP S2311 becomes “NO”, the CPU proceeds to the adjacent tone evaluating process of STEP S2314 through STEPS S2312 and S2313. Here, immediately after the result of the determination of STEP S2311 becomes “NO”, in STEP S2312, the CPU 1401 determines whether the value of the variable data item “i” is equal to a value obtained by subtracting 3 from the value of the variable data item iNoteCnt representing the number of notes of the input motif 108, and the value of the variable data item “k” is equal to 2. In this case, a note of the input motif 108 to be a process target becomes the (i+k)-th note, that is, the (iNoteCnt−3+2=iNoteCnt−1)-th note, that is, the final note of the input motif 108. In this state, in STEP S2311, in a case where the value of the (k+1)-th note type ci_NoteConnect[j][k×2+2], that is, the note type ci_NoteConnect[j][6] does not become ci_NullNoteType is a case where a note connection rule of
If the series of processes of STEPS S2309 to S2315 is repeatedly performed four times without satisfying any one of the conditions of STEPS S2310, S2311, S2312, and S2314 described above, whereby the result of the determination STEP S2309 becomes “NO”, with respect to four consecutive notes from the i-th note of the input motif 108, all of the note types and the adjacent tones are suitable for the note types and adjacent tones of the j-th note connection rule which is the current evaluation target. In this case, the CPU 1401 proceeds to STEP S2316 in which the CPU accumulates the evaluation points ci_NoteConnect[j][7] (see
Also, the number of note connection rules which are suitable for the input motif 108 is not always one. For example, the input motif may be suitable not only for a note connection rule for three notes but also for a note connection rule for four notes. Therefore, while the CPU 1401 increments the value of the variable data item “j” in STEP S2319, whenever the result of the determination of STEP S2309 becomes “NO” or the result of the determination of STEP S2311 becomes “YES”, whereby it is determined that a corresponding note connection rule is suitable, the evaluation points ci_NoteConnect[j][7] of the new suitable note connection rule is accumulated in the variable data item iValue, until evaluation on every note connection rule in STEP S2307 is completed.
Thereafter, the CPU 1401 increments the value of the variable data item “j” by +1 in STEP S2319, thereby proceeding to evaluation on the next note connection rule, and returns to the determining process of STEP S2307.
If evaluation on every note connection rule is completed, whereby the result of the determination of STEP S2307 becomes “YES”, in STEP S2320, the CPU 1401 accumulates the evaluation points accumulated in the variable data item iValue, in a variable data item iTotalValue corresponding to No. n chord progression data item which is the current process target.
Thereafter, the CPU 1401 increments the value of the variable data item “i” by +1 in STEP S2321, and returns to the determining process of STEP S2303, thereby proceeding to the process on the next note of the input motif 108 (see
If the suitability evaluation process on every note connection rule relative to every note of the input motif 108 finishes, the result of the determination STEP S2303 becomes “NO”. Here, the end location of the process target notes of the input motif 108 is originally the third note from the final note of the input motif 108, and the value of the variable data item “i” corresponding thereto is “(iNoteCnt−1)−3”, that is, “iNoteCnt−4”. However, as shown by i=7 in
If the result of the determination of STEP S2303 becomes “NO”, in STEP S2322, the CPU 1401 divides the value of the variable data item iTotalValue by the number (iNoteCnt−2) of processed notes of the input motif 108, thereby performing normalization, and stores the division result, as the matching level of No. n chord progression for the input motif 108, in the variable data item doValue. Thereafter, the CPU 1401 finishes the note-connectivity checking process of the flow chart of
First, in STEP S2401, the CPU 1401 initializes a variable area of the RAM 1403.
Subsequently, in STEP S2402, the CPU 1401 reads a music structure data item (see
Subsequently, in STEP S2403, the CPU 1401 sets the value of the variable data item “i” to an initial value “0”. Thereafter, while the CPU increments the value of the variable data item “i” in STEP S2409, with respect to the phrase of each measure of the music structure data item indicated by the variable data item “i”, the CPU automatically generates a melody for the corresponding phrase with reference to the input motif 108, the phrase sets (see
Specifically, first, in STEP S2404, the CPU 1401 determines whether the end of the music structure data item has been reached.
If the result of the determination of STEP S2404 is “NO”, in STEP S2405, the CPU 1401 determines whether the current measure of the music structure data item designated by the variable data item “i” coincides with a measure of the input motif 108.
If the result of the determination of STEP S2405 is “YES”, the CPU 1401 intactly outputs the input motif 108 as a part of the melody data 110 (see
If the result of the determination of STEP S2405 is “NO”, in STEP S2406, the CPU 1401 determines whether the current measure is the beginning measure of a refrain melody.
If the result of the determination of STEP S2406 is “NO”, in STEP S2407, the CPU 1401 performs a first melody generating process.
Meanwhile, if the result of the determination of STEP S2406 is “YES”, in STEP S2408, the CPU 1401 performs a second melody generating process.
After the process of STEP S2407 or S2408, in STEP S2409, the CPU 1401 increments the variable data item “i” by +1. Thereafter, the CPU 1401 returns to the determining process of STEP S2404.
In STEP S2501, the CPU 1401 determines whether a phrase type including the current measure is the same as the phrase type of the input motif 108. A phrase type including the current measure can be determined by referring to a “PartName[M]” item and a “iPartID[M]” item of a record having a “Measure” item corresponding to the value of the variable data item “i” and included in the music structure data item exemplified in
If the result of the determination of STEP S2501 is “YES”, the CPU 1401 copies the melody of the input motif 108, as the melody of the current measure, in a predetermined area of the RAM 1403. Thereafter, the CPU 1401 proceeds to a melody modifying process of STEP S2507.
If the result of the determination of STEP S2501 is “NO”, in STEP S2503, with respect to the phrase type including the current measure, the CPU 1401 determines whether a melody has been already generated and the even numbers/odd numbers of the measures coincide with each other.
If the result of the determination of STEP S2503 is “YES”, in STEP S2504, the CPU 1401 copies the generated melody as the melody of the current measure in a predetermined area of the RAM 1403. Thereafter, the CPU 1401 proceeds to the melody modifying process of STEP S2507.
If a melody for the corresponding phrase has not been generated yet (the result of the determination of STEP S2503 is “NO”), in STEP S2505, the CPU 1401 performs a phrase-set-DB retrieval process. In the phrase-set-DB retrieval process, the CPU 1401 extracts a phrase set corresponding to the input motif 108, from the phrase set DB 106.
Subsequently, in STEP S2506, the CPU 1401 copies the melody of a phrase having the same type as the phrase type including the current measure and included in the phrase set retrieved in STEP S2505, in a predetermined area of RAM 1403. Thereafter, the CPU 1401 proceeds to the melody modifying process of STEP S2507.
After the process of STEP S2502, S2504, or S2506, in STEP S2507, the CPU 1401 performs the melody modifying process of modifying the copied melody.
Thereafter, in STEP S2508, the CPU 1401 performs a melody optimizing process of optimizing the pitch of each note constituting the melody modified in STEP S2507. As a result, the CPU 1401 automatically generates a melody of the phrase of each measure represented by the music structure data item, and outputs the generated melody to the output melody area of the RAM 1403.
First, the CPU 1401 extracts the pitch sequence of the input motif 108, and stores the pitch sequence in array variable data items iMelodyB[0] to iMelodyB[iLengthB−1] retained in the RAM 1403. Here, in a variable data item iLengthB, the length of the pitch sequence of the input motif 108 is stored.
Subsequently, in STEP S2602, the CPU 1401 sets the value of the variable data item “k” to an initial value “0”. Thereafter, while incrementing the value of the variable data item “k” in STEP S2609, the CPU 1401 repeatedly performs a series of STEPS S2603 to S2609 on a phrase set (see
In this series of processes, first, in STEP S2604, the CPU 1401 extracts the pitch sequence of a phrase corresponding to the input motif 108, from the k-th phrase set represented by the variable data item “k”, and stores the pitch sequence in array variable data items iMelodyA[0] to iMelodyA[iLengthA−1] retained in the RAM 1403. Here, a variable data item iLengthA, the length of the pitch sequence of the phase retained in the phrase set DB 106 is stored.
Subsequently, the CPU 1401 performs a DP (Dynamic Programming) matching process between the array variable data items iMelodyB[0] to iMelodyB[iLengthB−1] regarding to the pitch sequence of the input motif 108 and set in STEP S2601 and the array variable data items iMelodyA[0] to iMelodyA[iLengthA−1] regarding to the pitch sequence of the corresponding phrase included in the k-th phrase set retained in the phrase set DB 106 and set in STEP S2604, thereby calculating a distance evaluation value between them, and stores the distance evaluation value in a variable data item doDistance retained in the RAM 1403.
Subsequently, in STEP S2606, the CPU 1401 determines whether a minimum distance evaluation value represented by the variable data item doMin retained in the RAM 1403 is larger than the distance evaluation value doDistance newly calculated by the DP matching process of STEP S2605.
If the result of the determination STEP S2606 is “NO”, in STEP S2607, the CPU 1401 stores the new distance evaluation value stored in the variable data item doDistance, in a variable data item doMin.
Subsequently, in STEP S2608, the CPU 1401 stores the value of the variable data item “k” in a variable data item iBestMochief retained in the RAM 1403.
If the result of the determination of STEP S2606 is “YES”, the CPU 1401 skips the processes of STEPS S2607 and S2608.
Thereafter, the CPU 1401 increments the value of the variable data item “k” by +1, thereby proceeding to the process on the next phrase set (see
If the DP matching process between every phrase set retained in the phrase set DB 106 and the input motif 108 finishes, whereby the result of the determination of the STEP S2603 becomes “YES”, in STEP S2610, the CPU 1401 outputs a phrase set having a number represented by the variable data item iBestMochief and retained in the phrase set DB 106, to a predetermined area of the RAM 1403. Thereafter, the CPU 1401 finishes the process of the flow chart exemplified in
First, in STEP S2701, the CPU 1401 stores an initial value “0” in the variable “i” which is retained in the RAM 1403 and is for counting the number of notes of the melody obtained by the copying process of
In the repetitive process of STEPS S2702 to S2709, first, in STEP S2702, the CPU 1401 acquires a modification type. The modification type is “PITCH SHIFT” or “LEFT/RIGHT REVERSING”, and the user can designate the modification type by a switch (not specifically shown).
In a case where the modification type is “PITCH SHIFT”, in STEP S2704, the CPU 1401 adds a predetermined value to pitch data “note[i]->iPit” retained in an iPit item of the array variable data item note[i], thereby performing pitch shift to raise pitches, for example, by two semitones as described with respect to the reference symbol “1201” of
In a case where the modification type is “LEFT/RIGHT REVERSING”, in STEP S2705, the CPU 1401 determines whether the value of the variable data item “i” is smaller than a value obtained by dividing the value the variable data item iNoteCnt by 2.
In a case where the result of the determination of STEP S2705 is “YES”, first, in STEP S2706, the CPU 1401 saves the pitch data “note[i]->iPit” retained in the iPit item of the array variable data item note[i], in a variable “ip” retained in the RAM 1403.
Subsequently, in STEP S2707, the CPU 1401 stores the value of a pitch item “note[iNoteCnt−i−1]->iPit” which is the (iNoteCnt−i−1)-th array element, in the pitch item “note[i]->iPit” which is the i-th array element.
Subsequently, in STEP S2708, the CPU 1401 loads the original pitch item value saved in the variable data item “ip” into the pitch item “note[iNoteCnt−i−1]->iPit” which is the (iNoteCnt−i−1)-th array element.
In a case where the result of the determination of STEP S2705 is “NO”, the CPU 1401 skips the processes of STEPS S2706, S2707, and S2708.
After the process of STEP S2704 or S2708, or after the result of the determination of STEP S2705 becomes “NO”, in STEP S2709, the CPU 1401 increments the value of the variable data item “i” by +1, thereby proceeding to the process on the next note, and returns to the determining process of STEP S2702.
By the above described process, the left/right reversing process described with respect to the reference symbol “1202” of
First, in STEP S2801, the CPU 1401 calculates the total number of combinations of different pitch candidates by the following expression.
IWnum=MAX_NOTE_CANDIDATÊiNoteCnt
Here, the operator “̂” represents a power operator. Also, a constant data item MAX_NOTE_CANDIDATE retained in the ROM 1402 represents the number of different pitch candidates ipitd[0] to ipitd[4] relative to one note shown in
Subsequently, in STEP S2802, the CPU 1401 sets a variable data item iCnt for counting different pitch candidates, to an initial value “0”. Thereafter, while incrementing the variable data item iCnt, +1 by +1, in STEP S2818, the CPU 1401 evaluates the validity of an input melody while changing the pitches of the corresponding melody, as long as it is determined in STEP S2803 that the value of the variable data item iCnt is smaller than the total number of combinations of different pitch candidates calculated in STEP S2801.
Whenever the value of the variable data item iCnt is incremented, the CPU 1401 performs a series of processes of STEPS S2805 to S2817.
First, in STEP S2805, the CPU 1401 stores an initial value “0” in the variable “i” which is retained in the RAM 1403 and is for counting the number of notes of the melody obtained by the copying process of
First, in STEP S2807, the CPU 1401 obtains a pitch correction value in a variable data item ipitdev retained in the RAM 1403 by calculating the following expression.
Ipitdev=ipitd[(iCnt/MAX_NOTE_CANDIDATÊi)modMAX_NOTE_CANDIDATE]
Here, “mod” represents remainder calculation.
Subsequently, in STEP S2809, the CPU 1401 adds the value of the variable data item ipitdev calculated in STEP S2807, to the pitch item value “note[i]->iPit” of the input melody, and stores the obtained result in the array variable data item ipit[i] representing the pitch information sequence.
Subsequently, in the same way as that of STEPS S2005 to S2007 of
If the CPU 1401 completes pitch correction corresponding to the current value of the variable data item iCnt, on every note constituting the input melody, the result of the determination STEP S2806 becomes “NO”. As a result, in STEP S2814, the CPU 1401 performs the same note-connectivity checking process as the process of
Subsequently, in STEP S2815, the CPU 1401 determines whether the value of the matching level newly obtained in the variable data item doValue in the note-connectivity checking process of STEP S2814 is larger than the value of the best matching level held in a variable data item iMaxValue.
If the result of the determination of STEP S2815 is “YES”, the CPU 1401 replaces the value of the variable data item iMaxValue with the value of the variable data item doValue in STEP S2816, and replaces the value of the variable data item iMaxCnt with the value of the variable data item iCnt in STEP S2817.
Thereafter, the CPU 1401 increments the value of the variable data item iCnt by +1 in STEP S2818, and returns to the determining process of STEP S2803.
If the above described operation is repeatedly performed on the variable data item iCnt which is sequentially incremented, and as a result, the note-connectivity checking process on every combination of different pitch candidates is completed, the result of the determination of STEP S2803 becomes “NO”.
As a result, in STEP S2819, the CPU 1401 stores an initial value “0” in the variable “i”. Thereafter, while incrementing the value of the variable “i”, +1 by +1, in STEP S2823, the CPU repeatedly performs a series of processes of STEPS S2820 to S2823, as long as it is determined in STEP S2820 that the value of the variable “i” is smaller than the value of the variable data item iNoteCnt representing the number of notes of the melody. In this repetitive process, pitch correction, that is, optimization using the best value obtained in the variable data item iMaxCnt is performed on every note of the melody.
Specifically, after the finish determination of STEP S2820 is performed, in STEP S2821, the CPU 1401 obtains an optimal pitch correction value in the array variable data item ipit[i] of the pitch information sequence by calculating the following expression.
ipit[i]=note[i]->iPit+ipitd[(iMaxCnt/(MAXNOTE_CANDIDATÊi)mod MAX_NOTE_CANDIDATE)]
Subsequently, in STEP S2822, the CPU 1401 overwrites the pitch item value “note[i]->iPit” of the note data of the input melody with the value of the array variable data item ipit[i] of the pitch information sequence.
Finally, the CPU 1401 increments the value of the variable “i” in STEP S2823, and then returns to the determining process of STEP S2820.
If the above described process on every note data item constituting the input melody is completed, the result of the determination STEP S2820 becomes “NO”. Therefore, the CPU 1401 finishes the process exemplified in the flow chart of
First, in STEP S2901, the CPU 1401 determines whether a refrain beginning melody has been generated.
If a refrain beginning melody has not been generated yet, and thus the result of the determination of STEP S2901 becomes “NO”, in STEP S2902, the CPU 1401 performs a phrase-set-DB retrieval process. This process is the same as the process of
Subsequently, in STEP S2903, the CPU 1401 copies the melody of a refrain beginning (C melody) phrase included in the phrase set retrieved in STEP S2902, in a predetermined area of the RAM 1403.
Subsequently, in STEP S2904, the CPU 1401 performs the same melody optimizing process of
The CPU 1401 stores the melody data obtained in STEP S2904 and having optimal pitches, as a part of the melody data 110, in the output melody area of the RAM 1403. Thereafter, the CPU 1401 finishes the process exemplified in the flow chart of
If a refrain beginning melody has been generated, and thus the result of the determination of STEP S2901 becomes “YES”, in STEP S2905, the CPU 1401 copies the generated refrain beginning melody, as the melody of the current measure, in the output melody area of the RAM 1403. Thereafter, the CPU 1401 finishes the process exemplified in the flow chart of
According to the above described embodiment, it becomes possible to quantify the correspondence relation between the input motif 108 and each chord progression data item, as the matching level, such that it is possible to appropriately select chord progression data items suitable for the input motif 108 based on the matching level. Therefore, it becomes possible to generate natural music.
Number | Date | Country | Kind |
---|---|---|---|
2014-235233 | Nov 2014 | JP | national |