一、Audio-音频简介_audio的位宽-程序员宅基地

技术标签: Linux  音视频  audio  

一、音频简介

音频是我们最常用到的功能,音频也是 linux 和安卓的重点应用场合。

处理器要想“听到”外界的声音必须要把外界的声音转化为自己能够理解的“语言”,处理 器能理解的就是 0 和 1,也就是二进制数据。所以我们需要先把外界的声音转换为处理器能理 解的 0 和 1,在信号处理领域,外界的声音是模拟信号,处理器能理解的是数字信号,因此这 里就涉及到一个模拟信号转换为数字信号的过程,而完成这个功能的就是 ADC 芯片。

同理,如果处理器要向外界传达自己的“心声”,也就是放音,那么就涉及到将处理器能理 解的 0 和 1 转化为外界能理解的连续变化的声音,这个过程就是将数字信号转化为模拟信号, 而完成这个功能的是 DAC 芯片。
在这里插入图片描述

二、音频的属性

● 响度(Loudness):响度就是人类可以感知到的各种声音的大小,也就是音量。响度与声波的振幅有直接关系。
● 音调(Pitch):音调与声音的频率有关系,当声音的频率越大时,人耳所感知到的音调就越高,否则就越低。
● 音色(Quality):同一种乐器,使用不同的材质来制作,所表现出来的音色效果是不一样的,这是由物体本身的结构特性所决定的。

其他名字解释:
● 样本:采样的初始资料,比如一段连续的声音波形。

● 采样器(Sampler):采样器是将样本转换成终态信号的关键。它可以是一个子系统,也可以指一个操作过程,甚至是一个算法,取决于不同的信号处理场景。理想的采样器要求尽可能不产生信号失真。
● 量化(Quantization):采样后的值还需要通过量化,也就是将连续值近似为某个范围内有限多个离散值的处理过程。因为原始数据是模拟的连续信号,而数字信号则是离散的,它的表达范围是有限的,所以量化是必不可少的一个步骤。
● 编码(Coding):计算机的世界里,所有数值都是用二进制表示的,因而我们还需要把量化值进行二进制编码。这一步通常与量化同时进行。
● 采样率(samplerate):采样就是把模拟信号数字化的过程,不仅仅是音频需要采样,所有的模拟信号都需要通过采样转换为可以用0101来表示的数字信号.采样频率越高,红色的间隔就越密集,记录这一段音频信号所用的数据量就越大,同时音频质量也就越高。根据奈奎斯特理论,采样频率只要不低于音频信号最高频率的两倍,就可以无损失地还原原始的声音。通常人耳能听到频率范围大约在20Hz~20kHz之间的声音,为了保证声音不失真,采样频率应在40kHz以上。常用的音频采样频率有:8kHz、11.025kHz、22.05kHz、16kHz、37.8kHz、44.1kHz、48kHz、96kHz、192kHz等。
● 声道数(channels):由于音频的采集和播放是可以叠加的,因此,可以同时从多个音频源采集声音,并分别输出到不同的扬声器,故声道数一般表示声音录制时的音源数量或回放时相应的扬声器数量。单声道(Mono)和双声道(Stereo)比较常见,顾名思义,前者的声道数为1,后者为2
● 音频帧(frame):这个概念在应用开发中非常重要,网上很多文章都没有专门介绍这个概念。音频跟视频很不一样,视频每一帧就是一张图像,而从上面的正玄波可以看出,音频数据是流式的,本身没有明确的一帧帧的概念,在实际的应用中,为了音频算法处理/传输的方便,一般约定俗成取2.5ms~60ms为单位的数据量为一帧音频。这个时间被称之为“采样时间”,其长度没有特别的标准,它是根据编解码器和具体应用的需求来决定的,我们可以计算一下一帧音频帧的大小:假设某音频信号是采样率为8kHz、双通道、位宽为16bit,20ms一帧,则一帧音频数据的大小为:int size = 8000 x 2 x 16bit x 0.02s = 5120 bit = 640 byte

