我有两个python脚本。第一次使用At Commands调用,第二次接收音频并将其发送到计算机麦克风。问题是,当我发送音频时,调制解调器会重置或听起来很慢。
First(docall.py)
import serial
se = serial.Serial()
se.port = 5
se.baudrate = 9600 # may be different
se.timeout = 0.5
a=1
se.open()
cont=0
while (a==1):
if not se.isOpen():
se.open()
if cont == 1:
se.write('AT+CHUP;\r\n')
se.write('ATD*264;\r\n')
if cont == 2:
se.write('AT^DDSETEX?;\r\n')
if cont == 3:
se.write('AT^DDSETEX=2;\r\n')
line = se.read(1024)
print (line)
cont=cont+1
se.close()
秒(audio.py)
import serial
import pyaudio
import wave
import time
CHUNK = 1024
FORMAT = pyaudio.paInt16
CHANNELS = 1
RATE = 8000
RECORD_SECONDS = 10
WIDTH = 2
pe = pyaudio.PyAudio()
stream= pe.open(format=pe.get_format_from_width(WIDTH),
channels=CHANNELS,
rate=RATE,
output=True,
frames_per_buffer=CHUNK)
mic= pe.open(format=pyaudio.paInt16,
channels=1,
rate=8000,
input=True,
frames_per_buffer=128)
se = serial.Serial()
se.port = 3
se.baudrate = 9600 # may be different
se.timeout = 0.5
se.open()
se.writeTimeout = 0
streaming = []
frames = []
while True:
re= se.read(CHUNK)
stream.write(re)
se.write(mic.read(612))
答案 0 :(得分:0)
您需要制作帧缓冲区160以匹配设备速率。我使用pa设备回调以便从设备进行写入和读取,每个缓冲区的密钥数为320帧。
device = Serial('/dev/tty.HUAWEIMobile-Diag', timeout=None, writeTimeout=0)
time.sleep(0.1) #this sleep needed for device buffer clean
device.flush()
device.flushInput()
device.flushOutput()
uni_stream = pe.open(format=pyaudio.paInt16,
channels=1,
rate=8000,
input=True,
output=True,
frames_per_buffer=160, stream_callback=uni_callback)
def uni_callback(in_data, frame_count, time_info, status):
data = device.read(320)
device.write(in_data)
return (data, pyaudio.paContinue)