matlab学习(一)(3.26-4.1)

一.信息隐藏的概念

信息隐藏是利用一些技术,使得要隐藏的信息是用眼睛看不出变化的。它将秘密信息隐藏在可公开的媒体信息中,使人们凭直观的视觉和听觉难以察觉基存在。

二.空域信息隐藏技术

空域信息隐藏是将信息直接嵌入到图像的像素值中的技术。主要应用于数字图像。

2.1.优点:

简单:实现起来相对简单,不需要复杂的数学变换。

隐蔽性:信息嵌入在图像中,不容易被察觉。

2.2.缺点:

易受攻击:空域信息隐藏容易受到各种攻击,例如压缩、裁剪、滤波等。

图像质量下降:嵌入信息可能导致图像质量的损失。(失真)

隐藏容量小

三.频域信息隐藏技术

频域信息隐藏是将信息嵌入到图像的频域系数中的技术。(如离散余弦变换或小波变换)将图像从空域转换到频域,然后在频域中进行信息隐藏**。**

3.1.优点:

安全性较高(更难以察觉):频域信息隐藏相对于空域更难被攻击,因为攻击者不容易直接操作频域系数。

隐藏效果较好:频域中的某些频率成分更适合隐藏信息。

隐藏容量大

3.2.缺点

比较复杂:频域变换和信息嵌入需要更复杂的数学操作。

图像处理质量影响:频域信息隐藏可能会影响图像的质量,尤其是在高频区域。

四.Arnold变换

4.1(test1)图片是方形的,在matlab(2018a)中实现,代码实现如下

function img = arnold(img, n)
    [x, y] = size(img);
    img = double(img);
    for j = 1:n
        temp = zeros(x);
        for i = 1:x
            for j = 1:y
                p = [i-1; j-1];
                p = mod([1, 1; 1, 2] * p, x);
                temp(i, j) = img(p(1)+1, p(2)+1);
            end
        end
        img = temp;
    end
    img = uint8(img);
end
function main()
    img = imread('test.png');
    img_transformed = arnold(img, 1);
    imshow(img_transformed);
    imwrite(img_transformed, 'test_transformed.png');
end

4.2 (test2)彩色图置换代码如下

img=imread('test.jpeg');%读取图片,根据Arnold变换的条件,图像必须是正方形
mysize=size(img);%当只有一个输出参数时,返回一个行向量,该行向量的第一个元素时矩阵的行数,第二个元素是矩阵的列数。
if numel(mysize)>2%如果输入是彩色图像
   img=rgb2gray(img); %将彩色到灰度图像的转换
   fprintf("图像为彩色图\n");  %其中\r或者\n表示换行
end
imshow(img,[])
title('彩色原图的灰度图');

figure(2)
imhist(img)	%原图的直方图统计

%如果输入的不是正方形图像,则打印如下
[h,w]=size(img);
if h>w
    img = imresize(img, [w w]);
    fprintf("图像长宽不一样,图像可能失真\r");
end
if h<w
    img = imresize(img, [h h]);  
    fprintf("图像长宽不一样,图像可能失真");
end
[h,w]=size(img);

%置乱与逆置乱必须采用共同参数的时候,就相当于密码,才能解密,让图像复原
n=10;%迭代次数
a=1;b=1;
N=h;%N代表图像宽高,宽高要一样

%置乱操作
imgnnn=zeros(h,w);
for i=1:n
    for y=1:h
        for x=1:w           
            xx=mod((x-1)+b*(y-1),N)+1;   %mod取余操作,(a,b)就是a除以b的余数
            yy=mod(a*(x-1)+(a*b+1)*(y-1),N)+1;        
            imgnnn(yy,xx)=img(y,x);                
        end
    end
    img=imgnnn;
end
imgnnn = uint8(imgnnn);

figure(3)
imshow(img,[])%置乱后的图片
title('置乱后的图片 a=1;b=1,n=10');
imwrite (imgnnn,'置乱后的图片.bmp');  %生成图像保存功能

%逆置乱复原
img2=imread('置乱后的图片.bmp');%读取置乱图片
for i=1:n
    for y=1:h
        for x=1:w            
            xx=mod((a*b+1)*(x-1)-b*(y-1),N)+1;%matlab索引中不能是0,要从1开始
            yy=mod(-a*(x-1)+(y-1),N)+1  ;        
            imgnnn(yy,xx)=img2(y,x);                   
        end
    end
    img2=imgnnn;
end
imgnnn = uint8(imgnnn);
figure(4)
imshow(imgnnn,[])
title('逆置乱的复原图片');
imwrite(imgnnn,'逆置乱的复原图片.bmp');%生成图像保存功能

五.PSNR和NC

PSNR(峰值信噪比)

PSNR值越高,表示重建质量越好。

NC(Normalized Compression Distance,标准化压缩距离)

当NC值为1时,表示两个数据序列之间的压缩距离非常小,即它们非常相似。

相关推荐
HC1825808583223 分钟前
“倒时差”用英语怎么说?生活英语口语学习柯桥外语培训
学习·生活
学习路上_write28 分钟前
FPGA/Verilog,Quartus环境下if-else语句和case语句RT视图对比/学习记录
单片机·嵌入式硬件·qt·学习·fpga开发·github·硬件工程
非概念33 分钟前
stm32学习笔记----51单片机和stm32单片机的区别
笔记·stm32·单片机·学习·51单片机
远望清一色38 分钟前
基于MATLAB边缘检测博文
开发语言·算法·matlab
无敌最俊朗@2 小时前
stm32学习之路——八种GPIO口工作模式
c语言·stm32·单片机·学习
远望清一色2 小时前
基于MATLAB的图片中文字的提取及识别
算法·matlab
EterNity_TiMe_2 小时前
【论文复现】STM32设计的物联网智能鱼缸
stm32·单片机·嵌入式硬件·物联网·学习·性能优化
L_cl3 小时前
Python学习从0到1 day28 Python 高阶技巧 ⑤ 多线程
学习
前端SkyRain3 小时前
后端Node学习项目-用户管理-增删改查
后端·学习·node.js
提笔惊蚂蚁3 小时前
结构化(经典)软件开发方法: 需求分析阶段+设计阶段
后端·学习·需求分析