No Description
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

besoins.tex 26KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493
  1. %%%%%%%%%%%%%%%%%%%%%%%
  2. \section{Expression fonctionnelle du besoin}
  3. %%%%%%%%%%%%%%%%%%%%%%%
  4. \subsection{Présentation générale}
  5. L'objectif est de concevoir et de développer l'architecture logicielle du superviseur afin d'assurer le fonctionnement de la plate-forme. Les fonctions attendues sont :
  6. \begin{enumerate}
  7. \item Assurer la communication entre le moniteur et le superviseur.
  8. \item Assurer la communication entre le superviseur et le robot.
  9. \item Superviser l'état du robot.
  10. \item Contrôler le déplacement du robot.
  11. \item Contrôler et diffuser les images de la webcam.
  12. \item Réaliser des missions.\\
  13. \end{enumerate}
  14. \noindent\framebox[\textwidth]{
  15. \begin{minipage}{0.9\textwidth}
  16. {\bf Remarque :} Les plateformes matérielle et logicielle ont de nouveau évoluées cette année. Les bibliothèques fournies ont été réécrites pour faciliter leur prise en main. Bien qu'elles aient été testées, elles comportent certainement des erreurs. Soyez indulgents, nous faisons de notre mieux pour fournir une plate-forme opérationnelle !\\
  17. {\bf Si vous remarquez des erreurs, des problèmes ou des optimisations à faire, n'hésitez pas à le communiquer} (via GitHub pour en garder la trace).
  18. \end{minipage}
  19. }\\
  20. \subsection{Diagramme de contexte}
  21. La figure~\ref{fig:contexte} présente le superviseur dans son contexte et ses interactions avec les autres composants de la plate-forme.
  22. \begin{figure}[htbp]
  23. \begin{center}
  24. \includegraphics[scale=0.6]{figures_pdf/contexte}
  25. \caption{Diagramme de contexte}
  26. \label{fig:contexte}
  27. \end{center}
  28. \end{figure}
  29. \FloatBarrier
  30. La webcam produit des données (\texttt{image}) sous la forme d'un tableau d'octets. Le robot reçoit des ordres (\texttt{ordre}) sous la forme d'une chaîne de caractères et retourne une réponse aussi sous la forme d'une chaîne (\texttt{reponse}). Le moniteur envoie un événement (\texttt{connecter serveur}) pour demander la connexion avec le serveur puis établit une communication bi-directionnelle sous la forme d'un flux d'octets (\texttt{inputStream} et \texttt{outputStream}).
  31. %Si l'on se focalise uniquement sur le superviseur, nous avons donc un unique processus (voir figure~\ref{fig:processus}).
  32. %
  33. % \begin{figure}[htbp]
  34. %\begin{center}
  35. %\includegraphics[scale=0.6]{figures_pdf/AADL/system}
  36. %\caption{Vue systéme du Superviseur}
  37. %\label{fig:processus}
  38. %\end{center}
  39. %\end{figure}
  40. %\FloatBarrier
  41. %%%%%%%%%%%%%%%%%%%%%%%%%
  42. \subsection{Description des fonctionnalités}
  43. %%%%%%%%%%%%%%%%%%%%%%%%%
  44. Vous trouverez dans cette partie la description des différentes fonctionnalités attendues. Les annexes apportent des compléments techniques.\\
  45. \noindent\fcolorbox{black}{Fond}{% couleur du texte, couleur du fond
  46. \begin{minipage}{\textwidth}
  47. L'expression des fonctionnalités est repérée par des encadrés avec un fond gris. C'est ce que vous devez réaliser.
  48. \end{minipage}
  49. }
  50. %%%%%%%%%%%%%%%%%%%%%%%%%
  51. \subsubsection{Fonctionnement du moniteur}
  52. %%%%%%%%%%%%%%%%%%%%%%%%%
  53. Le moniteur sert pour le contrôle du robot et la visualisation d'une scène. La communication entre le moniteur et le superviseur est réalisée par un socket avec un serveur du côté du superviseur. La communication est bi-directionnelle : le moniteur peut envoyer des requêtes et le superviseur peut envoyer des données pour mettre à jour certains éléments de l'interface. Les messages sont prédéfinis et sont présentés dans l'annexe~\ref{sec:comm_mon_sup}.
  54. %%%%%%%%%%%%%%%%%%%%%%%%%
  55. \subsubsection{Communication entre le superviseur et le moniteur}
  56. %%%%%%%%%%%%%%%%%%%%%%%%%
  57. La communication entre le serveur et le superviseur est réalisée à l'aide d'un socket. Le superviseur joue le rôle de serveur. Toutes les fonctions pour gérer la communication entre le moniteur et le superviseur sont fournies dans {\tt monitor}.
  58. Les figures~\ref{fig:diag1_2} et~\ref{fig:diag3_6} illustrent le mode de fonctionnement nominal attendu pour la communication entre le superviseur et le moniteur.
  59. %https://sequencediagram.org
  60. %%%%%%%%%%%%%%%%%%%%%%%%%
  61. \paragraph{Lancement du serveur.} Le lancement du serveur est réalisé à l'aide de la méthode {\tt Open} de la classe {\tt ComMonitor}.\\
  62. \req{Le lancement du serveur doit être réalisé au démarrage du superviseur. En cas d'échec du démarrage du serveur, un message textuel doit être affiché sur la console de lancement de l'application. Ce message doit signaler le problème et le superviseur doit s'arrêter.}
  63. %%%%%%%%%%%%%%%%%%%%%%%%%
  64. \paragraph{Etablissement du socket.} La connexion entre le moniteur et le superviseur est réalisée suite à la demande de l'utilisateur via l'interface graphique. Lorsque la demande est faite, un socket est créé, il faut donc que le serveur soit en attente d'une demande de connexion, c'est-à-dire que la méthode {\tt AcceptClient} de la classe {\tt ComMonitor} soit en cours d'exécution. Cette méthode est bloquante.\\
  65. \req{La connexion entre le moniteur et le superviseur (via le socket) doit être établie suite à la demande de connexion de l'utilisateur.}
  66. %Terminal->*Supervisor:exec
  67. %note left of Supervisor: (req 1) start server
  68. %Supervisor->+Supervisor: ComMonitor::Open()
  69. %Supervisor-->-Supervisor:err
  70. %alt err != failed
  71. % Supervisor->+Supervisor: ComMonitor::AcceptClient()
  72. % Monitor->Supervisor: connexion
  73. % note left of Supervisor: (req 2) connect socket
  74. % Supervisor->Monitor:accept
  75. % Supervisor-->-Supervisor:err
  76. %
  77. %else
  78. % Supervisor->Terminal: print("server failed")
  79. % destroy Supervisor
  80. %end
  81. \begin{figure}[htbp]
  82. \begin{center}
  83. \includegraphics[scale=0.4]{./seq_req/req1-2}
  84. \caption{Diagramme de séquence des fonctionnalités 1 à 2}
  85. \label{fig:diag1_2}
  86. \end{center}
  87. \end{figure}
  88. %%%%%%%%%%%%%%%%%%%%%%%%%
  89. \paragraph{Réception des messages.} La réception des messages du serveur par le superviseur est réalisée par l'appel de la méthode {\tt Read} de la classe {\tt ComMonitor}. Cette méthode est bloquante. Les messages du moniteur vers le superviseur sont pré-formatés dans la classe {\tt Message} et définis dans l'annexe~\ref{sec:mts}.\\
  90. \req{Tous les messages envoyés depuis le moniteur doivent être réceptionnés par le superviseur.}
  91. %%%%%%%%%%%%%%%%%%%%%%%%%
  92. \paragraph{Envoi des messages.} L'envoi des messages du superviseur vers le moniteur est réalisé à l'aide de la fonction {\tt Write} de la classe {\tt ComMonitor}. Les messages du superviseur vers le moniteur sont pré-formatés et définis dans l'annexe~\ref{sec:stm}.\\
  93. \req{L'application superviseur doit être capable d'envoyer les messages au moniteur (via le serveur) avec un délai d'au plus 10~ms.}
  94. %%%%%%%%%%%%%%%%%%%%%%%%%
  95. \paragraph{Détection de la perte de communication.} La perte de communication entre le moniteur et le superviseur est détectée lors de la lecture sur le socket. La méthode {\tt Read} retourne un message de type {\tt MESSAGE\_MONITOR\_LOST} si la communication est perdue. \\
  96. \req{Le superviseur doit détecter la perte de communication avec le moniteur. En cas de perte de la communication un message doit être affiché sur la console de lancement du superviseur.}
  97. %%%%%%%%%%%%%%%%%%%%%%%%%
  98. \paragraph{Reprise de la communication.} La communication entre le moniteur et le superviseur est fermé à l'aide de la méthode {\tt Close} de la classe {\tt ComMonitor}. {\bf Attention} cette fonctionnalité ne peut être mise en place que lorsque l'ensemble de l'application est déjà réalisée, il ne sert à rien d'y travailler tant que le reste n'est pas fait.\\
  99. \req{En cas de perte de communication entre le superviseur et moniteur, il faut stopper le robot, la communication avec le robot, fermer le serveur et déconnecter la caméra afin de revenir dans le même état qu'au démarrage du superviseur.}
  100. %loop message is not MESSAGE_MONITOR_LOST
  101. %par
  102. %note left of Monitor: (req 3) receive message from Monitor
  103. %Supervisor->+Supervisor: ComMonitor::Read()
  104. %Monitor->Supervisor: message
  105. %Supervisor-->-Supervisor: message
  106. %note over Supervisor: compute message
  107. %else
  108. %note left of Monitor: (req 4) send message to Monitor
  109. %note over Supervisor: wait message to send
  110. %Supervisor->Monitor: ComMonitor::Write(message)
  111. %end
  112. %note left of Monitor
  113. % (req 5) detect loss of
  114. % communication between Supervisor
  115. % and Monitor
  116. %end note
  117. %end
  118. %note right of Supervisor: (req 6) kill server
  119. %Supervisor->+Supervisor:ComMonitor::Close
  120. %Supervisor->Terminal:print("Monitor is lost")
  121. %note over Supervisor: clear Supervisor
  122. \begin{figure}[htbp]
  123. \begin{center}
  124. \includegraphics[scale=0.4]{./seq_req/req3-6}
  125. \caption{Diagramme de séquence des fonctionnalités 3 à 6}
  126. \label{fig:diag3_6}
  127. \end{center}
  128. \end{figure}
  129. \FloatBarrier
  130. %%%%%%%%%%%%%%%%%%%%%%%%%
  131. \subsubsection{Communication entre le superviseur et le robot}
  132. %%%%%%%%%%%%%%%%%%%%%%%%%
  133. La communication avec le robot s'effectue par le biais d'émetteur-récepteur Xbee. Pour communiquer, il est nécessaire de commencer par ouvrir la communication entre le superviseur et le boîtier Xbee. Toutes les fonctions de gestion de la communication entre le robot et le superviseur sont fournies dans la bibliothèque {\tt robot}. La figure~\ref{fig:diag7_9} illustre les fonctionnalités 7 à 9.
  134. \paragraph{Mettre en place la communication avec le robot.} L'ouverture de la communication (c'est-à-dire la réservation d'un port série) avec le robot se fait à l'aide de la fonction {\tt Open} de la classe {\tt ComRobot}. Cette demande est automatiquement demandée par le moniteur dès que le socket est en place.\\
  135. \req{Dès que la communication avec le moniteur est en place, la communication entre le superviseur et le robot doit être ouverte. Si la communication est active, il faut envoyer un message d'acquittement au moniteur. En cas d'échec, un message le signalant est renvoyé au moniteur.}
  136. \paragraph{Surveillance de la communication avec le robot.} La communication entre le robot et le superviseur peut être perdue. Afin de surveiller cela, il faut mettre en place un mécanisme permettant d'inférer cette perte. L'envoi des messages au robot se fait à l'aide de la fonction {\tt Write} de la classe {\tt ComRobot}. En cas d'échec de communication, la méthode retourne un message contenant un code d'erreur. Cependant, l'envoi d'un message par Xbee peut retourner un échec même si le médium de communication est encore opérationnel.
  137. De ce fait, le simple retour d'un échec ne suffit pas à déterminer si la communication est définitivement perdue ou bien si c'est une erreur fugace. Afin de conclure que la communication est perdue, il faut donc mettre en place un mécanisme de compteur. Pour cela, il faut incrémenter un compteur à chaque échec sur l'envoi d'un message et le remettre à zéro à chaque succès. Si le compteur dépasse 3, la communication est alors déclarée perdue.\\
  138. \req{La communication entre le robot et le superviseur doit être surveillée par un mécanisme de compteur afin de détecter une perte du médium de communication.}
  139. \paragraph{Perte de la communication avec le robot.} Le medium de communication entre le robot et le superviseur est stoppé par l'appel à la fonction {\tt close\_communication\_robot}.\\
  140. \req{Lorsque la communication entre le robot et le superviseur est perdue, un message spécifique doit être envoyé au moniteur. Le système doit fermer la communication entre le robot et le superviseur et se remettre dans un état initial permettant de relancer la communication.}
  141. %%%%%%%%%%%%%%%%%%%%%%%%%
  142. \subsubsection{Démarrage du robot}
  143. %%%%%%%%%%%%%%%%%%%%%%%%%
  144. Tous les messages entre le superviseur et le robot sont décrits dans l'annexe~\ref{sec:sec:comm_rob_sup}. L'envoi d'un message se fait par l'utilisation de la méthode {\tt Write} de la classe {\tt ComRobot}. La figure~\ref{fig:diag10_11} représente la séquence pour les fonctionnalités 10 et 11.\\
  145. \noindent\framebox[\textwidth]{
  146. \begin{minipage}{0.9\textwidth}
  147. {\bf Remarque :} Aucun mécanisme n'est mis en {\oe}uvre dans l'implémentation de {\tt Write} de {\tt ComRobot} pour se prémunir des appels concurrents.
  148. \end{minipage}
  149. }
  150. %%%%%%%%%%%%%%%%
  151. \paragraph{Démarrage sans watchdog du robot.} Le robot a deux modes de démarrage. Un mode simple, dit sans watchdog et un mode évolué exposé ci-après.\\
  152. \req{Lorsque l'utilisateur demande, via le moniteur, le démarrage sans watchdog, le robot doit démarrer dans ce mode. En cas de succès, un message d'acquittement est retourné au moniteur. En cas d'échec, un message indiquant l'échec est transmis au moniteur.}
  153. %note right of Monitor: (req 7) connect robot
  154. %Monitor->Supervisor:connexion robot
  155. %Supervisor->+Supervisor: ComRobot::Open()
  156. %Supervisor-->-Supervisor:err
  157. %alt err == 0
  158. %Supervisor->Monitor: ComMonitor::Write(ACK)
  159. %else
  160. %Supervisor->Monitor: ComMonitor::Write(NO_ACK)
  161. %end
  162. %note right of Monitor
  163. % (req 8) monitor communication with robot
  164. %end note
  165. %loop cmpt <= 3
  166. %Supervisor->+Supervisor: ComRobot:Write(message)
  167. %Supervisor-->-Supervisor:msg
  168. %alt msg is not an error
  169. % note over Supervisor: cmpt = 0
  170. %else
  171. % note over Supervisor: cmpt ++
  172. %end
  173. %end
  174. %note right of Monitor: (req 9) robot communication lost
  175. %Supervisor->Monitor: ComMonitor::Write(LOST_DMB)
  176. %Supervisor->Supervisor: ComRobot::Close()
  177. %note over Supervisor: initialize_communication_robot
  178. \begin{figure}[htbp]
  179. \begin{center}
  180. \includegraphics[scale=0.48]{./seq_req/req7-9}
  181. \caption{Diagramme de séquence des fonctionnalités 7 à 9}
  182. \label{fig:diag7_9}
  183. \end{center}
  184. \end{figure}
  185. \FloatBarrier
  186. %%%%%%%%%%%%%%%%
  187. \paragraph{Démarrage avec watchdog du robot.} En cas de perte de la communication entre le superviseur et le robot, ce dernier n'est plus contrôlable et continue à exécuter des ordres. Pour éviter cela, un mécanisme de surveillance à base de watchdog a été mis en place sur le robot.
  188. Le principe est simple : au démarrage du robot (c.-à-d. quand le robot traite l'ordre de démarrage avec watchdog), un watchdog périodique d'une seconde est lancé. \`A chaque expiration du watchdog un compteur dans le robot est incrémenté. Si le compteur atteint 3, le robot s'arrête et doit être redémarré manuellement. Pour éviter cela, le robot doit recevoir du superviseur un ordre spécifique de rechargement du watchdog (DMB\_RELOAD\_WD). Si l'ordre est valide, le compteur est décrémenté de 1 (minimum 0). Pour que cet ordre soit valide il faut qu'il arrive au moment où le watchdog expire avec un tolérance de 50~ms. \\
  189. \req{Lorsque l'utilisateur demande, via le moniteur, le démarrage avec watchdog, le robot doit démarrer dans ce mode. Un message d'acquittement est retourné au moniteur. En cas d'échec, un message indiquant l'échec est transmis au moniteur.
  190. Une fois le démarrage effectué, le robot doit rester vivant. Pour cela, il faut que le moniteur envoie régulièrement le message de rechargement du watchdog.}
  191. %alt
  192. %note right of Monitor
  193. % (req 10) start without watchdog
  194. %end note
  195. %Monitor->Supervisor:start_robot_without_wd
  196. %Supervisor->+Supervisor: ComRobot::Write(START_WITHOUT_WD)
  197. %Supervisor-->-Supervisor:err
  198. %note over Monitor, Supervisor:ack or no_ack
  199. %
  200. %else
  201. %note right of Monitor
  202. % (req 11) start with watchdog
  203. %end note
  204. %
  205. %Monitor->Supervisor:start_robot_with_wd
  206. %Supervisor->+Supervisor: ComRobot::Write(START_WITH_WD)
  207. %Supervisor-->-Supervisor:err
  208. %alt err == ROBOT_OK
  209. %Supervisor->Monitor: ComMonitor::Write(message(ACK))
  210. %note over Supervisor
  211. % start to reload wd periodically
  212. %end note
  213. %else
  214. %Supervisor->Monitor: ComMonitor::Write(message(NO_ACK)
  215. %end
  216. %end
  217. \begin{figure}[htbp]
  218. \begin{center}
  219. \includegraphics[scale=0.4]{./seq_req/req10-11}
  220. \caption{Diagramme de séquence des fonctionnalités 10 et 11}
  221. \label{fig:diag10_11}
  222. \end{center}
  223. \end{figure}
  224. \FloatBarrier
  225. %%%%%%%%%%%%%%%%%%%%%%%%%
  226. \subsubsection{Déplacement et état du robot}
  227. %%%%%%%%%%%%%%%%%%%%%%%%%
  228. Le robot n'a aucune intelligence et ne réagit qu'aux ordres qu'il reçoit. La figure~\ref{fig:diag12_13} représente la séquence pour les fonctionnalités 12 et 13.
  229. %%%%%%%%%%%%%%%%%%%%%%%%%
  230. \paragraph{Déplacement manuel du robot.} Le robot peut recevoir cinq ordres de mouvement (avancer, reculer, tourner à droite, tourner à gauche et stopper). Lorsque l'utilisateur presse les flèches de l'interface graphique un message est envoyé au superviseur avec le mouvement à réaliser.\\
  231. \req{Lorsque qu'un ordre de mouvement est reçu par le superviseur, le robot doit réaliser ce déplacement en moins de 100~ms.}
  232. %%%%%%%%%%%%%%%%%%%%%%%%%
  233. \paragraph{Niveau de batterie du robot.} Il est possible de récupérer le niveau de la batterie du robot à l'aide de la fonction {\tt Write} de {\tt ComRobot} avec l'entête {\tt DMB\_GET\_VBAT}. La valeur retournée est ensuite à transmettre au moniteur.\\
  234. \req{Le niveau de la batterie du robot doit être mis à jour toutes les 500~ms sur le moniteur.}
  235. %par
  236. %note right of Monitor
  237. % (req 12) move robot
  238. %end note
  239. %loop
  240. %Monitor->Supervisor:move_robot(move)
  241. %note over Supervisor: treat the message
  242. %Supervisor->Supervisor: ComRobot::Write(Message(move))
  243. %end
  244. %else
  245. %note right of Monitor
  246. % (req 13) check battery
  247. %end note
  248. %loop 500 ms
  249. %Supervisor->+Supervisor: ComRobot::Write(Message(GET_VBAT))
  250. %Supervisor-->-Supervisor: levelBat
  251. %Supervisor->Monitor:ComMonitor::Write(Message(levelBat))
  252. %end
  253. %end
  254. \begin{figure}[htbp]
  255. \begin{center}
  256. \includegraphics[scale=0.4]{./seq_req/req12-13}
  257. \caption{Diagramme de séquence des fonctionnalités 12 et 13}
  258. \label{fig:diag12_13}
  259. \end{center}
  260. \end{figure}
  261. \FloatBarrier
  262. %%%%%%%%%%%%%%%%%%%%%%%%%
  263. \subsubsection{Gestion de la caméra}
  264. %%%%%%%%%%%%%%%%%%%%%%%%%
  265. Les fonctions permettant la manipulation des images sont fournies dans les librairies {\tt img} et {\tt camera}. L'implémentation des méthodes utilise \textsc{openCV}, une libraire libre en C/C++ de traitement d'images.
  266. %%%%%%%%%%%%%%%%%%%%%%%%%
  267. \paragraph{Ouverture de la caméra.} La méthode {\tt Open} de la classe {\tt Camera} donne accès à la caméra.\\
  268. \req{La caméra doit être démarrée suite à une demande provenant du moniteur. Si l'ouverture de la caméra a échoué, il faut envoyer un message au moniteur.}
  269. %%%%%%%%%%%%%%%%%%%%%%%%%
  270. \paragraph{Capture d'une image (mode nominal).} La méthode {\tt Grab} de {\tt Camera} permet de capturer une image. L'envoi de l'image au moniteur s'effectue normalement par l'envoi d'un message\footnote{L'image est compressée lors de l'envoi du message.}. La fréquence de capture d'une image est fixée par un paramètre lors de l'instanciation d'un objet {\tt Camera}.\\
  271. \req{Dès que la caméra est ouverte, une image doit être envoyée au moniteur toutes les 100 ms.}
  272. %%%%%%%%%%%%%%%%%%%%%%%%%
  273. \paragraph{Fermeture de la caméra.} La méthode {\tt Close} de la classe {\tt Camera} permet de fermer proprement la caméra.\\
  274. \req{La caméra doit être fermée suite à une demande provenant du moniteur. Un message doit être envoyé au moniteur pour signifier l'acquittement de la demande. L'envoi périodique des images doit alors être stoppé.}
  275. %note right of Monitor
  276. %(req 14) open camera
  277. %end note
  278. %Monitor->Supervisor: open camera
  279. %Supervisor->+Supervisor: Camera::Open()
  280. %Supervisor-->-Supervisor: err
  281. %note over Monitor, Supervisor: ack or no_ack
  282. %par
  283. %loop camera active
  284. %note right of Monitor
  285. %(req 15) capture image
  286. %end note
  287. %Supervisor->+Supervisor: Camera:Grab()
  288. %Supervisor-->-Supervisor: image
  289. %Supervisor->+Supervisor: Img::ToJpg(image)
  290. %Supervisor-->-Supervisor: jpgimage
  291. %Supervisor->Monitor:ComMonitor::Write(Message(jpgimage))
  292. %end
  293. %else
  294. % note right of Monitor
  295. % (req 16) close camera
  296. % end note
  297. % Monitor->Supervisor: close camera
  298. % Supervisor->+Supervisor: Camera::Close()
  299. % Supervisor-->-Supervisor: err
  300. % note over Monitor, Supervisor: ack or no_ack
  301. %end
  302. \begin{figure}[htbp]
  303. \begin{center}
  304. \includegraphics[scale=0.4]{./seq_req/req14-16}
  305. \caption{Diagramme de séquence des fonctionnalités 14 et 16}
  306. \label{fig:diag14_15}
  307. \end{center}
  308. \end{figure}
  309. \FloatBarrier
  310. \paragraph{Calibration de l'arène} Pour accélérer le traitement de l'image et le rendre plus stable\footnote{Si vous placez un robot en dehors de l'arène, il y a de fortes chances pour que cela perturbe le calcul de la position du robot.}, il est préférable de limiter la zone d'étude à l'arène. Pour cela il est nécessaire de faire un pré-traitement qui recherche l'arène.
  311. Le calcul se fait par l'appel à la méthode {\tt SearchArena} de {\tt Img}. Il est possible de tracer sur l'image l'arène en faisant appel à la méthode {\tt DrawArena}.\\
  312. \req{Suite à une demande de recherche de l'arène, le superviseur doit stopper l'envoi périodique des images, faire la recherche de l'arène et renvoyer une image sur laquelle est dessinée cette arène. Si aucune arène n'est trouvée un message d'échec est envoyé.\\
  313. L'utilisateur doit ensuite valider visuellement via le moniteur si l'arène a bien été trouvée. L'utilisateur peut :
  314. \begin{itemize}
  315. \item valider l'arène : dans ce cas, le superviseur doit sauvegarder l'arène trouvée (pour l'utiliser ultérieurement) puis retourner dans son mode d'envoi périodique des images en ajoutant à l'image l'arène dessinée.
  316. \item annuler la recherche : dans ce cas, le superviseur doit simplement retourner dans son mode d'envoi périodique des images et invalider la recherche.
  317. \end{itemize}
  318. }
  319. %note left of Monitor:(req 17) find arena
  320. %Monitor->Supervisor:find arena
  321. %note over Supervisor:stop periodic image
  322. %Supervisor->+Supervisor: Camera:Grab()
  323. %Supervisor-->-Supervisor: image
  324. %Supervisor->+Supervisor: Img::SearchArena(image)
  325. %Supervisor-->-Supervisor: arena
  326. %alt arena == NULL
  327. %Supervisor->Monitor:ComMonitor::Write(Message(NO_ACK))
  328. %else
  329. %Supervisor->+Supervisor: Img::DrawArena(image, arena)
  330. %Supervisor-->-Supervisor: image
  331. %Supervisor->+Supervisor: Img::ToJpg(image)
  332. %Supervisor-->-Supervisor: jpgimage
  333. %Supervisor->Monitor:ComMonitor::Write(Message(jpgimage))
  334. %alt
  335. % Monitor->Supervisor: arena ok
  336. % note over Supervisor: save arena
  337. %else
  338. % Monitor->Supervisor: arena ko
  339. % note over Supervisor: delete arena
  340. %end
  341. %end
  342. %
  343. %note over Supervisor: restart periodic image
  344. \begin{figure}[htbp]
  345. \begin{center}
  346. \includegraphics[scale=0.4]{./seq_req/req17}
  347. \caption{Diagramme de séquence de la fonctionnalité 17}
  348. \label{fig:diag16}
  349. \end{center}
  350. \end{figure}
  351. \FloatBarrier
  352. %%%%%%%%%%%%%
  353. \paragraph{Calcul de la position du robot.} Le traitement d'une image pour trouver la position du robot se fait à l'aide de la méthode {\tt SearchRobot} de {\tt Img}. Il est possible de dessiner sur l'image la position trouvée en faisant appel à la méthode {\tt DrawRobot}. La position est envoyée du superviseur vers le moniteur en utilisant un message avec une entête dédié.\\
  354. \req{Suite à une demande de l'utilisateur de calculer la position du robot, le superviseur doit calculer cette position, dessiner sur l'image le résultat et envoyer un message au moniteur avec la position toutes les 100~ms. Si le robot n'a pas été trouvé, un message de position est envoyé avec une position (-1,-1).}
  355. %%%%%%%%%%%%%
  356. \paragraph{Stopper le calcul de la position du robot.} Il est possible pour l'utilisateur de demander l'arrêt du calcul de la position.\\
  357. \req{Suite à une demande de l'utilisateur de stopper le calcul de la position du robot, le superviseur doit rebasculer dans un mode d'envoi de l'image sans le calcul de la position.}
  358. % note right of Monitor:(req 18) compute position
  359. %Monitor->Supervisor:find_position
  360. %loop
  361. %Supervisor->+Supervisor: Camera:Grab()
  362. %Supervisor-->-Supervisor: image
  363. %Supervisor->+Supervisor: Img::SearchRobot(image, arena)
  364. %Supervisor-->-Supervisor: position
  365. %alt position != null
  366. % Supervisor->+Supervisor: Img::DrawRobot(image, positin)
  367. % Supervisor-->-Supervisor: image
  368. % Supervisor->Monitor:ComMonitor::Write(Message(position))
  369. %else
  370. % Supervisor->Monitor:ComMonitor::Write(Message(position nulle))
  371. %end
  372. % Supervisor->+Supervisor: Img::ToJpg(image)
  373. % Supervisor-->-Supervisor: jpgimage
  374. % Supervisor->Monitor:ComMonitor::Write(Message(image))
  375. %end
  376. \begin{figure}[htbp]
  377. \begin{center}
  378. \includegraphics[scale=0.4]{./seq_req/req18}
  379. \caption{Diagramme de séquence de la fonctionnalité 18}
  380. \label{fig:diag17}
  381. \end{center}
  382. \end{figure}
  383. \FloatBarrier
  384. %%%%%%%%%%%%%%%%%%%%%%%%%%
  385. \subsubsection{Réaliser une mission}
  386. %%%%%%%%%%%%%%%%%%%%%%%%%%
  387. TBD
  388. %Les missions à effectuer consistent à déplacer le robot d'une position à une autre. Le choix de la destination se fait par l'utilisateur en cliquant sur l'image du moniteur puis en envoyant un message de type mission en la validant avec le bouton\og send mission \fg.
  389. %
  390. %Une mission est constituée de différents champs décrits dans un objet \texttt{DMission}. La position à atteindre peut être récupérée à l'aide de la méthode \texttt{d\_mission\_get\_position}. De plus, une mission est identifiée par un numéro contenu dans son champ \texttt{id}.
  391. %
  392. %La réalisation d'une mission s'effectue à l'aide des méthodes \texttt{d\_robot\_move} et \texttt{d\_robot\_turn}. Quand le point final est atteint, le superviseur doit envoyer un message de type mission portant l'identifiant de la mission. La méthode {\tt d\_message\_mission\_terminate} permet de construire un message portant les valeurs appropriées.
  393. %
  394. %Il est aussi possible pour l'utilisateur de mettre fin à une mission en cours en envoyant un message d'alerte (bouton \og Stop mission \fg). Ce message est de type {\tt MESSAGE\_TYPE\_MISSION} et porte \texttt{MISSION\_TYPE\_STOP} comme valeur dans le champ type. Dans ce cas le robot doit immédiatement s'arrêter puis le superviseur doit envoyer un message de fin de mission.
  395. %
  396. %Le diagramme~\ref{diag:seq_position} donne un aperçu de cette séquence.\\
  397. %
  398. % \noindent\fcolorbox{black}{Fond}{% couleur du texte, couleur du fond
  399. %\begin{minipage}{\textwidth}
  400. %Réaliser la fonction qui permet d'effectuer une mission. Aucune méthode n'est fournie pour concevoir le déplacement, le plus simple étant de tourner le robot dans la direction du point à atteindre puis d'avancer de la distance souhaitée.
  401. %\end{minipage}
  402. %}