安防视频监控系统视频上云解决方案EasyCVR音频基础知识一文全介绍

标签: EasyCVR  TSINGSEE青犀视频  视频上云网关  

EasyCVR是TSINGSEE青犀视频研发的视频上云网关,设备端有公网IP,可通过海康SDK、Onvif/RTSP、GB28181、ehome协议接入到EasyCVR中;设备端无公网IP,可通过GB28181、ehome协议接入到EasyCVR中,也可在内网安装EasyNTS设备,与公网建立传输通道,这样即可通过海康SDK、Onvif/RTSP接到EasyCVR中。

EasyCVR.png

本文和大家讲一下EasyCVR中关于音频的一些知识,都是研发在编译当中用到的,大家可以简单了解一下。

1、ffplay 播放pcm,g771

> ffplay -i test.pcm -f s16le -ac 1 -ar 8000 
> ffplay -i test.g711a -f alaw -ac 1 -ar 8000 
> ffplay -i test.g711u -f mulaw -ac 1 -ar 8000 

注意:ac 通道 ar 采样率设置对

-i 指定要播放的文件
-f 编码格式
-ac 通道数
-ar 采样率

2、音频数据大小的计算

采样率16KHZ,位宽16bit,双声道,1分钟采集数据的大小
160002260/1024/1024
采样率16KHZ,位宽32bit,双声道,1分钟采集数据的大小
16000
4260/1024/1024
采样率16KHZ,位宽16bit,单声道,1分钟采集数据的大小
160002160/1024/1024
采样率16KHZ,位宽8bit,单声道,1分钟采集数据的大小
16000
1160/1024/1024

3、采样率

例如:16000Hz 表示1s中在连续信号中采集16000次,每一次叫做一个采样点

4、采样深度

例如:16bit 表示每一个采样点采集2个byte的数据,也就是2个字节

5、pcm格式音频存储格式

200.png

6、pcm和g711格式互转

#define BIAS        (0x84)      /* Bias for linear code. */  
  
/* 
 * linear2ulaw() - Convert a linear PCM value to u-law 
 * 
 * In order to simplify the encoding process, the original linear magnitude 
 * is biased by adding 33 which shifts the encoding range from (0 - 8158) to 
 * (33 - 8191). The result can be seen in the following encoding table: 
 * 
 *  Biased Linear Input Code    Compressed Code 
 *  ------------------------    --------------- 
 *  00000001wxyza           000wxyz 
 *  0000001wxyzab           001wxyz 
 *  000001wxyzabc           010wxyz 
 *  00001wxyzabcd           011wxyz 
 *  0001wxyzabcde           100wxyz 
 *  001wxyzabcdef           101wxyz 
 *  01wxyzabcdefg           110wxyz 
 *  1wxyzabcdefgh           111wxyz 
 * 
 * Each biased linear code has a leading 1 which identifies the segment 
 * number. The value of the segment number is equal to 7 minus the number 
 * of leading 0's. The quantization interval is directly available as the 
 * four bits wxyz.  * The trailing bits (a - h) are ignored. 
 * 
 * Ordinarily the complement of the resulting code word is used for 
 * transmission, and so the code word is complemented before it is returned. 
 * 
 * For further information see John C. Bellamy's Digital Telephony, 1982, 
 * John Wiley & Sons, pps 98-111 and 472-476. 
 */  
unsigned char  
linear2ulaw(  
    int     pcm_val)    /* 2's complement (16-bit range) */  
{  
    int     mask;  
    int     seg;  
    unsigned char   uval;  
  
    /* Get the sign and the magnitude of the value. */  
    if (pcm_val < 0) {  
        pcm_val = BIAS - pcm_val;  
        mask = 0x7F;  
    } else {  
        pcm_val += BIAS;  
        mask = 0xFF;  
    }  
  
    /* Convert the scaled magnitude to segment number. */  
    seg = search(pcm_val, seg_end, 8);  
  
    /* 
     * Combine the sign, segment, quantization bits; 
     * and complement the code word. 
     */  
    if (seg >= 8)        /* out of range, return maximum value. */  
        return (0x7F ^ mask);  
    else {  
        uval = (seg << 4) | ((pcm_val >> (seg + 3)) & 0xF);  
        return (uval ^ mask);  
    }  
  
}  
  
/* 
 * ulaw2linear() - Convert a u-law value to 16-bit linear PCM 
 * 
 * First, a biased linear code is derived from the code word. An unbiased 
 * output can then be obtained by subtracting 33 from the biased code. 
 * 
 * Note that this function expects to be passed the complement of the 
 * original code word. This is in keeping with ISDN conventions. 
 */  
int  
ulaw2linear(  
    unsigned char   u_val)  
{  
    int     t;  
  
    /* Complement to obtain normal u-law value. */  
    u_val = ~u_val;  
  
    /* 
     * Extract and bias the quantization bits. Then 
     * shift up by the segment number and subtract out the bias. 
     */  
    t = ((u_val & QUANT_MASK) << 3) + BIAS;  
    t <<= ((unsigned)u_val & SEG_MASK) >> SEG_SHIFT;  
  
    return ((u_val & SIGN_BIT) ? (BIAS - t) : (t - BIAS));  
}  
  
/* A-law to u-law conversion */  
unsigned char  
alaw2ulaw(  
    unsigned char   aval)  
{  
    aval &= 0xff;  
    return ((aval & 0x80) ? (0xFF ^ _a2u[aval ^ 0xD5]) :  
        (0x7F ^ _a2u[aval ^ 0x55]));  
}  
  
