基于DNA算法的遥感图像加解密matlab仿真

目录

1.程序功能描述

2.测试软件版本以及运行结果展示

3.核心程序

4.本算法原理

5.完整程序


1.程序功能描述

       通过DNA算法对遥感图像进行加密和解密,分析加解密处理后图像的直方图,相关性,熵,解密后图像质量等。

2.测试软件版本以及运行结果展示

MATLAB2022A版本运行

3.核心程序

..........................................................................
%generate_chenstream(x0,y0,z0,w0);//产生密钥流
x0=0.07628261275522;
y0=0.77258554999421;
z0=0.14153066287988;
w0=0.53152627474363;
[lx,ly,lz,lw]=generate_chenstream_gen(x0,y0,z0,w0,KEY_STREAM_LENGTH,0);   
load func\Scramble_matrix.mat %dna_enc(img,img_dna,lx_rule);//对M*N的img进行DNA编码,输出为M*4N的img_dna,编码规则为rule
dat1    = dna_rules(imgs,lx(1),0);
%置乱 
dat2    = dna_rules(R,ly(1),0);
%扩散
dat3    = dna_xor(dat1,dat2,lz(1));
%解码
dat_enc = dna_rules(dat3,lw(1),1);
dat_enc = uint8(dat_enc);subplot(132);
imshow(dat_enc);
title(['加密图']);save func\encode.mat dat_enc      % %计算熵
% disp('熵:');
% S1 = func_shang(imgs)
% S2 = func_shang(dat_enc)% %相关性分析
% disp('相关性分析:');
% [R1,R2,R3]=func_xgx(imgs,Row,Col);
% [R1,R2,R3]
% [R1,R2,R3]=func_xgx(dat_enc,Row,Col);
% [R1,R2,R3]load func\encode.mat         
[Row,Col,k]       = size(dat_enc);                    
KEY_STREAM_LENGTH = 4*Row*Col;%generate_chenstream(x0,y0,z0,w0);//产生密钥流
x0=0.07628261275522;
y0=0.77258554999421;
z0=0.14153066287988;
w0=0.53152627474363;
[lx,ly,lz,lw]=generate_chenstream_gen(x0,y0,z0,w0,KEY_STREAM_LENGTH,1);
load func\Scramble_matrix.mat %dna_enc(img,img_dna,lw_rule);
dat_dec1 = dna_rules(dat_enc,lw(1),0);
%inv_diffusion(img_dna);
dat_dec2 = dna_rules(R,ly(1),0);
%inv_permu_trans(img_dna,ly);
dat_dec3 = dna_xor(dat_dec1,dat_dec2,lz(1));
%dna_dec(img,img_dna,lx_rule);
dat_dec  = dna_rules(dat_dec3,lx(1),1);
dat_dec  = uint8(dat_dec);subplot(133);
imshow(dat_dec);
dat_dec_=dat_dec;
title(['解密图']);
save func\right_mat.mat dat_decPSNR = psnr(uint8(imgs), uint8(dat_dec))
29_005_2m

4.本算法原理

        DNA算法的核心在于利用DNA分子的双螺旋结构和碱基配对规则来进行信息编码和解密。DNA分子由四种核苷酸组成:腺嘌呤(A)、胞嘧啶(C)、鸟嘌呤(G)和胸腺嘧啶(T)。这四种核苷酸通过碱基互补配对规则(A与T配对,C与G配对)形成稳定的双链结构。

基于 DNA 算法的遥感图像加密步骤如下:

图像预处理

将遥感图像转换为灰度图像,以减少数据量。

对灰度图像进行分块处理,将其划分为若干个大小相同的子块。

DNA 编码

采用合适的编码方法将每个子块的像素值转换为 DNA 序列。例如,对于一个 8 位灰度值,可以使用 2 位 DNA 编码,即 00(A)、01(C)、10(G)、11(T)。

对每个子块的 DNA 序列进行随机化处理,以增加加密的安全性。

DNA 操作

杂交操作:随机选择两个子块的 DNA 序列进行杂交,生成新的 DNA 序列。

酶切操作:利用特定的酶对杂交后的 DNA 序列进行切割。

连接操作:将切割后的 DNA 片段进行连接,形成新的 DNA 序列。

