File: mmlmusic.rst.txt

package info (click to toggle)
python-pyo 1.0.6-2
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 52,332 kB
  • sloc: python: 135,133; ansic: 127,822; javascript: 16,116; sh: 395; makefile: 388; cpp: 242
file content (139 lines) | stat: -rw-r--r-- 5,367 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
Music Macro Language evaluator
=================================

.. currentmodule:: pyo

.. highlight:: none

The MML object implements acustom MML evaluator to allow simple and efficient
music composition within pyo. The language's rules are explained below.

The MML object generates triggers on new notes with additional streams to
handle frequency, amplitude, duration and custom parameters. See the object
documentation for more details.

Objects in this category
------------------------------

- :py:class:`MML` :     Generates music sequences based on a custom MML notation.

**API documentation**
---------------------

- The space separates the tokens in a music sequence (a token can be a note value,
  an amplitude control, a tempo statement, etc.).

Pre-Processing on music text
----------------------------

- A comment starts with a semicolon ( **;** ) and ends at the end of the line. This
  text will be removed before starting to evaluate the sequences.

- A musical voice is represented by a single line of code.

- We can break a long line into multiple short lines with the backslash ( **\\** ).

- The symbol equal ( **=** ), preceded by a variable name in UPPER CASE, creates a
  macro. The remaining part of the line is the macro body. Anywhere the 
  pre-processor finds the variable name in the music, it will be replaced by the
  macro's body.

Realtime Processing of the music
--------------------------------

**Voice number**

- The symbol #, followed by a number indicates the voice number for the line. This should be
  the first token of a line. If missing, the line defaults to voice number 0.

**Notes**

- The letters **a** to **g** correspond to the musical pitches and cause the
  corresponding note to be played.

- Sharp notes are produced by appending a **+** to the pitch value, and flat notes
  by appending a **-** to the pitch value.

- The length of a note is specified by an integer following the note name. If a
  note doesn't have a duration, the last specified duration is used. Default
  duration is the Sixteenth note. Length values are:

  - 0 = Thirty-second note
  - 1 = Sixteenth note
  - 2 = Dotted sixteenth note
  - 3 = Eighth note
  - 4 = Dotted eighth note
  - 5 = Quarter note
  - 6 = Dotted quarter note
  - 7 = Half note
  - 8 = Dotted half note
  - 9 = Whole note

- The letter **r** corresponds to a rest. The length of the rest is specified in
  the same manner as the length of a note.

- The letter **o**, followed by a number, selects the octave the instrument will play in.
  If the letter **o** is followed by the symbol **+**, the octave steps up by one. If followed
  by the symbol **-**, the octave steps down by one. If a number follows the symbol **+** or **-**,
  the octave steps up or down by the given amount of octaves.

**Tuplets**

- Notes surrounded by brakets ( **(** and **)** ) act as tuplet. Tuplet length is specified
  just after the closing bracket using the same values as for a note duration. Length of
  each note in tuplet will evenly be <note length of tuplet> / <count of notes in tuplet>.
  If not specified, tuplet duration defaults to 5 (quarter note).

**Tempo**

- The letter **t**, followed by a number, sets the tempo in beats-per-minute.
  If the letter **t** is followed by the symbol **+**, the tempo increases by one. If followed
  by the symbol **-**, the tempo decreases by one. If a number follows the symbol **+** or **-**,
  the tempo increases or decreases by the given amount of BPM.

**Volume**

- The letter **v**, followed by a number between 0 and 100, sets the volume for the following
  notes. If the letter **v** is followed by the symbol **+**, the volume increases by one. If
  followed by the symbol **-**, the volume decreases by one. If a number follows the symbol 
  **+** or **-**, the volume increases or decreases by the given amount.

**User variables**

- The letters **x**, **y** an **z**, followed by a real number, are user-defined parameters. They
  can be used to control specific parameters of the synthesizer.
  If the letter is followed by the symbol **+**, the value increases by 0.01. If followed
  by the symbol **-**, the value decreases by 0.01. If a number follows the symbol **+** or **-**,
  the value increases or decreases by the given amount.

**Random selection**

- Random choice within a set of values can be done with the **?** symbol, followed by the
  possible values inside square brackets.
  Ex. ?[c e g b-] ; the note is a random choice between c e g and b-.

- Random choice between a range can be done with the **?** symbol, followed by the range inside
  curly brackets. If two values are presents, they are the minimum and maximum of the range.
  If there is only one value, the range is 0 to this value and if the brackets are empty, the
  range is 0 to 1.
  Ex. v?{40 70} ; volume is set randomly between 40 and 70.

**Looping segments**

- The symbol **|:** starts a looped segment and the symbol **:|** ends it. A number right after the
  last symbol indicates how many loops to perform. If missing, the number of loops is two (the
  first pass + one repetition). It is possible to use loops inside other loops. There is no
  limit to the number of levels of loop embedding.

.. highlight:: python

**Objects**
-----------

*MML*
----------

.. autoclass:: MML
   :members:

   .. autoclasstoc::