Why double(img) / max(img(:)) ???

1 visualizzazione (ultimi 30 giorni)
Aude Rapet
Aude Rapet il 21 Ott 2016
Commentato: Aude Rapet il 21 Ott 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!!!

Risposta accettata

Image Analyst
Image Analyst il 21 Ott 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.
  1 Commento
Aude Rapet
Aude Rapet il 21 Ott 2016
Thank you very much Image Analyst!!

Accedi per commentare.

Più risposte (0)

Categorie

Scopri di più su Convert Image Type in Help Center e File Exchange

Tag

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by