/*** PCM与G711(a law)转换器*/
public class G711Converter {private static final short[] aLawDecompressTable = new short[]{-5504, -5248,-6016, -5760, -4480, -4224, -4992, -4736, -7552, -7296, -8064,-7808, -6528, -6272, -7040, -6784, -2752, -2624, -3008, -2880,-2240, -2112, -2496, -2368, -3776, -3648, -4032, -3904, -3264,-3136, -3520, -3392, -22016, -20992, -24064, -23040, -17920,-16896, -19968, -18944, -30208, -29184, -32256, -31232, -26112,-25088, -28160, -27136, -11008, -10496, -12032, -11520, -8960,-8448, -9984, -9472, -15104, -14592, -16128, -15616, -13056,-12544, -14080, -13568, -344, -328, -376, -360, -280, -264, -312,-296, -472, -456, -504, -488, -408, -392, -440, -424, -88, -72,-120, -104, -24, -8, -56, -40, -216, -200, -248, -232, -152, -136,-184, -168, -1376, -1312, -1504, -1440, -1120, -1056, -1248, -1184,-1888, -1824, -2016, -1952, -1632, -1568, -1760, -1696, -688, -656,-752, -720, -560, -528, -624, -592, -944, -912, -1008, -976, -816,-784, -880, -848, 5504, 5248, 6016, 5760, 4480, 4224, 4992, 4736,7552, 7296, 8064, 7808, 6528, 6272, 7040, 6784, 2752, 2624, 3008,2880, 2240, 2112, 2496, 2368, 3776, 3648, 4032, 3904, 3264, 3136,3520, 3392, 22016, 20992, 24064, 23040, 17920, 16896, 19968, 18944,30208, 29184, 32256, 31232, 26112, 25088, 28160, 27136, 11008,10496, 12032, 11520, 8960, 8448, 9984, 9472, 15104, 14592, 16128,15616, 13056, 12544, 14080, 13568, 344, 328, 376, 360, 280, 264,312, 296, 472, 456, 504, 488, 408, 392, 440, 424, 88, 72, 120, 104,24, 8, 56, 40, 216, 200, 248, 232, 152, 136, 184, 168, 1376, 1312,1504, 1440, 1120, 1056, 1248, 1184, 1888, 1824, 2016, 1952, 1632,1568, 1760, 1696, 688, 656, 752, 720, 560, 528, 624, 592, 944, 912,1008, 976, 816, 784, 880, 848};private final static int cClip = 32635;private static final byte[] aLawCompressTable = new byte[]{1, 1, 2, 2, 3, 3, 3,3, 4, 4, 4, 4, 4, 4, 4, 4, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5,5, 5, 5, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6,6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 6, 7, 7, 7, 7, 7, 7, 7, 7, 7,7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7,7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7};/*** PCM转G711** @param src    编码前的数据* @param offset 偏移量* @param len    长度* @param res    编码后存放的数据* @return 编码后res数组长度应为编码前src数组长度的一半*/public static int encode(byte[] src, int offset, int len, byte[] res) {int j = offset;int count = len / 2;short sample = 0;for (int i = 0; i < count; i++) {sample = (short) (((src[j++] & 0xff) | (src[j++]) << 8));res[i] = linearToALawSample(sample);}return count;}private static byte linearToALawSample(short sample) {int sign;int exponent;int mantissa;int s;sign = ((~sample) >> 8) & 0x80;if (!(sign == 0x80)) {sample = (short) -sample;}if (sample > cClip) {sample = cClip;}if (sample >= 256) {exponent = aLawCompressTable[(sample >> 8) & 0x7F];mantissa = (sample >> (exponent + 3)) & 0x0F;s = (exponent << 4) | mantissa;} else {s = sample >> 4;}s ^= (sign ^ 0x55);return (byte) s;}/*** G711A转PCM** @param src    解码前的数据* @param offset 偏移量* @param len    长度* @param res    解码后存放的数据* 解码后res数组长度应为解码前src数组长度的两倍*/public static void decode(byte[] src, int offset, int len, byte[] res) {for (int i = 0, j = 0; i < len; i++) {short s = aLawDecompressTable[src[i + offset] & 0xff];res[j++] = (byte) s;res[j++] = (byte) (s >> 8);}}
}

