1. Field of the Invention
The present invention relates generally to the automatic composition of music and/or sounds.
2. Description of the Related Art
The automatic composition of music is something that can be enjoyed by amateurs and professionals. While the variations in musical compositions are endless, the quality of a musical composition is difficult to quantify because what sounds good to one person may sound discordant to another. The wide variety of musical styles and compositions can make it difficult to begin a composition.
There are computer programs that can assist in the composition of music based on input from a user such as time signatures and chord progressions. The requirement for a user to know chord progressions and other musical terminology can be a barrier that prevents a user with no musical knowledge from using such programs. The underlying algorithms that determine how musical notes are combined and transitioned may also be limited to a specific ethnic and cultural musical aesthetic.
In view of the forgoing, there is a need for automatic composition of musical sequences capable of encompassing many styles of musical composition.
In one embodiment, a method for dynamically analyzing input sounds and processing the input sounds to define a new set of output sounds, is provided. The method includes receiving a first set of input sounds and a second set of input sounds, where each of the first and second sets of input sounds are processed to identify one of a tone, intensity, or frequency, and a duration. The method defines a node for each identified input sound and a link between the input sounds of the first and second sets of input sounds. The nodes and links from the first and second sets of input sounds create a respective first and second finite state automata. A history value is defined for processing the nodes of the first and second sets of input sounds, and the history value defines a number of previous nodes that will be identical in each of the first and second sets of input sounds before a particular node is shared between the first and second sets of input sounds. Then, the method forms the new set of output sounds from a third finite state automaton that includes nodes from the first and second set of input nodes and nodes that are shared based on meeting the history value.
In another embodiment, a method for the automatic composition of music is disclosed. The method begins by receiving a plurality of input sound sequences containing sound frequencies with corresponding time duration. The method continues with converting the plurality of input sound sequences to a finite state automaton using a system that allows over-generation, followed by receiving exploration rules that constrain how the finite state automaton is to be traversed. The next step is creating a path marker data structure indexing a plurality of path markers, where each path marker contains a path marker history and a path marker registry. After the path marker data structure is created, the method continues by traversing the finite state automaton with a graph exploration procedure that uses the exploration rules and the plurality of path markers to determine path across the finite state automaton. During the exploration the path marker history and the path marker registry of particular path markers are updated when traversing the finite state automaton. As the finite state automaton is traversed the method includes storing the paths across the finite state automaton to the path marker data structure to define recorded path markers, wherein the recorded path markers that are not found in the plurality of input sound sequences define a new music composition.
In yet another embodiment a computer readable media including program instructions for composing music is disclosed. The computer readable media includes program instructions for receiving a plurality of input sound sequences containing sound frequencies and corresponding and time durations. The computer readable media also includes program instructions for converting the plurality of input sound sequences to a finite state automaton using a system that allows over-generation. Program instructions for traversing the finite state automaton using a graph exploration procedure that uses exploration rules and a plurality of path markers to determine paths across the finite state automaton are also included. The computer readable media also includes program instructions for storing the paths across the finite state automaton to a path marker data structure to define recorded path markers. Wherein the recorded path markers that are not found in the plurality of input sound sequences define a new sound sequences.
In still another embodiment a method for generating new sound sequences based on input sounds is disclosed. The method is initiated by receiving a plurality of input sound sequences containing sound frequencies with corresponding time duration. The method continues by converting the plurality of input sound sequences to a finite state automaton using a system that allows over-generation. The next operation of the method is traversing the finite state automaton with a graph exploration procedure that uses exploration rules and a plurality of path markers to determine paths across the finite state automaton. The method continues by storing the paths across the finite state automaton to a path marker data structure to define recorded path markers, wherein the recorded path markers that are not found in the plurality of input sound sequences define a new sound sequence.
Other aspects and advantages of the invention will become apparent from the following detailed description, taken in conjunction with the accompanying drawings, illustrating by way of example the principles of the invention.
The invention, together with further advantages thereof, may best be understood by reference to the following description taken in conjunction with the accompanying drawings.
An invention is disclosed for automatically generating new sound combinations derived from input sounds having frequencies and temporal duration. For example, in one embodiment of the invention a microphone can input sound frequencies and durations that are used as the basis for a new combination of sound frequencies and duration. In another example, the invention could input a written musical composition to generate new musical composition. In the following description, numerous specific details are set forth in order to provide a thorough understanding of the present invention. It will be apparent, however, to one skilled in the art that the present invention may be practiced without some or all of these specific details. In other instances, well known process steps have not been described in detail in order not to unnecessarily obscure the present invention.
Broadly defined, “music” may be understood as a series of sound frequencies where the sound frequencies have a specified magnitude, intensity, and/or temporal duration. Music, being a sequence of notes, can be represented by a finite state automaton. In one embodiment, a finite state automaton is a transitional model composed of states and transitions. A FSA may be interpreted as a directed graph because the transition can have a direction. In one embodiment the states, also referred to as nodes, of the FSA, may represent a musical note having a frequency and duration. A transition between notes/states/nodes can be represented by a link connecting states/nodes in the FSA. The finite state automaton can be constructed in any number of ways. For instance, the finite state automaton may initially be constructed by parsing input sounds. The input sounds may be, in one embodiment, a set of sounds or a music clip. Once the finite state automaton is created, post processing and analysis may dictate a degree of generation that can be applied to the linking of nodes. Thus, new finite state automata can be created, defining new music or groups of sounds. In one embodiment, the new node combinations can be viewed as a new musical composition. As will be defined below in more detail, traversing the finite state automaton and applying a path marker, in accordance with one embodiment of the present invention, can generate the new node combinations. For instance, as the finite state automaton is traversed, a path maker can record the progression across the nodes. The node sequences within the path markers may allow for the recreation of the original music when the sound frequencies and durations captured within the nodes are given a sound or musical voice.
After operation 100 the procedure moves to operation 102 where a computer analyzes the musical notes and generates a finite state automaton. The finite state automaton is based on the sequence of musical notes and a user-defined history value allows over-generation within the finite state automaton. A more detailed description of how the history value 104 controls over-generation can be found below.
In operation 106 a graph exploration procedure is used to traverse the finite state automaton. The graph exploration procedure is prevented from entering infinite loops within the finite state automaton by exploration rules 108. The output of the operation 106 are paths that are saved in path markers 110. A path is a sequence of nodes that can be repeated, and in one embodiment, may be the result of traversing the FSA. Because the transition between two states/nodes may be determined by the transitions/links, a path may be a string of links. Path markers 110 can be used to record information regarding the paths taken through the finite state automaton. Included within the path markers are the original musical notes and possibly new combinations of musical notes. A more thorough description of the role path makers can be found in the discussion of
Because the path markers contain the possible combination of the finite state automaton, operation 112 uses the path markers in conjunction with a Musical Instrument Digital Interface (MIDI) synthesizer to generate sounds. The midi synthesizer gives the sound frequency and duration of the individual nodes stored within the path markers a “voice” such as a piano, trumpet, or other synthesized or recorded sound. Operation 114 outputs the musical notes as sounds from the MIDI synthesizer. In another embodiment the path markers can be turned into a written musical form capable of being displayed on a monitor, stored on computer readable media, or printed. In yet another embodiment the musical notes stored within the path markers are given a voice using a sound reproduction method other than MIDI.
Thus, using a history value of two when analyzing the sentence “You are a good girl.” with respect to the sentence “I am a good boy”, even though there appears to be the common node “a”, because the two preceding nodes “You are” 204 are not the same as “I am” 206 the pre-existing “a” node will not be shared and a new node will be created for the “a” in “You are a good girl.” Similarly, the two preceding nodes before “good”, “am a”, do not match “are a” so a new node will be created for “good” in the sentence “You are a good girl.” Note that traversing the finite state automaton in
The over-generation demonstrated with words in
Returning to the completion of operation 308, the procedure advances to operation 312 that writes the path marker history from the origin node to the path marker history for the destination node. The next step, operation 314, examines the path marker registry to determine if there are violations of exploration rules. Since the finite state automaton can be created with recursive paths (repeated notes or musical phrases included in the input sequences) it is possible that the graph exploration procedure could become mired in an infinite loop. The exploration rule is a user-defined value that examines the path marker history for repetitive loops and blocks the link if the exploration rule is violated. For example, the exploration rule can be set to examine the path marker history for four nodes that have been repeated three times. Therefore, when the graph exploration procedure attempts to traverse the same nodes for a fourth time the link will be blocked. In another embodiment it would be possible to assign different exploration rules to different portions of the musical composition. Having varying exploration rules would allow a user to have increased flexibility regarding portions of the musical composition such as the chorus or main theme. There are many possible variations of exploration rules because a user can define the number of nodes to examine and the number of times a loop can be repeated before the link is blocked. The examples given are not intended to be restrictive but rather exemplary of implementations of various exploration rules.
If the exploration rules have been violated, the procedure proceeds with operation 316 and writes to the path marker registry of the origin node that the specific link is blocked. The procedure continues to operation 318, which is also the destination if the exploration rules of operation 312 are not violated.
If there are un-followed links from the origin node, operation 318 returns the procedure to operation 302. If all of the links from the origin node have been followed, operation 318 advances the procedure to operation 320. Operation 320 checks if the procedure has traversed the nodes and arrived at the END node. If the exploration has come to the END node the procedure continues to operation 322 where the path marker history is written at the END node. If the graph exploration procedure has not reached the END node, operation 324 examines the path marker registry to see if any blocked links are saved. If there are no blocked links saved in the path marker registry, the procedure advances to operation 326 where the origin node path marker is deleted. Completion of operation 326 advances the procedure to operation 328 where the destination node is renamed as the origin node. Operation 328 is also the destination if operation 324 finds blocked links saved in the path marker registry. Following operation 328 the procedure returns to operation 302.
In another embodiment, a partial exploration of the FSA may be conducted. During a partial exploration, it is possible that only a portion of all of the sequences included in the FSA are generated. Partial exploration can allow the rapid generation of one or many paths as opposed to the generation of all the possible paths that can be a lengthy operation. The types of user-defined limitation controlling a partial exploration are unlimited. One example is a time duration ensuring that a partial exploration is completed within a user specified time period. Another example is terminating the partial exploration after a user specified number of sequences have been saved in the path marker history of the END node. It would also be possible to use combinations of user-defined limitations to control a partial exploration. As previously mentioned, there can be unlimited number of user defined limitations to control partial explorations and the particular examples provided are not intended to be restrictive.
Viewing
With node A designated the origin node the procedure returns to operation 302. Referencing
Referring to
As an alternative, the exploration rules could have been configured to block a departure link when two nodes have been repeated in a path marker history more than three times. In that case, operation 314 would have blocked the link between node H and node F after seeing the combination of node H and node F three times in the path marker for node H in
Many of the figures use words, phrases or letter designators because of the difficulty of representing sound in a written form. It should be understood that some of the same or similar techniques used to create a finite state automaton from words can be applied to the creation of a finite state automaton from sounds. For more information regarding creating finite state automata from words, reference may be made to co-owned U.S. Application: application Ser. No. 11/437,444, entitled, S
When creating the finite state automaton using sounds there are many different aspects of sound that can be considered when determining if two nodes can be linked. Sound frequency and a corresponding duration have been previously discussed. In another embodiment it would also be possible to analyze the amplitude of the sound frequency. Using the amplitude as a factor in determining node linking would ensure that quite sounds are not mixed with loud sounds. In another embodiment, a frequency with a duration that exceeds a specified time period can be analyzed for changes in amplitude. For example, a sustained note/sound may have a crescendo or diminuendo. Detecting the change in amplitude would make it possible to match nodes with similar amplitudes and the proper frequency at the beginning and ending of the sustained note/sound.
Although the END node path marker history in
One of the many benefits of analyzing input sounds and creating a finite state automaton is that the sounds do not need to be transcribed into a written format. This enables embodiments of the invention to be used with all forms of music including those with no written form. Thus, when the finite state automaton created by input sounds is traversed by the graph exploration procedure it is possible that cultural and ethnics themes, motifs, and harmonies will be replicated and modified in the resulting new music.
It should also be noted that the disclosed techniques capable of generating new sound sequences could be applied to other technology areas, such as, text sentence generation in any given language. To generate new sentences, input sentences could be converted into a finite state automaton and grammar rules could supplement the graph exploration procedure and exploration rules to foster the creation of coherent logical sentences. Accordingly, with the various applications in mind, it will be well understood that the described embodiments and equivalent modifications have a multitude of useful applications. The invention may be practiced with other computer system configurations including game consoles, gaming computers or computing devices, hand-held devices, microprocessor systems, microprocessor-based or programmable consumer electronics, minicomputers, mainframe computers and the like. The invention may also be practiced in distributing computing environments where tasks are performed by remote processing devices that are linked through a network. For instance, on-line gaming systems and software may also be used.
With the above embodiments in mind, it should be understood that the invention may employ various computer-implemented operations involving data stored in computer systems. These operations are those requiring physical manipulation of physical quantities. Usually, though not necessarily, these quantities take the form of electrical or magnetic signals capable of being stored, transferred, combined, compared, and otherwise manipulated. Further, the manipulations performed are often referred to in terms, such as producing, identifying, determining, or comparing.
Any of the operations described herein that form part of the invention are useful machine operations. The invention also relates to a device or an apparatus for performing these operations. The apparatus may be specially constructed for the required purposes, such as the carrier network discussed above, or it may be a general purpose computer selectively activated or configured by a computer program stored in the computer. In particular, various general purpose machines may be used with computer programs written in accordance with the teachings herein, or it may be more convenient to construct a more specialized apparatus to perform the required operations.
The invention can also be embodied as computer readable code on a computer readable medium. The computer readable medium is any data storage device that can store data, which can thereafter be read by a computer system. Examples of the computer readable medium include hard drives, network attached storage (NAS), read-only memory, random-access memory, FLASH based memory, CD-ROMs, CD-Rs, CD-RWs, DVDs, magnetic tapes, and other optical and non-optical data storage devices. The computer readable medium can also be distributed over a network coupled computer systems so that the computer readable code is stored and executed in a distributed fashion.
Although the foregoing invention has been described in some detail for purposes of clarity of understanding, it will be apparent that certain changes and modifications may be practiced within the scope of the appended claims. Accordingly, the present embodiments are to be considered as illustrative and not restrictive, and the invention is not to be limited to the details given herein, but may be modified within the scope and equivalents of the appended claims.
This application is a divisional application of U.S. application Ser. No. 11/542,699, filed on Oct. 3, 2006, and entitled “Automatic Composition of Sound Sequences Using Finite State Automata,” which is herein incorporated by reference. This application is related to U.S. application Ser. No. 11/437,444, filed May 19, 2006 and entitled, STRUCTURE FOR GRAMMAR AND DICTIONARY REPRESENTATION IN VOICE RECOGNITION AND METHOD FOR SIMPLIFYING LINK AND NODE-GENERATED GRAMMARS, and U.S. application Ser. No. 12/780,818, filed on May 14, 2010, and entitled METHOD AND SYSTEM FOR GRAMMAR FITNESS EVALUATION AS SPEECH RECOGNITION ERROR PREDICTOR,” both of which are herein incorporated by reference.
Number | Date | Country | |
---|---|---|---|
Parent | 11542699 | Oct 2006 | US |
Child | 13020776 | US |