-
Notifications
You must be signed in to change notification settings - Fork 1
/
application_2_grayscale.m
54 lines (44 loc) · 1.97 KB
/
application_2_grayscale.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
%{
BONUS
On essaye de transmettre une image par un canal dans lequel la transmission d’informations est très
lente. Dans une telle situation, l’idéal serait de pouvoir voir apparaître l’image progressivement,
c’est-à-dire grossièrement au début et avec de plus en plus de détails au fur et à mesure que les
informations arrivent. Cela permettrait d’arrêter la transmission très rapidement, si l’on juge l’image
inintéressante ou dès que la qualité est jugée suffisante. Tout cela doit bien évidemment se faire en
transmettant un volume de données le plus petit possible par rapport à ce que contient l’image
elle-même.
• Réaliser cela à partir de la décomposition de matrices en valeurs singulières. Cette
décomposition est décrite dans l’annexe mathématique.
• Comment peut-on évaluer la qualité de l’image courante par rapport à l’image d’origine
(qualité = 100% si les deux images sont identiques ...).
• Quels sont, à votre avis, les avantages et les inconvénients de ce codage de l’image ?
%}
clc;
clear;
close all;
%Temps en secondes entre chaque image
delai_affichage_image = 0.01;
%On convertit l'image en nuances de gris (0 - 255) pour chaque pixel
%On convertit la matrice en double (initialement uint8) pour pouvoir
%utiliser svd
I_INIT = rgb2gray(imread('img_bonus.jpg'));
%Affiche l'image
h = imshow(I_INIT);
cd = get(h,'CData');
%Décomposition en valeurs singulières
[~, D, ~] = svd(double(I_INIT));
%Nombre de valeurs singulières (!= 0)
N = nnz(diag(D));
for i=1:N
%Décomposition en valeurs singulières
[U, D, V] = svd(double(I_INIT));
%On garde N valeurs singulières dans la matrice diagonale
D(i:end, i:end) = 0;
%On reconstruit l'image
I = uint8(U * D * V');
qualite = i / N;
%Met à jour l'image
set(h,'CData',I);
title(sprintf("Image compressée en gardant %d valeurs singulières sur %d. (Qualité=%.1f%%)", i, N, qualite * 100));
pause(delai_affichage_image);
end