向音频文件添加噪声并使用 Librosa 重新转换噪声信号 Python
Add noise to Audio File and Reconvert the Noisy signal using Librosa Python
我正在使用 librosa 向信号添加噪声,但添加噪声后我无法将信号保存回 wav 文件。
我的代码如下:
import librosa
import matplotlib.pyplot as plt
import numpy as np
import math
file_path = r'path\to\file'
#
#
signal, sr = librosa.load(file_path, sr = 16000)
# plt.plot(signal)
#
RMS=math.sqrt(np.mean(signal**2))
STD_n= 0.001
noise=np.random.normal(0, STD_n, signal.shape[0])
#
# # X=np.fft.rfft(noise)
# # radius,angle=to_polar(X)
#
signal_noise = signal+noise
我想将 signal_noise 转换为 wav 文件。我尝试了不同的 librosa 功能,但找不到一个。我尝试使用 scipy.io.wavfile.write 但我收到了一个错误,可能是因为 Librosa 生成了规范化音频而 Scipy 没有。
你可以使用 soundfile
库来完成。将这些行添加到您的代码中:
import soundfile
soundfile.write('filename.wav',signal_noise,16000)
参数:
- 第一个参数为文件名
- 第二个参数是你要保存的音频
- 第三个参数是采样率
希望对您有所帮助!
我正在使用 librosa 向信号添加噪声,但添加噪声后我无法将信号保存回 wav 文件。
我的代码如下:
import librosa
import matplotlib.pyplot as plt
import numpy as np
import math
file_path = r'path\to\file'
#
#
signal, sr = librosa.load(file_path, sr = 16000)
# plt.plot(signal)
#
RMS=math.sqrt(np.mean(signal**2))
STD_n= 0.001
noise=np.random.normal(0, STD_n, signal.shape[0])
#
# # X=np.fft.rfft(noise)
# # radius,angle=to_polar(X)
#
signal_noise = signal+noise
我想将 signal_noise 转换为 wav 文件。我尝试了不同的 librosa 功能,但找不到一个。我尝试使用 scipy.io.wavfile.write 但我收到了一个错误,可能是因为 Librosa 生成了规范化音频而 Scipy 没有。
你可以使用 soundfile
库来完成。将这些行添加到您的代码中:
import soundfile
soundfile.write('filename.wav',signal_noise,16000)
参数:
- 第一个参数为文件名
- 第二个参数是你要保存的音频
- 第三个参数是采样率
希望对您有所帮助!