前提・実現したいこと
現在、Python で効果音の編集を行うプログラムを作成しています。編集したい音を入力とし、音のパラメータを2つ用意してパラメータの値を基に効果音の編集を行って、出来上がった音を出力するようにしています。
発生している問題
numpyのfftを使って入力ファイルをフーリエ変換し、編集後のデータをifftを使ってwavファイルに戻したいのですが、雑音だらけになってしまいます。なぜ雑音だらけになるのかが分かりません。ご指摘いただけないでしょうか。
該当のソースコード
python
1 2import wav 3import numpy 4 5freq = 500 6low = 500 7 8wf = wave.open("sword-slash.wav", "rb") 9 10numch = wf.getnchannels() #チャンネル数 11samplewidth = wf.getsampwidth() 12samplerate = wf.getframerate() #サンプリング周波数 13numsamples = wf.getnframes() #フレーム数 14 15buf = wf.readframes(wf.getnframes()) 16wf.close() 17 18//配列に格納 19if samplewidth == 2: 20 data = numpy.frombuffer(buf, dtype='int16') 21 after = numpy.zeros(numsamples, dtype='int16') 22if samplewidth == 4: 23 data = numpy.frombuffer(buf, dtype='int32') 24 after = numpy.zeros(numsamples, dtype='int32') 25 26N = numsamples 27start = 0 28 29G = numpy.fft.fft(data[start:start+N]) 30#G = abs(G) 31flist = numpy.fft.fftfreq(N, d=1/samplerate) 32 33G_roll = numpy.roll(flist, freq) #freq = 音の高さのパラメータ(音の高さを高くしたい) 34G_roll[flist > low] = 0 #ローパスのパラメータ(lowより大きい周波数は0にしたい) 35 36after = numpy.fft.ifft(G) 37 38ww = wave.open("sample2.wav", "wb") 39ww.setnchannels(numch) 40ww.setsampwidth(samplewidth) 41ww.setframerate(samplerate) 42ww.setnframes(numsamples) 43 44ww.writeframes(after) 45
補足情報(FW/ツールのバージョンなど)
python3.6でpycharmを使って実装しています