● 常见的音频编码方式有哪些?
上面提到过,模拟的音频信号转换为数字信号需要经过采样和量化,量化的过程被称之为编码,根据不同的量化策略,产生了许多不同的编码方式。
常见的编码方式有:
PCM 和 ADPCM,这些数据代表着无损的原始数字音频信号,添加一些文件头信息,就可以存储为WAV文件了,它是一种由微软和IBM联合开发的用于音频数字存储的标准,可以很容易地被解析和播放。
PCM是不压缩的,ADPCM是压缩的。
PCM是压缩音频的基础,ADPCM和MP3,WMA等一样,都是由某种压缩算法对PCM数据进行压缩后得到的。
ADPCM通过pcm的差值减少了位数,从而达到压缩效果,所以称为差分

● 常见的音频压缩格式有哪些?
首先简单介绍一下音频数据压缩的最基本的原理:因为有冗余信息,所以可以压缩。
(1) 频谱掩蔽效应:
人耳所能察觉的声音信号的频率范围为20Hz~20KHz,在这个频率范围以外的音频信号属于冗余信号。
(2) 时域掩蔽效应:
当强音信号和弱音信号同时出现时,弱信号会听不到,因此,弱音信号也属于冗余信号。
下面简单列出常见的音频压缩格式:
MP3,AAC,OGG,WMA,Opus,FLAC,APE,M4A,AMR,等等

版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_45309916/article/details/124934423

智能推荐

【Android SDK30版本】代码明显是正确的为何升级了sdk版本号就报错或是警告呢(已解决)_iscasting false because ihwdistributedwindowmanage-程序员宅基地

文章浏览阅读4.1k次,点赞2次,收藏4次。Android每次升级sdk都会有惊喜,功能报错,各种警告,无法使用等问题!_iscasting false because ihwdistributedwindowmanager is invalid.

读取风云4号卫星FullMask_Grid.raw文件_python读取fy-4a,4b数据行列号和经纬度查找表raw文件-程序员宅基地

