Files
SAE32_2025/rapport/rapport.tex
T

215 lines
15 KiB
TeX
Raw Normal View History

2026-01-08 20:45:13 +01:00
\documentclass[1&pt]{article}
2026-01-07 16:06:09 +01:00
\usepackage{graphicx}
\usepackage{array}
\usepackage[table]{xcolor}
\usepackage{colortbl}
\usepackage{geometry}
\usepackage[colorlinks=true, linkcolor=black, urlcolor=black, citecolor=black]{hyperref}
\usepackage{float}
\usepackage[T1]{fontenc}
\usepackage[utf8]{inputenc}
\usepackage{lmodern}
\usepackage{comment}
\graphicspath{{images/}}
\title{\textbf{RAPPORT SAE32\_2025 \\BUT Informatique - 2ème année \\SAE3.2-Application "Primitive Image Format"}}
2026-01-10 14:18:17 +01:00
\author{\textbf{Youness BOULALAM,Algassimou DIALLO,Ayoub ANHDIRE}}
2026-01-07 16:06:09 +01:00
\date{\textbf{07 janvier 2026}}
\begin{document}
\maketitle
Développement d'une application de conversion d'une image au format PIF (1ère image) + Affichage dans une fenetre d'une image contenue dans un fichier PIF (2ème image).
\begin{figure}[H]
\centering
\includegraphics[width=0.8\textwidth]{ConvertisseurFR}
\caption{Interface principale du convertisseur , notamment avec les tables de fréquences}
\end{figure}
\begin{figure}[H]
\centering
\includegraphics[width=0.45\textwidth]{Vis}
\caption{Interface principale du visualisateur ou l'utilisateur peut déplacer l'image avec la souris lorsqu'elle est trop grande}
\end{figure}
\section*{\underline{Comptes GIT utilisés pour ce projet}}
\begin{itemize}
\item \textbf{Youness BOULALAM} (Groupe 4) : \texttt{youness}
2026-01-10 14:18:17 +01:00
\item \textbf{Algassimou DIALLO} (Groupe 4) : \texttt{Diallo-VM-fbleau}
\item \textbf{Ayoub ANHDIRE} (Groupe 4) : \texttt{Ayoub ANHDIRE,Anhdire,Ayoub ANHDIRE}
2026-01-07 16:06:09 +01:00
\end{itemize}
\begin{center}
\textbf{Réalisé en JAVA} : Architecture MVC \\
2026-01-10 14:18:17 +01:00
\textbf{Dépôt Gitea : }\url{https://grond.iut-fbleau.fr/dialloa/SAE32_2025} \\
2026-01-07 16:06:09 +01:00
\textbf{Professeur :} M.Luc Hernandez \\
\textbf{Date de rendu : }11 janvier 2026 \\
\end{center}
\renewcommand{\contentsname}{Sommaire}
\tableofcontents
\section{Introduction}
Pour cette deuxieme SAE du semestre 3 , il nous a fallu réaliser \textbf{deux} programmes : un convertisseur d'une image au format png ou du moins supportable par la méthode \textit{read} de la classe \textbf{ImageIO}. L'image sera donnée en argument ou sinon elle sera sélectionner par un \textbf{JFileChooser}(à part s'il y a un deuxième argument et qu'il represente un chemin et un nom acceptable). Pour ce programme , on aura une interface simple avec la tables des fréquences , la tables des codes initiaux (Huffman) et la table des codes canoniques. A la suite de cela , l'utilisateur a la possibilité ou non de pouvoir sauvegarder son image au format PIF.
Le deuxieme programme est un visualisateur ou celui-ci est censé afficher dans une fenetre une image contenue dans un fichier au format PIF. Celui-ci est donnée en argument ou la sélection du fichier sera réalise à l'aide d' un \textbf{JFileChooser}. La taille de la fenetre sera la taille de l'image à afficher avec une taille qui ne dépasse pas l'écran : si l'image est plus petite que le fenetre , elle sera centré et si elle ets plus grande que la fenetre : elle sera partiellement visible et pourra etre déplacé à la souris en maintenant le bouton gauche enfoncé.
Ce projet a été réalisé en trinôme, et nous avons développé lapplication entièrementen Java, en respectant les bonnes pratiques vues en cours : architecture MVC, créationde makefile, et une interface graphique codée sans bibliothèque externe. Un soin particulier a été apporté à lergonomie : linterface est pensée pour être simple, claire, et agréable à utiliser.
\section{Répartition des taches}
\begin{center}
2026-01-08 21:33:24 +01:00
\begin{tabular}{|l|l|p{9cm}|}
2026-01-07 16:06:09 +01:00
\hline
2026-01-08 21:33:24 +01:00
\textbf{Nom} & \textbf{Tâches effectuées} \\
2026-01-07 16:06:09 +01:00
\hline
2026-01-08 21:33:24 +01:00
Algassimou DIALLO &
\begin{minipage}[t]{8.5cm}
\begin{itemize}
\item Creation de la structure generale du projet (Dossier, UML)
\item Implémentation de BitOutputStream
\item Implémentation de BitInputStraam
\item Implémentation complète du contrôleur (ConverterController)
\item Génération et affichage des fréquences
\item J'ai aussi travailler sur le constructeur de HuffmanTree et Huffman node
\item Intégration de linterface graphique (ConverterWindow)
\item Gestion du bouton Export et sauvegarde .pif dans un thread séparé
\item Creation et Test du MakeFile
\item Implémentation du PIFWriter (écriture des tables, pixels)
\item Implémentation du PIFReader (lecture, reconstruction, décodage)
\item Implémentation du contrôleur pour la vue
\end{itemize}
\end{minipage} \\
2026-01-07 16:06:09 +01:00
\hline
2026-01-08 21:33:24 +01:00
Youness BOULALAM &
\begin{minipage}[t]{8.5cm}
\begin{itemize}
\item Gestion des erreurs et messages utilisateur
\item Conversion RGBImage BufferedImage pour le Viewer
\item Conversion RGBImage BufferedImage pour le convertisseur
2026-01-10 16:27:13 +01:00
\item ouverture du fichier `.pif` via argument ou JFileChooser
\item demande de support sur des taches de mes camarades
\item
2026-01-08 21:33:24 +01:00
\end{itemize}
\end{minipage} \\
2026-01-07 16:06:09 +01:00
\hline
2026-01-08 21:33:24 +01:00
Ayoub ANHDIRE &
\begin{minipage}[t]{8.5cm}
\begin{itemize}
\item Javadoc (Équipe)
\item Génération des codes Huffman
\item Génération des codes canoniques
\item Interface d'affichage des fréquences
\item Test de BitOutputStream
\item Lecture de l'en-tête
\item Diagramme de classe
\end{itemize}
\end{minipage} \\
2026-01-07 16:06:09 +01:00
\hline
2026-01-08 21:33:24 +01:00
2026-01-07 16:06:09 +01:00
\end{tabular}
\end{center}
2026-01-08 21:33:24 +01:00
2026-01-07 16:06:09 +01:00
\section{Fontionnalités principales}
\subsection{Conversion au format PIF}
% appuyer cette section avec des diagrammes et des explications de votre code + diagramme objet (pour l'abre binaire}
2026-01-08 21:33:24 +01:00
\section{Fonctionnalités principales}
\subsection{Conversion au format PIF}
La conversion dune image vers le format PIF repose sur plusieurs étapes :
analyse des composantes RGB, calcul des fréquences, construction de larbre
de Huffman, création des codes canoniques, puis écriture finale dans un fichier
binaire structuré. Cette section présente les mécanismes mis en place et la
contribution de chaque membre du groupe.
2026-01-10 14:18:17 +01:00
\subsection{Contribution de Algassimou Pellel Diallo}
2026-01-08 21:41:52 +01:00
pipeline global, le role du controleur,
la navigation entre les etapes, les ecrans
le workflow user i.e comment le user convetit un fichier
ajout de diagramme
2026-01-10 14:18:17 +01:00
\subsection{Contribution de Ayoub Anhdire}
%TU dois parler du concept dabre binaire, comment Huffman contruit un arbre optimal
%La logique des codes canoniques, un diagramme dobjet de larbre ou un dessin claire
%pourquoi cette structure est pratiques à encoder
2026-01-08 21:41:52 +01:00
2026-01-10 14:18:17 +01:00
%et fais une section resumer vers la fin
Un \textit{arbre binaire} est une structure abstraite composé de noeuds dont la principale contrainte est qu'un noeud doit avoir au maximum deux enfants :
\begin{itemize}
\item un enfant gauche,
\item un enfant droit.
\end{itemize}
\subsection{Comment l'arbre d'Huffman est construit ? (Ayoub ANHDIRE)}
Au préalable , pour construire l'abre binaire de Huffman , il nous faut calculer les fréquences pour les composantes R,G et B. Après avoir calculé ces fréquences , pour constuire l'arbre d'Huffman , il nous faut prendre les feuilles avec les plus basses fréquences , c'est-à-dire les plus proches de zéro : en l'occurence , il faut en prendre deux et à partir de ces deux feuilles , on crée un nouveau noeud qui a comme fréquence la somme des feuilles correspondantes. Lorsqu'il ne reste plus qu'une feuille et qu'on ne peut plus appliquer ce principe : alors cela signifie que c'est la racine de l'arbre. Elle est censé avoir la plus grande fréquence que les feuilles de départ. Autrement dit , plus la fréquence est grande , plus le code Huffman associé sera court. \\
Essayons d'expliquer ce principe avec un diagramme objet et un petit dessin de l'arbre. Prenons l'exemple le plus simple avec simplement deux feuilles, voici le diagramme objet basé sur notre code et un dessin de l'arbre de ce diagramme objet :
2026-01-08 21:33:24 +01:00
2026-01-08 21:41:52 +01:00
2026-01-10 14:18:17 +01:00
\begin{figure}[H]
\centering
\includegraphics[width=0.5\textwidth]{images/Huffman.png}
\caption{Diagramme Objet - Construction de l'arbre Huffman}
\end{figure}
\begin{figure}[H]
\centering
\includegraphics[width=0.5\textwidth]{images/ARBRE.png}
\caption{Dessin Arbre Huffman - Basé sur le diagramme objet de la figure 3}
\end{figure}
Puisqu'il y a trois composantes R,G et B , il est censé avoir 3 arbres Huffman mais pour simplifier la compréhension , nous n'en avons fait qu'un seul : celui de la composante Rouge. Expliquons le diagramme objet : nous avons un objet \textit{freq} de la classe \textbf{FrequencyTable}. Cette classe permet d'initialiser les trois tableaux de fréquences(R,G et B) et ces tableaux sont passés en argument dans le constructeur de classe \textbf{HuffmanTree}. \\ Après ca on peut remarquer la présence de deux feuilles \textit{Node1} et \textit{Node2}. Elle ont comme fréquence respective 7 et 8. Comme répété plus haut , pour faciliter la compréhension ,nous avons choisis que deux feuilles. Voici la base de notre arbre. On remarque la présence d'un noeud \textit{Node3} avec comme fréquence , il a été obtenu en faisant la somme des deux noeuds \textit{Node1} et \textit{Node2} et la fréquence obtenu est 15 , donc 7+8. C'est la seule feuille qui reste dans notre arbre : on en conlu que c'est la racine de notre arbre , comme en témoigne l'attribut \underline{root} de la classe \textbf{HuffmanTree}. \\
Après avoir compris le principe de comment construire l'arbre Huffman , comment générer les codes Huffman ? Nous avons codé çela de manière récursive : si on saute vers un fils gauche on ajoute 0 et si on saute vers un fils droit on ajoute 1 : les codes sont enregistrés dans des dictionnaires : \textbf{Map<Integer,String>}. Pour chaque feuille , pour obtenir son code , on parcourt l'arbre de la racine jusqu'à la feuille. \\
La question qu'on se pose désormais : c'est est-ce-que cette solution est optimale ? La réponse est oui ! Pourquoi ? Comme on a placé les symboles fréquents près de la racine, la moyenne des longueurs de tous les codes est minimale. De plus, les codes sont différents, puisqu aucun code nest le début dun autre code, donc il ny a pas derreur possible à la lecture. Même si certains symboles ont la même fréquence et que larbre peut être légèrement différent, la longueur moyenne reste toujours la plus courte possible. Cest pour cela que la génération des codes à partir de larbre de Huffman est optimale : aucun autre code ne peut donner une longueur moyenne plus courte pour les mêmes symboles.
\subsection{Les codes canoniques et leur logique (Ayoub ANHDIRE)}
Un \textit{code canonique} est une version basé sur les codes Huffman : la longueur de chaque code Huffman est préservé mais les codes sont réorganisés de manière en commençant par les codes les plus courts. On commence par trier les codes initiaux par longueur du code puis par valeur. Les nouveaux codes s'obtiennent ainsi : le premier est rempli de zéro , le deuxieme commençant par 1 et rempli de zéro à droite mais bien faire attention à ce que la longueur ne soit pas dépassé, le troisième commençant par 11 et ainsi de suite jusqu'à avoir réalisé cela , jusqu'à ce que toutes les valeurs aient un code canonique.\\
Pour cela , la démarche que nous avons employé est celle la : on récupérait les entrées(des dictionnaires en l'occurence) des codes Huffman afin de les trier , puis on a trié la liste avec un \textbf{Comparator} que nous avons implémenté : on compare d'abord par la longueur des codes(longueur de la valeur dans le dictionnaire) ou sinon on trie par rapport à la valeur de la clé. Puis on fait une boucle qui parcoure toute la liste , on attribue un code canonique à chaque symbole qu'on ajoute dans un dictionnaire : \textbf{Map<Integer,String>}. \\
\subsection{Pourquoi les codes canoniques au lieu des codes Huffman ? (Ayoub ANHDIRE)}
Pour le décodage d'un fichier au format PIF , le fait de stocker l'arbre d'Huffman prendrait enormément de place et de temps mais on peut restituer ces codes Huffman grâce aux code canoniques. Il nous suffit juste de connaitre la longueur des codes et l'ordre des symboles pour pouvoir les reconstituer. On garde la même longueur que les codes initiaux, donc la compression reste optimale.
\subsection{Le résumé de ces deux principes(Ayoub ANHDIRE)}
Lalgorithme de Huffman sert à coder les symboles avec des codes plus courts pour les symboles fréquents et plus longs pour les rares, ce qui permet de gagner de lespace. Les codes sont optimaux, puisqu'aucun code n'est le début d'un autre, donc on peut les lire sans erreur. Les codes canoniques sont une version plus simple des codes Huffman : ils gardent la même longueur pour chaque symbole mais suivent d'autres contraintes qui les diffèrent des codes initiaux. Cela permet de stocker moins de données et de décoder plus vite, tout en gardant la même efficacité que Huffman.
2026-01-08 21:41:52 +01:00
2026-01-07 16:06:09 +01:00
% donner une explication de la forme des tables des codes dans le convertisseur, et du mécanisme qui exploite cette forme pour assurer l'encodage
\subsection{Visualisateur au format PIF}
% appuyer cette section avec des diagrammes et des explications de votre code
% donner une explication de la forme de la table des codes dans le visualisateur, et du mécanisme qui exploite cette forme pour assurer le décodage
\section{MakeFile du Projet}
% expliquer le makefile
\section{Conclusion}
Nous avons pensé que ce projet ... (à compléter)
% conclusion de groupe + conclusion Personnelle :
\subsection{Youness BOULALAM}
2026-01-10 16:36:48 +01:00
Dans ce projet jai pu contrairement au precedent j'ai pu avoir des discution avec mes colaborateurs afin de pouvoir rendre la meilleure version possible du project et pouvoir avoir une vue d'encemble de celui-ci.
Sans vous mentir le Java ce n'est pas vraiment ma tasse de the mais quand on est assister on peut facilement comprendre et moins rester bloquer sur un concepts qui peu aller nous demotiver et jusqu'a nous degouter du projet.
Je souhaite pour conclure remercer mes camarades Algassimou et Ayoub ainsi que vous MR Hernandez de nous avoir permis de faire ce projet det de le mener a bien.
2026-01-07 16:06:09 +01:00
\subsection{Algassimou DIALLO}
\subsection{Ayoub ANHDIRE}
2026-01-10 14:18:17 +01:00
Pour conclure, jai bien aimé ce projet en général, jai pris du plaisir
à coder en JAVA dautant plus que jaffectionne la programmation orientée objet. Ce projet ma permis daugmenter mes compétences techniques en JAVA, plus précisément dans la compréhension de structures abstraites notamment les dictionnaires ou encore les arbres. J'ai pu travailler d'autres notions comme la récursivité où j'avais du mal à comprendre la logique mais grâce à ce projet , j'ai pu m'améliorer et devélopper mes connaissances.
\\
Jai pu aussi développer mes qualités de communication avec mes camarades : chacun a joué un rôle ou il sait quil va perfectionner et la communication a été un enjeu majeur dans cette SAé car lorsque quelquun était
bloqué, il faisait signe et ne restait pas tout seul sans avancer dans sa tâche. En conclusion, ce projet a été pour moi une expérience enrichissante doù je tirerai certainement des profits.
2026-01-07 16:06:09 +01:00
\end{document}
2026-01-10 14:18:17 +01:00
% centering ==> pour center le texte pour une seule ligne ==> terminer par \par pour faire comprendre au compilateur que c'est la fin de la ligne à centrer !