File: 02-parameters.html

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 (234 lines) | stat: -rw-r--r-- 25,708 bytes parent folder | download | duplicates (2)
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
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234

<!DOCTYPE html>

<html lang="en">
<head>
<meta charset="utf-8"/>
<meta content="width=device-width, initial-scale=1.0" name="viewport"/><meta content="Docutils 0.17.1: http://docutils.sourceforge.net/" name="generator"/>
<title>02-parameters.py - Built-in arguments and conversions. — Pyo 1.0.5 documentation</title>
<link href="../../_static/pygments.css" rel="stylesheet" type="text/css"/>
<link href="../../_static/agogo.css" rel="stylesheet" type="text/css"/>
<link href="../../_static/sphinx-codeautolink.css" rel="stylesheet" type="text/css"/>
<link href="../../_static/autoclasstoc.css" rel="stylesheet" type="text/css"/>
<script data-url_root="../../" id="documentation_options" src="../../_static/documentation_options.js"></script>
<script src="../../_static/jquery.js"></script>
<script src="../../_static/underscore.js"></script>
<script src="../../_static/_sphinx_javascript_frameworks_compat.js"></script>
<script src="../../_static/doctools.js"></script>
<script src="../../_static/sphinx_highlight.js"></script>
<link href="../../_static/E-PyoIcon.ico" rel="shortcut icon"/>
<link href="../../about.html" rel="author" title="About these documents"/>
<link href="../../genindex.html" rel="index" title="Index"/>
<link href="../../search.html" rel="search" title="Search"/>
<link href="03-instruments.html" rel="next" title="03-instruments.py - Using custom instrument with events."/>
<link href="01-simple-sequences.html" rel="prev" title="01-simple-sequences.py - Looping over a list of values."/>
</head><body>
<div class="header-wrapper" role="banner">
<div class="header">
<div class="headertitle"><a href="../../index.html">Pyo 1.0.5 documentation</a></div>
<div aria-label="related navigation" class="rel" role="navigation">
<a accesskey="P" href="01-simple-sequences.html" title="01-simple-sequences.py - Looping over a list of values.">previous</a> |
          <a accesskey="N" href="03-instruments.html" title="03-instruments.py - Using custom instrument with events.">next</a> |
          <a accesskey="I" href="../../genindex.html" title="General Index">index</a>
