语音信号的A律压缩和u律压缩matlab仿真

目录

1.算法运行效果图预览

2.算法运行软件版本

3.部分核心程序

4.算法理论概述

4.1 A律压缩算法

4.2 μ律压缩算法

5.算法完整程序工程


1.算法运行效果图预览

2.算法运行软件版本

MATLAB2022a

3.部分核心程序

clc;
clear;
close all;
warning off;
addpath(genpath(pwd));
rng('default')[y, fs] = audioread('signal.wav');%=======A律编解码===================================
figure(1);
subplot(311),plot(y);
title('语音信号');
code2=alaw(y);
subplot(312),plot(code2);
title('A律编码语音信号');
u_code2=unalaw(code2);
subplot(313),plot(u_code2);
title('A律解码语音信号');
error2=u_code2-y;
figure(2);
plot(error2);
title('A律编解码误差');%=======U律编解码===================================
figure(3);
subplot(311),plot(y);
title('语音信号');
code3=mulaw(y);
subplot(312),plot(code3);
title('U律编码语音信号');
u_code3=unmulaw(code3);
subplot(313),plot(u_code3);
title('U律解码语音信号');
error3=u_code3-y;
figure(4);
plot(error3);
title('U律编解码误差');
03_010m

4.算法理论概述

       语音信号的量化过程是将采样后的信号按整个声波的幅度划分成有限个区段的集合,把落入某个区段内的样值归为一类,并赋于相同的量化值。采取二进制的方式,以8位或16位的方式来划分纵轴。也就是说在一个以8位为记录模式的音效中,其纵轴将会被划分为个量化等级,用以记录其幅度大小。采样原理的示意图如图所示:

       非均匀量化,用数字值表示采样后的信号幅度值的过程即为量化,量化后信号就变成了数字信号。量化可以分为均匀量化和非均匀量化两种。量化过程会产生量化误差。而量化误差在接收端的表现形式即为量化噪声。非均匀量化根据幅度的不同区间来确定量化间隔,幅度小的区间量化间隔小,幅度大的区间量化间隔大,故可以有效改善小型号的量噪比。A律压缩和μ律压缩是一种常见的语音信号压缩技术,用于在数字通信中对语音信号进行编码。这些算法可以有效地减少数据传输所需的比特数,同时保持足够的音频质量。本文将详细介绍A律压缩和μ律压缩算法的原理、实现以及应用领域。 

4.1 A律压缩算法

        A律压缩是一种非线性压缩算法,常用于8位PCM(脉冲编码调制)语音信号的压缩。其原理是通过对输入信号的幅度进行非线性映射,以便在更小的比特数上表示信号。A律压缩使用以下数学公式:

       其中x表示为归一化的压缩器输入电压;y为归一化的压缩器输出电压,A为压扩参数,表示压缩程度。很明显,小信号时为线性特性,大信号时近似为对数特性。这种压扩特性常把压缩、量化和编码合为一体。A律可用13段折线逼近(相当于A=87.6),便于用数字电路实现。 

       A律13折线特性曲线如下所示:

4.2 μ律压缩算法

       μ律压缩是一种类似于A律压缩的非线性压缩算法,通常在欧洲和亚洲地区使用。μ律压缩同样通过非线性映射来减小输入信号的幅度范围,从而降低所需的比特数。μ律压缩使用以下数学公式:

       μ律压缩在欧洲和亚洲的语音通信系统中广泛应用。类似于A律压缩,它可以有效地降低传输带宽,并保持合理的语音质量。μ律(m-Law)压扩主要用在北美和日本等地区的数字电话通信中。m为确定压缩量的参数,它反映最大量化间隔和最小量化间隔之比,通常取100≤m≤500。

        A律压缩和μ律压缩算法是在数字通信中常用的语音信号压缩技术。通过非线性映射,它们可以有效地减小数据传输所需的比特数,同时保持合理的语音质量。选择适当的算法取决于地区和特定应用的要求。

5.算法完整程序工程

OOOOO

