基本的な画像圧縮を行っています。画像で 8x8 ウィンドウを取得し、そのウィンドウをさらに 2x2 に分割してから、それらの平均値を見つける必要があります。これを行った後、この平均値マトリックスをしきい値平均 (画像全体の平均値またはその 8x8 ウィンドウの平均値) と比較する必要があります。要素がしきい値以上の場合、0 でない場合は 1 を割り当てる必要があります。この目的のために、以下のコードを記述しました。しかし、私は最初のステップ自体で立ち往生しています。この行に「インデックスがマトリックスの次元を超えています」というエラーが表示されます。P=J(i:(i+7),j:(j+7));
助けてください。最終的なマトリックスに 0 と 1 を比較して割り当てる方法がわかりません。私は試したX=bsxfun(@ge,M,thr)
..それは動作していません..そして私のコードは大きいようです..私はそれを書く方法でやっていますか?提案してください。もっと簡単にできると思います。私はmatlabを初めて使用します。学習を手伝ってください。これが私のコードです:
I=imread('C:\Users\Prem\Documents\MATLAB\mandrill.jpg');
G=rgb2gray(I);
J=imresize(G,[256 256]);
thr=mean(J(:));
[m,n]=size(J); % Reading the size of the image
for i=1:m
for j=1:n
P=J(i:(i+7),j:(j+7)); % Reading 8x8 window
% Sub dividing the 8 x 8 window into four 4x4 sub windows
tl = P(1:4, 1:4); % top left sub-window
tr = P(1:4, 5:8); % top right sub-window
bl = P(5:8, 1:4); % bottom left sub-window
br = P(5:8, 5:8); % bottom right sub-window
% Sub dividing the 4 x 4 window into four 2x2 sub windows
newtl_1 = tl(1:2, 1:2); % top left sub-window
newtr_1 = tl(1:2, 3:4); % top right sub-window
newbl_1 = tl(3:4, 1:2); % bottom left sub-window
newbr_1 = tl(3:4, 3:4); % bottom right sub-window
% Sub dividing the 4 x 4 window into four 2x2 sub windows
newtl_2 = tr(1:2, 1:2); % top left sub-window
newtr_2 = tr(1:2, 3:4); % top right sub-window
newbl_2 = tr(3:4, 1:2); % bottom left sub-window
newbr_2 = tr(3:4, 3:4); % bottom right sub-window
% Sub dividing the 4 x 4 window into four 2x2 sub windows
newtl_3 = bl(1:2, 1:2); % top left sub-window
newtr_3 = bl(1:2, 3:4); % top right sub-window
newbl_3 = bl(3:4, 1:2); % bottom left sub-window
newbr_3 = bl(3:4, 3:4); % bottom right sub-window
% Sub dividing the 4 x 4 window into four 2x2 sub windows
newtl_4 = br(1:2, 1:2); % top left sub-window
newtr_4 = br(1:2, 3:4); % top right sub-window
newbl_4 = br(3:4, 1:2); % bottom left sub-window
newbr_4 = br(3:4, 3:4); % bottom right sub-window
% median values of the four sub windows
m1=mean(newtl_1(:));
m2=mean(newtr_1(:));
m3=mean(newbl_1(:));
m4=mean(newbr_1(:));
% median values of the four sub windows
m5=mean(newtl_2(:));
m6=mean(newtr_2(:));
m7=mean(newbl_2(:));
m8=mean(newbr_2(:));
% median values of the four sub windows
m9=mean(newtl_3(:));
m10=mean(newtr_3(:));
m11=mean(newbl_3(:));
m12=mean(newbr_3(:));
% median values of the four sub windows
m13=mean(newtl_4(:));
m14=mean(newtr_4(:));
m15=mean(newbl_4(:));
m16=mean(newbr_4(:));
M=[m1 m2 m3 m4; m5 m6 m7 m8; m9 m10 m11 m12; m13 m14 m15 m16];
%X=bsxfun(@ge,M,thr)
end
end
imshow(M)