WO2005093711A1 - Autonomous musical output using a mutually inhibited neuronal network - Google Patents

Autonomous musical output using a mutually inhibited neuronal network Download PDF

Info

Publication number
WO2005093711A1
WO2005093711A1 PCT/IB2004/001053 IB2004001053W WO2005093711A1 WO 2005093711 A1 WO2005093711 A1 WO 2005093711A1 IB 2004001053 W IB2004001053 W IB 2004001053W WO 2005093711 A1 WO2005093711 A1 WO 2005093711A1
Authority
WO
WIPO (PCT)
Prior art keywords
nodes
node
musical
interval
creating
Prior art date
Application number
PCT/IB2004/001053
Other languages
French (fr)
Inventor
Pauli Laine
Juho NIEMISTÖ
Original Assignee
Nokia Corporation
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Nokia Corporation filed Critical Nokia Corporation
Priority to US10/591,828 priority Critical patent/US20070280270A1/en
Priority to PCT/IB2004/001053 priority patent/WO2005093711A1/en
Publication of WO2005093711A1 publication Critical patent/WO2005093711A1/en

Links

Classifications

    • GPHYSICS
    • G10MUSICAL INSTRUMENTS; ACOUSTICS
    • G10HELECTROPHONIC MUSICAL INSTRUMENTS; INSTRUMENTS IN WHICH THE TONES ARE GENERATED BY ELECTROMECHANICAL MEANS OR ELECTRONIC GENERATORS, OR IN WHICH THE TONES ARE SYNTHESISED FROM A DATA STORE
    • G10H1/00Details of electrophonic musical instruments
    • G10H1/0008Associated control or indicating means
    • G10H1/0025Automatic or semi-automatic music composition, e.g. producing random music, applying rules from music theory or modifying a musical piece
    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06NCOMPUTING ARRANGEMENTS BASED ON SPECIFIC COMPUTATIONAL MODELS
    • G06N3/00Computing arrangements based on biological models
    • G06N3/02Neural networks
    • GPHYSICS
    • G10MUSICAL INSTRUMENTS; ACOUSTICS
    • G10HELECTROPHONIC MUSICAL INSTRUMENTS; INSTRUMENTS IN WHICH THE TONES ARE GENERATED BY ELECTROMECHANICAL MEANS OR ELECTRONIC GENERATORS, OR IN WHICH THE TONES ARE SYNTHESISED FROM A DATA STORE
    • G10H2210/00Aspects or methods of musical processing having intrinsic musical character, i.e. involving musical theory or musical parameters or relying on musical knowledge, as applied in electrophonic musical tools or instruments
    • G10H2210/101Music Composition or musical creation; Tools or processes therefor
    • G10H2210/111Automatic composing, i.e. using predefined musical rules
    • GPHYSICS
    • G10MUSICAL INSTRUMENTS; ACOUSTICS
    • G10HELECTROPHONIC MUSICAL INSTRUMENTS; INSTRUMENTS IN WHICH THE TONES ARE GENERATED BY ELECTROMECHANICAL MEANS OR ELECTRONIC GENERATORS, OR IN WHICH THE TONES ARE SYNTHESISED FROM A DATA STORE
    • G10H2220/00Input/output interfacing specifically adapted for electrophonic musical tools or instruments
    • G10H2220/155User input interfaces for electrophonic musical instruments
    • G10H2220/371Vital parameter control, i.e. musical instrument control based on body signals, e.g. brainwaves, pulsation, temperature, perspiration; biometric information
    • GPHYSICS
    • G10MUSICAL INSTRUMENTS; ACOUSTICS
    • G10HELECTROPHONIC MUSICAL INSTRUMENTS; INSTRUMENTS IN WHICH THE TONES ARE GENERATED BY ELECTROMECHANICAL MEANS OR ELECTRONIC GENERATORS, OR IN WHICH THE TONES ARE SYNTHESISED FROM A DATA STORE
    • G10H2250/00Aspects of algorithms or signal processing methods without intrinsic musical character, yet specifically adapted for or used in electrophonic musical processing
    • G10H2250/311Neural networks for electrophonic musical instruments or musical processing, e.g. for musical recognition or control, automatic composition or improvisation
    • GPHYSICS
    • G10MUSICAL INSTRUMENTS; ACOUSTICS
    • G10HELECTROPHONIC MUSICAL INSTRUMENTS; INSTRUMENTS IN WHICH THE TONES ARE GENERATED BY ELECTROMECHANICAL MEANS OR ELECTRONIC GENERATORS, OR IN WHICH THE TONES ARE SYNTHESISED FROM A DATA STORE
    • G10H2250/00Aspects of algorithms or signal processing methods without intrinsic musical character, yet specifically adapted for or used in electrophonic musical processing
    • G10H2250/315Sound category-dependent sound synthesis processes [Gensound] for musical use; Sound category-specific synthesis-controlling parameters or control means therefor
    • G10H2250/435Gensound percussion, i.e. generating or synthesising the sound of a percussion instrument; Control of specific aspects of percussion sounds, e.g. harmonics, under the influence of hitting force, hitting position, settings or striking instruments such as mallet, drumstick, brush, hand