</div>
</div>
</div>
<div class="content-wrapper">
<div class="content">
<div class="sidebar">
<h3>Table of Contents</h3>
<ul>
<li class="toctree-l1"><a class="reference internal" href="../../about.html">About pyo</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../download.html">Installing pyo with pip</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../compiling.html">Compiling pyo from sources</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../structure.html">Structure of the library</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../gettingstarted.html">Getting started</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../winaudioinspect.html">Configuring the audio output (Windows)</a></li>
<li class="toctree-l1"><a class="reference internal" href="../../perftips.html">Improve performance of pyo programs</a></li>
</ul>
<ul class="current">
<li class="toctree-l1"><a class="reference internal" href="../../api/index.html">API documentation</a></li>
<li class="toctree-l1 current"><a class="reference internal" href="../index.html">Examples</a><ul class="current">
<li class="toctree-l2"><a class="reference internal" href="../01-intro/index.html">First steps</a></li>
<li class="toctree-l2"><a class="reference internal" href="../02-controls/index.html">Parameter control</a></li>
<li class="toctree-l2"><a class="reference internal" href="../03-generators/index.html">Synthesis generators</a></li>
<li class="toctree-l2"><a class="reference internal" href="../04-soundfiles/index.html">Playing with soundfiles</a></li>
<li class="toctree-l2"><a class="reference internal" href="../05-envelopes/index.html">Amplitude envelopes</a></li>
<li class="toctree-l2"><a class="reference internal" href="../06-filters/index.html">Filtering</a></li>
<li class="toctree-l2"><a class="reference internal" href="../07-effects/index.html">Creating sound effects</a></li>
<li class="toctree-l2"><a class="reference internal" href="../08-dynamics/index.html">Dynamic range of audio signals</a></li>
<li class="toctree-l2"><a class="reference internal" href="../09-callbacks/index.html">Calling python functions from audio objects</a></li>
<li class="toctree-l2"><a class="reference internal" href="../10-tables/index.html">Using tables</a></li>
<li class="toctree-l2"><a class="reference internal" href="../16-midi/index.html">How to use MIDI with pyo</a></li>
<li class="toctree-l2"><a class="reference internal" href="../17-osc/index.html">How to use OSC with pyo</a></li>
<li class="toctree-l2"><a class="reference internal" href="../19-multirate/index.html">Multirate audio processing</a></li>
<li class="toctree-l2"><a class="reference internal" href="../20-multicore/index.html">Multicore audio programming</a></li>
<li class="toctree-l2"><a class="reference internal" href="../21-utilities/index.html">Utilities</a></li>
<li class="toctree-l2 current"><a class="reference internal" href="index.html">Events framework</a></li>
<li class="toctree-l2"><a class="reference internal" href="../23-expression/index.html">Evaluating prefix expression</a></li>
</ul>
</li>
<li class="toctree-l1"><a class="reference internal" href="../../tutorials/index.html">Advanced tutorials</a></li>
</ul>
<div role="search">
<h3 style="margin-top: 1.5em;">Search</h3>
<form action="../../search.html" class="search" method="get">
<input name="q" type="text"/>
<input type="submit" value="Go"/>
</form>
</div>
</div>
<div class="document">
<div class="documentwrapper">
<div class="bodywrapper">
<div class="body" role="main">
<section id="parameters-py-built-in-arguments-and-conversions">
<h1>02-parameters.py - Built-in arguments and conversions.<a class="headerlink" href="#parameters-py-built-in-arguments-and-conversions" title="Permalink to this heading">¶</a></h1>
<p>An Events object is build on top of the python’s dictionary. Any argument
passed at the creation of the object becomes a key inside the built-in
structure. A lot of argument are pre-defined automatically processed to
facilitate the construction of event’s frequency, duration, amplitude,
and envelope.</p>
<section id="duration">
<h2>Duration<a class="headerlink" href="#duration" title="Permalink to this heading">¶</a></h2>
<p>The duration of an event can be defined with ‘dur’ argument, which is a
duration in seconds, or with ‘beat’ argument. A value given to ‘beat’ is
converted in seconds (and registered at the key ‘dur’), according to the
value given to the ‘bpm’ argument (which defaults to 120). A beat value
of 1 is the duration of the quarter note, 2 is a half note, 1/2 is an
eighth note, and so on…</p>
<p>The first argument that reaches the end of its sequence triggers the end
of the Events’s playback:</p>
<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">e</span> <span class="o">=</span> <span class="n">Events</span><span class="p">(</span><span class="n">freq</span> <span class="o">=</span> <span class="n">EventSeq</span><span class="p">([</span><span class="mi">250</span><span class="p">,</span> <span class="mi">300</span><span class="p">,</span> <span class="mi">350</span><span class="p">,</span> <span class="mi">400</span><span class="p">]),</span>
           <span class="n">beat</span> <span class="o">=</span> <span class="n">EventSeq</span><span class="p">([</span><span class="mi">1</span><span class="o">/</span><span class="mf">2.</span><span class="p">,</span> <span class="mi">1</span><span class="o">/</span><span class="mf">4.</span><span class="p">,</span> <span class="mi">1</span><span class="o">/</span><span class="mf">4.</span><span class="p">,</span> <span class="mi">1</span><span class="p">],</span> <span class="n">occurrences</span><span class="o">=</span><span class="mi">4</span><span class="p">))</span><span class="o">.</span><span class="n">play</span><span class="p">()</span>
