根据提示,补充代码,并在图片中嵌入秘密信息。 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:5 %输入代码 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 22:05:26 浏览: 105
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 %输入代码 b((i-1)*56+j)=bitget(wi((i-1)*8+j),1); end end k=1; i=1; for i=1:count wherestart=(i-1)*56; for j=1:8 l(i,j)=bin2dec(num2str(b(wherestart+(j-1)*7+2:wherestart+j*7))); end end %把每个像素值的高7位取出,顺序为2、3、4、5、6、7、8 modcount=1; for i=1:count for j=1:8 for k=1:7 l(i,j)=bitset(l(i,j),k,b(modcount)); modcount=modcount+1; end end end %把所有的56位的值按照模2加得到一个56位长度的Checksum值 z=sum(l,1); for i=1:5 lbit=dec2bin(z(i),7); if mod(sum(lbit=='1'),2)==0 z(i,8)=1; else z(i,8)=0; end 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('添加水印信息的图像');
阅读全文