Error using imshow function
10 Ansichten (letzte 30 Tage)
Ältere Kommentare anzeigen
the error I get is
Error using imageDisplayValidateParams
Expected input number 2, [LOW HIGH], to be non-NaN.
Error in checkDisplayRange (line 11)
validateattributes(display_range, {'numeric'},...
Error in imageDisplayValidateParams (line 57)
common_args.DisplayRange = checkDisplayRange(common_args.DisplayRange,mfilename);
Error in imageDisplayParseInputs (line 79)
common_args = imageDisplayValidateParams(common_args);
Error in imshow (line 198)
[common_args,specific_args] = ...
Error in FOA_good4 (line 125)
imshow(message,[]);
The code is
function FOA_DWT=FOA_good4(oo,pp)
X_axis=10*rand();
Y_axis=10*rand();
maxgen=oo;
sizepop=pp;
for ii=1:sizepop
disp('smelli');disp(ii);
X_F(ii)=X_axis+2*rand()-1;
Y_F(ii)=Y_axis+2*rand()-1;
D(ii)=(X_F(ii)^2+Y_F(ii)^2)^0.5;
S(ii)=1/D(ii);
disp(S(ii));
I = imread('lena512.bmp');
figure(1);
subplot(221);imshow(I);title('yuanshituxiang');
w=imread('22.bmp');
subplot(222);
imshow(w);title('shuiyintuxiang');
w1=w;
xx=1;yy=1;
T=10;m=90;
tt=xx;xx=xx+yy;yy=tt+2*yy;
while xx~=1&&yy~=1;
T=T+1;
if xx>m
xx=mod(xx,m);
end
if yy>m
yy=mod(yy,m);
end
tt=xx;xx=xx+yy;yy=tt+2*yy;
end
iTimes=20;
message=w1;
Mm=size(message,1);
Nm=size(message,2);
if Mm~=Nm
error('shuiyinbixuweifangzhen');
end
if Mm~=64
error('error');
end
tempImg=message;
for n=1:iTimes
for u=1:Mm
for v=1:Nm
temp=tempImg(u,v);
ax=mod((u-1)+(v-1),Mm)+1;
ay=mod((u-1)+2*(v-1),Nm)+1;
outImg(ax,ay)=temp;
end
end
tempImg=outImg;
message=tempImg;
w1=message;
end
watermark_zl=outImg;
imwrite(watermark_zl,'watermark_zl.bmp');
[cA1,cH1,cV1,cD1]=dwt2(I,'haar');
[cA2,cH2,cV2,cD2]=dwt2(cA1,'haar');
[cA3,cH3,cV3,cD3]=dwt2(cA2,'haar');
[mm1,nn1]=size(cA3);
[U,S,V]=svd(cA3);
[Uw,Sw,Vw]=svd(double(w1));
PCw=Uw*Sw;
Temp=S+S(ii)*PCw;
CW=U*Temp*V';
X3=idwt2(CW,cH3,cV3,cD3,'haar');
X2=idwt2(X3,cH2,cV2,cD2,'haar');
Y=idwt2(X2,cH1,cV1,cD1,'haar');
watermarked=Y;
A=uint8(watermarked);
imwrite(A,'dwt_svd_watermarked.bmp','bmp');
figure(1)
subplot(2,2,3)
imshow(watermarked,[]);
title('qiantushuiyinhoutuxiang')
[ccA1,ccH1,ccV1,ccD1]=dwt2(watermarked,'haar');
[ccA2,ccH2,ccV2,ccD2]=dwt2(ccA1,'haar');
[ccA3,ccH3,ccV3,ccD3]=dwt2(ccA2,'haar');
[cA1,cH1,cV1,cD1]=dwt2(I,'haar');
[cA2,cH2,cV2,cD2]=dwt2(cA1,'haar');
[cA3,cH3,cV3,cD3]=dwt2(cA2,'haar');
WNN=zeros(mm1,nn1);
WN=zeros(mm1,nn1);
WN=(U'*(ccA3-cA3)*V)/S(ii);
WNN=WN*Vw';
tempImg=WNN;
message_arnold=tempImg;
iTimes1=48-iTimes;
Mo=size(outImg,1);
No=size(outImg,2);
for n=1:iTimes1
for u=1:Mo
for v=1:No
temp1=tempImg(u,v);
bx=mod((u-1)+(v-1),Mo)+1;
by=mod((u-1)+2*(v-1),No)+1;
outImg1(bx,by)=temp1;
end
end
tempImg=outImg1;
end
message=outImg1;
figure(1);
subplot(2,2,4)
imshow(message,[]);
title('tiqushuiyin');
watermark_ok=message;
imwrite(watermark_ok,'watermark_ok.bmp','bmp');
PSNR=psnr(I,watermarked); disp('PSNR:');disp(PSNR)
NC=nc(WNN,watermark_zl);disp('wugongji:');disp(NC)
0 Kommentare
Antworten (1)
Image Analyst
am 29 Apr. 2015
It seems like you must have a nan in your message array somewhere. Get rid of them by setting them to zero:
message(isnan(message) = 0; % Set NaN's to 0.
imshow(message, []);
0 Kommentare
Siehe auch
Kategorien
Mehr zu Subplots finden Sie in Help Center und File Exchange
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!