-
Notifications
You must be signed in to change notification settings - Fork 19
/
Copy pathquantize.py
executable file
·68 lines (52 loc) · 1.53 KB
/
quantize.py
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
#!/usr/bin/env python3
import shelve
import sys
# QUANTIZE will be the accuracy of quantization.
# E.g. 24 = quant to the quarter note.
# Magic value of 0 = do nothing.
filename, QUANTIZE = sys.argv[1:]
QUANTIZE = int(QUANTIZE)
db = shelve.open(sys.argv[1])
notes = db["notes"]
def quantize(tick):
if QUANTIZE == 0:
return
offset = tick % QUANTIZE
if offset < QUANTIZE/2:
new_tick = tick-offset
else:
new_tick = tick-offset+QUANTIZE
if tick != new_tick:
print("Quantizing {} to {}".format(tick, new_tick))
return new_tick
def move(src, dst):
print("{} -> {}".format(src, dst))
if dst not in notes:
notes[dst] = []
notes[dst].extend(notes[src])
del notes[src]
ticks = sorted(notes.keys())
for tick, next_tick in zip(ticks, ticks[1:]):
for note in notes[tick]:
bar = tick//24//4
beat = tick/24%4
print("{bar:3}.{beat:3} | {note.note:3} | {note.velocity:3} | {note.duration:3}"
.format(bar=bar, beat=beat, note=note))
note.duration = quantize(note.duration)
if note.duration == 0:
note.duration = quantize(next_tick - tick)
for note in notes[ticks[-1]]:
if note.duration == 0 and QUANTIZE > 0:
note.duration = 24
ticks = sorted(notes.keys())
for src in ticks:
dst = quantize(src)
if src != dst:
move(src, dst)
ticks = sorted(notes.keys())
first = ticks[0]
if first > 0 and QUANTIZE > 0:
for tick in ticks:
move(tick, tick-first)
db["notes"] = notes
db.close()