The invention relates to channel allocation methods for music synthesis systems, and in particular to dynamic channel allocation methods.
Music synthesis systems can be employed in various devices or systems, such as mobile phones, computers, or game machines, for music synthesis.
MIDI player 100 utilizes channels. Audio instructions from MIDI player 100 correspond to channels thereof. A music synthesizer 102 is shown on the right of
Here, channel-10 in music synthesizer 102 is a specific channel for percussion audio instructions. If audio instructions are percussion type, the allocated channel in MIDI player 100 is channel-10 according to MIDI channel specifications. Thus, percussion audio instructions are always assigned to channel-10 in the music synthesizer 102 according to conventional allocation methods. All audio instructions sent to channel-10 in the music synthesizer 102 are interpreted as percussion audio instructions without pitch.
In an exemplary embodiment of dynamic channel allocation method for a music synthesis system with a synthesizer, by which audio instructions from sources are received. The sources can be players using MIDI or other formats. Available channels provided by the synthesizer are sought. Located available channels are assigned dynamically to the received audio instructions. Each audio instruction corresponds to a channel. If received audio instructions are percussion type, any available channel can be assigned as a percussion channel without channel limitation.
The present invention can be more fully understood by reading the subsequent detailed description and examples with references made to the accompanying drawings, wherein:
Methods of dynamic channel allocation for a music synthesis system are provided. The music synthesis system comprises a synthesizer with channels for music synthesis.
The number of available channels depends on the system resource. If the number of available channels is designed as fixed, the available channels are allocated before seeking. In step S34, if the number of available channels is floatable, the seeking of available channels comprises unused memory allocation. Thus, channels can be allocated dynamically. The available channels can be managed through some data structure, such as linking list, for better performance.
Here, any available channel can be dynamically set as a percussion instrument channel to be assigned to a percussion type audio instruction, while conventional allocation methods can only assign a specific channel, for example, channel-10, to the percussion type audio instruction. In step S30, the sources may have different priorities for music synthesis. For example, MIDI player-1 may be a main player and MIDI player-2 may be a secondary player. Thus, the received audio instructions can be divided according to the priorities of the sources therefrom. Channel assignation is executed according to predetermined priorities of the audio instructions. Namely, the audio instructions from the MIDI player-1 have higher priorities than the audio instructions from the MIDI player-2 to be assigned to the located channels.
The reception module 42 receives audio instructions from sources, such as MIDI players. The search module 44 is coupled to the reception module 42. The search module 44 seeks available channels provided by the music synthesizer 40. The assignation module 45, coupled to the search module 44, assigns channels to the audio instructions, each of which corresponds to a channel. The determination module 46 determines the type of each of the received audio instructions. Here, again, the number of available channels depends on the system resource. If the number of available channels is fixed, the search module 44 allocates unused memory as available channels before seeking. The available channels can be managed through some data structure, such as linking lists. For example, if the reception module 42 receives audio instructions from sources, the search module 44 allocates unused memory as available channels according to the system resource. The assignation module 45 then assigns the allocated available channels to the audio instructions.
If the audio instruction is a percussion type audio instruction, the setting module 47 sets the channel assigned to the percussion type audio instruction as a percussion instrument channel. If the audio instruction is a melody type audio instruction, the setting module 47 sets the channel assigned to the melody type audio instruction as a melody instrument channel. The synthesis module 48 synthesizes the audio instructions.
Specifically, sources may have different priorities. Thus, the channels are located and assigned the audio instructions according to the priorities. In some embodiment, audio instructions from one specific MIDI player may have higher priority than other audio instructions. The assignation module 46 executes channel assignation according to predetermined priorities of the audio instructions.
In some embodiment, the priorities of the audio instructions are determined by the order of the audio instructions received by the music synthesizer 40.
The synthesizer 52 allocates audio instructions 56 to channels 54 thereof. Each audio instruction corresponds to a channel. The synthesizer 52 also determines the type of each of the received audio instructions. If the audio instruction is a percussion type audio instruction, the synthesizer 52 sets the channel assigned to the percussion type audio instruction as a percussion instrument channel. If the audio instruction is a melody type audio instruction, the synthesizer 52 sets the channel assigned to the melody type audio instruction as a melody instrument channel. In some embodiment, the audio instructions may have priorities based on sources thereof. In some embodiment, the audio instructions may have priorities based on the order of being received by the synthesizer 52. If the audio instructions have priorities, the synthesizer 52 executes allocation according to predetermined priorities of the audio instructions. In one embodiment, the sources can be MIDI players.
For example, an audio instruction 608 comes from channel-1 of MIDI player-1 (600). The music synthesizer 606 receives the audio instruction 608 and seeks the available channel. Channel-3 (610) is sought as an available channel. Thus, the audio instruction 608 is assigned to channel-3 (610) of the synthesizer 606. Then, it is determined that the audio instruction 608 is a melody type audio instruction, and the channel assigned to the audio instruction 608 is set as a melody instrument channel.
As another example, an audio instruction 612 comes from channel-10 of MIDI player-1 (600). The music synthesizer 606 then seeks available channel. Channel-4 (614) is sought as an available channel. Thus, the audio instruction 612 is assigned to channel-4 (614) of the synthesizer 606. Then, it is determined that the audio instruction 612 is a percussion type audio instruction because the audio instruction 612 comes from channel-10 of MIDI player-1 (600), and the channel assigned to the audio instruction 612 is set as a percussion instrument channel.
In some embodiment, the synthesizer 606 has 20 channels to be assigned to 20 audio instructions. The audio instructions coming from channel-1, 3, 4, 10 of MIDI player-1 (600), channel-1, 2, 10 of MIDI player-2 (602), and channel-1, 2 of MIDI player-3 (604) are received by the music synthesizer 606. The music synthesizer 606 then seeks and assigns the 9 available channel-1, 2, 3, 4, 8, 10, 18, 19, 20 to the received audio instructions. Then, the type of each of the received audio instructions is determined, and the channel-4, 18 of the music synthesizer 606 assigned to the percussion type audio instructions are set as percussion instrument channels while the channel-1, 2, 3, 8, 10, 19, 20 of the music synthesizer 606 are set as melody instrument channels.
Compared to conventional methods, the present invention allocates channels more flexibly and dynamically, because percussion type audio instructions are only assigned to channel-10 in convention methods. The number of channels depends on the resources of a synthesizer. Moreover, if a synthesizer cannot find available channels thereof, rejection notification may be sent to MIDI players.
Thus, methods and systems of dynamic channel allocation for a music synthesizer may potentially resolve the inconvenience of conventional channel allocation methods. The disclosed methods are particularly useful for a music synthesizer in an embedded system.
Methods of the present invention, or certain aspects or portions of embodiments thereof, may take the form of program code (i.e., instructions) embodied in media, such as floppy diskettes, CD-ROMS, hard drives, firmware, or any other machine-readable storage medium, wherein, when the program code is loaded into and executed by a machine, such as a computer, the machine becomes an apparatus for practicing and embodiment of the invention. The methods and apparatus of the present invention may also be embodied in the form of program code transmitted over some transmission medium, such as electrical wiring or cabling, through fiber optics, or via any other form of transmission, wherein, when the program code is received and loaded into and executed by a machine, such as a computer, the machine becomes an apparatus for practicing and embodiment of the invention. When implemented on a general-purpose processor, the program code combines with the processor to provide a unique apparatus that operates analogously to specific logic circuits.
While the invention has been described by way of example and in terms of preferred embodiment, it is to be understood that the invention is not limited thereto. Those who are skilled in this technology can still make various alterations and modifications without departing from the scope and spirit of this invention. Therefore, the scope of the present invention shall be defined and protected by the following claims and their equivalents.
Number | Name | Date | Kind |
---|---|---|---|
5042355 | Kozuki | Aug 1991 | A |
5095800 | Matsuda | Mar 1992 | A |
5315057 | Land et al. | May 1994 | A |
5380949 | Matsuda | Jan 1995 | A |
5488196 | Zimmerman et al. | Jan 1996 | A |
5744740 | Mizuno | Apr 1998 | A |
5852251 | Su et al. | Dec 1998 | A |
5902947 | Burton et al. | May 1999 | A |
5902949 | Mohrbacher | May 1999 | A |
5959232 | Wakuda | Sep 1999 | A |
6091012 | Takahashi | Jul 2000 | A |
6198035 | Saito et al. | Mar 2001 | B1 |
6226697 | Tokuhiro | May 2001 | B1 |
6414232 | Ikeya | Jul 2002 | B2 |
6423893 | Sung et al. | Jul 2002 | B1 |
6670535 | Anderson et al. | Dec 2003 | B2 |
6806412 | Fay | Oct 2004 | B2 |
7005572 | Fay | Feb 2006 | B2 |
7012185 | Holm et al. | Mar 2006 | B2 |
7045700 | Hamalainen et al. | May 2006 | B2 |
7045752 | Posamentier et al. | May 2006 | B2 |
20010045455 | Kreuter et al. | Nov 2001 | A1 |
20020124715 | Fay | Sep 2002 | A1 |
20020170415 | Hruska et al. | Nov 2002 | A1 |
20020189430 | Mukojima | Dec 2002 | A1 |
20030015084 | Bengtson | Jan 2003 | A1 |
20040060422 | Anderson et al. | Apr 2004 | A1 |
20050056143 | Fay | Mar 2005 | A1 |
20050075882 | Fay et al. | Apr 2005 | A1 |
20050076770 | Stone et al. | Apr 2005 | A1 |
20050091065 | Fay et al. | Apr 2005 | A1 |