Definitions

  • Embodiments of the invention relate to generating autonomous musical output using a mutually inhibited neuronal network.
  • Embodiments of the invention are able to generate very long and 'musical' output that does not easily become non-periodic and has sub-periods.
  • Fig 1 illustrates a network object
  • Fig 2 illustrates a graphical user interface
  • An artificial neuronal network is a set of connected computational nodes.
  • the network is not a learning network in which changes in connection weights are inspected but is a small network of between 5 and 50 nodes (typically) in which the dynamic firing behavior of the network is inspected in detail at regular intervals.
  • Each node can be connected to receive a neuronal impulse or impulses, output from one or more other nodes, and each node can be connected to provide as output a neuronal impulse to one or more other nodes.
  • a neuronal impulse received at a node can have an activation or an inhibitory effect depending upon whether the connection on which the neuronal impulse is received is an activation connection or an inhibitory connection.
  • An activation effect increases the activation level of the node according to a simple activation function, such as a sigmoid function.
  • An inhibiting effect inhibits or prevents an increase in the activation level of the node. When the node's activation level reaches a threshold value, the node fires and produces a neuronal impulse as output. After firing the activity level of the node quickly goes to zero or a low nonzero value depending upon implementation.
  • An input impulse received at a node may be a neuronal impulse output from a connected node or may be one of a plurality of excitory impulses provided across the network according to a predetermined pattern. These excitory impulses have an activation effect. They increase the activity of the network and may be provided to all or some of the nodes of the network at each interval.
  • An additional feature of the described neuronal network model is the vanishing (excitation) parameter. If the vanishing (excitation) parameter is zero or not implemented, then if there is no excitory or neuronal activation input the activation level of the node would remain constant. However, in the preferred implementation, the current activation level is multiplied by the vanishing
  • (excitation) parameter value which is may be grater or less than 1 and is typically a value between 0.5 to 1.2. If the vanishing parameter is greater than 1 , then after a certain time, and even without any input, the activation level reaches the threshold and the node fires, after that the activation level decreases to or near to zero depending upon implementation. This feature introduces self-oscillation, which enhances the periodicity of the network output. If the vanishing parameter is below 1 there is no self-oscillation.
  • the presence of multiple inhibitory and activation connections in the neuronal network creates a neuronal central pattern generator (CPG), which makes a dynamic oscillating pattern in two dimensions that has cycles within cycles.
  • the dimensions include time and space i.e. the timing at which nodes fire and the identity of the nodes that fire.
  • the dynamic pattern of what nodes fire when, produced by the CPG is translated into real-time music that has cycles within cycles.
  • the neuronal network therefore creates music without any random operation, and it is deterministic and controllable.
  • the two dimensional oscillating pattern can be represented by dividing time into a series of intervals and identifying the nodes that fire in each respective interval.
  • the artificial neuronal network is modeled as a network object 10 in a computer program 2.
  • the network object 10 comprises a plurality of integrate-and-f ire node objects 20 that respectively represent each of the nodes of the network.
  • the connections of the network are maintained in a connection list 30 that comprises, for each node, pointers to the nodes that provide activation inputs and pointers to the nodes that provide inhibitory inputs.
  • the network object 10 defining the neuronal network is updated at each time interval. This involves providing excitory input impulses to the network nodes according to a predetermined pattern; calculating the excitation level of each node; determining which nodes fire; and translating the identity of the nodes that fire into a musical output.
  • Each node object computes for each interval, using an activation function, its activation level for that interval. The computation takes as its inputs the activation neuronal impulses, which the node received in the previous interval from connected nodes that fired in that previous interval, the inhibitory effect of inhibitory connections, the excitory input impulse received (if any) and a vanishing (excitation) parameter.
  • the activation neuronal impulses which the node received in the previous interval from connected nodes that fired in that previous interval (if any), increase the excitation level of the node. Let the energy received from activation neuronal impulses in the time interval n be received_neuronalJmpulse_energy(n).
  • the excitory input impulse received (if any) increase the excitation level of the node.
  • An inhibitory connection may reduce the excitation level of the node depending on the status of the node it is connected to. For example, if that node has a higher activation energy it will inhibit the increase in the excitation level of the node. Let the energy cost of the inhibitory connections at the time interval n be inhibition_cost(n).
  • the vanishing (excitation) parameter is used as a multiplying factor for the resultant calculated excitation level. If it is greater than 1 it increases the excitation level of the node and if it is less than 1 it decreases the excitation level of the node. Let the vanishing parameter at the time interval n be vanishing(n).
  • the activation calculation can then be coded as:
  • temp_activation level (n) received_neuronal_impulse_energy(n) + received_excitory_impulse_energy (n) + new_activation level (n-1)
  • temp_activation level (n) temp_activation level (n) - inhibition_cost(n)
  • new_activation_level(n) vanishing(n) * sigmoid(temp_ activationjevel (n))
  • the two dimensional oscillating pattern produced by the neuronal network is translated into a musical output. This is achieved by associating each node or each subset of the network nodes with a single percussive group/instrument.
  • the subsets are preferably, but not necessarily, non-overlapping.
  • a sub-set of nodes is typically a group of adjacent nodes. For example, if the music produced is drum music then each sub-set of nodes would be associated with, for example, one of Base drum, snare drum, hi hat, cymbal, torn drum, bong, percussion
  • the firing of the nodes in that interval are mapped in real-time to the sub-sets that contains those nodes.
  • the identified sub-sets are then each mapped to a percussive group identity that is provided to a MIDI synthesizer.
  • the output of the neuronal network can be deterministically controlled via a graphical user interface 100 illustrated in Fig 2.
  • the graphical user interface comprises a Setup control panel 110 that allows a user to program values for 'Beats', 'Seed' and 'Netsize'.
  • 'Netsize' specifies the number of nodes in the network. The user can, in this example, vary the number of node in the network between 7 and 64 by adjusting the 'Netsize' slider 112.
  • 'Beats' specifies the number of beats to a musical bar and is used to set the musical signature such as 4/4 time or % time.
  • the user can set the value of 'Beats' by adjusting the 'Beats' slider 114 between 3 and 23. This value determines the layout of the node control panel 140 and in particular the number of buttons 141 in each row of the array 142.
  • the 'Seed' slider 116 can be set by the user to determine a seed for the random generation of the network connections between nodes.
  • the button 118 initializes the network.
  • a schematic illustration of the network 2 is illustrated in a graphical display panel 120.
  • the schematic display of the network 2 comprises a plurality of nodes 4. In the illustrated example, there are 32 nodes corresponding to the programmed value of 'Netsize'. When a node 4 fires it is highlighted by illumination 6.
  • the graphical user interface 100 also comprises a network control panel 130. that comprises an 'Amplitude' slider 131 , an 'Excitation' slider 132, an 'Alternation' slider 133 and a 'Tempo' slider 134.
  • the 'Amplitude' slider 131 may be adjusted by the user to vary the musical output in real-time.
  • the value of 'Amplitude' can be adjusted to be between 0 and 120. This parameter value increases the excitory effect of neuronal activation impulses and excitory impulses on all the nodes of the network. Increasing the value generally increases the network activity and the effect of the node control panel 140 settings on the musical output.
  • the 'Excitement' slider 132 may be adjusted by the user to vary the musical output in real-time.
  • the value of 'Excitement' can be adjusted between 0 and 140. This parameter varies the vanishing (excitement) parameter that controls the preservation of energy and the self-oscillation of nodes. Increasing the value generally increases network activity without increasing the effect of the node control panel 140 settings on the musical output.
  • the 'Alternation' slider 133 may be adjusted by the user to vary the musical output in real-time.
  • the value of 'Alternation' can be adjusted between 0 and 100. This parameter varies the connection weight between nodes and controls the inhibition strength of inhibitory connections. Increasing the value generally increases the rigidity and repeatability of the musical output.
  • the 'Tempo' slider 134 may be adjusted by the user to vary the musical output in real-time.
  • the value of 'Tempo' can be adjusted between 0 and 70.
  • Tempo controls the duration of an interval.
  • a Break Switch option 135 can be selected by a user. When selected a simple break or fill-in is provided at an appropriate position such as every 2 nd , 4 th or 8 th bar at the second half of the respective bars, the excitation parameter is enhanced momentarily by 10% and 'amplitude' is increased by 5%. This creates more energetic drumming, the rhythm of which depends upon the overall network situation at the time.
  • An Alternate Rate option 136 controls the rate at which inhibition is calculated. When it is not selected inhibition is calculated every interval but when it is selected inhibition is calculated every second interval.
  • a node control panel 140 allows a user to control the pattern of the excitory input impulses and its variation in time.
  • the control panel 140 comprises an energy table 142 comprising and N row by M column array of user selectable buttons 141. Each row of the array corresponds to a different group of nodes. Each column corresponds to a portion of a musical bar and the value M is determined by the 'Beats' parameter 114.
  • Each button 141 allows a user to determine whether the excitory input impulse applied to a sub-set of neurons has a low value or a high value at a particular interval. Selecting a button 142 sets the excitory input impulse to a high value.
  • the ' influence' slider 146 is movable by a user during operation of the program and it determines the difference between a low value and a high value. If 'influence' is set close to 100% the musical output would be almost dictated by the energy table 142 configuration, whereas if influence is close to 0% the generated musical output would be based on the CPG network internal dynamics only.
  • the sliders 150 allow a user to adjust the sensitivity of different neuron groups to both excitory inputs and neuronal inputs. There is a different slide associated with each row. In practice, this allows a user to make certain groups of neurons more sensitive to the pattern of excitory impulses programmed in the respective row of the energy table 142.
  • the pattern of which nodes are excited when is determined by selecting different ones of the buttons 141.
  • the slider 146 determine the difference in effect between selecting and not selecting a button.
  • the sensitivity of the different node groups to inputs is set by adjusting the sliders 150.
  • the user defines the set-up parameters using the set-up control panel 110.
  • the program then randomly creates connections between the nodes.
  • Nodes are interconnected in such a way that each neuron's activity level inhibits growth of some other neuron's activity level.
  • the program initializes the other parameters in the network control panel 130 and the neuron control panel 140 at default values, which the user can modify while the program is running.
  • the network object is then updated at each interval and a music output is created in real-time at each interval.
  • the user can therefore increase the activity of the music by increasing 'Amplitude' 131 and/or 'Excitement' 140, the user can vary the stability of the music by changing 'Alternation' 133 and the user can vary the tempo of the music by varying 'Tempo' 134.
  • the user can also vary the pattern of excitory impulses provided to each group of nodes using the buttons 141 and slider 146 and their sensitivity to such input by adjusting the sliders 150. Once a desired musical style is achieved, it can be stored and recalled later if desired.
  • the neuron control panel 140 can be used to program a style of music.
  • a style of music For example (simplified rock) would be: Hihat x o x o x o x o x o Bass x o o o x o o o Snare o o x o o o x o
  • the tempo is set according to a slider 134
  • the tempo may be set by tapping a key or by shaking a device or from some other input.
  • a heart rate sensor may provide the tempo or the most prominent (bass-drum) drum beat is synchronized with the heart pulse.
  • the heart pulse rate may alternatively be used to control the interval between excitory impulses. As the heart rate increases, the interval decreases and as the heart rate decreases, the interval increases. Consequently, music can be generated during physical activity that changes with the activity level of the user. The changes to the music as the activity level changes are not just in the music tempo, but in the pattern of the music that is generated.
  • the history of the heart rate may also be used as an input parameter and pattern of music generated may depend upon the user identify a type of sport.

