一、简介

  1. 课程设计原理及设计方案
    语音语音加密原理框图在对语音信号进行预处理、加密解密分析之后,将各个步骤联系起来绘出了语音加密原理框图如下:


二、部分源代码

function varargout = Signal_encryption_gui1(varargin)
% SIGNAL_ENCRYPTION_GUI1 MATLAB code for Signal_encryption_gui1.fig
%      SIGNAL_ENCRYPTION_GUI1, by itself, creates a new SIGNAL_ENCRYPTION_GUI1 or raises the existing
%      singleton*.
%
%      H = SIGNAL_ENCRYPTION_GUI1 returns the handle to a new SIGNAL_ENCRYPTION_GUI1 or the handle to
%      the existing singleton*.
%
%      SIGNAL_ENCRYPTION_GUI1('CALLBACK',hObject,eventData,handles,...) calls the local
%      function named CALLBACK in SIGNAL_ENCRYPTION_GUI1.M with the given input arguments.
%
%      SIGNAL_ENCRYPTION_GUI1('Property','Value',...) creates a new SIGNAL_ENCRYPTION_GUI1 or raises the
%      existing singleton*.  Starting from the left, property value pairs are
%      applied to the GUI before Signal_encryption_gui1_OpeningFcn gets called.  An
%      unrecognized property name or invalid value makes property application
%      stop.  All inputs are passed to Signal_encryption_gui1_OpeningFcn via varargin.
%
%      *See GUI Options on GUIDE's Tools menu.  Choose "GUI allows only one
%      instance to run (singleton)".
%
% See also: GUIDE, GUIDATA, GUIHANDLES% Edit the above text to modify the response to help Signal_encryption_gui1% Last Modified by GUIDE v2.5 17-Jul-2017 13:59:22% Begin initialization code - DO NOT EDIT
gui_Singleton = 1;
gui_State = struct('gui_Name',       mfilename, ...'gui_Singleton',  gui_Singleton, ...'gui_OpeningFcn', @Signal_encryption_gui1_OpeningFcn, ...'gui_OutputFcn',  @Signal_encryption_gui1_OutputFcn, ...'gui_LayoutFcn',  [] , ...'gui_Callback',   []);
if nargin && ischar(varargin{1})gui_State.gui_Callback = str2func(varargin{1});
endif nargout[varargout{1:nargout}] = gui_mainfcn(gui_State, varargin{:});
elsegui_mainfcn(gui_State, varargin{:});
end
% End initialization code - DO NOT EDIT% --- Executes just before Signal_encryption_gui1 is made visible.
function Signal_encryption_gui1_OpeningFcn(hObject, eventdata, handles, varargin)
% This function has no output args, see OutputFcn.
% hObject    handle to figure
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
% varargin   command line arguments to Signal_encryption_gui1 (see VARARGIN)% Choose default command line output for Signal_encryption_gui1
global k1 k2 u1 u2 k11 k22 u11 u22
k1=0.3;u1=3.7;k2=0.6;u2=3.9;
k11=0.3;u11=3.7;k22=0.6;u22=3.9;handles.output = hObject;% Update handles structure
guidata(hObject, handles);
%设置GUI背景
ha=axes('units','normalized','position',[0 0 1 1]);
uistack(ha,'down')
H=imread('03.jpg');
image(H)
colormap gray
set(ha,'handlevisibility','off','visible','off');% UIWAIT makes Signal_encryption_gui1 wait for user response (see UIRESUME)
% uiwait(handles.figure1);% --- Outputs from this function are returned to the command line.
function varargout = Signal_encryption_gui1_OutputFcn(hObject, eventdata, handles)
% varargout  cell array for returning output args (see VARARGOUT);
% hObject    handle to figure
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)% Get default command line output from handles structure
varargout{1} = handles.output;% --- Executes on button press in pushbutton1.
function pushbutton1_Callback(hObject, eventdata, handles)
%录音5秒
fs=8000;                    %语音信号采样频率为8000
Data=1:64;Data=(Data'*Data)/64;
uiwait(msgbox('开始录音','录音','custom',Data,hot(64)));
y=audiorecorder(fs,16,1);
recordblocking(y, 5);
myRecording = getaudiodata(y);
audiowrite('F:\MATLAB\Matlab\bin\workplace\Signal_Encrypion\s.wav',myRecording,fs);
msgbox('录音结束','录音','custom',Data,hot(64));
% hObject    handle to pushbutton1 (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)% --- Executes on button press in pushbutton2.
function pushbutton2_Callback(hObject, eventdata, handles)
global k1 k2 u1 u2
k1=str2double(get(handles.edit1,'string'));
u1=str2double(get(handles.edit3,'string'));
k2=str2double(get(handles.edit2,'string'));
u2=str2double(get(handles.edit4,'string'));
% hObject    handle to pushbutton2 (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)% --- Executes on button press in pushbutton3.
function pushbutton3_Callback(hObject, eventdata, handles)
global k11 k22 u11 u22
k11=str2double(get(handles.edit5,'string'));
u11=str2double(get(handles.edit7,'string'));
k22=str2double(get(handles.edit6,'string'));
u22=str2double(get(handles.edit8,'string'));
% hObject    handle to pushbutton3 (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)% --- Executes on button press in pushbutton4.
function pushbutton4_Callback(hObject, eventdata, handles)
x=audioread('s.wav');
t=(0:length(x)-1)/44100;axes(handles.axes1);
plot(handles.axes1,t,x)                  %做原始语音信号的时域图形
grid on;  axis tight;
title('原始语音信号');
xlabel('time(s)');
ylabel('幅度');
% hObject    handle to pushbutton4 (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)% --- Executes on button press in pushbutton5.
function pushbutton5_Callback(hObject, eventdata, handles)
fs=44100;                    %语音信号采样频率为44100
x=audioread('s.wav');
t=(0:length(x)-1)/44100;Y=fft(x);             %对信号做2048点FFT变换
global N f
N=length(Y);
f=fs*(0:N/2-1)/N;axes(handles.axes1);
plot(handles.axes1,f,abs(Y(1:length(f))))           %做原始语音信号的FFT频谱图
grid on;  axis tight;
title('原始语音信号FFT频谱')
xlabel('Hz');
ylabel('幅度');
% hObject    handle to pushbutton5 (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)% --- Executes on button press in pushbutton6.
function pushbutton6_Callback(hObject, eventdata, handles)
x=audioread('s.wav');
sound(x)
% hObject    handle to pushbutton6 (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)% --- Executes on button press in pushbutton7.
function pushbutton7_Callback(hObject, eventdata, handles)
x=audioread('s.wav');
t=(0:length(x)-1)/44100;x1=ceil(1000*x);             %预处理语音信号(原始信号扩大1000倍)
x2=dec_to_bin(x1);           %将语音信号由10进制转化为2进制
%利用Logistic混沌映射,对语音信号进行加密
global k1 k2 u1 u2
z1=k1;z2=k2;
for m=1:80                     %迭代80次,达到充分混沌状态z1=u1*z1*(1-z1);
end

三、运行结果

四、matlab版本及参考文献

1 matlab版本
2014a

2 参考文献
[1]韩纪庆,张磊,郑铁然.语音信号处理(第3版)[M].清华大学出版社,2019.
[2]柳若边.深度学习:语音识别技术实践[M].清华大学出版社,2019.

【语音加密】基于matlab GUI语音信号加密解密【含Matlab源码 295期】相关推荐

  1. 【运动学】基于matlab GUI三体运动模拟【含Matlab源码 871期】

    ⛄一.获取代码方式 获取代码方式1: 完整代码已上传我的资源:[运动学]基于matlab GUI三体运动模拟[含Matlab源码 871期] 点击上面蓝色字体,直接付费下载,即可. 获取代码方式2: ...

  2. 【音乐播放】基于matlab GUI动感音乐播放【含Matlab源码 778期】

    ⛄一.获取代码方式 获取代码方式1: 完整代码已上传我的资源:[音乐播放]基于matlab GUI动感音乐播放[含Matlab源码 778期] 点击上面蓝色字体,直接付费下载,即可. 获取代码方式2: ...

  3. 【雷达通信】基于matlab GUI相控阵雷达方向图【含Matlab源码 1048期】

    ⛄一.获取代码方式 获取代码方式1: 完整代码已上传我的资源:[雷达通信]基于matlab GUI相控阵雷达方向图[含Matlab源码 1048期] 点击上面蓝色字体,直接付费下载,即可. 获取代码方 ...

  4. 【数据分析】基于matlab GUI齿轮箱振动数据分析【含Matlab源码 2122期】

    一.获取代码方式 获取代码方式1: 完整代码已上传我的资源:[数据分析]基于matlab GUI齿轮箱振动数据分析[含Matlab源码 2122期] 点击上面蓝色字体,直接付费下载,即可. 获取代码方 ...

  5. 【光学】基于matlab GUI维达尔之眼计算【含Matlab源码 2545期】

    ⛄一.获取代码方式 获取代码方式1: 完整代码已上传我的资源:[光学]基于matlab GUI维达尔之眼计算[含Matlab源码 2545期] 点击上面蓝色字体,直接付费下载,即可. 获取代码方式2: ...

  6. 【光学】基于matlab GUI双孔干涉【含Matlab源码 2119期】

    ⛄一.获取代码方式 获取代码方式1: 完整代码已上传我的资源:[光学]基于matlab GUI双孔干涉[含Matlab源码 2119期] 点击上面蓝色字体,直接付费下载,即可. 获取代码方式2: 付费 ...

  7. 【光学】基于matlab GUI双缝干涉和牛顿环【含Matlab源码 2165期】

    ⛄一.获取代码方式 获取代码方式1: 完整代码已上传我的资源:[光学]基于matlab GUI双缝干涉和牛顿环[含Matlab源码 2165期] 点击上面蓝色字体,直接付费下载,即可. 获取代码方式2 ...

  8. 【数字信号】基于matlab GUI电话按键识别【含Matlab源码 2382期】

    ⛄一.获取代码方式 获取代码方式1: 完整代码已上传我的资源:[数字信号]基于matlab GUI电话按键识别[含Matlab源码 2382期] 点击上面蓝色字体,直接付费下载,即可. 获取代码方式2 ...

  9. Matlab GUI/APP 浅谈(附计算器源码)

    Matlab GUI/APP 浅谈(附计算器源码) 今天没有什么段子,也没有心灵鸡汤.毒鸡汤啥的,纯粹聊一聊这些年从有关MATLAB GUI/APP开发中悟出的一点道理,顺便把计算器的源代码给大家. ...

  10. 【课程设计】基于java GUI实现学生个人信息管理系统(源码+论文+ppt+视频)

    源码资料 免费下载 不经常在线,需要源码和资料的留言私信我,主页有联系方式 技术架构 开发语言 主要用的是Java语言中的GUI(图形用户界面)和AWT(抽象窗口工具包)编程. (1) GUI 图形用 ...

最新文章

  1. 网页制作的中的一些工具代码
  2. 在公共区块链中通过加密保护数据
  3. MySQL 常用运算符
  4. CIO常犯的五个错误
  5. pytorch 保存、读取 tensor 数据
  6. 大数据可视化dataease(有所帮助)
  7. 【leetcode 简单】第四十一题 Excel表列序号
  8. 在QTP中巧用WebTable对象的ChildItem方法进行测试
  9. ICML 2019 | 强化学习用于推荐系统,蚂蚁金服提出生成对抗用户模型
  10. Typora下载地址
  11. 公测: 机智云自动生成app代码
  12. python mq_解析Python实现MQ消息队列以及消息队列的优点
  13. 信鸽推送避免打开多个相同的activity
  14. Excel:筛选后序号自动排序。
  15. 三层交换 VLAN 互访配置
  16. 中南大学计算机博士就业,求救!中南大学博士毕业要求
  17. #Python#错误之ModuleNotFoundError: No module named ‘yaml‘
  18. galaxy s6 android8,这些三星机型确认可以升级Android 8.0
  19. 1NF | 2NF | 3NF的区分以及什么是函数依赖、部分函数依赖、值传递依赖(最详细的讲解1NF、2NF、3NF的关系)
  20. Echart在Openlayers的应用-航班的炫光特效

热门文章

  1. delete语句与reference约束 FK_subplan_job_id冲突问题,导致job无法删除解决办法
  2. 设计模式详解(链接)
  3. VBA连接MySQL数据库以及ODBC的配置(ODBC版本和MySQL版本如果不匹配会出现驱动和应用程序的错误)...
  4. 一般人想象不到的创业者付出的5种努力 创业者的背后
  5. poj 2195(KM求最小权匹配)
  6. office向快速访问工具栏加快速操作
  7. Atitit  信息管理 艾提拉著 CAPT2 数据存储与分类 聚集.docx 目录 1. 按照存储位置 1 1.1. 网盘 1 1.2. 存储在eml imap中 方便检索 1 1.3. 分散与
  8. Atitit 上传进度的实现与原理 目录 1.1. 前端 1 1.2. 读取进度 1 1.3. 后端 定时注入进度 1 1.1.前端                         wind
  9. Atitit 为什么互联网机会这么大
  10. Atitit 法学体系树与知识点attilax大总结 法学体系 0301法学类 030101 法学理论 宪法 行政法 民法 商法 婚姻法和继承法 经济法 社会法 刑法 民事诉讼法 行政诉讼法