</pre></div>
</div>
<p>The ‘durmul’ argument allow to change the note duration without changing
the time gap between successive events:</p>
<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="c1"># Staccato</span>
<span class="n">e1</span> <span class="o">=</span> <span class="n">Events</span><span class="p">(</span><span class="n">freq</span> <span class="o">=</span> <span class="n">EventSeq</span><span class="p">([</span><span class="mi">250</span><span class="p">,</span> <span class="mi">300</span><span class="p">,</span> <span class="mi">350</span><span class="p">,</span> <span class="mi">400</span><span class="p">]),</span>
            <span class="n">beat</span> <span class="o">=</span> <span class="n">EventSeq</span><span class="p">([</span><span class="mi">1</span><span class="o">/</span><span class="mf">2.</span><span class="p">,</span> <span class="mi">1</span><span class="o">/</span><span class="mf">4.</span><span class="p">,</span> <span class="mi">1</span><span class="o">/</span><span class="mf">4.</span><span class="p">,</span> <span class="mi">1</span><span class="p">],</span> <span class="n">occurrences</span><span class="o">=</span><span class="mi">4</span><span class="p">),</span>
            <span class="n">durmul</span> <span class="o">=</span> <span class="mf">0.5</span><span class="p">)</span><span class="o">.</span><span class="n">play</span><span class="p">()</span>

<span class="c1"># Overlapping</span>
<span class="n">e2</span> <span class="o">=</span> <span class="n">Events</span><span class="p">(</span><span class="n">freq</span> <span class="o">=</span> <span class="n">EventSeq</span><span class="p">([</span><span class="mi">250</span><span class="p">,</span> <span class="mi">300</span><span class="p">,</span> <span class="mi">350</span><span class="p">,</span> <span class="mi">400</span><span class="p">]),</span>
            <span class="n">beat</span> <span class="o">=</span> <span class="n">EventSeq</span><span class="p">([</span><span class="mi">1</span><span class="o">/</span><span class="mf">2.</span><span class="p">,</span> <span class="mi">1</span><span class="o">/</span><span class="mf">4.</span><span class="p">,</span> <span class="mi">1</span><span class="o">/</span><span class="mf">4.</span><span class="p">,</span> <span class="mi">1</span><span class="p">],</span> <span class="n">occurrences</span><span class="o">=</span><span class="mi">4</span><span class="p">),</span>
            <span class="n">durmul</span> <span class="o">=</span> <span class="mf">1.5</span><span class="p">)</span><span class="o">.</span><span class="n">play</span><span class="p">()</span>
</pre></div>
</div>
</section>
<section id="frequency">
<h2>Frequency<a class="headerlink" href="#frequency" title="Permalink to this heading">¶</a></h2>
<p>The ‘freq’ argument can be used directly to specify the root note. But
it is sometimes easier to create a melody with ‘midinote’ or ‘degree’,
and let the engine do the conversion to frequency for you. The ‘midinote’
argument is a MIDI note number between 0 and 127, fractionnal numbers
are allowed to do micro-tonal scaling. The ‘degree’ argument needs a
value in octave.degree format where octave is the number of the desired
octave and degree is a 2-digits degree number between 00 and 11. For
an example, the MIDI note 48 is 4.00 in octave.degree notation.</p>
<p>The midinote and degree arguments will automatically convert and store
the frequency, in Hz, as the ‘freq’ argument:</p>
<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">e3</span> <span class="o">=</span> <span class="n">Events</span><span class="p">(</span><span class="n">midinote</span> <span class="o">=</span> <span class="n">EventSeq</span><span class="p">([</span><span class="mi">60</span><span class="p">,</span> <span class="mi">64</span><span class="p">,</span> <span class="mi">67</span><span class="p">,</span> <span class="mi">72</span><span class="p">]),</span>
            <span class="n">beat</span> <span class="o">=</span> <span class="n">EventSeq</span><span class="p">([</span><span class="mi">1</span><span class="o">/</span><span class="mf">2.</span><span class="p">,</span> <span class="mi">1</span><span class="o">/</span><span class="mf">4.</span><span class="p">,</span> <span class="mi">1</span><span class="o">/</span><span class="mf">4.</span><span class="p">,</span> <span class="mi">1</span><span class="p">],</span> <span class="n">occurrences</span><span class="o">=</span><span class="mi">4</span><span class="p">))</span><span class="o">.</span><span class="n">play</span><span class="p">()</span>
