本章主要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所示
原图像5-1 图像5-2
解密功能测试
本节为加密功能测试,输入一个加密后如图像5-3所示,输出一个解密图像如图像5-4所示
图像5-3 图像5-4
---恢复内容结束---