G711A与PCM互转(Java版)相关推荐

  1. 哔哩哔哩 BV、AV互转 Java版

    从python移植的B站AV号BV号互转算法源码 private static String table = "fZodR9XQDSUm21yCkr6zBqiveYah8bt4xsWpHnJ ...

  2. 我的世界java版存档转基岩版_我的世界基岩版与java版存档互转

    如何将Java地图转换为PE / Bedrock版本! 你有没有看过你一直想在PE / Bedrock Edition上玩的Java版地图?那么实际上有一种方法可以做到这一点!让我们开始 (此方法是唯 ...

  3. 2021年 第12届 蓝桥杯 第3次模拟赛真题详解及小结【Java版】

    蓝桥杯 Java B组 省赛决赛 真题详解及小结汇总[2013年(第4届)~2021年(第12届)] 第11届 蓝桥杯-第1.2次模拟(软件类)真题-(2020年3月.4月)-官方讲解视频 说明:大部 ...

  4. [科幻]Java版三体中黑暗森林法则的猜想

    这两天去电影院看了<星际穿越>,作为大刘的磁铁发现里面有许多元素和<三体>近乎一样,只是小说文字被好莱坞完美视觉化了,很怀疑导演诺兰在拍这部片子之前是否看过了<三体> ...

  5. 哔哩哔哩 BV、AV互转 C#版

    哔哩哔哩 BV.AV互转 C#版 从JAVA移植的(从python移植的B站AV号BV号互转算法源码)//套娃 引用@ty1937 https://blog.csdn.net/ty1937/artic ...

  6. java微信支付代码_10行代码搞定微信支付(Java版)

    原标题:10行代码搞定微信支付(Java版) 微信支付痛点 对于大多数同学来说,要开发微信支付可不简单.附上微信支付官方文档网页链接 从文档上可以看出,你需要解决很多问题,我就随便挑几个吧. xml与 ...

  7. java版阿里云,百度ai,讯飞语音识别效果简单对比及demo

    因为公司的业务的需要,对三家的语音识别(简短语句识别java版)进行了调用和对比,把自己的测试成果贴出来供需要的人参考使用.并贴出主要代码块 阿里云的一句话识别: package com.alibab ...

  8. 北大青鸟集团java书本_APTECH北大青鸟第二学期毕业设计图书管理系统(JAVA版).ppt...

    APTECH北大青鸟第二学期毕业设计图书管理系统(JAVA版) 项目背景 我们的客户经营着一家图书馆,从最开始的几百本书发展到现在已有上万本图书,会员也从最初的几十人发展到几千人. 开始时,他们采用的 ...

  9. hmcl离线登陆_最好用的Java版启动器HMCL

    原标题:最好用的Java版启动器HMCL 推荐的启动器是什么了?就是 Hello Minecraft! Launcher 简称HMCL,这款启动器特色很多.一张图片简单说明!!! 支持离线登录代表了什 ...

最新文章

  1. Python 标准库之 Queue
  2. 【Codeforces】908B New Year and Buggy Bot(暴力+全排列)
  3. 第六课.模型评估与模型选择
  4. 旋转矩阵、欧拉角、四元数比较
  5. 对YUV4:2:0认识理解
  6. iframe有那些缺点
  7. Java 实现常见排序算法
  8. 深度学习(四十六)Adversarial Autoencoders学习笔记
  9. Mysql事务隔离与Spring
  10. MA1 轻轻松松学统计分析(下)
  11. 量子计算机物理装置的总称,量子到底是什么?解读量子世界以及量子的实际应用!...
  12. 【Tensorflow】op的理解和自定义损失函数
  13. SpringBoot——入门(HelloWorld和探究HelloWorld)
  14. 专接本计算机与科学技术,计算机科学与技术专业专接本考什么
  15. 干货丨吉时利源表测试方法详
  16. stage.frameRate改变帧频
  17. ledkvm切换器结构大变样:采用双滑轨设计,更易用
  18. 合并多个PPT文件到一个文件中的方法
  19. C Primer Plus NO.5
  20. difference用法

热门文章

  1. 亚商投资顾问早餐FM/0324互联网医疗迎利好
  2. 探索iOS之AudioUnit音效框架
  3. win10怎么新建计算机用户,win10家庭版怎样创建新用户
  4. 为什么理想滤波器不可实现
  5. php结束代码,php语句以什么符号结束
  6. UE4 炮弹追踪 学习笔记
  7. 安装ORB-SLAM3教程
  8. SpringBoot+MySql+LayUI实现数据导出的功能(Excel表)
  9. Android客户端网络DNS优化实践
  10. python htmlparser怎么用_HTMLParser模块怎么在python中使用