Abstract

A method of creating autonomous musical output comprising: creating a mutually inhibiting neuronal network comprising a plurality of nodes arranged to integrate and fire; associating each of the plurality of nodes with a musical instrument; and creating, when a node fires, a musical output corresponding to the musical instrument associated with the firing node.

Description

TITLE
Autonomous musical output using a mutually inhibited neuronal network.
FIELD OF THE INVENTION Embodiments of the invention relate to generating autonomous musical output using a mutually inhibited neuronal network.
BACKGROUND TO THE INVENTION
"A Method of Generating Musical Motion Patterns", a Doctoral Dissertation, Hakapaino, Helsinki, 2000 by Pauli Laine describes in detail the autonomous creation of music using a central pattern generator and, in particular, a mutually inhibited neuronal network (MINN). This methodology described in the dissertation was unable to reliably produce good musical patterns and it easily generated chaotic patterns that were without noticeable periodicity. It was also difficult it to generate patterns with longer period-lengths (like 16-32 or 64) or with sub-periods (for example a larger period 64 and inside that patterns of 8).
It would be desirable to provide an improved mechanism and method for autonomously producing music.
BRIEF DESCRIPTION OF THE INVENTION
Embodiments of the invention are able to generate very long and 'musical' output that does not easily become non-periodic and has sub-periods.
BRIEF DESCRIPTION OF THE DRAWINGS
For a better understanding of the present invention reference will now be made by way of example only to the accompanying drawings in which: Fig 1 illustrates a network object; and Fig 2 illustrates a graphical user interface.
DETAILED DESCRIPTION OF EMBODIMENTS OF THE INVENTION
An artificial neuronal network (ANN) is a set of connected computational nodes. In embodiments of the invention, the network is not a learning network in which changes in connection weights are inspected but is a small network of between 5 and 50 nodes (typically) in which the dynamic firing behavior of the network is inspected in detail at regular intervals.
Each node can be connected to receive a neuronal impulse or impulses, output from one or more other nodes, and each node can be connected to provide as output a neuronal impulse to one or more other nodes.
A neuronal impulse received at a node can have an activation or an inhibitory effect depending upon whether the connection on which the neuronal impulse is received is an activation connection or an inhibitory connection. An activation effect increases the activation level of the node according to a simple activation function, such as a sigmoid function. An inhibiting effect inhibits or prevents an increase in the activation level of the node. When the node's activation level reaches a threshold value, the node fires and produces a neuronal impulse as output. After firing the activity level of the node quickly goes to zero or a low nonzero value depending upon implementation.
An input impulse received at a node may be a neuronal impulse output from a connected node or may be one of a plurality of excitory impulses provided across the network according to a predetermined pattern. These excitory impulses have an activation effect. They increase the activity of the network and may be provided to all or some of the nodes of the network at each interval. An additional feature of the described neuronal network model is the vanishing (excitation) parameter. If the vanishing (excitation) parameter is zero or not implemented, then if there is no excitory or neuronal activation input the activation level of the node would remain constant. However, in the preferred implementation, the current activation level is multiplied by the vanishing
(excitation) parameter value, which is may be grater or less than 1 and is typically a value between 0.5 to 1.2. If the vanishing parameter is greater than 1 , then after a certain time, and even without any input, the activation level reaches the threshold and the node fires, after that the activation level decreases to or near to zero depending upon implementation. This feature introduces self-oscillation, which enhances the periodicity of the network output. If the vanishing parameter is below 1 there is no self-oscillation.
The presence of multiple inhibitory and activation connections in the neuronal network creates a neuronal central pattern generator (CPG), which makes a dynamic oscillating pattern in two dimensions that has cycles within cycles. The dimensions include time and space i.e. the timing at which nodes fire and the identity of the nodes that fire. The dynamic pattern of what nodes fire when, produced by the CPG, is translated into real-time music that has cycles within cycles. The neuronal network therefore creates music without any random operation, and it is deterministic and controllable.
The two dimensional oscillating pattern can be represented by dividing time into a series of intervals and identifying the nodes that fire in each respective interval.
NETWORK MODEL
Referring to Fig. 1 , the artificial neuronal network is modeled as a network object 10 in a computer program 2. The network object 10 comprises a plurality of integrate-and-f ire node objects 20 that respectively represent each of the nodes of the network. The connections of the network are maintained in a connection list 30 that comprises, for each node, pointers to the nodes that provide activation inputs and pointers to the nodes that provide inhibitory inputs.
The network object 10 defining the neuronal network is updated at each time interval. This involves providing excitory input impulses to the network nodes according to a predetermined pattern; calculating the excitation level of each node; determining which nodes fire; and translating the identity of the nodes that fire into a musical output.
Determining which nodes fire when depends upon the calculation of the excitation level of each node, which occurs at each node object 20 at each interval. Each node object computes for each interval, using an activation function, its activation level for that interval. The computation takes as its inputs the activation neuronal impulses, which the node received in the previous interval from connected nodes that fired in that previous interval, the inhibitory effect of inhibitory connections, the excitory input impulse received (if any) and a vanishing (excitation) parameter.
The activation neuronal impulses, which the node received in the previous interval from connected nodes that fired in that previous interval (if any), increase the excitation level of the node. Let the energy received from activation neuronal impulses in the time interval n be received_neuronalJmpulse_energy(n).
The excitory input impulse received (if any) increase the excitation level of the node. Let the energy received from excitory input impulses at the time interval n be received_excitory_impulse_energy(n).
An inhibitory connection may reduce the excitation level of the node depending on the status of the node it is connected to. For example, if that node has a higher activation energy it will inhibit the increase in the excitation level of the node. Let the energy cost of the inhibitory connections at the time interval n be inhibition_cost(n).
The vanishing (excitation) parameter is used as a multiplying factor for the resultant calculated excitation level. If it is greater than 1 it increases the excitation level of the node and if it is less than 1 it decreases the excitation level of the node. Let the vanishing parameter at the time interval n be vanishing(n).
The activation calculation can then be coded as:
temp_activation level (n) = received_neuronal_impulse_energy(n) + received_excitory_impulse_energy (n) + new_activation level (n-1)
temp_activation level (n)= temp_activation level (n) - inhibition_cost(n)
new_activation_level(n)= vanishing(n) * sigmoid(temp_ activationjevel (n))
If the resultant computed activation level ( new_activation_level(n) ) exceeds a threshold value, then the node fires.
The two dimensional oscillating pattern produced by the neuronal network is translated into a musical output. This is achieved by associating each node or each subset of the network nodes with a single percussive group/instrument. The subsets are preferably, but not necessarily, non-overlapping. A sub-set of nodes is typically a group of adjacent nodes. For example, if the music produced is drum music then each sub-set of nodes would be associated with, for example, one of Base drum, snare drum, hi hat, cymbal, torn drum, bong, percussion For each interval, the firing of the nodes in that interval are mapped in real-time to the sub-sets that contains those nodes. The identified sub-sets are then each mapped to a percussive group identity that is provided to a MIDI synthesizer.
USER CONTROL
The output of the neuronal network can be deterministically controlled via a graphical user interface 100 illustrated in Fig 2.
The graphical user interface comprises a Setup control panel 110 that allows a user to program values for 'Beats', 'Seed' and 'Netsize'.
'Netsize' specifies the number of nodes in the network. The user can, in this example, vary the number of node in the network between 7 and 64 by adjusting the 'Netsize' slider 112.
'Beats' specifies the number of beats to a musical bar and is used to set the musical signature such as 4/4 time or % time. The user can set the value of 'Beats' by adjusting the 'Beats' slider 114 between 3 and 23. This value determines the layout of the node control panel 140 and in particular the number of buttons 141 in each row of the array 142.
The 'Seed' slider 116 can be set by the user to determine a seed for the random generation of the network connections between nodes.
The button 118 initializes the network. When initialized, a schematic illustration of the network 2 is illustrated in a graphical display panel 120. The schematic display of the network 2 comprises a plurality of nodes 4. In the illustrated example, there are 32 nodes corresponding to the programmed value of 'Netsize'. When a node 4 fires it is highlighted by illumination 6. The graphical user interface 100 also comprises a network control panel 130. that comprises an 'Amplitude' slider 131 , an 'Excitation' slider 132, an 'Alternation' slider 133 and a 'Tempo' slider 134.
The 'Amplitude' slider 131 may be adjusted by the user to vary the musical output in real-time. The value of 'Amplitude' can be adjusted to be between 0 and 120. This parameter value increases the excitory effect of neuronal activation impulses and excitory impulses on all the nodes of the network. Increasing the value generally increases the network activity and the effect of the node control panel 140 settings on the musical output.
The 'Excitement' slider 132 may be adjusted by the user to vary the musical output in real-time. The value of 'Excitement' can be adjusted between 0 and 140. This parameter varies the vanishing (excitement) parameter that controls the preservation of energy and the self-oscillation of nodes. Increasing the value generally increases network activity without increasing the effect of the node control panel 140 settings on the musical output.
The 'Alternation' slider 133 may be adjusted by the user to vary the musical output in real-time. The value of 'Alternation' can be adjusted between 0 and 100. This parameter varies the connection weight between nodes and controls the inhibition strength of inhibitory connections. Increasing the value generally increases the rigidity and repeatability of the musical output.
The 'Tempo' slider 134 may be adjusted by the user to vary the musical output in real-time. The value of 'Tempo' can be adjusted between 0 and 70. Tempo controls the duration of an interval.
A Break Switch option 135 can be selected by a user. When selected a simple break or fill-in is provided at an appropriate position such as every 2nd, 4th or 8th bar at the second half of the respective bars, the excitation parameter is enhanced momentarily by 10% and 'amplitude' is increased by 5%. This creates more energetic drumming, the rhythm of which depends upon the overall network situation at the time.
An Alternate Rate option 136 controls the rate at which inhibition is calculated. When it is not selected inhibition is calculated every interval but when it is selected inhibition is calculated every second interval.
A node control panel 140 allows a user to control the pattern of the excitory input impulses and its variation in time.
The control panel 140 comprises an energy table 142 comprising and N row by M column array of user selectable buttons 141. Each row of the array corresponds to a different group of nodes. Each column corresponds to a portion of a musical bar and the value M is determined by the 'Beats' parameter 114.
Each button 141 allows a user to determine whether the excitory input impulse applied to a sub-set of neurons has a low value or a high value at a particular interval. Selecting a button 142 sets the excitory input impulse to a high value.
The 'influence' slider 146 is movable by a user during operation of the program and it determines the difference between a low value and a high value. If 'influence' is set close to 100% the musical output would be almost dictated by the energy table 142 configuration, whereas if influence is close to 0% the generated musical output would be based on the CPG network internal dynamics only.
The sliders 150 allow a user to adjust the sensitivity of different neuron groups to both excitory inputs and neuronal inputs. There is a different slide associated with each row. In practice, this allows a user to make certain groups of neurons more sensitive to the pattern of excitory impulses programmed in the respective row of the energy table 142.
The pattern of which nodes are excited when is determined by selecting different ones of the buttons 141. The slider 146 determine the difference in effect between selecting and not selecting a button. The sensitivity of the different node groups to inputs is set by adjusting the sliders 150.
At set-up the user defines the set-up parameters using the set-up control panel 110. The program then randomly creates connections between the nodes.
Nodes are interconnected in such a way that each neuron's activity level inhibits growth of some other neuron's activity level.
The program initializes the other parameters in the network control panel 130 and the neuron control panel 140 at default values, which the user can modify while the program is running. The network object is then updated at each interval and a music output is created in real-time at each interval.
The user can therefore increase the activity of the music by increasing 'Amplitude' 131 and/or 'Excitement' 140, the user can vary the stability of the music by changing 'Alternation' 133 and the user can vary the tempo of the music by varying 'Tempo' 134.
The user can also vary the pattern of excitory impulses provided to each group of nodes using the buttons 141 and slider 146 and their sensitivity to such input by adjusting the sliders 150. Once a desired musical style is achieved, it can be stored and recalled later if desired.
The neuron control panel 140 can be used to program a style of music. For example (simplified rock) would be: Hihat x o x o x o x o Bass x o o o x o o o Snare o o x o o o x o
It would be a simply modification to the illustrated graphical user interface to include a drop-down menu for selecting different musical styles. The selection of a particular style would automatically program the energy table 142 of the neuron control panel 140 with the appropriate configuration i.e. which of the buttons 141 are depressed.
Although embodiments of the present invention have been described in the preceding paragraphs with reference to various examples, it should be appreciated that modifications to the examples given can be made without departing from the scope of the invention as claimed. For example, although in the described embodiment the tempo is set according to a slider 134, in alternative embodiments the tempo may be set by tapping a key or by shaking a device or from some other input. For example a heart rate sensor may provide the tempo or the most prominent (bass-drum) drum beat is synchronized with the heart pulse. The heart pulse rate may alternatively be used to control the interval between excitory impulses. As the heart rate increases, the interval decreases and as the heart rate decreases, the interval increases. Consequently, music can be generated during physical activity that changes with the activity level of the user. The changes to the music as the activity level changes are not just in the music tempo, but in the pattern of the music that is generated. The history of the heart rate may also be used as an input parameter and pattern of music generated may depend upon the user identify a type of sport.
The above described methodology may be used to compose a ring-tone for a mobile telephone. Whilst endeavoring in the foregoing specification to draw attention to those features of the invention believed to be of particular importance it should be understood that the Applicant claims protection in respect of any patentable feature or combination of features hereinbefore referred to and/or shown in the drawings whether or not particular emphasis has been placed thereon.

