在数字信号处理的课程设计期间,在老师建议下,笔者额外做了语音信号的加密解密,由于课上基本没有介绍,自己接触也很少,从零开始。本想从网上找一个合适的例程改改,无奈在网上查找半天也没有找到自己想要的简单例子,一搜出来的全是混沌加密啥的,要么就是没有程序的大段文字,于是决定自己写一个简单的语音信号的加密解密程序,能体现加密解密的基本思想。

这次我是在matlab上对语音信号进行的处理,处理的语音文件是提前准备好的.wav格式的音频文件(可以通过格式工厂把其他格式的音频文件转成wav文件,方便matlab直接读取)。笔者此处所写加密解密程序的核心在于模二相加,模二相加有一个特点,模二相加两次,数据就会还原,这就和加密解密用同一个密钥的特点不谋而合,也就是我们事先给出一个密钥(这个密钥可以用伪随机数产生,笔者是直接给出的),只要我们用同一个密钥对数据进行模二相加,就可以实现加密解密。先贴出效果图。

加密解密密钥相同时:(正确解密)

加密后信号的时域波形完全变了,解密后恢复成原波形。

加密解密密钥不同时:(错误解密)

由于解密密钥错误,解密波形错误。

接下来笔者将先逐段分析实现代码,最后会将整段代码贴出,供大家学习交流使用。

首先是对wav格式的音频文件进行读取,读取使用matlab提供的audioread函数,得到两个参数x,fs,其中x是一个代表左右声道的列数为2的矩阵,fs是采样频率,此处为了处理方便,笔者采用了单列处理,将音频文件中的一部分取出,由于audioread读出的是浮点数,不方便处理,故在处理前先将其转换为整数。

clear all;
clc;
[x,fs]=audioread('C:\Users\11616\Desktop\keshe\boy.wav');
x=x(:,1);%双声道分列处理
x=x(20000:20000*5-1)
x=ceil(x*10000)%全部变为整数
n=length(x);

至此我们得到了一列n点可以表示音频的整数矩阵,笔者最开始的思路是将这些整数转换成二进制序列,然后再与二进制密钥进行位运算,看起来简单的两个过程笔者卡了1天,原因在于matlab虽然提供了将10进制整数转成2进制的函数dec2bin,但是这个函数有两个问题,查看help发现这个函数只能对非负整数进行转换,这是第一个问题,当笔者一通操作解决这个问题之后,发现这个函数转换出的2进制序列是按位存储在矩阵中的,并不是笔者想要的二进制数,由于才疏学浅且对matlab不熟悉,到此笔者就没有继续硬磕了,就在发愁的时候笔者突然发现自己钻了牛角尖为什么一定要转换成2进制再模二相加呢??到此最终方案浮出水面,模二相加实际上就是按位异或,而matlab提供的bitxor函数可以将两个整数直接按位异或,到此这个程序变得异常简单。

定义密钥key1,如果追求演示效果,可以把key2置成一个比较大的整数,做一个简单的搬移,上边的效果图和下面的程序中笔者均置零了,所以大家可以忽略这个key2。还需要注意的是在播放前记得要把数据转换成原始状态。

key1=123456789
key2=0
x=x+key2;
for i=1:ny(i)=bitxor(x(i),key1,'int32');
end
x=x-key2;
x1=x/10000;
sound(x1,fs);%播放原音频
pause(4);
y2=y-key2;
y1=y2/10000;
sound(y1,fs);%播放加密音频

至此加密部分完成了,而解密和上面基本一样,只是再做一次异或。

for i=1:nz(i)=bitxor(y(i),key1,'int32');
end
pause(4);
z2=z-key2;
z1=z2/10000;
sound(z1,fs);%播放解密音频

完整代码:

clear all;
clc;
[x,fs]=audioread('C:\Users\11616\Desktop\keshe\boy.wav');
x=x(:,1);%双声道分列处理
x=x(20000:20000*5-1)
x=ceil(x*10000)%全部变为整数
n=length(x);
key1=123456789
key2=0
x=x+key2;
for i=1:ny(i)=bitxor(x(i),key1,'int32');
end
x=x-key2;
x1=x/10000;
sound(x1,fs);%播放原音频
pause(4);
y2=y-key2;
y1=y2/10000;
sound(y1,fs);%播放加密音频
for i=1:nz(i)=bitxor(y(i),key1,'int32');
end
pause(4);
z2=z-key2;
z1=z2/10000;
sound(z1,fs);%播放解密音频

有误之处,欢迎指正。