</pre></div>
</div>
<p>The ‘degree’ argument uses an octave.degree notation. Ex.: 6.07 means
the perfect fifth (07) of the sixth octave:</p>
<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">e4</span> <span class="o">=</span> <span class="n">Events</span><span class="p">(</span><span class="n">degree</span> <span class="o">=</span> <span class="n">EventSeq</span><span class="p">([</span><span class="mf">5.00</span><span class="p">,</span> <span class="mf">5.04</span><span class="p">,</span> <span class="mf">5.07</span><span class="p">,</span> <span class="mf">6.00</span><span class="p">]),</span>
            <span class="n">beat</span> <span class="o">=</span> <span class="n">EventSeq</span><span class="p">([</span><span class="mi">1</span><span class="o">/</span><span class="mf">2.</span><span class="p">,</span> <span class="mi">1</span><span class="o">/</span><span class="mf">4.</span><span class="p">,</span> <span class="mi">1</span><span class="o">/</span><span class="mf">4.</span><span class="p">,</span> <span class="mi">1</span><span class="p">],</span> <span class="n">occurrences</span><span class="o">=</span><span class="mi">4</span><span class="p">))</span><span class="o">.</span><span class="n">play</span><span class="p">()</span>
</pre></div>
</div>
<p>One can transpose an entire sequence (or sequence the transposition
values) with the ‘transpo’ argument. Transposition values are relative
midi note (0 means no transposition, -12 is the lower octave):</p>
<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">e5</span> <span class="o">=</span> <span class="n">Events</span><span class="p">(</span><span class="n">degree</span> <span class="o">=</span> <span class="n">EventSeq</span><span class="p">([</span><span class="mf">5.00</span><span class="p">,</span> <span class="mf">5.04</span><span class="p">,</span> <span class="mf">5.07</span><span class="p">,</span> <span class="mf">6.00</span><span class="p">]),</span>
            <span class="n">beat</span> <span class="o">=</span> <span class="n">EventSeq</span><span class="p">([</span><span class="mi">1</span><span class="o">/</span><span class="mf">2.</span><span class="p">,</span> <span class="mi">1</span><span class="o">/</span><span class="mf">4.</span><span class="p">,</span> <span class="mi">1</span><span class="o">/</span><span class="mf">4.</span><span class="p">,</span> <span class="mi">1</span><span class="p">],</span> <span class="n">occurrences</span><span class="o">=</span><span class="mi">4</span><span class="p">),</span>
            <span class="n">transpo</span> <span class="o">=</span> <span class="o">-</span><span class="mi">12</span><span class="p">)</span><span class="o">.</span><span class="n">play</span><span class="p">()</span>
</pre></div>
</div>
</section>
<section id="amplitude">
<h2>Amplitude<a class="headerlink" href="#amplitude" title="Permalink to this heading">¶</a></h2>
<p>Amplitude values are given either with ‘amp’ (linear amplitude), ‘db’
(decibel values) or ‘midivel’ (MIDI velocity between 0 and 127). Decibel
values and MIDI velocity are internally converted to linear gain and stored
as the ‘amp’ argument:</p>
<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="c1"># Sequence with accented notes.</span>
<span class="n">e6</span> <span class="o">=</span> <span class="n">Events</span><span class="p">(</span><span class="n">degree</span> <span class="o">=</span> <span class="n">EventSeq</span><span class="p">([</span><span class="mf">5.00</span><span class="p">,</span> <span class="mf">5.04</span><span class="p">,</span> <span class="mf">5.07</span><span class="p">,</span> <span class="mf">6.00</span><span class="p">]),</span>
            <span class="n">beat</span> <span class="o">=</span> <span class="n">EventSeq</span><span class="p">([</span><span class="mi">1</span><span class="o">/</span><span class="mf">2.</span><span class="p">,</span> <span class="mi">1</span><span class="o">/</span><span class="mf">4.</span><span class="p">,</span> <span class="mi">1</span><span class="o">/</span><span class="mf">4.</span><span class="p">,</span> <span class="mi">1</span><span class="p">],</span> <span class="n">occurrences</span><span class="o">=</span><span class="mi">4</span><span class="p">),</span>
            <span class="n">db</span> <span class="o">=</span> <span class="n">EventSeq</span><span class="p">([</span><span class="o">-</span><span class="mi">3</span><span class="p">,</span> <span class="o">-</span><span class="mi">6</span><span class="p">,</span> <span class="o">-</span><span class="mi">12</span><span class="p">,</span> <span class="o">-</span><span class="mi">3</span><span class="p">]))</span><span class="o">.</span><span class="n">play</span><span class="p">()</span>