Claims

1. A method of creating autonomous musical output comprising: creating a mutually inhibiting neuronal network comprising a plurality of nodes arranged to integrate and fire; associating each of the plurality of nodes with a musical instrument; and creating, when a node fires, a musical output corresponding to the musical instrument associated with the firing node.
2. A method as claimed in claim 1 , wherein the plurality of nodes is comprised of a plurality of subsets of the plurality of nodes and each sub-set is associated with a single, different percussive group.
3. A method as claimed in claim 2, wherein each sub-set is a grouping of adjacent ones of the plurality of nodes.
4. A method as claimed in claim 2 or 3, wherein the plurality of nodes is comprised of eight sub-sets and each sub-set is associated with one of: Base drum, snare drum, hi hat, cymbal, torn drum, bong, percussion.
5. A method as claimed in any preceding claim, comprising: changing the musical output by changing the musical instrument to which a node is associated.
6. A method as claimed in any one of claims 1 to 5, comprising: exciting some or all of the plurality of nodes according to a pattern that determines what level of excitement is provided to which nodes at different times.
7. A method as claimed in claim 6, comprising changing the musical output by changing the pattern.
8. A method as claimed in claim 7, wherein a user changes the pattern by selecting what level of excitement is provided to which nodes at different times.
9. A method as claimed in any preceding claim further comprising, at each one of a plurality of sequential periods of time: calculating an excitation level for each of the plurality of nodes; determining from the calculated excitation level which nodes fire in the current interval of time; translating the identity of the nodes that fire in the current interval of time into a real-time musical output comprising notes of the musical instruments associated with the firing nodes.
10. A method as claimed in claim 9, comprising, after a node fires, preventing it from subsequently firing for at least a delay period.
11. A method as claimed in claim 10, wherein the delay period duration is user programmable.
12. A method as claimed in claim 9, 10 or 11 wherein calculation of the excitation level of a node at a first interval is dependent upon whether the node was excited, in the preceding interval, by the firing of a node or nodes to which it is connected by an activation connection.
13. A method as claimed in any one of claims 9 to 12, comprising: providing excitory impulses to the plurality of nodes according to a predetermined pattern that determines what impulses are provided to which nodes at different times, wherein calculation of the excitation level of a node at a first interval is dependent upon an excitory input impulse received by the node at the first interval.
14. A method as claimed in any one of claims 9 to 13, wherein calculation of the excitation level of a node at a first interval involves multiplying the current or previous excitation level by a factor.
15. A method as claimed in claim 14, wherein the factor is greater than 1.
16. A method as claimed in claim 15, wherein the factor is user programmable.
17. A method as claimed in any one of claims 9 or 16, wherein the calculation of the excitation level of a node at a first interval is dependent upon the node or nodes to which it is connected by an inhibitory connection.
18. A method as claimed in any preceding claim wherein the step of creating a mutually inhibiting neuronal network comprises user specification of the number of nodes in the network.
19. A method as claimed in any preceding claim wherein the step of creating a mutually inhibiting neuronal network comprises user specification of the tempo of the musical output.
20. A method as claimed in any preceding claim further comprising : displaying a visual representation of each node of the network; displaying an indication when a node fires ; and simultaneously providing, for each firing node, musical output corresponding to the musical instrument associated with the firing node.
21. A Computer program comprising instructions for carrying out the method of any preceding claim.
22.. A method of creating autonomous musical output comprising: creating a mutually inhibiting neuronal network comprising a plurality of nodes arranged to integrate and fire; associating each of the plurality of nodes with a particular musical output; and exciting some or all of the plurality of nodes according to a predetermined pattern that determines what level of excitement is provided to which nodes at different times.
23. A method as claimed in claim 22, comprising changing the musical output by changing the predetermined pattern.
24. A method as claimed in claim 23, wherein a user changes the predetermined pattern by selecting what level of excitement is provided to which nodes at different times.
25. A method as claimed in any one of claims 22, 23 or 24, wherein the step of associating each of the plurality of nodes with a musical output associates each of the plurality of nodes with a musical instrument, the method further comprising: creating, when a node fires, a musical output corresponding to the musical instrument associated with the firing node.
26. A method as claimed in claim 25, wherein the plurality of nodes is comprised of a plurality of non-overlapping subsets of the plurality of nodes and each subset is associated with a single, different percussive group.
27. A method as claimed in claim 26, wherein each sub-set is a grouping of , adjacent ones of the plurality of nodes.
28. A method as claimed in claim 26 or 27, wherein the plurality of nodes is comprised of eight non-overlapping sub-sets and each sub-set is associated with one of: Base drum, snare drum, hi hat, cymbal, tom drum, bong, percussion.
29. A method of creating autonomous musical output comprising: creating a mutually inhibiting neuronal network comprising a plurality of nodes arranged to integrate and fire; and at each one of a plurality of sequential time intervals: calculating an excitation level for each of the plurality of nodes wherein said calculation involves, for at least some of the nodes, multiplying the excitation level of the node at the previous time interval by a factor; determining from the calculated excitation level which nodes fire in the current time interval; and translating the identity of the nodes that fire in the current time interval into a realtime musical output.
30. A method as claimed in claim 29, wherein the factor is greater than 1.
31. A method as claimed in claim 29 or 30, wherein the factor is user programmable.
32. A method of providing a visual representation of the music comprising displaying a plurality of nodes; associating each node with a musical instrument; and highlighting a node when contemporaneously output music comprises a note of the instrument associated with that node.
33. A method of contemporaneously generating music comprising: upon a persons heart rate, comprising: measuring a persons heart rate; providing the measured heart rate as an input to a musical central pattern generator.
34. A method for contemporaneously generating an oscillating output comprising: creating a mutually inhibiting neuronal network comprising a plurality of nodes arranged to integrate and fire; exciting some or all of the plurality of nodes according to a pattern that determines what level of excitement is provided to which nodes at different times.; and measuring a persons heart rate and changing the pattern in dependence upon the measured heart rate.
35. A method or user interface substantially as hereinbefore described with reference to and/or as shown in the accompanying drawings.
36. Any novel subject matter or combination including novel subject matter disclosed, whether or not within the scope of or relating to the same invention as the preceding claims.
PCT/IB2004/001053 2004-03-11 2004-03-11 Autonomous musical output using a mutually inhibited neuronal network WO2005093711A1 (en)

