我正在使用librosa向信号添加噪声,但添加噪声后,我无法将信号保存回wav文件。
我的代码如下:
import librosa
import matplotlib.pyplot as plt
import numpy as np
import math
file_path = r'pathtofile'
#
#
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.waffile.write,但我遇到了一个错误,可能是因为Librosa生成了Normalized音频,而scipy没有。
您可以使用soundfile
库执行此操作。将这些行添加到您的代码:
import soundfile
soundfile.write('filename.wav',signal_noise,16000)
参数:
- 第一个参数是文件名
- 第二个参数是要保存的音频
- 第三个参数是采样率
希望这对你有所帮助!