155GIT1 / 10. cvičení: Porovnání verzí

Z GeoWikiCZ
(Není zobrazeno 28 mezilehlých verzí od 2 dalších uživatelů.)
Řádek 4: Řádek 4:
== Náplň cvičení ==
== Náplň cvičení ==


# načtení obrázku <code>imread(), imshow()</code>
# načtení obrazových dat <code>imread(), imshow()</code>
# základní informace <code>imfinfo()</code>
# základní informace <code>imfinfo()</code>
# binary, indexed, greyscale a truecolor
# binary, indexed, grayscale a truecolor
# příkazy <code>image()</code>, <code>imagesc()</code>, [http://geo.fsv.cvut.cz/user/gin/git1/matlab/matlab.pdf#119 barevné schéma] <code>colormap()</code>
# příkazy <code>image()</code>, <code>imagesc()</code>, [http://geo.fsv.cvut.cz/user/gin/git1/matlab/matlab.pdf#page=127 barevné schéma] <code>colormap()</code>
# převod do odstínů šedi <code>rgb2ind -> ind2gray</code>
# převod do odstínů šedi <code>rgb2ind -> ind2gray</code>
# rozklad obrázku na jednotlivé vrstvy [http://upload.wikimedia.org/wikipedia/commons/3/33/Beyoglu_4671_tricolor.png RGB]
# rozklad obrázku na jednotlivé vrstvy [http://upload.wikimedia.org/wikipedia/commons/3/33/Beyoglu_4671_tricolor.png RGB]
Řádek 14: Řádek 14:


=== Načtení obrázku do matice ===
=== Načtení obrázku do matice ===
Data: https://upload.wikimedia.org/wikipedia/commons/a/ae/Aristotle_Altemps_Inv8575.jpg


<source lang=octave>
<source lang=octave>
% načtení z URL
% načtení z URL
obr1 = imread('http://upload.wikimedia.org/wikipedia/commons/a/ae/Aristotle_Altemps_Inv8575.jpg');
jmeno1 = 'Aristotle_Altemps_Inv8575.jpg';
obr1 = imread(jmeno1);
size(obr1)
size(obr1)
% zobrazení obrázku v grafickém okně
% zobrazení obrázku v grafickém okně
imshow(obr1)
imshow(obr1)
% zobrazení metadat
% zobrazení metadat
imfinfo(url1)
imfinfo(jmeno1)
</source>
 
''Poznámka:'' Matlab i novější verze Octave umí číst data i přes protokol HTTP/HTTPS:
 
<source lang=octave>
url1 = 'https://upload.wikimedia.org/wikipedia/commons/a/ae/Aristotle_Altemps_Inv8575.jpg';
obr1 = imread(url1);
</source>
</source>


Řádek 30: Řádek 40:
obr2 = rand(100, 100) * 255;
obr2 = rand(100, 100) * 255;
image(obr2)
image(obr2)
% škálovat data, tak aby bylo využito célé barevné schéma
colormap('gray')
 
% škálovat data tak, aby bylo využito celé barevné schéma
figure()
imagesc(obr2)
colormap('gray')
 
figure()
figure()
imagesc([0 50], [0 50], obr2)
imagesc([0 50], [0 50], obr2)
% nastavit vlastní barevné schéma
colormap('gray')
colormap('gray')
</source>
</source>


=== Typy obrazových dat ===
=== Typy obrazových dat ===
 
