使用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却没有。

解决方法

U可以使用soundfile库来实现。将这些行添加到您的代码中:

import soundfile
soundfile.write('filename.wav',signal_noise,16000)

参数:

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

希望对您有帮助!