作者:张明云
链接:https://www.jianshu.com/p/1d1f893e53e9
來源:简书

什么是WAV和PCM?

WAV:wav是一种无损的音频文件格式,WAV符合 PIFF(Resource Interchange File Format)规范。所有的WAV都有一个文件头,这个文件头音频流的编码参数。WAV对音频流的编码没有硬性规定,除了PCM之外,还有几乎所有支持ACM规范的编码都可以为WAV的音频流进行编码。
PCM:PCM(Pulse Code Modulation----脉码调制录音)。所谓PCM录音就是将声音等模拟信号变成符号化的脉冲列,再予以记录。PCM信号是由[1]、[0]等符号构成的数字信号,而未经过任何编码和压缩处理。与模拟信号比,它不易受传送系统的杂波及失真的影响。动态范围宽,可得到音质相当好的影响效果。
简单来说:wav是一种无损的音频文件格式,pcm是没有压缩的编码方式。

WAV和PCM的关系

WAV可以使用多种音频编码来压缩其音频流,不过我们常见的都是音频流被PCM编码处理的WAV,但这不表示WAV只能使用PCM编码,MP3编码同样也可以运用在WAV中,和AVI一样,只要安装好了相应的Decode,就可以欣赏这些WAV了。在Windows平台下,基于PCM编码的WAV是被支持得最好的音频格式,所有音频软件都能完美支持,由于本身可以达到较高的音质的要求,因此,WAV也是音乐编辑创作的首选格式,适合保存音乐素材。因此,基于PCM编码的WAV被作为了一种中介的格式,常常使用在其他编码的相互转换之中,例如MP3转换成WMA。
简单来说:pcm是无损wav文件中音频数据的一种编码方式,但wav还可以用其它方式编码。

将录音写成wav格式的文件

有时候需要将录音文件保存为wav格式,这需要手动填充wav的文件头信息,整段代码非常简单,大致如下:

