假如你是一个工程师 完善下面的代码 符合下列要求 关于图片隐写-完全脆弱图像水印 嵌入秘密信息 clc; clear; oi=imread('lena.bmp'); [orow,ocol]=size(oi); pixelcount= ;%计算总像素个数 count= ;%总像素分为8个一组 wi=oi(:); for i=1:count%用于存放56比特 for j=1:56 %输入代码 end end k=1; i=1; for i=1:count wherestart=8*(i-1); for j=1:8 b(i,j)=wi(wherestart+j); end end %把每个像素值的高7位取出,顺序为2、3、4、5、6、7、8 modcount=1; for i=1:count for j=1:8 for k=1:7 %输入代码 end end end %把所有的56位的值按照模2加得到一个56位长度的Checksum值 z=sum(l,1); for i=1:56 %输入代码 end %从图像中随机选取56个像素点 key=123%用户选取随机嵌入的位置 z=uint8(z); [row,col]=randselect(oi,56,key); for k=1:56 temp(k)=oi(row(k),col(k)); temp1=str2bit(temp(k)); temp1(8)=z(k); oi(row(k),col(k))=bit2str(temp1); end imwrite(oi,'watermarked.bmp','bmp'); figure; subplot(1,2,1);imshow('lena.bmp');title('原始图像'); subplot(1,2,2);imshow('watermarked.bmp');title('添加水印信息的图像');
时间: 2023-12-10 16:05:26 浏览: 103
完整版 可直接运行 MATLAB DCT程序 图片添加水印 水印添加 图片水印提取源码 源程序代码 含原图和水印图.rar
5星 · 资源好评率100%
clc;
clear;
oi=imread('lena.bmp');
[orow,ocol]=size(oi);
pixelcount=orow*ocol;%计算总像素个数
count=floor(pixelcount/8);%总像素分为8个一组
wi=oi(:);
for i=1:count%用于存放56比特
for j=1:56
%输入代码:将秘密信息嵌入像素值的最低位
%wi((i-1)*8+j)=bitset(wi((i-1)*8+j),1,secret_info(j));
end
end
k=1;
i=1;
for i=1:count
wherestart=8*(i-1);
for j=1:8
b(i,j)=bitget(wi(wherestart+j),1);%把每个像素值的最低位取出
end
end
%把所有的56位的值按照模2加得到一个56位长度的Checksum值
l=sum(b,1);
for i=1:56
%输入代码:将Checksum值的每一位按照模2加的方式计算出来
%l(i)=mod(sum(b(:,i)),2);
end
%从图像中随机选取56个像素点
key=123;%用户选取随机嵌入的位置
z=uint8(l);
[row,col]=randselect(oi,56,key);
for k=1:56
temp=oi(row(k),col(k));
temp1=bitget(temp,1, 'uint8');
temp1(8)=z(k);
oi(row(k),col(k))=bitset(temp,1,temp1);%将Checksum值的每一位嵌入随机选取的像素点中
end
imwrite(oi,'watermarked.bmp','bmp');
figure;
subplot(1,2,1);imshow('lena.bmp');title('原始图像');
subplot(1,2,2);imshow('watermarked.bmp');title('添加水印信息的图像');
阅读全文