L-System/rapport/chapters/chapitre4.tex

115 lines
5.2 KiB
TeX
Raw Normal View History

2021-04-20 11:51:25 +02:00
\chapter{Élements techniques}
2021-04-17 01:12:28 +02:00
2021-04-13 18:21:34 +02:00
\section{Moteur de réécriture}
2021-04-17 01:12:28 +02:00
2021-04-17 13:19:48 +02:00
Le moteur de réécriture est chargé d'appliquer les règles de réécritures itérativement à partir de l'axiome pour obtenir le mot final.
2021-04-20 11:51:25 +02:00
Nous avons d'un côté l'axiome qui est le mot de départ et une liste de règles qui contient 2 données : le mot à remplacer et son remplaçant.
Le mot est réécrit en 2 temps :\\
2021-04-17 13:19:48 +02:00
\begin{itemize}
2021-04-20 11:51:25 +02:00
\item On change toutes les occurrences du mot à remplacer par \$\{identifiant de la règle\}.
\item On remplace toutes les occurrences de \$\{identifiant de la règle\} par la règle associée.
2021-04-17 13:19:48 +02:00
\end{itemize}
2021-04-20 14:39:17 +02:00
On répète cette opération n fois, pour obtenir le mot final.\\
L'algorithme de réécriture est séparé en 3 parties:\\
\begin{algorithm}
\DontPrintSemicolon
\KwIn{axiom: $String$, rules : $List[Tuple[String, String]$, recurrence: $Integer$}
\KwOut{Le mot réécrit itérativement: $String$}
\caption{{\sc Rewrite} Fonction principale appelé par la fenêtre principale}
$rewritten \gets \emptyset$\;
\For{$i \gets 0$ \textbf{à} $recurrence$} {
$toRewrite \gets replaceRulesByID(rewritten, rules)$\;
$rewritten \gets = replaceIDByRuleApplication(toRewrite, rules)$\;
}
$rewritten = rewritten.replace("[", "Y[")$\;
\Return{$rewritten$}\;
\end{algorithm}
\begin{algorithm}
\DontPrintSemicolon
\KwIn{rewritten: $String$, rules : $List[Tuple[String, String]$}
\KwOut{Le mot partiellement réécrit}
\caption{{\sc replaceRulesByID} remplace les occurrences des différentes règles par \$\{id\}}
$toRewrite \gets rewritten$\;
\For{$i \gets 0$ \textbf{à} $rules.size()$}{
$pair \gets rules.get(i)$\;
$toRwrite \gets toRewrite.replace(pair[0], "\$\{" + i + "\}")$\;
}
\Return{$toRewrite$}
\end{algorithm}
\begin{algorithm}
\DontPrintSemicolon
\KwIn{toRewrite: $String$, rules : $List[Tuple[String, String]$}
\KwOut{Le mot entièrement réécrit}
\caption{{\sc replaceIDByRuleApplication} remplace les occurrences \$\{id\} par la définition des différentes règles}
$rewritten \gets toRewrite$\;
\For{$i \gets 0$ \textbf{à} $rules.size()$}{
$rewritten \gets rewritten.replace("\$\{" + i + "\}", rules.get(i)[1]$\;
}
\Return{$rewritten$}
\end{algorithm}
\clearpage
\section{Parser}
\label{sec:parser}
Le rôle du parser est à partir d'un mot réécrit par le moteur de réécriture de convertir celui-ci en une structure de données plus facilement manipulable afin de l'afficher dans le moteur graphique.
En appliquant les règles précédemment énoncé, il construit un arbre grâce la structure de données suivante
2021-04-17 13:19:48 +02:00
2021-04-20 14:39:17 +02:00
\begin{algorithm}
\DontPrintSemicolon
\caption{{\sc Element} Branche de l'arbre, si parent est vide alors, cet element est la racine}
\Struct{Element}{
propery: $ElementProperty$ \Comment{enumérateur, valeurs possibles: $DRAW$ ou $NOTHING$}\;
parent: $Element$\;
rotation: $Float[3]$\;
children: $List[Element]$\;
}
\end{algorithm}
2021-04-17 01:12:28 +02:00
2021-04-20 14:39:17 +02:00
\section{Moteur graphique}
\label{sec:interface3d}
Nous utilisons Java OpenGL pour afficher une fenêtre 3D, gl2 pour afficher les lignes de la grille, glu pour placer la caméra et GLUT pour afficher les cylindres.\\
Pour naviguer dans l'espace 3D, voir la section \ref{sec:nav_3d}.\\
Pour afficher le L-Système nous utilisons une méthode récursive.
2021-04-20 11:51:25 +02:00
\begin{figure}[h!]
\centering
\includegraphics[width=0.8\linewidth]{pics/3dGUI.png}
\caption{Fenêtre 3D}
\label{fig:3d_frame}
\end{figure}
\clearpage
2021-04-20 14:39:17 +02:00
\section{Interface principale}
\label{sec:menu}
2021-04-17 01:12:28 +02:00
2021-04-16 11:48:15 +02:00
\subsection{Composition de l'interface}
2021-04-17 01:12:28 +02:00
2021-04-20 14:39:17 +02:00
\paragraph{L'interface} utilisateur de notre logiciel a été conçu grâce à la bibliothèque \Swing \ de \Java. Elle se compose de trois classes, une contenant la fenêtre principale \classe{MainFrame}, une autre permettant de créer des onglets, \classe{Tab} et une troisième classe gérant les événements, \classe{Listener}.
2021-04-16 11:48:15 +02:00
\subsection{Classes de l'interface}
2021-04-17 01:12:28 +02:00
2021-04-16 11:48:15 +02:00
\subsubsection{MainFrame}
2021-04-17 01:12:28 +02:00
2021-04-20 11:51:25 +02:00
\paragraph{La classe \classe{MainFrame}} est une classe héritant de la classe JFrame de \Swing. Elle permet de créer une fenêtre de base, de taille prédéfinie dans laquelle peuvent être placés des composants graphiques. Elle comprend aussi un bouton de fermeture qui, une fois cliqué, permet l'arrêt du programme.\\
Elle comporte aussi une instance de la classe JTabbedPane \label{jtpane}, un conteneur graphique donc le but est de disposer ses composants sous la forme d'onglets.
2021-04-16 11:48:15 +02:00
\subsubsection{Tab}
2021-04-17 01:12:28 +02:00
2021-04-20 11:51:25 +02:00
\paragraph{La classe \classe{Tab}} est une classe héritant de la classe JPanel de \Swing. JPanel est un composant de base dans lequel il est possible d'ajouter d'autres composants graphiques. Les intances de \classe{Tab} créées sont ensuite ajoutées par la classe \classe{MainFrame} à son composant de la classe JTabbedPane \ref{jtpane}.
2021-04-16 11:48:15 +02:00
\subsubsection{Listener}
2021-04-17 01:12:28 +02:00
2021-04-20 14:39:17 +02:00
\paragraph{La classe \classe{Listener}} est une classe implémentant certaines classes Listener de \\\Swing (\classe{ActionListener, KeyListener et MouseWheelListener}). Elle permet de capter toutes les actions effectuées par l'utilisateur et d'appeler les méthodes correspondantes des classes de l'interface. Elle permet ainsi de créer de nouveaux onglets (Nouvelles instances de Tab) mais aussi d'en fermer ou bien encore de lancer la génération du modèle.
2021-04-20 11:51:25 +02:00
\section{Pair ou un tuple a 2 entrées en java}