Если я удалю uint8
, когда я даю матрице B
ее размер, я получаю результат, который затеняется красной плоскостью. Я также добавил []
в imshow(B, [])
, чтобы решить проблему вывода всего темного цвета, но это не помогает.
function myThirdAssignment(I,WindowSize,K0,K1,K2)
%if size(I,3)==1
%[rows, columns, numberOfColorChannels] = size(I);
%elseif size(I,3)==3
x= im2double(imread(I));
%gray1=rgb2gray(x);
%[r, c, numberOfColorChannels] = size(gray1);
%end
if nargin==1 % If number of arguments of the function are equal to 1 then use
% the following default values for K0,K1,K2, & Window size.
K0= 0.5;
K1= 1;
K2= 0.5;
WindowSize=3;
end
figure(1); imshow(x); title('ORIGINAL IMAGE');
imwrite(x,'OriginalImage.bmp.bmp'); %writing data of original image in to current directory.
% GIVING B THE SAME ROWS AND COLUMS AS THE ORIGINAL IMAGE
[rows, columns, numberOfColorChannels] = size(x);
B = zeros(rows, columns, numberOfColorChannels, 'uint8');
% CALCULATING CEIL & FLOOR VALUES TO MAKE PROGRAM MORE GENERAL
p= ceil((WindowSize / 2)); %3/2= 1.5=2
s= floor((WindowSize / 2)); %3/2=1.5=1
B(i,j)= 2*x(i,j);
else
B(i,j)= x(i,j);
end
%--------------------------------------------
end
end
%RGB = cat(3, B, B, B);
figure(2);imshow(B, []); title('IMAGE AFTER LOCAL HISTOGRAM EQUALIZATION');
imwrite(B,'enhancedImage.jpeg.jpeg'); %writing data of enhanced image in to current directory
end
Я использовал это изображение как ввод.