用java实现图像的置乱加密,基于Amold置乱的彩色图像加密算法

本章主要Arnold变换是一种二维映射并且具有可逆的特点,Arnold变换是V.J.Arnold 在研究遍历理论时提出的正方形区域的一种变换,该变换的特点是变换前后的像素位置虽然变乱,但是整个图像的面积不变,Arnold变换具有周期性即迭代到一定的次数能够变换为原图。Arnold 变换只能作用在方形图像上,在Arnold变换中和分别是变换前后的像素值,和在坐标图像中可表示为该图像的第行和第列。表示的是该图像在第行和第列的像素值。迭代次数增加会加深置乱程度,继续迭代达到周期时又可以变回原图。周期T为置乱的新图迭代为原图的最少次数。 具体的各像素值位置置乱公式如公式(2-1)、(2-2)所示:

x'=(5x+2y)mod(n)      (2-1)

y'=(7x+3y)mod(n)      (2-2)

其中,与表示置乱后的像素值的行列位置,与表示原始图像的像素值的行列位置,表示图像的行数或列数

具体功能如下:经过Arnold使变的“混乱不堪”,由于Arnold变换的周期性,继续使用Arnold变换,实现重现图像。利用Arnold变换的这种特性,可实现图像的加密与解密。

理想状态经过Arnold使变的“混乱不堪”,让人眼看不出图像的真实内容。解密后图像又不失真。

加密功能源码

A=imread('11','jpg');%读取图像11,jpg

C=imread('11','jpg');

C=rgb2gray(C);

A=rgb2gray(A);

imshow(A);for k=1:50

for x=1:508

for y=1:508x1=x+y;

y1=x+2*y;if(x1>508)

x1=mod(x1,508);

endif(y1>508)

y1=mod(y1,508);

endif x1==0x1=508;

endif y1==0y1=508;

end

B(x1,y1)=A(x,y);

end

end

A=B;if(A==C)

d=k;

end

end

imshow(B);

imwrite(B,'111.png')

解密功能源码

clear

A=imread('111.png');for k=1:50

for x=1:508

for y=1:508x1=2*x-y;

y1=y-x;if(x1>508)

x1=mod(x1,508);

endif(y1>508)

y1=mod(y1,508);

endif x1<0x1=x1+508;

endif y1<0y1=y1+508;

endif x1==0x1=508;

endif y1==0y1=508;

end

B(x1,y1)=A(x,y);

end

end

A=B;

end

imshow(B);

imwrite(B,'123.png');

加密功能测试

本节为加密功能测试,输入一个明文图像如原图像5-1所示,输出一个置乱后图像如图像5-2所示

705afd62cc3a1ac957a9de7ce4cdc942.png                                       

54e7a1b8d6842dc1978c80987da51ccc.png

原图像5-1                                                                   图像5-2

解密功能测试

本节为加密功能测试,输入一个加密后如图像5-3所示,输出一个解密图像如图像5-4所示

6768ed328c5d07d7742bf5f5ffe9b074.png                                                      

5cd5af21193b7f492c26f6de6cc5a600.png

图像5-3                                                                                             图像5-4

---恢复内容结束---

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值