Python:实时或从WAV文件获取音量分贝级别

2022-03-28 00:00:00 python numpy signal-processing wav pyaudio

问题描述

对于项目工作,我需要通过录制的音频文件或使用麦克风实时录制来测量音量。经过初步研究,我尝试使用声音文件库。使用soundfile读取该文件,并使用20*np.log10(np.sqrt(np.mean(np.absolute(a)**2)))计算了dB值。我得到了声音文件的负值。但是正常的声音可能在50-70分贝的范围内,我得到的是负值。有人能帮我解决这个问题吗?


解决方案

简答:db不等于db。您的结果可能是正确的。

详细答案:数据库级别总是定义与某些参考值的关系。For audio / acoustics, there are many reference values,您需要指定要使用哪个值才能使以分贝为单位的值有意义。当你说

正常声音可能在50-70 dB范围内

这句话不太准确,你的意思可能是

正常声音可能在50-70 dB SPL范围内

您给出的值相对于reference sound pressure level of 20 µPa。

在数字系统中,声音文件通常用浮点数< 1表示,然后我们用参考值1来表示dB FS (dB full scale)。根据数学定律,dB FS值为负值。

同样清楚的是,您不能将dB FS值与dB SPL值直接关联:如果您播放同一音频文件(即取一些dB FS值)并播放两次,但打开扬声器的音量旋钮,则会导致两个不同的值dB SPL(您听到的)。

相关文章