我正在尝试获取传入音频样本的 dB 级别。在每个视频帧上,我更新 dB 级别并绘制一个代表 0 - 100% 值的条形(0% 是任意值,例如 -20.0dB,100% 是 0dB。)
gdouble sum, rms;
sum = 0.0;
guint16 *data_16 = (guint16 *)amap.data;
for (gint i = 0; i < amap.size; i = i + 2)
{
gdouble sample = ((guint16)data_16[i]) / 32768.0;
sum += (sample * sample);
}
rms = sqrt(sum / (amap.size / 2));
dB = 10 * log10(rms);
这已从标记为答案的代码示例中改编为 C,来自此处。我想知道这个非常简单的方程式中缺少什么。
回答:夹克关于丢失标志的代码是正确的,所以一切最终都是积极的。代码10 * log(rms)
也不正确。应该是20 * log(rms)
因为我将幅度转换为分贝(作为输出功率的度量)。