Как извлечь информацию о частоте из входного аудиопотока (используя PortAudio)? - PullRequest
2 голосов
/ 03 ноября 2008

Я хочу записать звук (голос) с помощью PortAudio (PyAudio) и вывести соответствующую звуковую волну на экран. Безнадежно, как я, я не могу извлечь информацию о частоте из аудиопотока, чтобы я мог нарисовать ее в форме Гц / время.


Вот пример фрагмента кода, который записывает и воспроизводит записанное аудио в течение пяти секунд, если это поможет:

p = pyaudio.PyAudio()

chunk = 1024
seconds = 5

stream = p.open(format=pyaudio.paInt16,
                channels=1,
                rate=44100,
                input=True,
                output=True)

for i in range(0, 44100 / chunk * seconds):
    data = stream.read(chunk)
    stream.write(data, chunk)

Я хочу извлечь необходимую информацию из вышеуказанной переменной «data». (Или используйте другой высокоуровневый подход с PortAudio или другой библиотекой с привязками Python.)


Буду очень признателен за любую помощь! Ценится даже смутно связанный с ним аудио-анализ мудрости. :)

Ответы [ 2 ]

4 голосов
/ 03 ноября 2008

То, что вы хотите, это, вероятно, преобразование Фурье аудиоданных. Есть несколько пакетов, которые могут рассчитать это для вас. scipy и numpy - это два из них. Его часто называют «быстрое преобразование Фурье» (БПФ), но это всего лишь название алгоритма.

Вот пример его использования: https://svn.enthought.com/enthought/browser/Chaco/trunk/examples/advanced/spectrum.py

1 голос
/ 20 февраля 2009

Преобразование Фурье мало поможет вам, если вы хотите, чтобы анализ проводился как в частотной, так и во временной области. Возможно, вы захотите взглянуть на «Wavelet Transforms». Есть пакет под названием pywavelets ... http://www.pybytes.com/pywavelets/#discrete-wavelet-transform-dwt

...