【图像加密】基于matlab GUI双随机相位编码光学图像加密解密【含Matlab源码 1633期】

本文主要是介绍【图像加密】基于matlab GUI双随机相位编码光学图像加密解密【含Matlab源码 1633期】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

✅博主简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,Matlab项目合作可私信。
🍎个人主页:海神之光
🏆代码获取方式:
海神之光Matlab王者学习之路—代码获取方式
⛳️座右铭:行百里者,半于九十。

更多Matlab仿真内容点击👇
Matlab图像处理(进阶版)
路径规划(Matlab)
神经网络预测与分类(Matlab)
优化求解(Matlab)
语音处理(Matlab)
信号处理(Matlab)
车间调度(Matlab)

⛄一、双相位编码单通道彩色图像加密简介(附lunwen)

1 前言
在国际上不断发展的新一代信息安全理论与技术的研究中,基于光学理论与方法的数据加密、隐藏和提取技术成为了一个重要的组成部分。近年来,国内外很多学者都开始从事这方面的研究,并提出了很多新方法,新技术.在这些研究中,大多是采用单色光照明,因此所恢复的图像将会失去彩色信息.
色彩是自然界的基本属性之一,图像的色彩信息在许多场合都是非常有用的,彩色图像信息的加密处理正受到越来越多的重视.在这类研究中,彩色图像通常被分成3个或多个通道,再采用和灰度图像相同的处理方法,解密时将各个通道组合起来,以恢复原来的彩色图像,这类方法常被称为多通道彩色图像处理.由于使用了多个通道,则相应的光学实现系统也就需要多个光源和多套光学元件,在增加了实验难度的同时,也增加了系统的成本,使此类方法的实用性受到限制.
本文提出一种基于双相位编码的单通道彩色图像加密方法.在该方法中, 图像首先被从RGB空间转换到HSI(色调、饱和度、强度) 空间, 再将其合并到一个通道中,采用双相位编码技术加密.其中,(强度)分量可作为双相位编码时的原始待加密图像,而编码时所用的密钥,可由H(色调)分量和S(饱和度) 分量获得.因为在HSI空间中, 色调与一个角度相对应,可以将其作为一个相位角来处理,该相位即可作为双相位编码中的相位密钥之一;而采用双随机相位加密技术对S分量加密后得到的相息图,可作为双相位编码的另一个密钥.由于仅使用一个通道对彩色图像加密,其相应的光学实现系统仅需一个光源和一套光学元件,不仅使实验难度降低,也减少了系统的成本.又因为采用双随机相位加密技术得到的S分量的相息图,在加密的过程中引进了随机相位因子,在不知密钥的情况下解密出S分量几乎不可能,从而保证了本方法的安全性.模拟实验结果证明了本文所提出方法的有效性。

2.色彩空间的转换
本文中,图像的彩色信息被转换成振幅和位相信息,以实现单通道加密.而彩色图像通常用红、绿、蓝三元组的二维矩阵来表示.为此,首先需将彩色图像用HSI表示.在RGB和HSI之间的变换公式有多种形式, 所有变换方法的基本思想都是一致的.一般而言,对
在这里插入图片描述
2.1 RGB 到HSI 的彩色模型转换
在这里插入图片描述
2.2 HSI 到RGB 的彩色模型转换
在这里插入图片描述
3.彩色图像的单通道加密
3.1.密钥 ——— S 分量的加密

在这里插入图片描述
3.2 基于双相位的单通道彩色图像加密
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

⛄二、部分源代码

function varargout = main(varargin)
% MAIN MATLAB code for main.fig
% MAIN, by itself, creates a new MAIN or raises the existing
% singleton*.
%
% H = MAIN returns the handle to a new MAIN or the handle to
% the existing singleton*.
%
% MAIN(‘CALLBACK’,hObject,eventData,handles,…) calls the local
% function named CALLBACK in MAIN.M with the given input arguments.
%
% MAIN(‘Property’,‘Value’,…) creates a new MAIN or raises the
% existing singleton*. Starting from the left, property value pairs are
% applied to the GUI before main_OpeningFcn gets called. An
% unrecognized property name or invalid value makes property application
% stop. All inputs are passed to main_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 main

% Last Modified by GUIDE v2.5 08-Jun-2021 11:15:19

% Begin initialization code - DO NOT EDIT
gui_Singleton = 0;
gui_State = struct(‘gui_Name’, mfilename, …
‘gui_Singleton’, gui_Singleton, …
‘gui_OpeningFcn’, @main_OpeningFcn, …
‘gui_OutputFcn’, @main_OutputFcn, …
‘gui_LayoutFcn’, [] , …
‘gui_Callback’, []);
if nargin && ischar(varargin{1})
gui_State.gui_Callback = str2func(varargin{1});
end

