File: demo_simple_robot_voice.py

package info (click to toggle)
aubio 0.4.9-5
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 3,720 kB
  • sloc: python: 20,447; ansic: 20,127; makefile: 348; sh: 232
file content (29 lines) | stat: -rwxr-xr-x 1,015 bytes parent folder | download | duplicates (6)
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
#! /usr/bin/env python

import sys
from aubio import source, sink, pvoc

if __name__ == '__main__':
    if len(sys.argv) < 2:
        print('usage: %s <inputfile> <outputfile>' % sys.argv[0])
        sys.exit(1)
    samplerate = 44100
    f = source(sys.argv[1], samplerate, 256)
    g = sink(sys.argv[2], samplerate)
    total_frames, read = 0, 256

    win_s = 512                          # fft size
    hop_s = win_s // 2                   # hop size
    pv = pvoc(win_s, hop_s)              # phase vocoder

    while read:
        samples, read = f()
        spectrum = pv(samples)           # compute spectrum
        #spectrum.norm *= .8             # reduce amplitude a bit
        spectrum.phas[:] = 0.            # zero phase
        new_samples = pv.rdo(spectrum)   # compute modified samples
        g(new_samples, read)             # write to output
        total_frames += read

    format_str = "read {:d} samples from {:s}, written to {:s}"
    print(format_str.format(total_frames, f.uri, g.uri))