重复上述操作多次,以增加加密的复杂性。

密钥生成与管理

生成随机密钥,用于控制 DNA 操作的过程。密钥可以包括杂交的位置、酶切的位置和连接的方式等信息。

对密钥进行加密存储,以确保安全性。

加密图像生成

将经过多次 DNA 操作后的 DNA 序列转换回二进制数据,得到加密后的子块。
将加密后的子块组合起来,形成加密后的遥感图像。

       基于 DNA 算法的遥感图像加解密是一种具有创新性和潜力的方法。通过利用 DNA 分子的结构和特性,结合密码学的原理,可以实现对遥感图像的高效、安全加密和解密。然而,目前该方法还存在一些挑战,如 DNA 操作的准确性和稳定性、密钥管理的复杂性等。

5.完整程序

VVV

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

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

相关文章

MongoDB安装配置及配置和启动服务

MongoDB 安装配置 附:MongoDB官网下载地址: https://www.mongodb.com/download-center/community 注: 官网可以下载最新版的MongoDB安装包,有MSI安装版和ZIP安装版。我们课堂上使用4.4.4的ZIP安装版。安装版参考博客&#xff1…

jmeter中对于有中文内容的csv文件怎么保存

jmeter的功能很强大,但是细节处没把握好就得不到预期的结果。今天来讲讲有中文内容的csv文件的参数化使用中需要注意的事项。 对于有中文内容,涉及到编码格式,为了让jmeter能正确地读取csv文件中的中文,需要把文件转码为UTF-8BOM…

【服务器部署】Docker部署小程序

