我正在尝试对声音的频率和幅度进行一些更改。我目前正在获取声音数据,但是每当我尝试将其乘以一个值(例如改变幅度)时,都会听到很多噪音。我想知道如何以一种干净的方式做到这一点。我需要遍历数据,因为频率和幅度的变化取决于用户的输入(我稍后将使用网络摄像头根据手的位置进行更改)。使用当前代码,我的输入文件只有一个通道。我不确定为什么,但是在“ getNewWave”中,如果将其更改为np.int16,音频也会产生噪音。谢谢!
import pyaudio
import wave
import sys
import numpy as np
def getNewWave(data):
newdata = np.frombuffer(data, np.int8)
#make some changes to amplitude and frequency
return newdata
def main():
CHUNK = 1024
if len(sys.argv) < 2:
print("Missing input wav file. File must have single channel")
sys.exit(-1)
wf = wave.open(sys.argv[1], 'rb')
p = pyaudio.PyAudio()
stream = p.open(format=pyaudio.paInt16,
channels=1,
rate=wf.getframerate(),
output=True, frames_per_buffer=CHUNK)
data = wf.readframes(CHUNK)
while data != '':
stream.write(getNewWave(data))
data = wf.readframes(CHUNK)
stream.stop_stream()
stream.close()
p.terminate()
main()