This repository has been archived on 2022-03-31. You can view files and clone it, but cannot push or open issues or pull requests.
heyawake-prolog/rendu/rendu.tex

179 lines
8.2 KiB
TeX
Raw Normal View History

2021-03-15 21:18:23 +01:00
\documentclass{article}
\usepackage[utf8x]{inputenc} % encodage utf-8
\usepackage[french]{babel} % en français
\usepackage[T1]{fontenc} % encodage T1 police
\usepackage[hidelinks]{hyperref} % lien dans table des matières
\usepackage[nameinlink, noabbrev]{cleveref} % lien pour les images
2021-03-15 21:18:23 +01:00
\usepackage{listings} % intégration code
2021-03-16 03:33:00 +01:00
\usepackage{xcolor} % couleur
\usepackage{enumitem} % listes personalisées
\usepackage{graphicx} % intégration images
2021-03-15 21:18:23 +01:00
2021-03-16 03:33:00 +01:00
% liste avec flèches
\newlist{listeFleche}{itemize}{4}
\setlist[listeFleche]{label=$\rightarrow$}
% couleurs
2021-03-16 01:27:08 +01:00
\definecolor{defaultPredicat}{RGB}{121, 94, 38}
\definecolor{definitionChar}{RGB}{175, 0, 219}
\definecolor{argsAndPredicat}{RGB}{0, 96, 181}
\definecolor{string}{RGB}{163, 99, 21}
\definecolor{comment}{RGB}{0, 128, 0}
2021-03-15 21:18:23 +01:00
\lstset{
frame=single, % encadré
2021-03-16 01:27:08 +01:00
breaklines=true, % lignes dans le cadre
columns=fullflexible, % contenu bien présenté dans le cadre
2021-03-16 03:33:00 +01:00
language=Prolog, % language
tabsize=4, % nb d'espace par tabulation
2021-03-16 01:27:08 +01:00
% chiffres
numbers=left,
numberstyle=\tiny,
% affichage
basicstyle=\ttfamily,
keywordstyle=\color{defaultPredicat},
identifierstyle=\color{argsAndPredicat},
stringstyle=\color{string},
commentstyle=\color{comment},
literate=
{:-}{{\textcolor{definitionChar}{:- }}}1
% utf-8 fix source: https://en.wikibooks.org/wiki/LaTeX/Source_Code_Listings
{á}{{\'a}}1 {é}{{\'e}}1 {í}{{\'i}}1 {ó}{{\'o}}1 {ú}{{\'u}}1
{Á}{{\'A}}1 {É}{{\'E}}1 {Í}{{\'I}}1 {Ó}{{\'O}}1 {Ú}{{\'U}}1
{à}{{\`a}}1 {è}{{\`e}}1 {ì}{{\`i}}1 {ò}{{\`o}}1 {ù}{{\`u}}1
{À}{{\`A}}1 {È}{{\'E}}1 {Ì}{{\`I}}1 {Ò}{{\`O}}1 {Ù}{{\`U}}1
{ä}{{\"a}}1 {ë}{{\"e}}1 {ï}{{\"i}}1 {ö}{{\"o}}1 {ü}{{\"u}}1
{Ä}{{\"A}}1 {Ë}{{\"E}}1 {Ï}{{\"I}}1 {Ö}{{\"O}}1 {Ü}{{\"U}}1
{â}{{\^a}}1 {ê}{{\^e}}1 {î}{{\^i}}1 {ô}{{\^o}}1 {û}{{\^u}}1
{Â}{{\^A}}1 {Ê}{{\^E}}1 {Î}{{\^I}}1 {Ô}{{\^O}}1 {Û}{{\^U}}1
{ã}{{\~a}}1 {}{{\~e}}1 {ĩ}{{\~i}}1 {õ}{{\~o}}1 {ũ}{{\~u}}1
{Ã}{{\~A}}1 {}{{\~E}}1 {Ĩ}{{\~I}}1 {Õ}{{\~O}}1 {Ũ}{{\~U}}1
{œ}{{\oe}}1 {Œ}{{\OE}}1 {æ}{{\ae}}1 {Æ}{{\AE}}1 {ß}{{\ss}}1
{ű}{{\H{u}}}1 {Ű}{{\H{U}}}1 {ő}{{\H{o}}}1 {Ő}{{\H{O}}}1
{ç}{{\c c}}1 {Ç}{{\c C}}1 {ø}{{\o}}1 {å}{{\r a}}1 {Å}{{\r A}}1
{}{{\euro}}1 {£}{{\pounds}}1 {«}{{\guillemotleft}}1
{»}{{\guillemotright}}1 {ñ}{{\~n}}1 {Ñ}{{\~N}}1 {¿}{{?`}}1 {¡}{{!`}}1,
2021-03-16 03:33:00 +01:00
% espaces normaux sans underscore
showspaces=false,
showstringspaces=false,
showtabs=false
2021-03-15 21:18:23 +01:00
}
\author{Kévin Martins Da Veiga [20009472] et Anri Kennel [20010664]}
\title{Projet Heyawake en Prolog}
\date{}
\begin{document}
\maketitle
\tableofcontents
\newpage
\section{Présentation du Projet}
\subsection{Introduction et règles du jeu}
2021-03-16 03:33:00 +01:00
L'Heyawake est un puzzle joué dans une grille rectangulaire séparés en plusieurs aires dont le but
est de colorés des cases en noir et blanc en accord avec les règles :
\begin{listeFleche}
\item Certaines aires contiennent un chiffre qui montre combien il y a de cases noires dans l'aire
\begin{listeFleche}
2021-03-16 03:38:30 +01:00
\item Aire avec un 0 ne doivent pas avoir de cases noires
\item Aire avec un 1 contient une case noire
\item Etc\dots
2021-03-16 03:33:00 +01:00
\end{listeFleche}
\item Toutes les cases blanches doivent être connectés en un seul groupe, pas de groupe isolés, elles doivent toutes être reliés
\item Deux cases noires de peuvent être l'un à côté de l'autre horizontalement et verticalement (en diagonale, c'est possible)
\begin{listeFleche}
\item Ca veut dire que les cases noires doivent être que entourés de cases blanches
\end{listeFleche}
\item Une rangée de case blanche ne peuvent pas être alignée au-delà de 2 aires
\end{listeFleche}
2021-03-15 21:18:23 +01:00
\subsection{Réalisation}
2021-03-16 03:33:00 +01:00
\begin{listeFleche}
\item Mettre toutes les aires avec un 0 en blanc
2021-03-16 03:38:30 +01:00
\item Mettre les aires avec 1 et que d'une case en noire
2021-03-16 03:33:00 +01:00
\item Mettre des cases noires là où une rangée de cases blanches dans plus de 2 aires peut se faire
\item Toujours mettre du blanc autour des celulles noires
\begin{listeFleche}
\item En suivant cette étape, quand on met une case noire dans une aire avec un chiffre 1, colore tout le reste de l'aire en blanc
\end{listeFleche}
\item Toujours verifié que les cases blanches ne sont pas piégés entre des cases noires
\begin{listeFleche}
\item Ca implique que dans ce schéma suivant avec B une case blanche, N une case noire et X une case vide :
\begin{listeFleche}
\item B X B $\rightarrow$ B B B
\item N B N $\rightarrow$ N B N
\item B N B $\rightarrow$ B N B
\item Le X doit obligatoirement devenir blanc pour laisser une sortie à la case blanc qui se trouve entre les cases noires
\end{listeFleche}
\end{listeFleche}
\end{listeFleche}
Le programme se lance en appelant le prédicat \emph{run} avec comme argument une liste de listes des aires.
\begin{lstlisting}
run([[0,0,1,1,2], [2,0,2,2,-1], [3,0,5,1,-1],
[0,2,0,4,-1], [1,2,1,3,0], [3,2,5,2,0],
[1,4,1,4,1], [2,3,5,5,4], [0,5,1,5,-1]]).
% [X1, Y1, X2, Y2, N] avec N le nombre de case noire dans l'aire
\end{lstlisting}
Cet appel correspond au puzzle ci-dessous
\begin{figure}[ht]
\centering
\includegraphics[width=5cm, height=5cm]{default}
\caption{Puzzle de difficulté facile d'Heyawake}
\label{fig:default}
2021-03-16 03:33:00 +01:00
\end{figure}
2021-03-15 21:18:23 +01:00
\section{Résolution d'une grille avec des aires}
\subsection{Ce que l'on a essayé}
2021-03-16 03:33:00 +01:00
\begin{listeFleche}
\item On vérifie les aires avec un 2 et de 4 cases puis on colorie la case 2 en noire et ses diagonales
\begin{listeFleche}
\item On colore les cases adjacentes au noire en blanc, on le fais autant de fois que nécessaire
\end{listeFleche}
\item On regarde quelles cases doivent être colorés en noire pour éviter de faire des lignes de 4 cases blanches
\item On connecte les cases blanches entre elle sans faire de lignes de plus de 3 cases dans des zones différentes
\item Maintenant on essaie de rajouter des cases noires :
\begin{listeFleche}
\item On met une case noire pour éviter des groupes de 3 cases blanches
\item On colorie les cases adjacentes à la nouvelle case noire en blanc
\end{listeFleche}
\item On fait en sorte que toutes les cases blanches soient connectés en rajoutant des cases blanches si possible
\item On remplie les cases noires là où on peut les mettre, et on continue jusqu'à qu'il n'y est plus de cases sans couleurs.
2021-03-16 03:33:00 +01:00
\end{listeFleche}
2021-03-15 21:18:23 +01:00
\section{Le programme}
2021-03-16 03:33:00 +01:00
\subsection{Le prédicat \emph{\texttt{aire}} en détail}
Le prédicat \emph{\texttt{aire}} fonctionne comme l'image ci-contre. Il regarde chaque case de l'aire.
Une fois arrivé à l'extremité d'une aire, il descend d'une case si il y une ligne en dessous puis il parcours
le chemin inverse avec le prédicat \emph{\texttt{airereverse}}.
Par exemple, sur la \autoref{fig:default}, prenons l'aire en bas à droite :
2021-03-16 03:33:00 +01:00
\begin{figure}[ht]
\centering
\includegraphics[width=5cm, height=5cm]{aireExplication}
\caption{Explication fonctionnement \emph{\texttt{aire}}}
\end{figure}
2021-03-15 21:18:23 +01:00
\subsection{Listing des prédicats utilisés}
2021-03-16 03:33:00 +01:00
\begin{listeFleche}
\item \textbf{\texttt{aire(X1, Y1, X2, Y2, E, T)}} :
Ce prédicat fait scanne l'aire renseignée et assigne une couleur via le prédicat \emph{\texttt{case}}.
\item \textbf{\texttt{airereverse(X1, Y1, X2, Y2, 0, T)}} :
Ce prédicat est appellée par le prédicat \emph{\texttt{aire}} et permet de vérifier tout les éléments
d'une aire.
\item \textbf{\texttt{case(X, Y, C)}} :
Ce prédicat renvoie la couleur d'une case du puzzle.
\item \textbf{\texttt{run([[X1, Y1, X2, Y2, E] | Q])}} :
Ce prédicat lance la résolution du puzzle.
\end{listeFleche}
2021-03-15 21:18:23 +01:00
2021-03-16 03:33:00 +01:00
\section{Annexe : le code}
2021-03-15 21:18:23 +01:00
\lstinputlisting{../resolveur.pl}
\end{document}