一、下载Docker 安装之前,一定查看是否安装docker,如果有,卸载老版本 我是虚拟机装的Centos7,linux 3.10 内核,docker官方说至少3.8以上,建议3.10以上(ubuntu下要linux内核3.8以上&#xff0c…

(JAVA)贪心算法、加权有向图与求得最短路径的基本论述与实现

1. 贪心算法 1.1 贪心算法的概述: 贪心算法是一种对某些求最优解问题的更简单、更迅速的设计技术。 贪心算法的特点是一步一步地进行,常以当前情况为基础根据某个优化测度作最优选择,而不考虑各种可能的整体情况,省去了为找最优…

LeetCode-3192 使二进制数组全部等于1的最少操作次数Ⅱ

今天的每日一题就是昨天的延伸,预判成功。 LeetCode-3191 使二进制数组全部等于1的最少操作次数-CSDN博客文章浏览阅读115次。如果数组第一个元素就是0,那么第一个元素是肯定要翻转的,而我们只有从索引0的位置开始翻转才可以翻转到第一个元素…

生成模型初认识

生成模型初认识 参考学习资料:李宏毅-机器学习 以下为课程过程中的简易笔记 生成模型 为什么要用生成模型?——创造力:同一个输入,产生不同的输出(distribution),有一定概率发生某种随机事件…

【天池比赛】【零基础入门金融风控 Task2赛题理解】【2.3.6】

【天池比赛】【零基础入门金融风控 Task2赛题理解】【2.3.1-2.3.5】 2.3.6 变量分布可视化 2.3.6.1 单一变量分布可视化 对于 pandas.core.series.Series 类型的变量: index:含义:它表示 Series 对象的索引,也就是每个数据点对…

MySQL-15.DQL-排序查询

一.DQL-排序查询 -- 排序查询 -- 1.根据入职时间,对员工进行升序排序 select * from tb_emp order by entrydate asc ;-- 2.根据入职时间,对员工进行降序排序 select * from tb_emp order by entrydate desc ;-- 3.根据 入职时间 对公司员工进行 升序排序…

人工神经网络(Artificial Neural Networks,简称ANNs)-激活函数-5

建议在阅读本文之前先了解神经网络。 在构建神经网络的过程中,您需要做出的选择之一是在隐藏层和网络的输出层使用什么是激活函数。本文讨论了神经网络中的激活函数。 目录 ​​​​​​​ 什么是激活函数?神经网络的元素为什么我们需要非线性激活函数?激活函数的变体 …

质因数分解

#include <stdio.h>int main() {long long x;while (scanf("%lld", &x) ! EOF) { // 读取输入直到文件结束if (x 0) break; // 如果输入为0则退出循环for (long long i 2; i * i < x; i) {while (x % i 0) { // 当x能被i整除时printf("%lld &q…

Leetcode 组合总和

这个Java代码实现的是LeetCode上的“组合总和”&#xff08;Combination Sum&#xff09;问题&#xff0c;采用的是回溯算法&#xff08;Backtracking&#xff09;。下面是详细的算法思想解释&#xff1a; 算法思想&#xff1a; 回溯算法的基本思路&#xff1a; 回溯算法是一种…

考研前所学的c语言01(2024/10/15)

1.变量由字母数字下划线组成&#xff0c;但是首字母只能是字母和下划线 2.基本函数01 3.基本代码02&#xff08;符号常量&#xff09; 4. A 是字符常量&#xff08;character constant&#xff09;。它表示单个字符&#xff0c;并且它的类型是 char&#xff0c;一个字节 "…

无极低码课程【redis windows下服务注册密码修改】

下载Windows版本的Redis linux环境 (自行下载) 1.打开官网https://redis.io/downloads/ windows环境 1.打开github https://github.com/microsoftarchive/redis/releases 然后选择你喜欢的版本zip或msi下载 2.这里下载zip版,解压后后,打开安装目录 3.双击redis-server…

LabVIEW智能螺杆空压机测试系统

基于LabVIEW软件开发的螺杆空压机测试系统利用虚拟仪器技术进行空压机的性能测试和监控。系统能够实现对螺杆空压机关键性能参数如压力、温度、流量、转速及功率的实时采集与分析&#xff0c;有效提高测试效率与准确性&#xff0c;同时减少人工操作&#xff0c;提升安全性。 项…

ZW3D二次开发_文件_修改文件引用

1.假设零件图纸与工程图图纸关联&#xff08;默认情况下在零件图纸中新建工程图图纸会自动关联&#xff09; 可以通过查询-》关联文件 查看关联的文件 此时可以查看到零件图纸所关联的工程图图纸 当工程图图纸名字修改后&#xff0c;上图文件列表中的工程图图纸名将对应不上&a…

时空数据时序预测模型: HA、VAR、GBRT、GCN、DCRNN、FCCF、ST-MGCN

HA (Historical Average) HA (Historical Average&#xff0c;历史平均模型) 是一种基础的时间序列预测方法&#xff0c;通常用于预测具有周期性或季节性规律的数据。它通过计算历史上同一时间段的平均值来预测未来值&#xff0c;假设数据会遵循某种周期性的变化模式。以下是对…

Java项目-基于Springboot的智慧养老平台项目(源码+文档).zip

作者&#xff1a;计算机学长阿伟 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、ElementUI等&#xff0c;“文末源码”。 开发运行环境 开发语言&#xff1a;Java数据库&#xff1a;MySQL技术&#xff1a;SpringBoot、SpringClud、Vue、Mybaits Plus、ELementUI工具&…

车辆管理新篇章:SpringBoot技术解析

2相关技术 2.1 MYSQL数据库 MySQL是一个真正的多用户、多线程SQL数据库服务器。 是基于SQL的客户/服务器模式的关系数据库管理系统&#xff0c;它的有点有有功能强大、使用简单、管理方便、安全可靠性高、运行速度快、多线程、跨平台性、完全网络化、稳定性等&#xff0c;非常…

【计算机网络 - 基础问题】每日 3 题(四十七)

✍个人博客&#xff1a;https://blog.csdn.net/Newin2020?typeblog &#x1f4e3;专栏地址&#xff1a;http://t.csdnimg.cn/fYaBd &#x1f4da;专栏简介&#xff1a;在这个专栏中&#xff0c;我将会分享 C 面试中常见的面试题给大家~ ❤️如果有收获的话&#xff0c;欢迎点赞…

Oracle数据库系统表空间过大,清理SYSTEM、SYSAUX表空间

一.前言 在oracle数据库中&#xff0c;system为系统表空间&#xff0c;存放着一些我们经常用到的系统表和视图&#xff0c;sysaux为辅助表空间&#xff0c;辅助着系统表空间。这两个表空间不宜添加数据文件&#xff0c;会使系统表空间过于臃肿&#xff0c;从而影响数据库的使用…