文章浏览阅读3.2k次,点赞2次,收藏23次。读取风云4号卫星FullMask_Grid.raw文件1、下载FullMask_Grid.raw文件下载网址:国家卫星气象中心(http://satellite.nsmc.org.cn/PortalSite/StaticContent/DocumentDownload.aspx?TypeID=3)2、读取FullMask_Grid.raw文件import numpy as npimport h5pydef fy4disk(rawfile,dim): """ FY-4A数据行列_python读取fy-4a,4b数据行列号和经纬度查找表raw文件

基于阿里云物联网平台开发终端设备的通用方法(python语言实现)_阿里云上的设备状态未激活如何处理在python中配置-程序员宅基地

文章浏览阅读2.8k次。万物互联,物联网是未来的发展趋势。如何将设备接入物联网平台,实现设备之间的通信呢?本文以阿里云物联网平台为例,使用python开发语言,介绍设备终端接入平台的通用方法。阅读本文需要了解MQTT协议、python等相关知识。_阿里云上的设备状态未激活如何处理在python中配置

CelebA-HQ-img:数据集的目录_/celeba-hq/train/images/-程序员宅基地

文章浏览阅读578次。CelebA-HQ-img:数据集的目录_/celeba-hq/train/images/

一文搞懂CSS 3D动画效果_css3d-程序员宅基地

文章浏览阅读6.6k次,点赞20次,收藏93次。本文主要介绍了CSS 动画效果,不用js也可以实现。主要包括旋转、定位、透视。还有几个项目案例,欢迎大家阅读学习,如有不足请批评指正。_css3d

java web的三大框架是什么_Java web常用的三大框架是什么-蛙课网-程序员宅基地

文章浏览阅读1.8k次。我们经常听别人说起java web的三大框架,但是对于初学者来说,java web的三大框架就是一个名词,毫无概念,所以我们今天就来说一下java web请添加链接描述三大框架是什么。java web常用的三大框架指:SSH,即:Spring、Struts、Hibernate,是用来开发web应用程序中使用的。Spring是一个开源框架,它是为了解决企业应用开发的复杂性而创建的。框架的主要优势之一..._java web开发中常用的技术框架有哪些?请列举其中至少三个。

随便推点

一文详解基于测距的空间定位算法_平面定位精度计算方法-程序员宅基地

文章浏览阅读1.3w次,点赞15次,收藏133次。一文详解基于测距的空间定位算法文章目录一文详解基于测距的空间定位算法0 定位算法分类0.1 基于测距与非基于测距的定位算法0.2 集中式与分布式定位算法0.3 绝对与相对定位算法0.4 本文内容概述1 包围盒定位法1.1 算法原理1.2 算法性能2 基于RSSI的定位法2.1 算法原理3 基于TOA的定位法3.1 算法原理3.2 算法性能4 基于TDOA的定位法4.1 算法原理4.2 算法性能5 基于AOA的定位法5.1 算法原理5.2 算法性能6 算法优缺点总结0 定位算法分类0.1 基于测距与非基_平面定位精度计算方法

黑群晖DSM安装教程及详细配置_黑群晖安装系统文件损坏-程序员宅基地

文章浏览阅读10w+次,点赞39次,收藏345次。本文同步发布在个人博客:YouForever - 专注于互联网分享 欢迎访问为什么要安装黑群晖先说说什么是NAS服务器,简单来说就是一个网络存储器,你可以存放音乐、视频、文件等,方便地从各个设备进行访问。而群晖的Synology DSM,就是一个非常优秀的NAS服务器。NAS百度百科NAS(Network Attached Storage:网络附属存储)按字面简单说就是连接在网络上,具备资料存储功能的装置,因此也称为“网络存储器”。它是一种专用数据存储服务器。是啊,群晖官方的不香吗,可以方._黑群晖安装系统文件损坏

2024年必火创业项目:小城市创业者的首选清单-程序员宅基地

文章浏览阅读360次,点赞4次,收藏7次。这些项目不仅具有广阔的市场前景,而且适合小城市的消费特点,对于想要开实体店或创业的朋友们来说,无疑是有价值的参考。当然,创业的道路并非一帆风顺,但只要我们保持坚定的信念和不懈的努力,相信一定能够在小城市的创业舞台上绽放光彩。作为一名经验丰富的创业者,我建议大家在创业前充分调研市场,了解消费者需求,制定详细的创业计划,并不断学习和提升自身能力,以应对市场竞争和变化。烘焙食品以其独特的口感和精美的外观,受到越来越多消费者的喜爱。同时,我们还不断研发新的产品,推陈出新,以满足市场的不断变化和消费者的需求。

windows开启远程Wmi服务支持-程序员宅基地

文章浏览阅读481次。wmi不仅支持本地也同样支持远程,这里介绍一下怎么快速的让当前操作系统开启远程服务。 首先这里以windwos7为例,有的朋友说,开启远程wmi没有,我说这个东西有用,他说没有用,我说小伙子还是太年轻了。这里需要当前用户是管理员权限的,当然默认的登陆用户都是管理员的,但是存在着像我一样的懒人,不给虚拟机的windows设置密码,这样是不行的,需要给当然..._远程wmi调用

Error:(84, 17) java: 方法不会覆盖或实现超类型的方法-程序员宅基地

文章浏览阅读6.7w次,点赞6次,收藏11次。今天遇到了这问题,但也一直纳闷哪出的问题,后来网上查了一下按一下方法也确实能解决问题。------------------------------------------------------------以下为今天网上找的一事例------------------------------------------------------------------------遇到一个奇怪的_java: 方法不会覆盖或实现超类型的方法

图像分割评估指标——surface-distance计算库_average surface distance-程序员宅基地

文章浏览阅读8.5k次,点赞16次,收藏60次。一、简介当我们评价图像分割的质量和模型表现时,经常会用到各类表面距离的计算。这里推荐一个deepmind的表面距离度量计算库surface-distance。该库的下载地址:https://download.csdn.net/download/Joker00007/12718748Github地址:https://github.com/deepmind/surface-distance(注:Github上的代码存在Bug,可直接在第一个链接下载,该文件是已经改完错误的)这个库主要包含了以下几个表面_average surface distance

推荐文章

热门文章

相关标签