Jednotlivé obrázky ke stažení do pracovního adresáře z následujících url:
* obrázek ve stupních šedi: [http://upload.wikimedia.org/wikipedia/commons/f/fa/Grayscale_8bits_palette_sample_image.png příklad]
* indexovaný obrázek: [http://upload.wikimedia.org/wikipedia/commons/7/7c/Adaptative_8bits_palette_sample_image.png příklad]
* RGB-obrázek: [https://upload.wikimedia.org/wikipedia/commons/b/bc/Parrot.red.macaw.1.arp.750pix.jpg příklad]
<source lang=octave>
<source lang=octave>
% binární rastr
% binární rastr
obr3 = round(rand(25, 25));
obr3 = round(rand(25, 25));
ob = imagesc(obr3) % vs. image()
ob = imagesc(obr3) % vs. image(), viz níže
% obr3_1 = 255 * round(rand(25, 25));
% image(obr3)
% image(obr3_1)
colormap('gray')
colormap('gray')
% rastr v odstínech šedi
% rastr v odstínech šedi
obr4 = imread('http://upload.wikimedia.org/wikipedia/commons/f/fa/Grayscale_8bits_palette_sample_image.png');
jmeno4 = 'Grayscale_8bits_palette_sample_image.png';
obr4 = imread(jmeno4);
size(obr4)
size(obr4)
% indexovaný rastr
% indexovaný rastr
obr5 = imread('http://upload.wikimedia.org/wikipedia/commons/7/7c/Adaptative_8bits_palette_sample_image.png');
jmeno5 = 'Adaptative_8bits_palette_sample_image.png';
obr5 = imread(jmeno5);
size(obr5)
size(obr5)
[obr5, cmap5] = imread('http://upload.wikimedia.org/wikipedia/commons/7/7c/Adaptative_8bits_palette_sample_image.png');
[obr5, cmap5] = imread(jmeno5);
size(cmap5)
size(cmap5)
imshow(obr5)
imshow(obr5)
imshow(obr5, cmap5)
imshow(obr5, cmap5)
% true color (RGB)
% true color (RGB)
obr6 = imread('http://upload.wikimedia.org/wikipedia/commons/6/69/Truecolor.png');
jmeno6 = 'Parrot.red.macaw.1.arp.750pix.jpg';
obr6 = imread(jmeno6);
size(obr6)
size(obr6)
imshow(obr6)
</source>
</source>


Řádek 62: Řádek 88:


<source lang=octave>
<source lang=octave>
% RGB na indexovaný
% RGB na indexovaný rastr
% Matlab
[obr6_i, cmap6] = rgb2ind(obr6, 256);
[obr6_i, cmap6] = rgb2ind(obr6, 256);
% Octave
[obr6_i, cmap6] = rgb2ind(obr6);
size(obr6)
size(obr6)
size(obr6_i)
size(obr6_i)
size(cmap6)
size(cmap6)
% indexovaný na odstíny šedi
% indexovaný rastr na odstíny šedi
obr5_g = ind2gray(obr5, cmap5);
obr5_g = ind2gray(obr5, cmap5);
imshow(obr5, cmap5)
imshow(obr5, cmap5)
figure()
figure()
imshow(obr5_g)
imshow(obr5_g)
 
% formalne existuji i funkce pro opacny prevod, napr.
% odstíny šedi na indexovaný rastr
[obr5_i, cmap5_i] = gray2ind(obr5_g);
figure()
imshow(obr5_i, cmap5_i)
</source>
</source>


Řádek 109: Řádek 142:
imshow(mat2gray(B(:,:,3), [0, 255]))
imshow(mat2gray(B(:,:,3), [0, 255]))
</source>
</source>
''Poznámka pro Octave:'' Funkce <tt>mat2gray</tt> je součástí balíčku "image", který lze doinstalovat příkazem: <tt>pkg install image</tt>.

Verze z 24. 4. 2019, 08:17

Obrazová data

Náplň cvičení

  1. načtení obrazových dat imread(), imshow()
  2. základní informace imfinfo()
  3. binary, indexed, grayscale a truecolor
  4. příkazy image(), imagesc(), barevné schéma colormap()
  5. převod do odstínů šedi rgb2ind -> ind2gray
  6. rozklad obrázku na jednotlivé vrstvy RGB

Ukázky

Načtení obrázku do matice

Data: https://upload.wikimedia.org/wikipedia/commons/a/ae/Aristotle_Altemps_Inv8575.jpg

% načtení z URL
jmeno1 = 'Aristotle_Altemps_Inv8575.jpg';
obr1 = imread(jmeno1);
size(obr1)
% zobrazení obrázku v grafickém okně
imshow(obr1)
% zobrazení metadat
imfinfo(jmeno1)

Poznámka: Matlab i novější verze Octave umí číst data i přes protokol HTTP/HTTPS:

url1 = 'https://upload.wikimedia.org/wikipedia/commons/a/ae/Aristotle_Altemps_Inv8575.jpg';
obr1 = imread(url1);

Zobrazení matice jako obrázku

obr2 = rand(100, 100) * 255;
image(obr2)
colormap('gray')

% škálovat data tak, aby bylo využito celé barevné schéma
figure()
imagesc(obr2)
colormap('gray')

figure()
imagesc([0 50], [0 50], obr2)
colormap('gray')

Typy obrazových dat

Jednotlivé obrázky ke stažení do pracovního adresáře z následujících url:

% binární rastr
obr3 = round(rand(25, 25));
ob = imagesc(obr3) % vs. image(), viz níže
% obr3_1 = 255 * round(rand(25, 25));
% image(obr3)
% image(obr3_1)
colormap('gray')
% rastr v odstínech šedi
jmeno4 = 'Grayscale_8bits_palette_sample_image.png';
obr4 = imread(jmeno4);
size(obr4)
% indexovaný rastr
jmeno5 = 'Adaptative_8bits_palette_sample_image.png';
obr5 = imread(jmeno5);
size(obr5)
[obr5, cmap5] = imread(jmeno5);
size(cmap5)
imshow(obr5)
imshow(obr5, cmap5)
% true color (RGB)
jmeno6 = 'Parrot.red.macaw.1.arp.750pix.jpg';
obr6 = imread(jmeno6);
size(obr6)
imshow(obr6)

Konverze typů obrazových dat

% RGB na indexovaný rastr
% Matlab
[obr6_i, cmap6] = rgb2ind(obr6, 256);
% Octave
[obr6_i, cmap6] = rgb2ind(obr6);
size(obr6)
size(obr6_i)
size(cmap6)
% indexovaný rastr na odstíny šedi
obr5_g = ind2gray(obr5, cmap5);
imshow(obr5, cmap5)
figure()
imshow(obr5_g)
% formalne existuji i funkce pro opacny prevod, napr.
% odstíny šedi na indexovaný rastr
[obr5_i, cmap5_i] = gray2ind(obr5_g);
figure()
imshow(obr5_i, cmap5_i)

Rozklad na vrstvy RGB

size(obr6)
R = obr6;
G = obr6;
B = obr6;
size(R)
% vynulování
R(:,:,[2 3]) = 0;
G(:,:,[1 3]) = 0;
B(:,:,[1 2]) = 0;
% test
size(R)
R(1,:,1)
R(1,:,2)
R(1,:,3)
% vykreslení vrstev RGB
figure()
subplot(3,1,1)
imshow(R)
subplot(3,1,2)
imshow(G)
subplot(3,1,3)
imshow(B)
% převod do stupňů šedi
figure()
subplot(3,1,1)
imshow(mat2gray(R(:,:,1), [0, 255]))
subplot(3,1,2)
imshow(mat2gray(G(:,:,2), [0, 255]))
subplot(3,1,3)
imshow(mat2gray(B(:,:,3), [0, 255]))

Poznámka pro Octave: Funkce mat2gray je součástí balíčku "image", který lze doinstalovat příkazem: pkg install image.