</pre></div>
</div>
</section>
<section id="envelope">
<h2>Envelope<a class="headerlink" href="#envelope" title="Permalink to this heading">¶</a></h2>
<p>Different shapes for the amplitude envelope are defined according to the
presence of certain parameters. The amplitude envelope is automatically
created in the EventGenerator __init__ method.</p>
<p>If ‘envelope’ receives a PyoTableObject, it will be used as the amplitude
envelope of the events. If ‘envelope’ is None and ‘decay’ gets a value,
the envelope will be an ADSR built with ‘attack’, ‘decay’, ‘sustain’ and
‘release’ argument. If both ‘envelope’ and ‘decay’ are None, the envelope
will be an ASR, defined with ‘attack’, ‘sustain’ and ‘release’ arguments.</p>
<p>The following defines an Adsr envelope:</p>
<div class="highlight-default notranslate"><div class="highlight"><pre><span></span><span class="n">e7</span> <span class="o">=</span> <span class="n">Events</span><span class="p">(</span><span class="n">degree</span> <span class="o">=</span> <span class="n">EventSeq</span><span class="p">([</span><span class="mf">5.00</span><span class="p">,</span> <span class="mf">5.04</span><span class="p">,</span> <span class="mf">5.07</span><span class="p">,</span> <span class="mf">6.00</span><span class="p">]),</span>
            <span class="n">beat</span> <span class="o">=</span> <span class="n">EventSeq</span><span class="p">([</span><span class="mi">1</span><span class="o">/</span><span class="mf">2.</span><span class="p">,</span> <span class="mi">1</span><span class="o">/</span><span class="mf">4.</span><span class="p">,</span> <span class="mi">1</span><span class="o">/</span><span class="mf">4.</span><span class="p">,</span> <span class="mi">1</span><span class="p">],</span> <span class="n">occurrences</span><span class="o">=</span><span class="mi">4</span><span class="p">),</span>
            <span class="n">attack</span> <span class="o">=</span> <span class="mf">0.001</span><span class="p">,</span> <span class="n">decay</span> <span class="o">=</span> <span class="mf">0.05</span><span class="p">,</span> <span class="n">sustain</span> <span class="o">=</span> <span class="mf">0.5</span><span class="p">,</span> <span class="n">release</span> <span class="o">=</span> <span class="mf">0.005</span><span class="p">,</span>
            <span class="n">db</span> <span class="o">=</span> <span class="n">EventSeq</span><span class="p">([</span><span class="o">-</span><span class="mi">3</span><span class="p">,</span> <span class="o">-</span><span class="mi">6</span><span class="p">,</span> <span class="o">-</span><span class="mi">12</span><span class="p">,</span> <span class="o">-</span><span class="mi">3</span><span class="p">]))</span><span class="o">.</span><span class="n">play</span><span class="p">()</span>
</pre></div>
</div>
</section>
<section id="complete-example">
<h2>Complete Example<a class="headerlink" href="#complete-example" title="Permalink to this heading">¶</a></h2>
<div class="highlight-python notranslate"><div class="highlight"><pre><span></span><span class="kn">from</span> <a class="sphinx-codeautolink-a" href="../../api/alphabetical.html#module-pyo" title="pyo"><span class="nn">pyo</span></a> <span class="kn">import</span> <span class="o">*</span>

<span class="n">s</span> <span class="o">=</span> <a class="sphinx-codeautolink-a" href="../../api/classes/server.html#pyo.Server" title="pyo.lib.server.Server"><span class="n">Server</span></a><span class="p">()</span><span class="o">.</span><span class="n">boot</span><span class="p">()</span>

<span class="c1">### Envelope</span>

