如何解决使用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)
参数:
- 第一个参数是文件名
- 第二个参数是您要保存的音频
- 第三个参数是采样率
希望对您有帮助!
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。