Python:实时或从WAV文件获取音量分贝级别
问题描述
对于项目工作,我需要通过录制的音频文件或使用麦克风实时录制来测量音量。经过初步研究,我尝试使用声音文件库。使用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(您听到的)。
相关文章