if nargout
[varargout{1:nargout}] = gui_mainfcn(gui_State, varargin{:});
else
gui_mainfcn(gui_State, varargin{:});
end
% End initialization code - DO NOT EDIT

% — Executes just before main is made visible.
function main_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 main (see VARARGIN)

% Choose default command line output for main
handles.output = hObject;
% Update handles structure
guidata(hObject, handles);
%设置状态标签
setappdata(handles.figure,‘OriginalImFlag’,false);
setappdata(handles.figure,‘ArnoldImFlag’,false);
setappdata(handles.figure,‘EncryptionImFlag’,false);
setappdata(handles.figure,‘DecryptionImFlag’,false);

setappdata(handles.figure,‘makeRM1Flag’,false);
setappdata(handles.figure,‘makeRM2Flag’,false);

setappdata(handles.figure,‘KeyFlag’,false);
setappdata(handles.figure,‘ArnoldCountKeyFlag’,false);
setappdata(handles.figure,‘LogisticXKeyFlag’,false);
setappdata(handles.figure,‘LogisticUKeyFlag’,false);
setappdata(handles.figure,‘LogisticNKeyFlag’,false);
setappdata(handles.figure,‘ChenXKeyFlag’,false);
setappdata(handles.figure,‘ChenYKeyFlag’,false);
setappdata(handles.figure,‘ChenZKeyFlag’,false);
setappdata(handles.figure,‘ChenCKeyFlag’,false);
setappdata(handles.figure,‘ChenHKeyFlag’,false);
setappdata(handles.figure,‘ChenTKeyFlag’,false);
setappdata(handles.figure,‘ChenNKeyFlag’,false);

%隐藏坐标轴
set(handles.axesOriginalIm,‘Visible’,‘off’);
set(handles.axesArnoldIm,‘Visible’,‘off’);
set(handles.axesEncryptionIm,‘Visible’,‘off’);
set(handles.axesDecryptionIm,‘Visible’,‘off’);
% UIWAIT makes main wait for user response (see UIRESUME)
% uiwait(handles.figure);

% — Outputs from this function are returned to the command line.
function varargout = main_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;

function File_Callback(hObject, eventdata, handles)

function FileOpenOriginal_Callback(hObject, eventdata, handles)
[filename, pathname] = uigetfile( …
{‘.jpg;.bmp;.png;.jpeg’,‘Image Files ( .jpg,.bmp, .png,.jpeg)’; …
.’,‘All Files (.)’}, …
‘Pick an image’);
if isequal(filename,0) || isequal(pathname,0)
return;
end
fpath=[pathname filename];%将文件名和目录名组合成一个完整的路径
global OriginalIm
OriginalIm=imread(fpath);
OriginalIm=im2double(OriginalIm);
if length(size(OriginalIm))==3
OriginalIm=rgb2gray(OriginalIm);
end
axes(handles.axesOriginalIm); %用axes命令设定当前操作的坐标轴是axes_src
cla;%清空坐标图
imshow(OriginalIm);
title(‘原图’);
h_fig=findall(0,‘Type’,‘figure’,‘Tag’,‘figure’);
setappdata(h_fig,‘makeRM1Flag’,false);
setappdata(h_fig,‘makeRM2Flag’,false);
setappdata(h_fig,‘OriginalImFlag’,true);

function FileOpenKey_Callback(hObject, eventdata, handles)
[filename, pathname] = uigetfile( …
{‘.csv;.txt’,‘Image Files ( .csv,.txt)’; …
.’,‘All Files (.)’}, …
‘Pick an image’);
if isequal(filename,0) || isequal(pathname,0)
return;
end
fpath=[pathname filename];%将文件名和目录名组合成一个完整的路径
k=importdata(fpath);
key=k.data;
global ArnoldCount LogisticX LogisticU LogisticN ChenX ChenY ChenZ ChenC ChenH ChenT ChenN;
ArnoldCount=key(1);
LogisticX=key(2);
LogisticU=key(3);
LogisticN=key(4);
ChenX=key(5);
ChenY=key(6);
ChenZ=key(7);
ChenC=key(8);
ChenH=key(9);
ChenT=key(10);
ChenN=key(11);
set(handles.editArnoldCount,‘string’,num2str(ArnoldCount));
set(handles.editLogisticX,‘string’,num2str(LogisticX));
set(handles.editLogisticU,‘string’,num2str(LogisticU));
set(handles.editLogisticN,‘string’,num2str(LogisticN));
set(handles.editChenX,‘string’,num2str(ChenX));
set(handles.editChenY,‘string’,num2str(ChenY));
set(handles.editChenZ,‘string’,num2str(ChenZ));
set(handles.editChenC,‘string’,num2str(ChenC));
set(handles.editChenH,‘string’,num2str(ChenH));
set(handles.editChenT,‘string’,num2str(ChenT));
set(handles.editChenN,‘string’,num2str(ChenN));