Priority Applications (2)

Application Number Priority Date Filing Date Title
US10/591,828 US20070280270A1 (en) 2004-03-11 2004-03-11 Autonomous Musical Output Using a Mutually Inhibited Neuronal Network
PCT/IB2004/001053 WO2005093711A1 (en) 2004-03-11 2004-03-11 Autonomous musical output using a mutually inhibited neuronal network

Applications Claiming Priority (1)

Application Number Priority Date Filing Date Title
PCT/IB2004/001053 WO2005093711A1 (en) 2004-03-11 2004-03-11 Autonomous musical output using a mutually inhibited neuronal network

Publications (1)

Publication Number Publication Date
WO2005093711A1 true WO2005093711A1 (en) 2005-10-06

Family

ID=35056414

Family Applications (1)

Application Number Title Priority Date Filing Date
PCT/IB2004/001053 WO2005093711A1 (en) 2004-03-11 2004-03-11 Autonomous musical output using a mutually inhibited neuronal network

Country Status (2)

Country Link
US (1) US20070280270A1 (en)
WO (1) WO2005093711A1 (en)

Families Citing this family (2)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US10339439B2 (en) * 2014-10-01 2019-07-02 Thalchemy Corporation Efficient and scalable systems for calculating neural network connectivity in an event-driven way
US9715870B2 (en) * 2015-10-12 2017-07-25 International Business Machines Corporation Cognitive music engine using unsupervised learning

Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4926064A (en) * 1988-07-22 1990-05-15 Syntonic Systems Inc. Sleep refreshed memory for neural network
US5072130A (en) * 1986-08-08 1991-12-10 Dobson Vernon G Associative network and signal handling element therefor for processing data
US5151969A (en) * 1989-03-29 1992-09-29 Siemens Corporate Research Inc. Self-repairing trellis networks
US5285522A (en) * 1987-12-03 1994-02-08 The Trustees Of The University Of Pennsylvania Neural networks for acoustical pattern recognition
US6356884B1 (en) * 1994-10-13 2002-03-12 Stephen L. Thaler Device system for the autonomous generation of useful information

