Как сдвинуть фазу записанного wav-файла на 180 градусов
Есть ли способ сдвинуть фазу файла WAV в Python? Я пытаюсь добиться активного снижения шума. Я планирую записать окружающий шум, а затем сдвинуть его фазу на 180 градусов. Затем я запишу другой wav-файл с кем-то, говорящим с микрофоном, на этот раз, а затем скомбинирую второй wav-файл с тем, который находится на 180 градусов в противофазе, в надежде отменить или уменьшить шум. Я попробовал это с дерзостью, и это работает. Мне уже удалось записать звук с помощью Pyaudio, единственная проблема - сдвинуть фазу записанного звука и объединить его с другим wav-файлом. Как мне сдвинуть фазу файла WAV. Вот текущий скрипт ниже:
import pyaudio
import wave
import matplotlib.pyplot as plt
import numpy as np
import scipy.io.wavfile
import scipy.signal as sp
FORMAT = pyaudio.paInt16
CHANNELS = 2
RATE = 44100
CHUNK = 1024
RECORD_SECONDS = 5
WAVE_OUTPUT_FILENAME = "file1.wav"
audio = pyaudio.PyAudio()
# start Recording
stream = audio.open(format=FORMAT, channels=CHANNELS,
rate=RATE, input=True,
frames_per_buffer=CHUNK)
print ("recording...")
frames = []
for i in range(0, int(RATE / CHUNK * RECORD_SECONDS)):
data = stream.read(CHUNK)
frames.append(data)
print ("finished recording")
# stop Recording
stream.stop_stream()
stream.close()
audio.terminate()
waveFile = wave.open(WAVE_OUTPUT_FILENAME, 'wb')
waveFile.setnchannels(CHANNELS)
waveFile.setsampwidth(audio.get_sample_size(FORMAT))
waveFile.setframerate(RATE)
waveFile.writeframes(b''.join(frames))
waveFile.close()
x = scipy.io.wavfile.read('file1.wav')
n = x[1]
y = np.zeros(n.shape)
y = n.cumsum(axis=0)
times = np.linspace(0, len(n), len(n))
plt.title("Plot 261 $speech1.wav\n $Secades, M.F.\spadesuit SIGNLAB \spadesuit 6Feb2018$")
plt.xlabel("n")
plt.ylabel("$speech1.wav$")
plt.plot(times,n)
plt.show()