peterf@2
|
1 #!/usr/bin/env python
|
peterf@2
|
2 '''CREATED:2013-12-08 14:28:34 by Brian McFee <brm2132@columbia.edu>
|
peterf@2
|
3
|
peterf@2
|
4 Demonstration of harmonic-percussive source separation
|
peterf@2
|
5 '''
|
peterf@2
|
6 from __future__ import print_function
|
peterf@2
|
7
|
peterf@2
|
8 import argparse
|
peterf@2
|
9 import sys
|
peterf@2
|
10 import librosa
|
peterf@2
|
11
|
peterf@2
|
12
|
peterf@2
|
13 def hpss_demo(input_file, output_harmonic, output_percussive):
|
peterf@2
|
14 '''HPSS demo function.
|
peterf@2
|
15
|
peterf@2
|
16 :parameters:
|
peterf@2
|
17 - input_file : str
|
peterf@2
|
18 path to input audio
|
peterf@2
|
19 - output_harmonic : str
|
peterf@2
|
20 path to save output harmonic (wav)
|
peterf@2
|
21 - output_percussive : str
|
peterf@2
|
22 path to save output harmonic (wav)
|
peterf@2
|
23 '''
|
peterf@2
|
24
|
peterf@2
|
25 # 1. Load the wav file, resample
|
peterf@2
|
26 print('Loading ', input_file)
|
peterf@2
|
27
|
peterf@2
|
28 y, sr = librosa.load(input_file)
|
peterf@2
|
29
|
peterf@2
|
30 # Separate components with the effects module
|
peterf@2
|
31 print('Separating harmonics and percussives... ')
|
peterf@2
|
32 y_harmonic, y_percussive = librosa.effects.hpss(y)
|
peterf@2
|
33
|
peterf@2
|
34 # 5. Save the results
|
peterf@2
|
35 print('Saving harmonic audio to: ', output_harmonic)
|
peterf@2
|
36 librosa.output.write_wav(output_harmonic, y_harmonic, sr)
|
peterf@2
|
37
|
peterf@2
|
38 print('Saving percussive audio to: ', output_percussive)
|
peterf@2
|
39 librosa.output.write_wav(output_percussive, y_percussive, sr)
|
peterf@2
|
40
|
peterf@2
|
41
|
peterf@2
|
42 def process_arguments(args):
|
peterf@2
|
43 '''Argparse function to get the program parameters'''
|
peterf@2
|
44
|
peterf@2
|
45 parser = argparse.ArgumentParser(description='harmonic-percussive example')
|
peterf@2
|
46
|
peterf@2
|
47 parser.add_argument('input_file',
|
peterf@2
|
48 action='store',
|
peterf@2
|
49 help='path to the input file (wav, mp3, etc)')
|
peterf@2
|
50
|
peterf@2
|
51 parser.add_argument('output_harmonic',
|
peterf@2
|
52 action='store',
|
peterf@2
|
53 help='path to the harmonic output (wav)')
|
peterf@2
|
54
|
peterf@2
|
55 parser.add_argument('output_percussive',
|
peterf@2
|
56 action='store',
|
peterf@2
|
57 help='path to the percussive output (wav)')
|
peterf@2
|
58
|
peterf@2
|
59 return vars(parser.parse_args(args))
|
peterf@2
|
60
|
peterf@2
|
61
|
peterf@2
|
62 if __name__ == '__main__':
|
peterf@2
|
63 # get the parameters
|
peterf@2
|
64 parameters = process_arguments(sys.argv[1:])
|
peterf@2
|
65
|
peterf@2
|
66 # Run the HPSS code
|
peterf@2
|
67 hpss_demo(parameters['input_file'],
|
peterf@2
|
68 parameters['output_harmonic'],
|
peterf@2
|
69 parameters['output_percussive'])
|