将噪声添加到音频文件,并使用Librosa Python重新转换噪声信号



我正在使用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)

参数:

  • 第一个参数是文件名
  • 第二个参数是要保存的音频
  • 第三个参数是采样率

希望这对你有所帮助!

最新更新