The present disclosure relates to an electronic musical instrument, a sound production method for an electronic musical instrument, and a storage medium therefor.
Some electronic musical instruments are equipped with a layer function for simultaneously playing two or more timbres. See, e.g., Japanese Patent Application Laid-Open Publication No. 2016-173599. This is a function by an electronic keyboard instrument that can produce sounds that reproduce the heavy unison performance of a piano and strings in an orchestra; that is, simultaneously generating the piano sound and the strings sound.
The features and advantages of the invention will be set forth in the descriptions that follow and in part will be apparent from the description, or may be learned by practice of the invention.
The objectives and other advantages of the invention will be realized and attained by the structure particularly pointed out in the written description and claims thereof as well as the appended drawings.
To achieve these and other advantages and in accordance with the purpose of the present invention, as embodied and broadly described, in one aspect, the present disclosure provides an electronic musical instrument that includes: a plurality of performance elements that specify pitch data; a sound source that produces musical sounds; and a processor configured to perform the following: when a user performance of the plurality of performance elements satisfies a prescribed condition, instructing the sound source to produce a sound of a first timbre and a sound of a second timbre, both corresponding to a pitch data specified by the user performance; and when the user performance of the plurality of performance elements does not satisfy the prescribed condition, instructing the sound source to produce the sound of the first timbre corresponding to the pitch data specified by the user performance and not instructing the sound source to produce the sound of the second timbre.
In another aspect, the present disclosure provides a method of sound production performed by a processor in an electronic musical instrument that includes, in addition to the processor, a plurality of performance elements that specify pitch data and a sound source that produces musical sounds, the method including via said processor: when a user performance of the plurality of performance elements satisfies a prescribed condition, instructing the sound source to produce a sound of a first timbre and a sound of a second timbre, both corresponding to a pitch data specified by the user performance; and when the user performance of the plurality of performance elements does not satisfy the prescribed condition, instructing the sound source to produce the sound of the first timbre corresponding to the pitch data specified by the user performance and not instructing the sound source to produce the sound of the second timbre.
In another aspect, the present disclosure provides a non-transitory computer-readable storage medium storing a program executable by a processor in an electronic musical instrument that includes, in addition to the processor, a plurality of performance elements that specify pitch data and a sound source that produces musical sounds, the program causing the processor to perform the following: when a user performance of the plurality of performance elements satisfies a prescribed condition, instructing the sound source to produce a sound of a first timbre and a sound of a second timbre, both corresponding to a pitch data specified by the user performance; and when the user performance of the plurality of performance elements does not satisfy the prescribed condition, instructing the sound source to produce the sound of the first timbre corresponding to the pitch data specified by the user performance and not instructing the sound source to produce the sound of the second timbre.
It is to be understood that both the foregoing general description and the following detailed description are exemplary and explanatory, and are intended to provide further explanation of the invention as claimed.
Hereinafter, embodiments for carrying out the present disclosure will be described in detail with reference to the drawings.
The performer can select a timbre by means of a group 102 of 10 TONE buttons 102 arranged in the TONE section (broken line 102) on the upper right panel of the electronic keyboard instrument 100, for example. Similarly, the layer timbre setting mode can be set or canceled by pressing the LAYER button 103 on the upper right panel.
In the state where the layer timbre setting mode is canceled, the LED (Light Emitting Diode) of the LAYER button 103 is turned off, and the performer selects the basic timbre (first timbre) described later by the TONE button 102. The LED of the TONE button 102 of the selected timbre then lights up.
When the performer presses the LAYER button 103 in this state, the layer timbre setting mode is set and the LED of the LAYER button 103 lights up. In this layer timbre setting mode setting state, the TONE button 102 is used for selecting the layer timbre, and when the performer selects the TONE button 102, the LED of the selected TONE button 102 blinks. You cannot select the same timbre as the basic timbre.
When the performer presses the LAYER button 103 again in this state, the layer timbre setting mode is canceled, and the LED of the TONE button 102 of the timbre that has been blinking is turned off.
The CPU 201 executes control operations of the electronic keyboard instrument 100 of
The key scanner 206 constantly scans the key-pressed/released state of the keyboard 101 of
The I/O interface 207 detects the operating state of the TONE button 102 group and the LAYER button 103 in
A timer 210 is connected to the CPU 201. The timer 210 generates an interrupt at regular time intervals (for example, 1 millisecond). When this interrupt occurs, the CPU 201 executes an elapsed time monitoring process described later using the flowchart of
In the present application, the layer timbre means a timbre (second timbre) that is superimposed on the basic timbre (first timbre). The “layer mode on” means that the layer timbre is superimposed on the basic timbre and the layer timbre and the basic timbre are sounded in unison, and the “layer mode off” means that only the basic timbre is sounded.
In the above-mentioned keyboard event processing, when a key release keyboard event occurs while the CPU 201 is in a state where the above-mentioned layer mode on is set, the CPU instructs the sound source LSI 204 to mute the first musical tone of the basic timbre for which the corresponding key is released and to mute the second musical tone of the layer timbre for which the corresponding key is released. The CPU 201 sets the layer mode off when it instructs the sound source LSI 204 to mute the first musical tones of all the basic timbres and the second musical tones of all the layer timbres. Here, the CPU 201 determines whether or not the number of keys pressed during the preset elapsed time that defines simultaneous key pressing period has reached the above-mentioned preset number of notes that can be regarded as a chord playing while the layer mode off is set.
A waveform ROM 211 is connected to the sound source LSI 204. According to the sound production instructions from the CPU 201, the sound source LSI 204 starts reading the musical tone waveform data 214 from the waveform ROM 211 at a speed corresponding to the pitch data included in the sound production instructions, and outputs the data to the D/A converter 212. The sound source LSI 204 may have, for example, the ability to simultaneously produce a maximum of 256 voices by time division processing. According to mute instructions from the CPU 201, the sound source LSI 204 stops reading the musical tone waveform 214 corresponding to the mute instructions from the waveform ROM 211, and ends the sound production of the musical note corresponding to the mute instructions.
The LCD controller 208 is an integrated circuit that controls the display state of the LCD 104 of
The network interface 205 is connected to a communication network such as Local Area Network (LAN), and receives control programs (see the flowcharts of keyboard event processing and the elapsed time monitoring processing described later) and/or data used by the CPU 201 from an external device. Then, they can be loaded into RAM 203 or the like and used.
An operation example of the embodiment shown in
In the layer mode on state, the layer mode on state is maintained even if some of the keys for which the above determination is made are released and the number of notes becomes less than N. When all the keys with which the above determination is made are released, the layer mode is turned off.
In addition, once the layer mode is turned on, as long as that state is maintained, the musical tone of the pitch corresponding to a new key press is produced with the basic timbre (i.e., not with the layer timbre) no matter what the performer plays.
The number of played notes N that is regarded as a chord playing and the elapsed time T that defines simultaneous key pressing period may be set for each timbre separately.
First, when the key press event t1 occurs in the layer mode off state, the sound production of the basic timbre of pitch C2, for example, is started (the black solid line period of t1), and measurement of the elapsed time is started. Subsequently, the key pressing event t2 occurs within 25 milliseconds from the occurrence of the key pressing event t1, and the sound production of the basic timbre of the pitch E2 is started (the black solid line period of t2). Further, the key pressing event t3 occurs, and the sound production with the basic timbre of the pitch G2 is started (the black solid line period of t3), but the key pressing event t3 occurs after more than 25 milliseconds have passed since the occurrence of the key pressing event t1. Thus, the number of key presses during the elapsed time T=25 milliseconds since the first key press event t1, which defines simultaneous key pressing period, is 2, which is less than the number of the pressed keys N=3 that can be regarded as a chord playing. In this case, therefore, for the key press events t1, t2, and t3, the second musical tone of the layer timbre is not produced, and the first musical tones of the basic timbre indicated by the respective black solid lines in the t1, t2, and t3 parts are produced (that is, the layering condition is not satisfied).
After that, the key press event t4 occurs, the sound production of the basic timbre of the pitch C4 is started (the black solid line period of t4), and measurement of the elapsed time is started again. Subsequently, the key pressing events t5 and t6 occur within the elapsed time T=25 milliseconds, which are considered to be the same time key pressing events as the key pressing event t4, and the sound production of the basic timbre of pitches E4 and G4 starts (the black solid line period of t5 and t6). As a result, the number of notes at the time when T=25 milliseconds has elapsed from the occurrence of the key press event t4 becomes 3, and the number of the pressed keys for the chord playing determination, N=3 or more, is satisfied (i.e., the layering condition is satisfied). In this case, for the key press events t4, t5, and t6, as shown by the gray dashed line, in addition to the sound production of the first musical tones of the basic timbre, the sounds of three-note chord of pitches C4, E4, and G4 are produced with the second tones of the layer timbre (301 in
Then, while the layer mode is kept on, the key press event t7 occurs, and the sound production of the first musical tone with the basic timbre of pitch B4 ♭ (the black solid line period of t7) is started, but the three keys corresponding to the key press events t4, t5, and t6 have not been released, and the layer mode on state is maintained. In this case, for the key press event t7, the second musical tone of the layer timbre is not produced, and only the first musical tone of the basic timbre indicated by the solid black line of t7 is produced (i.e., the layering condition is not met).
Then, the key pressing events t8, t9, and t10 occur within the elapsed time T=25 ms form each other, which are considered to be simultaneously pressed, and the sound production of the first musical tones with the basic timbre of pitches C3, E3, and G3, respectively, (the black solid line periods of t8, t9, and t10) is started, but the three keys corresponding to the key pressing events t4, t5, and t6 have not been released and the layer mode on state is still maintained. In this case as well, for the key press events t8, t9, and t10, the second musical tone of the layer timbre is not produced, and the first musical tones of the basic timbre indicated by the solid black lines of t8, t9, and t10 are produced (i.e., the layering condition is not met).
The key press event t4 is released at the timing of the white circle in t4, and the sound production of the first musical tone of the basic timbre and the sound production of the second musical tone of the layer timbre corresponding to the key press event t4 (the gray dashed period of t4) are terminated, but the sound production of the first musical tones of the basic timbre and the sound production of the second musical tones of the layer timbre corresponding to the key press events t5 and t6 (each gray dashed period of t5 and t6) are continued. When the key press event t5 is released (at the timing of the white circle in t5), the sound production of the first musical tone of the basic timbre and the sound production of the second musical tone of the layer timbre corresponding to the key pressing event t5 (the gray dashed period of t5) are terminated (muted). However, the sound production of the first musical tone of the basic timbre and the sound production of the second musical tone of the layer timbre corresponding to the key press event t6 (the period of the gray dashed line of t6) are continued. Then, when the key press event t6 is also released (at the timing of the white circle in t6), the sound production of the first musical tone of the basic timbre and the sound production of the second musical tone of the layer timbre corresponding to the key press event t6 (the gray dashed period of t6) are terminated (muted). Since the release of all the keys corresponding to the key press events t4, t5, and t6 that have triggered the layer mode on is completed, the layer mode on is canceled and the layer mode is turned off.
After the layer mode off is set, the key press event t11 occurs, the sound production of the first musical tone with the basic timbre of pitch C2 (the black solid line period of t11) is started, and the measurement of the elapsed time starts. Subsequently, the key pressing events t12, t13, and t14 occur within 25 milliseconds from the occurrence of the key pressing event t11, and the sound production of the corresponding first musical tones with the basic timbre of the pitch E2, G2, and C3 (the black solid line periods of t12, t13, and t14) is started. As a result, the number of musical tones at the time when T=25 milliseconds has elapsed from the occurrence of the key press event t11 becomes 4, and the number of the pressed notes N=3 or more for a chord playing is satisfied (i.e., the layering condition is satisfied). Therefore, for the key press events t11, t12, t13, and t14, as shown by the gray dashed lines, in addition to the sound production of the first musical tones of the basic timbre, the second musical tones of the layer timbre are produced with the four-note chord of the pitches C2, E2, G2, and C3 (302 in
In the keyboard event processing illustrated in the flowchart of
When it is determined in step S401 that the interrupt notification indicates a key press event, the CPU 201 instructs the sound source LSI 204 to produce sound of the first musical tone of the basic timbre with a pitch indicated by the pitch data (note number) included in the interrupt notification indicating the key press event (step S402). The performer can specify the basic timbre by pressing any of the TONE buttons 102 in
Next, the CPU 201 determines whether the layer mode is currently on or off (step S403). In this process, whether the layer mode is on or not is determined depending on whether the logical value of a predetermined variable (hereinafter, this variable is referred to as a “layer mode variable”) stored in the RAM 203 of
If it is determined in step S403 that the layer mode is currently on, the flow chart of the current keyboard event processing shown in the flowchart of
If it is determined in step S403 that the layer mode is currently off, the CPU 201 determines whether or not the elapsed time for shifting to the layer mode on is zero (step S404). The elapsed time is held as the value of a predetermined variable (hereinafter, this variable is referred to as an “elapsed time variable”), for example, in the RAM 203 of
When it is determined that the elapsed time is 0 (when the determination in step S404 is YES), the CPU 201 starts interrupt processing by the timer 210 and starts measuring the elapsed time (step S405). This state corresponds to the processing when the key pressing event t1, t4, or t11 in the operation explanatory diagram of
When it is determined that the elapsed time is not 0 (when the determination in step S404 is NO), the elapsed time for shifting to the layer mode on has already been measured, and therefore, the start of the measurement of the elapsed time in step S405 is skipped. This state corresponds to the process that is performed when any one of the key pressing events t2, t5, t6, t12, t13, and t14 occurs in the operation explanatory diagram of
After the measurement of the elapsed time for shifting to the layer mode on is started in step S405, or the determination in step S404 is NO because the measurement of the elapsed time has been already started, the CPU 201 stores the pitch data whose sound production is instructed in the key press event (the note number whose sound production with the basic timbre is instructed in step S402) in RAM 203, for example, as a candidate for sound production with the layer timbre (step S406).
After that, the CPU 201 adds 1 to the value of a variable on the RAM 203 (hereinafter, this variable is referred to as the “current number of notes” variable) for counting the current number of tones that are considered to be pressed at the same time so as to update the value of the current number of notes variable (step S407). The value of this current number of notes variable is counted in order to compare it with the prescribed number of notes N that is regarded as being pressed at the same time when the elapsed time T has elapsed in the elapsed time monitoring process shown in the flowchart of
After that, the CPU 201 ends the current keyboard event processing shown in the flowchart of
By repeating the series of processes from steps S404 to S407 for each keyboard event process described above, as preparation for the transition from layer mode off to layer mode on, in the operation example of
When it is determined in step S401 described above that the interrupt notification indicates a key release event, the CPU 201 instructs the sound source LSI 204 to mute the first musical tone of the basic timbre with the pitch data (note number) included in the interrupt notification indicating the key release event that has been produced by the sound source LSI 204 (see step S402). By this processing, in the operation example of
Next, the CPU 201 determines whether or not the released key is the key for which the layer mode is turned on (step S409). Specifically, the CPU 201 determines whether or not the pitch data of the released key is included in the pitch data group (see step S406) of the candidates for the sound production with the layer timbre stored in the RAM 203.
If the determination in step S409 is NO, the CPU 201 ends the current keyboard event processing shown in the flowchart of
If the determination in step S409 is YES, the CPU 201 instructs the sound source LSI to mute the second tone of the layer timbre that has been produced by the sound source LSI with the pitch data (note number) included in the interrupt notification indicating the key release event (see step S504 in
Subsequently, the CPU 201 deletes the record of the pitch data of the released key from the pitch data group of the candidates for the sound generation of the layer timbre stored in the RAM 203 (see step S406) (step S411).
Thereafter, the CPU 201 determines whether or not all the keys that have triggered the layer mode on have been released (step S412). Specifically, the CPU 201 determines whether or not all the pitch data for the sound production of the layer timbre stored in the RAM 203 have been deleted.
If the determination in step S412 is NO, the CPU 201 ends the current keyboard event processing shown in the flowchart of
If the determination in step S412 is YES, the CPU 201 sets the layer mode off by setting the value of the layer mode variable stored in the RAM 203 to a value indicating off (step S413). In the operation example of
After that, the CPU 201 ends the current keyboard event processing shown in the flowchart of
In the elapsed time monitoring process exemplified by the flowchart of
Next, the CPU 201 determines whether or not the value of the elapsed time variable is equal to or greater than the elapsed time T, which defines a time period for simultaneous kay pressing (step S502).
When the determination in step S502 is NO, that is, when the value of the elapsed time variable is less than the elapsed time T, which defines a time period for simultaneous kay pressing, the current elapsed time monitoring process shown in the flowchart of
When the determination in step S502 is YES, that is, when the elapsed time variable value becomes equal to or greater than the elapsed time T, which defines a time period for simultaneous kay pressing, the CPU 201 determines whether or not the value of the current number of notes variable stored in the RAM 203 (see step S407 of
If the determination in step S503 is YES, the CPU 201 instructs the sound source LSI 204 to produce second tones of the layer timbre with the pitch data of the notes indicated by the current number of notes variable stored in RAM 203 (see step S406 in
Subsequently, the CPU 201 sets the value of the layer mode variable stored in the RAM 203 to a value indicating “on,” to set the layer mode on (step S505).
According to the above steps S504 and S505, in the operation example of
After the sound production instruction for the layer tone is issued in step S504 and the layer mode on is set in step S505, or when it is determined that the current value of the number of notes variable is less than N and the determination in step S503 becomes NO, the CPU 201 clears the value of the elapsed time variable stored in the RAM 203 to 0 (step S506).
Further, the CPU 201 clears the value of the current number of notes variable stored in the RAM 203 to 0 (step S507).
Thereafter, the CPU 201 ends the elapsed time monitoring process shown in the flowchart of
In the operation explanatory diagram of
As described above, the possible basic timbres (first timbre) having the time-range amplitude characteristics of
As described above, the possible layer timbres (second timbres) having the time domain amplitude characteristic of
When playing a long note, two contrasting tones, the first musical tone 603 of the basic timbre and the second musical tone 604 of the layer timbre, are generated at the same time. At the time of key pressing, the first musical tone 603 of the basic timbre is dominant, and later in time and when the key is released, the second musical tone 604, which is a layer timbre with a slow rise and decay, is produced in the form of crossfading, thereby realizing a comfortable thick sound especially when playing a chord.
On the other hand, when playing a short note, the first musical tone 605 of the basic timbre, which has a rapid decay, is quickly attenuated, and the second musical tone 606 of the layer timbre, which has a longer decay, remains. As a result, when a quick single note phrase is played, the rising tone of the first musical tone 605 of the basic timbre corresponding to the current key press and the attenuated tone of the second musical tone 606 of the layer timbre corresponding to the immediately preceding key press overlap, and a distorted sound is produced.
Therefore, by taking into account the fact that long notes are mainly used in chord playing, short notes are often used in single-tone solo performance as well as the fact that the second musical tone of the layer timbre has a slow rise, thereby not affecting the performance even if a slight delay in sound production occurs, the above-described embodiment is controlled such that the second musical tones of the layer timbre are not generated except when the user's performance is regarded as a chord playing.
That is, although the production of the second musical tones of the layer timbre is suspended while the key press is being monitored for a certain period (T=25 milliseconds in the above embodiment) in order to determine whether or not a chord is played, because the layer timbre is a tone for which a rise time of about 1 to 2 seconds is set, a delay of such a degree provides almost no influence on music.
As described above, in this embodiment, a basic timbre that is always sounded when a key is pressed and a layer timbre that is sounded only when the layer mode is on for the key is pressed are selected in advance, and it is judged whether or not the user's performance is a chord playing based on the number of keys pressed and the time interval of the multiple key presses. Then, the layer mode on status is set with respect to only the note group corresponding to the pressed keys that are determined to be a chord playing, and the corresponding second musical tones of the layer timbre for the note group are produced.
According to the above embodiment, because the unison effect can be automatically added only to the required musical tones by the performer performing naturally without performing any special operations, the performer can concentrate on his/her own performance without compromising the performance or musical tones.
In addition to or as an alternative to the embodiment described above, one or more of the following features can also be implemented.
1. Enable the unison performance function with the layer timbre only in a specific key range, for example, in the key range of C3 or lower.
2. Enable the unison performance function with the layer timbre only in a specific velocity range, for example, only for sounds with a velocity value of 64 or less.
3. If a solo performance (non-layer performance) is recognized, the unison performance function with the layer timbre will not be activated for a certain set period of time. For example, while performing a solo performance that does not meet the conditions for transition to the layer mode on, even if a chord is played for a moment, the system will not transition to the layer mode on and will be regarded as part of the solo for a duration of 3 seconds, for example.
4. When the legato playing method is recognized, the unison playing function with layer timbre is activated.
In the above-described embodiments, an example in which the unison playing function by the layer timbre is implemented in the electronic keyboard instrument 100 has been described, but the present function may also be implemented in an electronic string instrument such as a guitar synthesizer or a guitar controller.
It will be apparent to those skilled in the art that various modifications and variations can be made in the present invention without departing from the spirit or scope of the invention. Thus, it is intended that the present invention cover modifications and variations that come within the scope of the appended claims and their equivalents. In particular, it is explicitly contemplated that any part or whole of any two or more of the embodiments and their modifications described above can be combined and regarded within the scope of the present invention.
Number | Date | Country | Kind |
---|---|---|---|
2020-109089 | Jun 2020 | JP | national |