Mercurial > hg > constant-q-cpp
view yeti/plotfile.yeti @ 66:3d165bf186f1
Add little program to plot cq of an audio file
author | Chris Cannam <c.cannam@qmul.ac.uk> |
---|---|
date | Fri, 14 Feb 2014 14:24:37 +0000 |
parents | |
children | 642df7b3346f |
line wrap: on
line source
program plotfile; af = load may.stream.audiofile; plot = load may.plot; cm = load may.matrix.complex; mat = load may.matrix; { cqt } = load cqt; plotfile f = (testStream = af.open f; eprintln "Opened file stream..."; cq = cqt { maxFreq = testStream.sampleRate/2, minFreq = 50, binsPerOctave = 24 } testStream; eprintln "Generated kernel and primed transform, now calculating..."; bigM = mat.concatHorizontal (map cm.magnitudes cq.output); eprintln "Plotting..."; \() (plot.plot [Contour bigM])); usage () = (eprintln "\nUsage: plotfile file.wav"; eprintln "\n Loads audio from file.wav and plots a 24bpo Constant-Q spectrogram"; eprintln " from 50Hz up to half the file samplerate"); case (list _argv) of file::[]: plotfile file; _: usage (); esac;