annotate tools/gen_sound.py @ 544:f79d1d3df8e8

pep8 cleanup
author Neil Muller <neil@dip.sun.ac.za>
date Sat, 11 Feb 2012 12:31:33 +0200
parents 5b9f371c2bb8
children 15713dfe555d
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
245
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
1 # Generate 'perfect' sine wave sounds
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
2
537
5b9f371c2bb8 PEP-8 cleanup of tools
Stefano Rivera <stefano@rivera.za.net>
parents: 249
diff changeset
3 # Design notes: produces ~= (use requested) s raw CDDA audio - 44100 Hz
5b9f371c2bb8 PEP-8 cleanup of tools
Stefano Rivera <stefano@rivera.za.net>
parents: 249
diff changeset
4 # 16 bit signed values
245
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
5 # Input is freq in Hz - 440 for A, etc. - must be an integer
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
6 # Output is written the file beep<freq>.pcm
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
7 # Convert to ogg with oggenc -r <file>
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
8
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
9 import sys
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
10 import math
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
11 import struct
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
12
537
5b9f371c2bb8 PEP-8 cleanup of tools
Stefano Rivera <stefano@rivera.za.net>
parents: 249
diff changeset
13 CDDA_RATE = 44100
5b9f371c2bb8 PEP-8 cleanup of tools
Stefano Rivera <stefano@rivera.za.net>
parents: 249
diff changeset
14 MAX = 105 * 256 # Max value for sine wave
245
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
15
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
16
249
913257638e6f Add length parameter
Neil Muller <neil@dip.sun.ac.za>
parents: 245
diff changeset
17 def gen_sine(freq, secs):
245
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
18 filename = 'beep%s.pcm' % freq
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
19 # We need to generate freq cycles and sample that CDDA_RATE times
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
20 samples_per_cycle = CDDA_RATE / freq
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
21 data = []
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
22 for x in range(samples_per_cycle):
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
23 rad = float(x) / samples_per_cycle * 2 * math.pi
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
24 y = MAX * math.sin(rad)
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
25 data.append(struct.pack('<i', y))
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
26 output = open(filename, 'w')
249
913257638e6f Add length parameter
Neil Muller <neil@dip.sun.ac.za>
parents: 245
diff changeset
27 for x in range(int(freq * secs)):
245
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
28 output.write(''.join(data))
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
29 output.close()
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
30
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
31
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
32 if __name__ == "__main__":
f87a3485d927 Add tool for making beeps
Neil Muller <neil@dip.sun.ac.za>
parents:
diff changeset
33 freq = int(sys.argv[1])
249
913257638e6f Add length parameter
Neil Muller <neil@dip.sun.ac.za>
parents: 245
diff changeset
34 if len(sys.argv) > 2:
913257638e6f Add length parameter
Neil Muller <neil@dip.sun.ac.za>
parents: 245
diff changeset
35 secs = float(sys.argv[2])
913257638e6f Add length parameter
Neil Muller <neil@dip.sun.ac.za>
parents: 245
diff changeset
36 else:
913257638e6f Add length parameter
Neil Muller <neil@dip.sun.ac.za>
parents: 245
diff changeset
37 secs = 0.25
913257638e6f Add length parameter
Neil Muller <neil@dip.sun.ac.za>
parents: 245
diff changeset
38 gen_sine(freq, secs)