OOO

O

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/59332.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

DP-GAN剩余代码

在前面计算完损失后,该进行更新: 1:netEMA是模型的生成器: 遍历生成器的state_dict,将每一个键对应的值乘以EMA_decay。 接着根据当前迭代步数计算num_upd,每1000,2500,10000代倍数就执行一次。 当num…

HCIA---TCP/UDP协议

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 目录 文章目录 一.UDP协议简介 UDP协议的特点: 二.TCP协议简介 TCP协议特点 三.TCP和UDP的区别 四.TCP/IP结构详解 五.TCP运输连接的阶段 ​编…

idea中提示Unsupported characters for the charset ‘ISO-8859-1‘

application.properties中文注释拉黄线 ,提示Unsupported characters for the charset ISO-8859-1 解决办法: 注意: 改完之后之前输入的中文就变成“ ???”了,建议备份一下 1、打开setti…

【项目 计网2】4.4网络模型 4.5协议 4.6网络通信的过程

文章目录 4.4网络模型OSI七层参考模型TCP/IP四层模型(常用)简介四层介绍 4.5协议简介常见协议UDP协议TCP协议IP协议以太网帧协议(MAC地址封装)ARP协议(IP->MAC) 4.6网络通信的过程封装分用 4.4网络模型 …

LVS负载均衡部署-NAT

文章目录 LVS-NAT模式配置原理实验环境DR添加网卡准备两台Real Server134:145:测试: 修改RS网关配置DR:开启路由转发下载软件配置查看配置 测试 LVS-NAT模式配置 原理 当客户端访问DR时即访问的外网接口然后由DR将流量在本地转发…

自编码器的学习

先奉上视频 https://www.bilibili.com/video/BV1Vx411j78H/?spm_id_from333.788.recommend_more_video.-1&vd_sourceeb433c8780bdd700f49c6fc8e3bd0911

基于Java+SpringBoot+SpringCloud+Vue的智慧养老平台设计与实现(源码+LW+部署文档等)

博主介绍: 大家好,我是一名在Java圈混迹十余年的程序员,精通Java编程语言,同时也熟练掌握微信小程序、Python和Android等技术,能够为大家提供全方位的技术支持和交流。 我擅长在JavaWeb、SSH、SSM、SpringBoot等框架…

【eNSP】静态路由

【eNSP】静态路由 原理网关路由表 实验根据图片连接模块配置路由器设备R1R2R3R4 配置PC的IP地址、掩码、网关PC1PC2PC3 配置静态路由查看路由表R1R2R3R4测试能否通信 原理 网关 网关与路由器地址相同,一般路由地址为.1或.254。 网关是当电脑发送的数据的目标IP不在…

【LeetCode】数据结构题解(12)[用栈实现队列]

用栈实现队列 😉 1.题目来源👀2.题目描述🤔3.解题思路🥳4.代码展示 所属专栏:玩转数据结构题型❤️ 🚀 >博主首页:初阳785❤️ 🚀 >代码托管:chuyang785❤️ &…

功能上新|全新GPU性能优化方案

GPU优化迎来了全新的里程碑!我们深知移动游戏对高品质画面的追求日益升温,因此UWA一直着眼于移动设备GPU性能优化,以确保您的游戏体验尽善尽美。然而,不同GPU芯片之间的性能差异及可能导致的GPU瓶颈问题,让优化工作变得…

【Linux升级之路】5_基础IO

🌟hello,各位读者大大们你们好呀🌟 🍭🍭系列专栏:【Linux升级之路】 ✒️✒️本篇内容:文件操作,文件管理,重定向,简易shell添加重定向功能,文件属…

深度学习,计算机视觉任务

目录 计算机视觉任务 1.K近邻算法 2.得分函数 3.损失函数的作用 4.向前传播整体流程 5.反向传播计算方法 计算机视觉任务 机器学习的流程: 数据获取 特征工程 建立模型 评估与应用 计算机视觉: 图像表示:计算机眼中的图像&#…