音频相关知识

音频

指人耳可以听到的声音频率在20HZ~20kHz之间的声波,称为音频。

说出的声音

我们习惯了声音,但是并不知道声音是什么,声音其实就是声波吧,本质是一种波。声音是一种具有固定频段的波。
人的说话频率基本上为300Hz-3400Hz,但是人耳朵听觉频率基本上为20Hz-20000Hz。

传感器

人说出的这种具有固定频段的波,经过特定传感器的采集,可以将现实世界中的波转换成模拟电信号,然后经过采样、量化、编码的处理可以将模拟电信号转换成数字电信号。
传感器可以感受波的波动,将这种波动转变成电信号的波动,看到我们眼中的就是波形了。
然后我们就可以用电子设备来录制和播放声音了,其实就是下面的过程:
现实声波—(传感器)---->电信号—(电子设备)---->录制和播放现实声波

1、采样率

实际中,人发出的声音信号为模拟信号,想要在实际中处理必须为数字信号,即采用采样、量化、编码的处理方案。处理的第一步为采样,即模数转换。简单地说就是通过波形采样的方法记录1秒钟长度的声音,需要多少个数据。根据奈魁斯特(NYQUIST)采样定理,用两倍于一个正弦波的频繁率进行采样就能完全真实地还原该波形。所以,对于声音信号而言,要想对离散信号进行还原,必须将抽样频率定为40KHz以上。实际中,一般定为44.1KHz。44.1KHz采样率的声音就是要花费44100个数据来描述1秒钟的声音波形。原则上采样率越高,声音的质量越好,采样频率一般共分为22.05KHz、44.1KHz、48KHz三个等级。22.05 KHz只能达到FM广播的声音品质,44.1KHz则是理论上的CD音质界限,48KHz则已达到DVD音质了。

2、码率

对于音频信号而言,必须进行编码。在这里,编码指信源编码,即数据压缩。如果,未经过数据压缩,直接量化进行传输则被称为PCM(脉冲编码调制)。要算一个PCM音频流的码率是一件很轻松的事情,采样率值×采样大小值×声道数 bps

一个采样率为44.1KHz,采样大小为16bit,双声道的PCM编码的WAV文件,它的数据速率则为 44.1K×16×2 =1411.2 Kbps。我们常说128K的MP3,对应的WAV的参数,就是这个1411.2 Kbps,这个参数也被称为数据带宽,它和ADSL中的带宽是一个概念。将码率除以8,就可以得到这个WAV的数据速率,即176.4KB/s。这表示存储一秒钟采样率为44.1KHz,采样大小为16bit,双声道的PCM编码的音频信号,需要176.4KB的空间,1分钟则约为10.34M,这对大部分用户是不可接受的,尤其是喜欢在电脑上听音乐的朋友,要降低磁盘占用,只有2种方法,降低采样指标或者压缩。降低采样指标是不可取的,因此专家们研发了各种压缩方案。最原始的有DPCM、ADPCM,其中最出名的为MP3。所以,采用了数据压缩以后的码率远小于原始码。

码率就是音频文件或者音频流中1秒中的数据量,如1.44Mbps,就是1秒钟内的数据量达1.44Mbits。

小结

对于人类的语音信号而言,实际处理一般经过以下步骤:

人嘴说话——>声电转换——>采样(模数转换)——>量化(将数字信号用适当的数值表示)——>编码(数据压缩)——> 传输(网络或者其他方式)——>解码(数据还原)——>反采样(数模转换)——>电声转换——>人耳听声。

采样频率,时间,声道,量化与储存大小的关系

采样频率44.1kHz,量化位数16位,意味着每秒采集数据44.1k个,zd每个数据占2字节,这是一个声道的数据,双声道再版乘以2,最后结果再乘以60秒,就是44.1×1000×2×2×60=10584000字节,1MB=1024×1024=1048576字节,所以一分钟权的存储容量为10584000/1048576=10.09MB,约为10.1MB。

采样率单位是 Hz,所以 K = 1000
在 b 和 B 等数据量单位中,K = 1024

量化位数就是采样的一个样本被量化成了多少 bit
算法其实就是: 一秒采多少个样本 * 一个样本多少 bit * 秒数 * 声道数 ,就得到时长为秒数的音频需要多少 bit 的存储量了

数据量=采样频率×量化位数×声道数×时间(秒)/8(时长为时间秒的音频大小为数据量大小)
44.1 x 1000 x 16 x 2 x 60 / 8 = 10584000B = 10.1MB(因为乘以了60秒,所以算出的是一分钟的数据大小,这段时长1分钟的音频大小为10.1M)

采样频率×量化位数×声道数×时间(秒) 得出的结果单位是 b

**采样频率×量化位数×声道数×时间(秒)/ 8 ** 得出的结果单位是 B

**采样频率×量化位数×声道数×时间(秒)/ 8 / 1024 ** 得出的结果单位是 KB

采样频率×量化位数×声道数×时间(秒)/8 / 1024 / 1024 得出的结果单位是 MB

1MB=1024×1024=1048576B
10584000 / 1048576 = 10.09 = 10.1

参考:

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值