Why double(img) / max(img(:)) ???
1 Ansicht (letzte 30 Tage)
Ältere Kommentare anzeigen
Aude Rapet
am 21 Okt. 2016
Kommentiert: Aude Rapet
am 21 Okt. 2016
Hi, I am beginner in Matlab and I have to understand a code.
I don't understand this line : im = double(imread('control_dic.tif'))/max(max(double(imread('control_dic.tif'))))
I do understand that double(imread('control_dic.tif')) converts my image to the variable double but I don't understand why max(max(double(imread('control_dic.tif')
Thank you!!!
0 Kommentare
Akzeptierte Antwort
Image Analyst
am 21 Okt. 2016
imread() reads in the image. It seems to be a uint8 image. They didn't have to do it twice, but they did. Anyway they then wanted to convert it to the range 0-1 like mat2gray() or im2double() would do but they decided to do it manually. The called max() twice because the first call to max() returns the maxes of the columns, not the whole image. Doing it twice gets the overall max. It appears to be the code of someone with not much more experience than you. You can do it like most people would do it like this:
grayImage = imread('control_dic.tif');
im = im2double(grayImage); % Only if you NEED it in the range 0-1 (which I virtually never do).
which reads in the image only once, and is simpler, and thus easier to understand, maintain, and share with others.
Weitere Antworten (0)
Siehe auch
Kategorien
Mehr zu Convert Image Type finden Sie in Help Center und File Exchange
Produkte
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!