2017-12-18 21:50:27 +01:00
|
|
|
import time
|
|
|
|
import numpy as np
|
|
|
|
import pyaudio
|
|
|
|
import config
|
|
|
|
|
|
|
|
|
|
|
|
def start_stream(callback):
|
|
|
|
p = pyaudio.PyAudio()
|
|
|
|
frames_per_buffer = int(config.MIC_RATE / config.FPS)
|
|
|
|
stream = p.open(format=pyaudio.paInt16,
|
|
|
|
channels=1,
|
|
|
|
rate=config.MIC_RATE,
|
|
|
|
input=True,
|
|
|
|
frames_per_buffer=frames_per_buffer)
|
|
|
|
overflows = 0
|
|
|
|
prev_ovf_time = time.time()
|
|
|
|
while True:
|
|
|
|
try:
|
2017-12-19 16:50:24 +01:00
|
|
|
y = np.fromstring(stream.read(frames_per_buffer, exception_on_overflow=False), dtype=np.int16)
|
2017-12-18 21:50:27 +01:00
|
|
|
y = y.astype(np.float32)
|
2018-01-06 21:02:04 +01:00
|
|
|
#stream.read(get_read_available(), exception_on_overflow=False)
|
2017-12-18 21:50:27 +01:00
|
|
|
callback(y)
|
|
|
|
except IOError:
|
|
|
|
overflows += 1
|
|
|
|
if time.time() > prev_ovf_time + 1:
|
|
|
|
prev_ovf_time = time.time()
|
|
|
|
if config.USE_GUI:
|
|
|
|
gui.label_error.setText('Audio buffer has overflowed {} times'.format(overflows))
|
|
|
|
else:
|
|
|
|
print('Audio buffer has overflowed {} times'.format(overflows))
|
|
|
|
stream.stop_stream()
|
|
|
|
stream.close()
|
|
|
|
p.terminate()
|