private RandomAccessFile fopen(String path) throws IOException {File f = new File(path);if (f.exists()) {f.delete();} else {File parentDir = f.getParentFile();if (!parentDir.exists()) {parentDir.mkdirs();}}RandomAccessFile file = new RandomAccessFile(f, "rw");// 16K、16bit、单声道/* RIFF header */file.writeBytes("RIFF"); // riff idfile.writeInt(0); // riff chunk size *PLACEHOLDER*file.writeBytes("WAVE"); // wave type/* fmt chunk */file.writeBytes("fmt "); // fmt idfile.writeInt(Integer.reverseBytes(16)); // fmt chunk sizefile.writeShort(Short.reverseBytes((short) 1)); // format: 1(PCM)file.writeShort(Short.reverseBytes((short) 1)); // channels: 1file.writeInt(Integer.reverseBytes(16000)); // samples per secondfile.writeInt(Integer.reverseBytes((int) (1 * 16000 * 16 / 8))); // BPSecondfile.writeShort(Short.reverseBytes((short) (1 * 16 / 8))); // BPSamplefile.writeShort(Short.reverseBytes((short) (1 * 16))); // bPSample/* data chunk */file.writeBytes("data"); // data idfile.writeInt(0); // data chunk size *PLACEHOLDER*Log.d(TAG, "wav path: " + path);return file;
}private void fwrite(RandomAccessFile file, byte[] data, int offset, int size) throws IOException {file.write(data, offset, size);Log.d(TAG, "fwrite: " + size);
}private void fclose(RandomAccessFile file) throws IOException {try {file.seek(4); // riff chunk sizefile.writeInt(Integer.reverseBytes((int) (file.length() - 8)));file.seek(40); // data chunk sizefile.writeInt(Integer.reverseBytes((int) (file.length() - 44)));Log.d(TAG, "wav size: " + file.length());} finally {file.close();}
}

转载补充

在此文章之外还搜索了相关资料,这里予以补充。

wav就是pcm+文件头,pcm就是采集的麦克风的adc值

PCM基本工作原理

脉冲调制就是把一个时间连续,取值连续的模拟信号变换成时间离散,取值离散的数字信号后在信道中传输。脉冲编码调制就是对模拟信号先抽样,再对样值幅度量化,编码的过程。
所谓抽样,就是对模拟信号进行周期性扫描,把时间上连续的信号变成时间上离散的信号。该模拟信号经过抽样后还应当包含原信号中所有信息,也就是说能无失真的恢复原模拟信号。它的抽样速率的下限是由抽样定理确定的。在该实验中,抽样速率采用8Kbit/s。
所谓量化,就是把经过抽样得到的瞬时值将其幅度离散,即用一组规定的电平,把瞬时抽样值用最接近的电平值来表示。
一个模拟信号经过抽样量化后,得到已量化的脉冲幅度调制信号,它仅为有限个数值。
所谓编码,就是用一组二进制码组来表示每一个有固定电平的量化值。然而,实际上量化是在编码过程中同时完成的,故编码过程也称为模/数变换,可记作A/D。
PCM话音信号先经防混叠低通滤波器,进行脉冲抽样,变成8KHz重复频率的抽样信号(即离散的脉冲调幅PAM信号),然后将幅度连续的PAM信号用"四舍五入"办法量化为有限个幅度取值的信号,再经编码后转换成二进制码。对于电话,CCITT规定抽样率为8KHz,每抽样值编8位码,即共有28=256个量化值,因而每话路PCM编码后的标准数码率是64kb/s。为解决均匀量化时小信号量化误差大,音质差的问题,在实际中采用不均匀选取量化间隔的非线性量化方法,即量化特性在小信号时分层密,量化间隔小,而在大信号时分层疏,量化间隔大。

【数字音频】WAV和PCM的关系和区别相关推荐

  1. WAV和PCM的关系和区别

    音频基础知识 声道数(通道数) 即声音的通道的数目.很好理解,有单声道和立体声之分,单声道的声音只能使用一个喇叭发声(有的也处理成两个喇叭输出同一个声道的声音),立体声的PCM可以使两个喇叭都发声(一 ...

  2. 数字音频接口(I2S,PCM/TDM)

    概述 数字音频接口DAI,即Digital Audio Interfaces,顾名思义,DAI表示在板级或板间传输数字音频信号的方式.相比于模拟接口,数字音频接口抗干扰能力更强,硬件设计简单,DAI在 ...

  3. 数字音频接口(I2S,PCM/TDM,PDM)

    概述 数字音频接口DAI,即Digital Audio Interfaces,顾名思义,DAI表示在板级或板间传输数字音频信号的方式.相比于模拟接口,数字音频接口抗干扰能力更强,硬件设计简单,DAI在 ...

  4. micropython i2s_数字音频接口(I2S,PCM/TDM,PDM)

    概述 数字音频接口DAI,即Digital Audio Interfaces,顾名思义,DAI表示在板级或板间传输数字音频信号的方式.相比于模拟接口,数字音频接口抗干扰能力更强,硬件设计简单,DAI在 ...

  5. 智慧城市与数字城市、智能城市的关系和区别

    智慧城市与数字城市.智能城市的概念经常被混淆,其实三者之间是有区别的,智慧城市与数字城市.智能城市的区别也反映了人们对信息技术在城市发展中扮演角色和发挥作用认识的逐步深入. 智慧城市的定义 智慧城市是 ...

  6. 音频数据格式:PCM,WAV,MIDI

    1. 前言 限于作者能力水平,本文可能存在谬误,因此而给读者带来的损失,作者不做任何承诺. 2. 音频数据格式基础 2.1 PCM(Pulse Code Modulation):脉冲编码调制 把声源数 ...

  7. voip 音频采集时间_数字音频基础------从PCM说起

    "不得不说,现在网上的文章,包括百科词条,在数字音频基础概念上有太多混乱的表达,甚至存在错误.比如比特率.位率.位速和码率这四个词其实是同一个意思.再比如千比特kb表示1000bit,而不是 ...

  8. [Android] [音视频系列]在 Android 平台使用 AudioRecord 和 AudioTrack API 完成音频 PCM 数据的采集和播放,并实现读写音频 wav 文件

    参考 官方文档地址:https://developer.android.google.cn/reference/android/media/AudioRecord GitHub 地址:https:// ...

  9. 【精华贴】数字音频接口详解-I2S接口PCM/TDM接口PDM接口

    一.概述 数字音频接口DAI,即Digital Audio Interfaces,顾名思义,DAI表示在板级或板间传输数字音频信号的方式.相比于模拟接口,数字音频接口抗干扰能力更强,硬件设计简单,DA ...

最新文章

  1. 杠杆原理的形象演示,你都懂了吗?
  2. 新建远程仓库并推送项目
  3. 2021 re:Invent ,我们到底该关注哪些发布?
  4. __proto__VS。 JavaScript原型
  5. 泰戈尔专集:飞鸟集·新月集·园丁集(美冠纯美阅读书系·外国卷) 读后感
  6. python简化逻辑式
  7. python 100days github_GitHub - 382982408/Python-100-Days: Python - 100天从新手到大师
  8. 天宝营养冲刺深交所IPO:业绩明显波动,深创投是股东
  9. Qt动态翻译不生效!
  10. Redis 基础 - 优惠券秒杀《初步优化(异步秒杀)》
  11. c语言编程中精度eps是什么,c语言eps是什么意思
  12. 开吃吧无线订餐机 改变餐饮O2O外卖行业
  13. 哈工大深圳计算机学院复试分数线,哈尔滨工业大学深圳研究生院复试线:2011哈尔滨工业大学深圳研究生院复试分数线...
  14. 产品研发杂谈(GJB5000A)
  15. html判断按键状态,javascript判断鼠标按键和键盘按键的方法
  16. 行为驱动开发(BDD)你准备好了吗?
  17. App Crash收集和分析
  18. 1688关键字搜索部分示例
  19. fir低通滤波器 阻带衰减在5khz处为-60db matlab,数字信号处理习题集zz
  20. C/C++族谱管理系统[铁木真家族]

热门文章

  1. 《统计学习方法》啃书辅助:附录B 牛顿法和拟牛顿法
  2. 《黑客帝国》人名的解析!
  3. 写给想成为游戏原画师的新人们
  4. maven环境变量配置详细步骤(win10)
  5. 12否: 互励互教式的儿童视频网站
  6. Windows-Terminal美化以及通过OhMyPosh美化PowerShell
  7. F1~F12与Fn快捷键之间的转换
  8. “误入”清华夸夸群?一行Python代码帮你写个机器人
  9. 怎么修改Linux网络名为ens33,Centos7更改ens33网卡名称为eth0
  10. 足球大数据:引人发思的问题