<span class="c1"># Using a PyoTableObject to define the envelope.</span>
<a class="sphinx-codeautolink-a" href="../../api/classes/tables.html#pyo.CosTable" title="pyo.lib.tables.CosTable"><span class="n">env</span></a> <span class="o">=</span> <a class="sphinx-codeautolink-a" href="../../api/classes/tables.html#pyo.CosTable" title="pyo.lib.tables.CosTable"><span class="n">CosTable</span></a><span class="p">([(</span><span class="mi">0</span><span class="p">,</span> <span class="mf">0.0</span><span class="p">),</span> <span class="p">(</span><span class="mi">128</span><span class="p">,</span> <span class="mf">1.0</span><span class="p">),</span> <span class="p">(</span><span class="mi">1024</span><span class="p">,</span> <span class="mf">0.7</span><span class="p">),</span> <span class="p">(</span><span class="mi">4096</span><span class="p">,</span> <span class="mf">0.7</span><span class="p">),</span> <span class="p">(</span><span class="mi">8192</span><span class="p">,</span> <span class="mf">0.0</span><span class="p">)])</span>

<span class="n">e8</span> <span class="o">=</span> <a class="sphinx-codeautolink-a" href="../../api/classes/events.html#pyo.Events" title="pyo.lib.events.Events"><span class="n">Events</span></a><span class="p">(</span>
    <span class="n">degree</span><span class="o">=</span><a class="sphinx-codeautolink-a" href="../../api/classes/events.html#pyo.EventSeq" title="pyo.lib.events.EventSeq"><span class="n">EventSeq</span></a><span class="p">([</span><span class="mf">5.00</span><span class="p">,</span> <span class="mf">5.04</span><span class="p">,</span> <span class="mf">5.07</span><span class="p">,</span> <span class="mf">6.00</span><span class="p">]),</span>
    <span class="n">beat</span><span class="o">=</span><a class="sphinx-codeautolink-a" href="../../api/classes/events.html#pyo.EventSeq" title="pyo.lib.events.EventSeq"><span class="n">EventSeq</span></a><span class="p">([</span><span class="mi">1</span> <span class="o">/</span> <span class="mf">2.0</span><span class="p">,</span> <span class="mi">1</span> <span class="o">/</span> <span class="mf">4.0</span><span class="p">,</span> <span class="mi">1</span> <span class="o">/</span> <span class="mf">4.0</span><span class="p">,</span> <span class="mi">1</span><span class="p">],</span> <span class="n">occurrences</span><span class="o">=</span><span class="mi">4</span><span class="p">),</span>
    <span class="n">db</span><span class="o">=</span><a class="sphinx-codeautolink-a" href="../../api/classes/events.html#pyo.EventSeq" title="pyo.lib.events.EventSeq"><span class="n">EventSeq</span></a><span class="p">([</span><span class="o">-</span><span class="mi">3</span><span class="p">,</span> <span class="o">-</span><span class="mi">6</span><span class="p">,</span> <span class="o">-</span><span class="mi">12</span><span class="p">,</span> <span class="o">-</span><span class="mi">3</span><span class="p">]),</span>
    <span class="n">envelope</span><span class="o">=</span><a class="sphinx-codeautolink-a" href="../../api/classes/tables.html#pyo.CosTable" title="pyo.lib.tables.CosTable"><span class="n">env</span></a><span class="p">,</span>
<span class="p">)</span><span class="o">.</span><span class="n">play</span><span class="p">()</span>

<span class="n">s</span><span class="o">.</span><span class="n">gui</span><span class="p">(</span><span class="nb">locals</span><span class="p">())</span>
</pre></div>
</div>
</section>
</section>
<div class="clearer"></div>
</div>
</div>
</div>
</div>
<div class="clearer"></div>
</div>
</div>
<div class="footer-wrapper">
<div class="footer">
<div class="left">
<div aria-label="related navigaton" role="navigation">
<a href="01-simple-sequences.html" title="01-simple-sequences.py - Looping over a list of values.">previous</a> |
            <a href="03-instruments.html" title="03-instruments.py - Using custom instrument with events.">next</a> |
            <a href="../../genindex.html" title="General Index">index</a>
</div>
<div aria-label="source link" role="note">
</div>
</div>
<div class="right">
<div class="footer" role="contentinfo">
        © Copyright 2021, Olivier Bélanger.
      Created using <a href="https://www.sphinx-doc.org/">Sphinx</a> 5.3.0.
    </div>
</div>
<div class="clearer"></div>
</div>
</div>
</body>
</html>