/* u-law to A-law conversion */  
unsigned char  
ulaw2alaw(  
    unsigned char   uval)  
{  
    uval &= 0xff;  
    return ((uval & 0x80) ? (0xD5 ^ (_u2a[0xFF ^ uval] - 1)) :  
        (0x55 ^ (_u2a[0x7F ^ uval] - 1)));  
}  

EasyCVR播放界面

EasyCVR.png

EasyCVR支持阿里云、腾讯云、华为云、七牛云等,支持S3和Swift接口的对象存储服务,简单配置,部署更高效;且支持传统网络摄像机、NVR、编码器、SDK等设备,最大程度的提高了硬件设备的兼容性。

视频相关解决方案均可访问TSINGSEE青犀视频,可以联系我们获取演示方案,直观感受,也可自行下载及测试。

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

智能推荐

【Spark 内核】 Spark 内核解析-下

Spark内核泛指Spark的核心运行机制,包括Spark核心组件的运行机制、Spark任务调度机制、Spark内存管理机制、Spark核心功能的运行原理等,熟练掌握Spark内核原理,能够帮助我们更好地完成Spark代码设计,并能够帮助我们准确锁定项目运行过程中出现的问题的症结所在。 Spark Shuffle 解析 Shuffle 的核心要点 ShuffleMapStage与ResultSta...

Reflect反射的基础知识

写个父类: 写个子类: 利用反射获得该子类中的属性,方法,构造,父类及接口: 运行结果:...

spring cloud netflix (07) 服务的消费者(feign)

前言 完整知识点:spring cloud netflix 系列技术栈 Feign (同步通信 HTTP通信) feign是基于接口完成服务与服务之间的通信的 搭建Feign服务 项目结构 项目搭建 pom.xml application类 application.yml 使用feign完成服务与服务之间的通信 feign是基于接口完成服务与服务之间的通信的...

AtCoder Beginner Contest 174 E.Logs

AtCoder Beginner Contest 174 E.Logs 题目链接 到最后才发现是二分,菜菜的我/(ㄒoㄒ)/~~ 我们直接二分 [1,max{a[i]}][1,max\lbrace a[i]\rbrace][1,max{a[i]}] 即可,对每一个 midmidmid,每个数 a[i]a[i]a[i] 只需要切 a[i]−1mid\frac{a[i]-1}{mid}mi...

小程序基础与实战案例

小程序开发工具与基础 小程序开发准备: 申请小程序账号( appid ) 下载并安装微信开发者工具 具体步骤如下: 先进入 微信公众平台 ,下拉页面,把鼠标悬浮在小程序图标上 然后点击 小程序开发文档 照着里面给的步骤,就可以申请到小程序账号了。 然后就可以下载 开发者工具 了 下载完打开后的界面就是这个样子 下面让我们来新建一个小程序开发项目: 在AppID输入自己刚刚注册的AppID就可以,或...

猜你喜欢

VMware centOS7 下通过minikube部署Kubernetes

1、环境准备: VMware CentOS-7-x86_64 CPU:2*2core 内存:8G 宿主机和虚拟机需网络互通,虚拟机外网访问正常 Centos发行版版本查看:cat /etc/centos-release root用户操作 2、禁用swap分区 Kubernetes 1.8开始要求关闭系统的Swap,可暂时关闭或永久禁用, 使用 $ free -m 确认swap是否为开启状态 $ s...

逻辑回归与scikit-learn

欢迎关注本人的微信公众号AI_Engine LogisticRegression 算法原理 一句话概括:逻辑回归假设数据服从伯努利分布,通过极大化似然函数(损失函数)的方法,运用梯度下降或其他优化算法来求解参数,来达到将数据二分类的目的。 定义:逻辑回归(Logistic Regression)是一种用于解决二分类(0 or 1)问题的机器学习方法,用于估计某种事物的可能性(不是概率)。比如某用户...

指针OR数组?用他们来表达字符串又有何不同?

cocowy的编程之旅 在学习C语言的过程中我们经常可以看到或者听到这样一句话:数组其实等价于指针,例如: 在这里可以轻松的看出输出后他们的值相等,其实在计算机内存里面,p为本地变量,有着他自己的作用域。而指针变量q保存着这个数组的首地址,通过*号指向这个地址保存的变量值。 然而我们再看一个例子: 这个时候计算机报错,这是为什么呢? 其实原因很简单,指针说指向的这个字符串的地址是位于计算机代码段地...

广度搜索

广度搜索的基本使用方法 广度搜索不同于深度搜索,是一种一步一步进行的过程,每一个点只记录一遍。需要用到队列记录每一步可以走到的位置,找到目标位置输出步数即可。 用到的知识:结构体、队列 如图 首先我们需要定义一个结构体来存储每个遍历到的点和步数 广搜不会用到递归,所以可以直接在主函数里写,这里需要定义一个结构体队列 初始化队列并将起始点入列 遍历 完整代码...

NIO Socket 编程实现tcp通信入门(二)

1、NIO简介 NIO面向通道和缓冲区进行工作,数据总是从通道读取到缓冲区中,或者从缓冲区写入到通道中。可以双向传输数据,是同步非阻塞式IO。NIO还引入了选择器机制,从而实现了一个选择器监听多个底层通道,减少了线程并发数。用NIO实现socket的Tcp通信需要掌握下面三个知识点: Buffer 缓冲区 Channel 通道 Selector 选择器   2、java.nio.Buff...