数字信号处理-基于matlab的语音信号的加密解密相关推荐

  1. 《数字语音处理》- 1. 基于MATLAB的语音信号时域特征分析

    声明 本文仅在CSDN发布,其他均为盗版.请支持正版! 正版链接: https://blog.csdn.net/meenr/article/details/117629753 基于MATLAB的语音信 ...

  2. matlab如何采集两路语音信号,基于MATLAB的语音信号采集与处理

    内容介绍 原文档由会员 大雨倾盆 发布 基于MATLAB的语音信号采集与处理 2.4万字 114页 原创作品,已通过查重系统 摘要 语音信号处理作为目前发展最为迅速的信息科学研究领域的核心技术,它是一 ...

  3. 基于matlab 的语音信号分析和处理,基于matlab_的语音信号分析和处理

    基于matlab_的语音信号分析和处理 1 基于MATLAB 的语音信号分析和处理 福建师范大学协和学院 信息技术系 电子信息科学与技术专 124122006028 王祯飞 指导老师 黄小芬[摘要]本 ...

  4. 基于matlab的语音信号滤波处理

    基于matlab的语音信号滤波处理 摘要:本课程设计的主要目的是在MATLAB环境下,使用窗口设计法设计一个滤波器,并对语音信号进行滤波去噪.开发平台为MATLAB,设计方法为窗口设计法.用麦克风采集 ...

  5. matlab的dft谱分析,数字信号处理基于matlab(用DFT作谱分析,窗函数的设计)

    数字信号处理基于matlab(用DFT作谱分析,窗函数的设计) 1实验一用DFT作谱分析X11111X212344321N108X3COSN1PI/4N208X4SINN2PI/8FIGURESUBP ...

  6. Matlab语音采集与读写程序,基于MATLAB的语音信号录制采集和分析的程序设计

    理 论广 角 ● I 基于 MATLAB的语音信号录制采集和分析的程序设计 刘 晓炯 (西北民族大学电气工程学院 甘肃 兰州I 730030) [摘 要]语音信号处理技术是语音处理领域中新近发展起来的 ...

  7. 基于matlab的语音信号去噪毕业论文,MATLAB的FIR数字滤波器语音信号的去噪研究和仿真...

    摘要:语音信号作为人类语言交流的重要手段,语音处理的质量直接影响人们的正常通信.本文基于MATLAB对语音信号及加噪信号进行时域和频域分析,设计了FIR数字滤波器,完成对加噪信号滤波的处理.结果表明设 ...

  8. 频域参数 matlab,基于MATLAB的语音信号时频域参数分析

    22 科技广场 2007.9 基于MATLAB的语音信号时频域参数分析 the Character Analysis of Speech Signal with Time and Frequency ...

  9. 判断清浊音 matlab,基于MATLAB的语音信号的清浊音分析.doc

    基于MATLAB的语音信号的清浊音分析 目录 1 语音信号概述1 1.1 语音信号的基本组成1 1.2 语音信号的"短时谱"1 1.3 基音周期2 1.4 短时分析技术2 2 语音 ...

最新文章

  1. Linux下nginx+tomcat+memcached集群
  2. 手动安装K8s第三节:etcd集群部署
  3. CSS3+jQuery实现时钟插件
  4. 洛谷 P1101 单词方阵
  5. 视频文件详细信息python3_如何用python3爬取自己的收藏夹视频信息
  6. 李航第一章课后习题答案
  7. intent android 匿名,Android 匿名启动activity 启动系统activity
  8. print输出 pytorch_pytorch打印网络结构的实例
  9. hexo博客添加暗色模式_我如何将暗模式添加到我的网站
  10. python爬虫Day1(requests基本使用)
  11. Hadoop-2.4.1学习之Writable及事实上现
  12. 2021年中国无线通信模组企业排名
  13. 网络-DNS域名系统详解与DNS攻击
  14. 数据处理之异常值处理
  15. C语言数组制作拼图游戏,C语言例子自制拼图游戏
  16. android 壁纸制作教程,[教程]怎样制作Android手机壁纸/桌面
  17. RabbitMQ基础篇 (一)
  18. 【IT职场】如何成为T型甚至A型人物。
  19. 学会这招,远离年金险99%的坑
  20. 改进YOLOv5系列:10.最新HorNet结合YOLO应用首发! | 多种搭配,即插即用 | Backbone主干、递归门控卷积的高效高阶空间交互高效

热门文章

  1. 【OMNeT+INET】浅谈OMNeT开源库INET(二)
  2. 科视Christie 连续第13年为第 24 届上海国际电影节提供放映支持
  3. Matlab中用于数据预测spline()函数的使用
  4. 服务器怎么装普通系统,普通主机安装服务器系统安装
  5. CVE-2019-5736复现
  6. Redis数据库的订阅发布
  7. linux系统6.8下载,centos6.8
  8. 成人高考计算机分数线,成人高考高起本计算机科学与技术录取分数线-成人高考高起本计算机科学与技术分数线公布时间-成人高考高起本计算机科学与技术分数线-学赛网...
  9. turtle.seth()
  10. Windows Forms、 MFC、WTL、 WxWidgets、Qt、GTK