Family Cites Families (26)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
JP2583347B2 (en) * 1989-07-21 1997-02-19 富士通株式会社 Performance operation pattern information generator
US5138924A (en) * 1989-08-10 1992-08-18 Yamaha Corporation Electronic musical instrument utilizing a neural network
US5136687A (en) * 1989-10-10 1992-08-04 Edelman Gerald M Categorization automata employing neuronal group selection with reentry
US5308915A (en) * 1990-10-19 1994-05-03 Yamaha Corporation Electronic musical instrument utilizing neural net
US5195170A (en) * 1991-08-12 1993-03-16 The United States Of America As Represented By The Administrator Of The National Aeronautics And Space Administration Neural-network dedicated processor for solving assignment problems
US5355435A (en) * 1992-05-18 1994-10-11 New Mexico State University Technology Transfer Corp. Asynchronous temporal neural processing element
US5446828A (en) * 1993-03-18 1995-08-29 The United States Of America As Represented By The Secretary Of The Navy Nonlinear neural network oscillator
US5581658A (en) * 1993-12-14 1996-12-03 Infobase Systems, Inc. Adaptive system for broadcast program identification and reporting
DE69629486T2 (en) * 1995-10-23 2004-06-24 The Regents Of The University Of California, Oakland CONTROL STRUCTURE FOR SOUND SYNTHESIS
DE69621135D1 (en) * 1996-12-11 2002-06-13 St Microelectronics Srl Fuzzy logic filter method and fuzzy logic filter
US6051770A (en) * 1998-02-19 2000-04-18 Postmusic, Llc Method and apparatus for composing original musical works
US6292791B1 (en) * 1998-02-27 2001-09-18 Industrial Technology Research Institute Method and apparatus of synthesizing plucked string instruments using recurrent neural networks
AUPP547898A0 (en) * 1998-08-26 1998-09-17 Canon Kabushiki Kaisha System and method for automatic music generation
US7054850B2 (en) * 2000-06-16 2006-05-30 Canon Kabushiki Kaisha Apparatus and method for detecting or recognizing pattern by employing a plurality of feature detecting elements
AUPR150700A0 (en) * 2000-11-17 2000-12-07 Mack, Allan John Automated music arranger
US7223913B2 (en) * 2001-07-18 2007-05-29 Vmusicsystems, Inc. Method and apparatus for sensing and displaying tablature associated with a stringed musical instrument
US7398259B2 (en) * 2002-03-12 2008-07-08 Knowmtech, Llc Training of a physical neural network
US7667131B2 (en) * 2003-06-09 2010-02-23 Ierymenko Paul F Player technique control system for a stringed instrument and method of playing the instrument
US20050076772A1 (en) * 2003-10-10 2005-04-14 Gartland-Jones Andrew Price Music composing system
JP2005301921A (en) * 2004-04-15 2005-10-27 Sharp Corp Musical composition retrieval system and musical composition retrieval method
EP1530195A3 (en) * 2003-11-05 2007-09-26 Sharp Kabushiki Kaisha Song search system and song search method
JP4199097B2 (en) * 2003-11-21 2008-12-17 パイオニア株式会社 Automatic music classification apparatus and method
US7166795B2 (en) * 2004-03-19 2007-01-23 Apple Computer, Inc. Method and apparatus for simulating a mechanical keyboard action in an electronic keyboard
US7202408B2 (en) * 2004-04-22 2007-04-10 James Calvin Fallgatter Methods and electronic systems for fingering assignments
US7193148B2 (en) * 2004-10-08 2007-03-20 Fraunhofer-Gesellschaft Zur Foerderung Der Angewandten Forschung E.V. Apparatus and method for generating an encoded rhythmic pattern
GB2465917B (en) * 2005-05-03 2010-08-04 Codemasters Software Co Rhythm action game apparatus and method