h_fig=findall(0,‘Type’,‘figure’,‘Tag’,‘figure’);
setappdata(h_fig,‘makeRM1Flag’,false);
setappdata(h_fig,‘makeRM2Flag’,false);
setappdata(handles.figure,‘KeyFlag’,true);

function FileOpenEncryption_Callback(hObject, eventdata, handles)
global EncryptionIm;
[filename, pathname] = uigetfile(‘encryption.mat’,‘Pick an encryption file’);
if isequal(filename,0) || isequal(pathname,0)
return;
end
fpath=[pathname filename];%将文件名和目录名组合成一个完整的路径
try
load(fpath,‘-mat’);
catch
msgbox(‘输入的源文件不能进行解密,请输入*.mat文件!’,‘error’);
return;
end

axes(handles.axesEncryptionIm); %用axes命令设定当前操作的坐标轴是axes_src
cla;%清空坐标图
imshow(abs(EncryptionIm));
title(‘加密图’);
h_fig=findall(0,‘Type’,‘figure’,‘Tag’,‘figure’);
setappdata(h_fig,‘makeRM1Flag’,false);
setappdata(h_fig,‘makeRM2Flag’,false);
setappdata(h_fig,‘ArnoldImFlag’,true);
setappdata(h_fig,‘EncryptionImFlag’,true);

function FileSaveKey_Callback(hObject, eventdata, handles)
[filename, pathname] = uiputfile(‘key.csv’,‘Save file name’);
if isequal(filename,0) || isequal(pathname,0)
return;%如果点了“取消”
else
fpath=fullfile(pathname, filename);%获得全路径的另一种方法
end
global ArnoldCount LogisticX LogisticU LogisticN ChenX ChenY ChenZ ChenC ChenH ChenT ChenN;
T=table(ArnoldCount,LogisticX,LogisticU,LogisticN,ChenX,ChenY,ChenZ,ChenC,ChenH,ChenT,ChenN);
writetable(T,fpath,‘WriteRowNames’,true,‘Delimiter’,‘,’);

function FileSaveEncryption_Callback(hObject, eventdata, handles)
[filename, pathname] = uiputfile(‘EncryptionIm.mat’,‘Save file name’);
if isequal(filename,0) || isequal(pathname,0)
return;%如果点了“取消”
else
fpath=fullfile(pathname, filename);%获得全路径的另一种方法
end
global EncryptionIm;
save(fpath,‘EncryptionIm’);
% imwrite(abs(EncryptionIm),fpath);%保存图片

function FileSaveDecryption_Callback(hObject, eventdata, handles)
[filename, pathname] = uiputfile(‘original.jpg’,‘Save file name’);
if isequal(filename,0) || isequal(pathname,0)
return;%如果点了“取消”
else
fpath=fullfile(pathname, filename);%获得全路径的另一种方法
end

⛄三、运行结果

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

⛄四、matlab版本及参考文献

1 matlab版本
2014a

2 参考文献
[1]杨晓苹,高丽娟,王晓雷,翟宏琛,王明伟.基于双相位编码的单通道彩色图像加密[J].物理学报. 2009,58(03)

3 备注
简介此部分摘自互联网,仅供参考,若侵权,联系删除

🍅 仿真咨询
1 各类智能优化算法改进及应用

生产调度、经济调度、装配线调度、充电优化、车间调度、发车优化、水库调度、三维装箱、物流选址、货位优化、公交排班优化、充电桩布局优化、车间布局优化、集装箱船配载优化、水泵组合优化、解医疗资源分配优化、设施布局优化、可视域基站和无人机选址优化

2 机器学习和深度学习方面
卷积神经网络(CNN)、LSTM、支持向量机(SVM)、最小二乘支持向量机(LSSVM)、极限学习机(ELM)、核极限学习机(KELM)、BP、RBF、宽度学习、DBN、RF、RBF、DELM、XGBOOST、TCN实现风电预测、光伏预测、电池寿命预测、辐射源识别、交通流预测、负荷预测、股价预测、PM2.5浓度预测、电池健康状态预测、水体光学参数反演、NLOS信号识别、地铁停车精准预测、变压器故障诊断

3 图像处理方面
图像识别、图像分割、图像检测、图像隐藏、图像配准、图像拼接、图像融合、图像增强、图像压缩感知

4 路径规划方面
旅行商问题(TSP)、车辆路径问题(VRP、MVRP、CVRP、VRPTW等)、无人机三维路径规划、无人机协同、无人机编队、机器人路径规划、栅格地图路径规划、多式联运运输问题、车辆协同无人机路径规划、天线线性阵列分布优化、车间布局优化

5 无人机应用方面
无人机路径规划、无人机控制、无人机编队、无人机协同、无人机任务分配