Patent Citations (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US5072130A (en) * 1986-08-08 1991-12-10 Dobson Vernon G Associative network and signal handling element therefor for processing data
US5285522A (en) * 1987-12-03 1994-02-08 The Trustees Of The University Of Pennsylvania Neural networks for acoustical pattern recognition
US4926064A (en) * 1988-07-22 1990-05-15 Syntonic Systems Inc. Sleep refreshed memory for neural network
US5151969A (en) * 1989-03-29 1992-09-29 Siemens Corporate Research Inc. Self-repairing trellis networks
US6356884B1 (en) * 1994-10-13 2002-03-12 Stephen L. Thaler Device system for the autonomous generation of useful information

Also Published As

Publication number Publication date
US20070280270A1 (en) 2007-12-06

Similar Documents

Publication Publication Date Title
KR101854706B1 (en) Method and recording medium for automatic composition using artificial neural network
US5308915A (en) Electronic musical instrument utilizing neural net
US20060011050A1 (en) Electronic percussion instrument and percussion tone control program
US10636400B2 (en) Method for producing and streaming music generated from biofeedback
US20220208019A1 (en) A method, system, app or kit of parts for teaching musical rhythm, in particular percussion
Drew et al. Model of song selectivity and sequence generation in area HVc of the songbird
JP7274082B2 (en) Music generating device, music generating method, and music generating program
US20070280270A1 (en) Autonomous Musical Output Using a Mutually Inhibited Neuronal Network
Brown Exploring rhythmic automata
Eck A network of relaxation oscillators that finds downbeats in rhythms
JP6693596B2 (en) Automatic accompaniment data generation method and device
Ohmura et al. Music Generation System Based on Human Instinctive Creativity
Spicer et al. The learning agent based interactive performance system
Koons et al. Intrinsically musical game worlds: abstract music generation as a result of gameplay
Laine A method for generating musical motion patterns
Kerlleñevich et al. Santiago-a real-time biological neural network environment for generative music creation
Bilotta et al. In search of musical fitness on consonance
EP4318460A1 (en) Automatic performance device, electronic musical instrument, performance system, automatic performance method, and program
Burt “A PLETHORA OF POLYS”–A LIVE ALGORITHMIC MICROTONAL IMPROVISATIONAL COMPOSITION FOR IPAD
JP2006133696A (en) Electronic musical instrument
Reid et al. Perspectives on Time: performance practice, mapping strategies, & composition with MIGSI.
JP2797888B2 (en) Music synthesizer
Garba et al. Music/multimedia technology: Melody synthesis and rhythm creation processes of the hybridized interactive algorithmic composition model
Garba et al. A Review of Multimedia and Music Technology: Mathematical Foundations of Rhythm Generations in Algorithmic Composition
Onishi et al. A Kansei model for musical chords based on the structure of the human auditory system

Legal Events

Date Code Title Description
AK Designated states

Kind code of ref document: A1

Designated state(s): AE AG AL AM AT AU AZ BA BB BG BR BW BY BZ CA CH CN CO CR CU CZ DE DK DM DZ EC EE EG ES FI GB GD GE GH GM HR HU ID IL IN IS JP KE KG KP KR KZ LC LK LR LS LT LU LV MA MD MG MK MN MW MX MZ NA NI NO NZ OM PG PH PL PT RO RU SC SD SE SG SK SL SY TJ TM TN TR TT TZ UA UG US UZ VC VN YU ZA ZM ZW

AL Designated countries for regional patents

Kind code of ref document: A1

Designated state(s): BW GH GM KE LS MW MZ SD SL SZ TZ UG ZM ZW AM AZ BY KG KZ MD RU TJ TM AT BE BG CH CY CZ DE DK EE ES FI FR GB GR HU IE IT LU MC NL PL PT RO SE SI SK TR BF BJ CF CG CI CM GA GN GQ GW ML MR NE SN TD TG

121 Ep: the epo has been informed by wipo that ep was designated in this application
NENP Non-entry into the national phase

Ref country code: DE

WWW Wipo information: withdrawn in national office

Country of ref document: DE

122 Ep: pct application non-entry in european phase
WWE Wipo information: entry into national phase

Ref document number: 10591828

Country of ref document: US

WWP Wipo information: published in national office

Ref document number: 10591828

Country of ref document: US