6 无线传感器定位及布局方面
传感器部署优化、通信协议优化、路由优化、目标定位优化、Dv-Hop定位优化、Leach协议优化、WSN覆盖优化、组播优化、RSSI定位优化

7 信号处理方面
信号识别、信号加密、信号去噪、信号增强、雷达信号处理、信号水印嵌入提取、肌电信号、脑电信号、信号配时优化

8 电力系统方面
微电网优化、无功优化、配电网重构、储能配置

9 元胞自动机方面
交通流 人群疏散 病毒扩散 晶体生长

10 雷达方面
卡尔曼滤波跟踪、航迹关联、航迹融合

这篇关于【图像加密】基于matlab GUI双随机相位编码光学图像加密解密【含Matlab源码 1633期】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/893136

相关文章

Python中OpenCV与Matplotlib的图像操作入门指南

《Python中OpenCV与Matplotlib的图像操作入门指南》:本文主要介绍Python中OpenCV与Matplotlib的图像操作指南,本文通过实例代码给大家介绍的非常详细,对大家的学... 目录一、环境准备二、图像的基本操作1. 图像读取、显示与保存 使用OpenCV操作2. 像素级操作3.

C/C++的OpenCV 进行图像梯度提取的几种实现

《C/C++的OpenCV进行图像梯度提取的几种实现》本文主要介绍了C/C++的OpenCV进行图像梯度提取的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录预www.chinasem.cn备知识1. 图像加载与预处理2. Sobel 算子计算 X 和 Y

c/c++的opencv图像金字塔缩放实现

《c/c++的opencv图像金字塔缩放实现》本文主要介绍了c/c++的opencv图像金字塔缩放实现,通过对原始图像进行连续的下采样或上采样操作,生成一系列不同分辨率的图像,具有一定的参考价值,感兴... 目录图像金字塔简介图像下采样 (cv::pyrDown)图像上采样 (cv::pyrUp)C++ O

在Spring Boot中实现HTTPS加密通信及常见问题排查

《在SpringBoot中实现HTTPS加密通信及常见问题排查》HTTPS是HTTP的安全版本,通过SSL/TLS协议为通讯提供加密、身份验证和数据完整性保护,下面通过本文给大家介绍在SpringB... 目录一、HTTPS核心原理1.加密流程概述2.加密技术组合二、证书体系详解1、证书类型对比2. 证书获

8种快速易用的Python Matplotlib数据可视化方法汇总(附源码)

《8种快速易用的PythonMatplotlib数据可视化方法汇总(附源码)》你是否曾经面对一堆复杂的数据,却不知道如何让它们变得直观易懂?别慌,Python的Matplotlib库是你数据可视化的... 目录引言1. 折线图(Line Plot)——趋势分析2. 柱状图(Bar Chart)——对比分析3

使用Java实现Navicat密码的加密与解密的代码解析

《使用Java实现Navicat密码的加密与解密的代码解析》:本文主要介绍使用Java实现Navicat密码的加密与解密,通过本文,我们了解了如何利用Java语言实现对Navicat保存的数据库密... 目录一、背景介绍二、环境准备三、代码解析四、核心代码展示五、总结在日常开发过程中,我们有时需要处理各种软

基于Go语言实现Base62编码的三种方式以及对比分析

《基于Go语言实现Base62编码的三种方式以及对比分析》Base62编码是一种在字符编码中使用62个字符的编码方式,在计算机科学中,,Go语言是一种静态类型、编译型语言,它由Google开发并开源,... 目录一、标准库现状与解决方案1. 标准库对比表2. 解决方案完整实现代码(含边界处理)二、关键实现细

Python+wxPython构建图像编辑器

《Python+wxPython构建图像编辑器》图像编辑应用是学习GUI编程和图像处理的绝佳项目,本教程中,我们将使用wxPython,一个跨平台的PythonGUI工具包,构建一个简单的... 目录引言环境设置创建主窗口加载和显示图像实现绘制工具矩形绘制箭头绘制文字绘制临时绘制处理缩放和旋转缩放旋转保存编

python+OpenCV反投影图像的实现示例详解

《python+OpenCV反投影图像的实现示例详解》:本文主要介绍python+OpenCV反投影图像的实现示例详解,本文通过实例代码图文并茂的形式给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前言二、什么是反投影图像三、反投影图像的概念四、反向投影的工作原理一、利用反向投影backproj

Android实现一键录屏功能(附源码)

《Android实现一键录屏功能(附源码)》在Android5.0及以上版本,系统提供了MediaProjectionAPI,允许应用在用户授权下录制屏幕内容并输出到视频文件,所以本文将基于此实现一个... 目录一、项目介绍二、相关技术与原理三、系统权限与用户授权四、项目架构与流程五、环境配置与依赖六、完整