Browse Source

ajout rapport étudiant

PE Hladik 2 years ago
parent
commit
6db2a525a2

BIN
doc/sujets/tex/rapport_etudiant/.DS_Store View File


BIN
doc/sujets/tex/rapport_etudiant/figures-pdf/.DS_Store View File


BIN
doc/sujets/tex/rapport_etudiant/figures-pdf/diag_fonc_gen.pdf View File


BIN
doc/sujets/tex/rapport_etudiant/figures-pdf/diag_fonc_moniteur.pdf View File


doc/sujets/tex/conception/figures_pdf/activity/th_receiveFromMon.png → doc/sujets/tex/rapport_etudiant/figures-pdf/th_receiveFromMon.png View File


doc/sujets/tex/conception/figures_pdf/activity/th_sendToMon.png → doc/sujets/tex/rapport_etudiant/figures-pdf/th_sendToMon.png View File


doc/sujets/tex/conception/figures_pdf/activity/th_server.png → doc/sujets/tex/rapport_etudiant/figures-pdf/th_server.png View File


BIN
doc/sujets/tex/rapport_etudiant/figures/.DS_Store View File


+ 3224
- 0
doc/sujets/tex/rapport_etudiant/figures/diag_fonc_gen.graffle
File diff suppressed because it is too large
View File


+ 2917
- 0
doc/sujets/tex/rapport_etudiant/figures/diag_fonc_moniteur.graffle
File diff suppressed because it is too large
View File


+ 512
- 0
doc/sujets/tex/rapport_etudiant/rapport_etudiant.tex View File

@@ -0,0 +1,512 @@
1
+% Description du contenu du rapport à rendre pour l'UF temps réel en 4AE et 4IR
2
+% Auteur : P.-E. Hladik
3
+% Institut : INSA de Toulouse
4
+
5
+\documentclass[11pt, a4paper]{paper}
6
+\usepackage{a4wide,color}
7
+
8
+\usepackage[utf8]{inputenc}
9
+\usepackage[T1]{fontenc}
10
+\usepackage[frenchb]{babel}
11
+
12
+\usepackage{graphicx}
13
+\usepackage{amssymb}
14
+\usepackage{hyperref}
15
+
16
+\usepackage{amstext}
17
+\usepackage{amsmath}
18
+
19
+\usepackage[dvipsnames]{xcolor}
20
+
21
+\usepackage{placeins}
22
+
23
+\newcounter{cptreq}
24
+
25
+
26
+\usepackage{framed}
27
+
28
+
29
+\title{{\Huge Rapport de projet De Stijl 2.0}\\
30
+{\large version \today}\\
31
+---\\
32
+}
33
+\author{\color{blue}{Mettez ici vos noms et les parties sur lesquelles vous avez travaillées :}\\
34
+\color{blue}{conception, robot, vidéo, mission, intégration, rédaction du compte-rendu}\\
35
+\color{blue}{Exemple : P.-E. Hladik (conception, robot, rédaction du compte-rendu)}
36
+}
37
+
38
+\begin{document}
39
+
40
+%%%%%%%%%%%%%%
41
+% PAGE DE GARDE
42
+\maketitle
43
+
44
+
45
+{\color{red}
46
+\begin{framed}
47
+\begin{center}{\bf\Large --- Ce qu'il faut faire --- } \end{center}
48
+
49
+{\bf Remplacez tous les textes en bleu et supprimer les textes en rouge}\\
50
+
51
+
52
+{\bf Le rapport est à rendre en pdf et à déposer sur moodle avant le 31 mars 2019 23h59:
53
+\url{https://moodle.insa-toulouse.fr/mod/assign/view.php?id=33071}}\\
54
+
55
+{\bf Vous devez \underline{aussi} rendre les fichiers {\tt tasks.h} et {\tt tasks.cpp}.}\\
56
+
57
+Vous pouvez utiliser word ou un autre logiciel d'édition pour rédiger ce rapport, par contre vous devez  {\bf impérativement respecter la structure ci-après et le rendre au format pdf}.\\
58
+
59
+
60
+Critères d'évaluation :
61
+\begin{itemize}
62
+	\item Qualité rédactionnelle,
63
+	\item Exhaustivité et justesse des règles de codage,
64
+	\item Qualité de la conception (clarté, respect de la syntaxe, exhaustivité, justesse),
65
+	\item Qualité des explications,
66
+	\item Respect des règles dans la production du code.\\
67
+\end{itemize}
68
+
69
+Compétences évaluées :
70
+\begin{itemize}
71
+	\item rédaction et communication sur un dossier de conception,
72
+	\item concevoir une application concurrente temps réel,
73
+	\item analyser une conception,
74
+	\item passer d'un modèle de conception à une implémentation,
75
+	\item écriture de code et utilisation de primitives au niveau système.
76
+\end{itemize}
77
+\end{framed}
78
+}
79
+
80
+%%%%%%%%%%%%%%
81
+% DEBUT DU RAPPORT
82
+\newpage
83
+
84
+
85
+
86
+
87
+%%%%%%%%%%%%%%
88
+% CONCEPTION
89
+\section{Conception}
90
+
91
+{\color{red} Mettez dans cette partie tous les éléments de votre conception en particulier vos diagrammes AADL (vue globale du système) et les diagrammes d'activité (détails des threads). Cette partie doit être auto-suffisante pour comprendre votre application.
92
+
93
+Pour faciliter la lecture des schémas, vous allez présenter votre conception en trois parties, l'une focalisée sur la communication entre le moniteur et le superviseur, la seconde consacrée au traitement vidéo et la troisième au contrôle du robot.
94
+
95
+Si vous le souhaitez, au lieu de dessiner vos diagrammes sous un éditeur, vous pouvez joindre un scan de vos schémas — ils doivent être lisibles et propres.}
96
+
97
+% VUE GENERAL DU SYSTEME
98
+\subsection{Diagramme fonctionnel général}
99
+
100
+{\color{red} Mettez ici un diagramme fonctionnel qui présente les principaux blocs de votre conception. Pour cela, inspirez vous du diagramme ci-dessous (fig.~\ref{fig:diag_fonc_gen}) en indiquant pour chaque groupe de threads les données et ports partagés. La figure~\ref{fig:diag_fonc_gen} a été réalisée à partir du document de conception. {\bf Vous devez absolument conserver le découpage en trois groupes de threads ({\tt th\_group\_gestion\_moniteur}, {\tt th\_group\_vision}, {\tt th\_group\_gestion\_robot}).}}
101
+
102
+\begin{figure}[htbp]
103
+\begin{center}
104
+{\includegraphics[scale=.5]{./figures-pdf/diag_fonc_gen}}
105
+{\caption{Diagramme fonctionnel du système}}
106
+\end{center}
107
+\label{fig:diag_fonc_gen}
108
+\end{figure}
109
+\FloatBarrier
110
+
111
+% DIAGRAMME FONCTIONNEL GT MONITEUR
112
+\subsection{Groupe de threads gestion du moniteur}
113
+
114
+{\color{red}Placez ici :
115
+\begin{itemize}
116
+\item le diagramme fonctionnel en AADL décrivant le groupe de threads de gestion du moniteur (voir exemple de la figure~\ref{fig:diag_fonc_moniteur} réalisée à partir du dossier de conception),
117
+\item remplir le tableau~\ref{tab:gt_moniteur} pour expliquer le rôle de chacun des threads,
118
+\item les diagrammes d'activité de chaque thread de ce groupe.
119
+\end{itemize}
120
+
121
+Décrivez tous les éléments (paramètres, variables, etc.) qui vous semblent pertinents pour comprendre les diagrammes.}
122
+
123
+% DIAGRAMME FONCTIONNEL GT MONITEUR
124
+\subsubsection{Diagramme fonctionnel du groupe gestion du moniteur}
125
+
126
+{\color{red} Exemple de diagramme fonctionnel pour le groupe de thread de gestion du moniteur. Mettez à jour ce diagramme avec votre conception.}
127
+
128
+\begin{figure}[htbp]
129
+\label{fig:diag_fonc_moniteur}
130
+\begin{center}
131
+{\includegraphics[scale=.5]{./figures-pdf/diag_fonc_moniteur}}
132
+{\caption{Diagramme fonctionnel du groupe de threads gestion du moniteur}}
133
+\end{center}
134
+\end{figure}
135
+\FloatBarrier
136
+
137
+% DESCRIPTION THREADS GT MONITEUR
138
+\subsubsection{Description des threads  du groupe gestion du moniteur}
139
+{\color{red} Remplissez le tableau ci-dessous pour expliquer le rôle de chaque thread et donner son niveau de priorité.}
140
+
141
+
142
+\begin{table}[htp]
143
+\caption{Description des threads du groupe {\tt th\_group\_gestion\_moniteur}}
144
+\begin{center}
145
+\begin{tabular}{|p{3cm}|p{8.5cm}|p{2cm}|}
146
+\hline
147
+\bf Nom du thread &	\bf Rôle &	\bf Priorité \\
148
+\hline
149
+\hline
150
+\color{blue}tCommuniquer	& \color{blue}Prend en charge les messages entrants depuis le moniteur & \color{blue}25\\
151
+\hline
152
+\color{blue}tEnvoyer	& \color{blue}Envoi l'ensemble des messages du superviseur au moniteur & \color{blue}30\\
153
+\hline
154
+\color{blue}... &	\color{blue}... &	\color{blue}...\\
155
+\hline
156
+\end{tabular}
157
+\end{center}
158
+\label{tab:gt_moniteur}
159
+\end{table}%
160
+
161
+% DIAGRAMMES D'ACTIVITE GT MONITEUR
162
+\subsubsection{Diagrammes d'activité  du groupe gestion du moniteur}
163
+{\color{red}Décrivez le comportement de chacun de vos threads avec des diagrammes d'activité. Apportez les explications qui vous semblent nécessaires pour comprendre votre conception. A titre d'exemple les diagrammes fonctionnels tirés du document de conception sont remis.}
164
+
165
+\begin{figure}[htbp]
166
+\label{fig:act_communiquer}
167
+\begin{center}
168
+{\includegraphics[scale=.3]{./figures-pdf/th_receiveFromMon.png}}
169
+{\caption{Diagramme d'activité du thread {\tt th\_receiveFromMon}}}
170
+\end{center}
171
+\end{figure}
172
+
173
+
174
+\begin{figure}[htbp]
175
+\label{fig:act_envoyer}
176
+\begin{center}
177
+{\includegraphics[scale=.3]{./figures-pdf/th_sendToMon}}
178
+{\caption{Diagramme d'activité du thread {\tt th\_sendToMon}}}
179
+\end{center}
180
+\end{figure}
181
+
182
+
183
+\begin{figure}[htbp]
184
+\label{fig:act_envoyer}
185
+\begin{center}
186
+{\includegraphics[scale=.3]{./figures-pdf/th_server}}
187
+{\caption{Diagramme d'activité du thread {\tt th\_server}}}
188
+\end{center}
189
+\end{figure}
190
+\FloatBarrier
191
+
192
+% DIAGRAMME FONCTIONNEL GT VISION
193
+\subsection{Groupe de threads vision}
194
+
195
+% DIAGRAMME FONCTIONNEL GT VISION
196
+\subsubsection{Diagramme fonctionnel du groupe vision}
197
+
198
+{\color{blue} Ajoutez le diagramme fonctionnel du groupe de threads de vision.}
199
+
200
+% DESCRIPTION THREADS GT VISION
201
+\subsubsection{Description des threads du groupe vision}
202
+{\color{red} Remplissez le tableau ci-dessous pour expliquer le rôle de chaque thread et donner son niveau de priorité.}
203
+
204
+
205
+\begin{table}[htp]
206
+\caption{Description des threads du groupe {\tt th\_group\_vision}}
207
+\begin{center}
208
+\begin{tabular}{|p{3cm}|p{8.5cm}|p{2cm}|}
209
+\hline
210
+\bf Nom du thread &	\bf Rôle &	\bf Priorité \\
211
+\hline
212
+\hline
213
+\color{blue}... &	\color{blue}... &	\color{blue}...\\
214
+\hline
215
+\end{tabular}
216
+\end{center}
217
+\label{tab:gt_moniteur}
218
+\end{table}%
219
+\FloatBarrier
220
+
221
+% DIAGRAMMES D'ACTIVITE GT VISION
222
+\subsubsection{Diagrammes d'activité du groupe vision}
223
+{\color{blue}Décrivez le comportement de chacun de vos threads avec des diagrammes d'activité. Apportez les explications qui vous semblent nécessaires pour comprendre votre conception.}
224
+
225
+
226
+% DIAGRAMME FONCTIONNEL GT ROBOT
227
+\subsection{Groupe de threads gestion du robot}
228
+
229
+% DIAGRAMME FONCTIONNEL GT ROBOT
230
+\subsubsection{Diagramme fonctionnel du groupe gestion robot}
231
+{\color{blue} Ajoutez le diagramme fonctionnel du groupe de threads de gestion du robot.}
232
+
233
+% DESCRIPTION THREADS GT ROBOT
234
+\subsubsection{Description des threads du groupe gestion robot}
235
+{\color{red} Remplissez le tableau ci-dessous pour expliquer le rôle de chaque thread et donner son niveau de priorité.}
236
+
237
+
238
+\begin{table}[htp]
239
+\caption{Description des threads du groupe {\tt th\_group\_gestion\_robot}}
240
+\begin{center}
241
+\begin{tabular}{|p{3cm}|p{8.5cm}|p{2cm}|}
242
+\hline
243
+\bf Nom du thread &	\bf Rôle &	\bf Priorité \\
244
+\hline
245
+\hline
246
+\color{blue}... &	\color{blue}... &	\color{blue}...\\
247
+\hline
248
+\end{tabular}
249
+\end{center}
250
+\label{tab:gt_moniteur}
251
+\end{table}%
252
+\FloatBarrier
253
+
254
+% DIAGRAMMES D'ACTIVITE GT ROBOT
255
+\subsubsection{Diagrammes d'activité du groupe robot}
256
+{\color{blue}Décrivez le comportement de chacun de vos threads avec des diagrammes d'activité. Apportez les explications qui vous semblent nécessaires pour comprendre votre conception.}
257
+
258
+
259
+%%%%%%%%%%%%%%%
260
+% ANALYSE ET VALIDATION
261
+\section{Analyse et validation de la conception}
262
+
263
+{\color{red}Pour chacune des fonctionnalités attendues, indiquez si elle a été réalisée. Ajoutez d'éventuelles remarques de conception si le fonctionnement n'est pas exactement celui attendu et justifiez le respect des propriétés temporelles. Vous n'êtes pas obligé de répondre à ces éléments pour les fonctionnalités réalisées dans la conception préliminaire (ces fonctionnalités sont indiquées dans la suite par un astérisque). Si vous ne souhaitez pas apporter de détails supplémentaires pour ces fonctionnalités, supprimez les de la liste ci-dessous.}
264
+
265
+{\color{gray}
266
+\stepcounter{cptreq}
267
+\subsection{Fonctionnalité \thecptreq *}
268
+
269
+\paragraph{Description :} 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.
270
+
271
+\paragraph{\color{black}Réalisation :}  {\color{blue} Fait en partie. La fonctionnalité est impléméntée sauf pour l'arrêt suite à l'échec de démarrage du serveur. L'implémentation actuelle stoppe la tâche en charge du démarrage du serveur, mais pas l'ensemble de l'application. Après discussion avec le client, la version actuelle est suffisante.}
272
+}
273
+%%%
274
+{\color{gray}
275
+\stepcounter{cptreq}
276
+\subsection{Fonctionnalité \thecptreq *}
277
+
278
+\paragraph{Description :} La connexion entre le moniteur et le superviseur (via le socket) doit être établie suite à la demande de connexion de l'utilisateur.
279
+
280
+\paragraph{\color{black}Réalisation :}  {\color{red} indiquez si la fonctionnalité est traitée et s'il y a des remarques particulières.}
281
+}
282
+
283
+%%%
284
+{\color{gray}
285
+\stepcounter{cptreq}
286
+\subsection{Fonctionnalité \thecptreq *}
287
+
288
+\paragraph{Description :} Tous les messages envoyés depuis le moniteur doivent être réceptionnés par le superviseur.
289
+
290
+\paragraph{\color{black}Réalisation :}  {\color{red} indiquez si la fonctionnalité est traitée et s'il y a des remarques particulières.}
291
+%%%
292
+\stepcounter{cptreq}
293
+\subsection{Fonctionnalité \thecptreq *}
294
+
295
+\paragraph{Description :} L'application superviseur doit être capable d'envoyer les messages au moniteur (via le serveur) avec un délai d'au plus 10~ms.
296
+
297
+\paragraph{\color{black}Réalisation :}  {\color{red} indiquez si la fonctionnalité est traitée et s'il y a des remarques particulières.}
298
+}
299
+%%%
300
+\stepcounter{cptreq}
301
+\subsection{Fonctionnalité \thecptreq}
302
+
303
+\paragraph{Description :} 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.
304
+
305
+\paragraph{\color{black}Réalisation :}  {\color{red} indiquez si la fonctionnalité est traitée et s'il y a des remarques particulières.}
306
+%%%
307
+\stepcounter{cptreq}
308
+\subsection{Fonctionnalité \thecptreq}
309
+
310
+\paragraph{Description :} 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.
311
+
312
+\paragraph{\color{black}Réalisation :}  {\color{red} indiquez si la fonctionnalité est traitée et s'il y a des remarques particulières.}
313
+%%%
314
+{\color{gray}
315
+\stepcounter{cptreq}
316
+\subsection{Fonctionnalité \thecptreq *}
317
+
318
+\paragraph{Description :} 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.
319
+
320
+\paragraph{\color{black}Réalisation :}  {\color{red} indiquez si la fonctionnalité est traitée et s'il y a des remarques particulières.}
321
+}
322
+%%%
323
+\stepcounter{cptreq}
324
+\subsection{Fonctionnalité \thecptreq}
325
+
326
+\paragraph{Description :} 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.
327
+
328
+\paragraph{\color{black}Réalisation :}  {\color{red} indiquez si la fonctionnalité est traitée et s'il y a des remarques particulières.}
329
+
330
+%%%
331
+\stepcounter{cptreq}
332
+\subsection{Fonctionnalité \thecptreq}
333
+
334
+\paragraph{Description :} 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.
335
+
336
+\paragraph{\color{black}Réalisation :}  {\color{red} indiquez si la fonctionnalité est traitée et s'il y a des remarques particulières.}
337
+
338
+%%%
339
+{\color{gray}
340
+\stepcounter{cptreq}
341
+\subsection{Fonctionnalité \thecptreq *}
342
+
343
+\paragraph{Description :} 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.
344
+
345
+\paragraph{\color{black}Réalisation :}  {\color{red} indiquez si la fonctionnalité est traitée et s'il y a des remarques particulières.}
346
+}
347
+%%%
348
+\stepcounter{cptreq}
349
+\subsection{Fonctionnalité \thecptreq}
350
+
351
+\paragraph{Description :} 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.
352
+
353
+Une fois le démarrage effectué, le robot doit rester vivant en envoyant régulièrement le message de rechargement du watchdog.
354
+
355
+\paragraph{\color{black}Réalisation :}  {\color{red} indiquez si la fonctionnalité est traitée et s'il y a des remarques particulières.}
356
+
357
+%%%
358
+{\color{gray}
359
+\stepcounter{cptreq}
360
+\subsection{Fonctionnalité \thecptreq *}
361
+
362
+\paragraph{Description :} 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.
363
+
364
+\paragraph{\color{black}Réalisation :}  {\color{blue} Cette fonctionnalité a été implémentée à l'aide d'une tâche qui envoie toutes les 100~ms un ordre de mouvement au robot une fois que celui-ci est démarré (tâche th\_move). Cette implémentation ne garantit pas que le temps soit inférieur à 100~ms entre la réception du message et sa prise en compte par le robot. En effet, le temps de traitement de la réception par la tâche th\_receiveFromMon, le temps de traitement de la tâche th\_move et celui de l'envoi de l'ordre via le Xbee ne sont pas considérés. Afin de réduire ces délais, les priorités de  th\_receiveFromMon et de th\_move sont élevés mais ne permettent pas de garantir l'exigence de temps. Augmenter la fréquence de la tâche th\_move permettrait de tenir cette contrainte, mais risque de surcharger la communication avec le robot (une version avec l'envoi de l'ordre que s'il a changé serait souhaitable). Finalement, une version asynchrone (attente d'un événement-donnée entre th\_receiveFromMon et de th\_move) aurait été préférable. Cependant, après discussion avec le client, la version périodique à 100~ms est cependant validée.}
365
+}
366
+%%%
367
+\stepcounter{cptreq}
368
+\subsection{Fonctionnalité \thecptreq}
369
+
370
+\paragraph{Description :} Le niveau de la batterie du robot doit être mis à jour toutes les 500~ms sur le moniteur.
371
+
372
+\paragraph{\color{black}Réalisation :}  {\color{red} indiquez si la fonctionnalité est traitée et s'il y a des remarques particulières.}
373
+%%%
374
+\stepcounter{cptreq}
375
+\subsection{Fonctionnalité \thecptreq}
376
+
377
+\paragraph{Description :} 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.
378
+
379
+\paragraph{\color{black}Réalisation :}  {\color{red} indiquez si la fonctionnalité est traitée et s'il y a des remarques particulières.}
380
+%%%
381
+\stepcounter{cptreq}
382
+\subsection{Fonctionnalité \thecptreq}
383
+
384
+\paragraph{Description :} Dès que la caméra est ouverte, une image doit être envoyée au moniteur toutes les 100 ms.
385
+
386
+\paragraph{\color{black}Réalisation :}  {\color{red} indiquez si la fonctionnalité est traitée et s'il y a des remarques particulières.}
387
+%%%
388
+\stepcounter{cptreq}
389
+\subsection{Fonctionnalité \thecptreq}
390
+
391
+\paragraph{Description :} 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é.
392
+
393
+\paragraph{\color{black}Réalisation :}  {\color{red} indiquez si la fonctionnalité est traitée et s'il y a des remarques particulières.}
394
+%%%
395
+\stepcounter{cptreq}
396
+\subsection{Fonctionnalité \thecptreq}
397
+
398
+\paragraph{Description :} 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é.\\
399
+
400
+L'utilisateur doit ensuite valider visuellement via le moniteur si l'arène a bien été trouvée. L'utilisateur peut :
401
+\begin{itemize}
402
+	\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.
403
+ 	\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.
404
+\end{itemize}
405
+
406
+\paragraph{\color{black}Réalisation :}  {\color{red} indiquez si la fonctionnalité est traitée et s'il y a des remarques particulières.}
407
+%%%
408
+\stepcounter{cptreq}
409
+\subsection{Fonctionnalité \thecptreq}
410
+
411
+\paragraph{Description :} 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).
412
+
413
+\paragraph{\color{black}Réalisation :}  {\color{red} indiquez si la fonctionnalité est traitée et s'il y a des remarques particulières.}
414
+\stepcounter{cptreq}
415
+\subsection{Fonctionnalité \thecptreq}
416
+
417
+\paragraph{Description :} 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.
418
+
419
+\paragraph{\color{black}Réalisation :}  {\color{red} indiquez si la fonctionnalité est traitée et s'il y a des remarques particulières.}
420
+
421
+
422
+%%%%%%%%%%%%%%%%%%%
423
+% TRANSFORMATION AADL2XENO
424
+\section{Transformation AADL vers Xenomai}
425
+ 
426
+ {\color{red} Cette section est consacrée à la méthode pour passer d'un modèle AADL à un code sous Xenomai. Pour chacun des éléments AADL, vous expliquerez {\bf comment vous l'avez traduit en code} et quels {\bf services de Xenomai} vous avez utilisés {\bf en expliquant ce qu'ils font}. Chaque élément devra être illustré avec des {\bf extraits de code de votre projet}.}
427
+ 
428
+ % THREAD
429
+\subsection{Thread}
430
+% INSTANCIATION THREAD
431
+\subsubsection{Instanciation et démarrage}
432
+ {\color{blue} Expliquer comment vous implémentez sous Xenomai l'instanciation et le démarrage d'un  thread AADL.}
433
+ 
434
+ {\color{blue} {\bf Exemple de réponse} : Chaque thread a été implémenté par un {\tt RT\_TASK} déclarés dans le fichier {\tt tasks.h}. La création de la tâche se fait à l'aide du service {\tt rt\_task\_create} et son démarrage à l'aide de {\tt rt\_task\_start}. Toutes les tâches sont crées dans la méthode {\tt init} de {\tt tasks.cpp} et démarrées dans la méthode {\tt run}.
435
+
436
+Par exemple, pour la tâche {\tt th\_server}, sa déclaration est faite ligne 73 dans le fichier {\tt tasks.h}
437
+\begin{verbatim}
438
+  RT_TASK th_server;
439
+\end{verbatim}
440
+sa création ligne 102 de {\tt tasks.cpp} lors de l'appel de
441
+\begin{verbatim}
442
+  rt_task_create(&th_server, "th_server", 0, PRIORITY_TSERVER, 0)
443
+\end{verbatim}
444
+et son démarrage ligne 146 avec
445
+\begin{verbatim}
446
+  rt_task_start(&th_server, (void(*)(void*)) & Tasks::ServerTask, this)
447
+\end{verbatim}
448
+}
449
+
450
+% CODE THREAD
451
+\subsubsection{Code à exécuter}
452
+ {\color{blue} Comment se fait le lien sous Xenomai entre le thread et le traitement à exécuter.}
453
+
454
+% PRIORITE THREAD
455
+\subsubsection{Niveau de priorités}
456
+ {\color{blue} Expliquer comment vous fixez sous Xenomai le niveau de priorité d'un thread AADL.}
457
+
458
+% PERIODICITE THREAD
459
+\subsubsection{Activation périodique}
460
+ {\color{blue} Expliquer comment vous rendez périodique l'activation d'un thread AADL sous Xenomai.}
461
+
462
+% THREAD EVENEMENTIEL
463
+\subsubsection{Activation événementielle}
464
+ {\color{blue} Expliquer les moyens mis en {\oe}uvre dans l'implémentation sous Xenomai pour gérer les activations événementielles d'un thread AADL.}
465
+
466
+ 
467
+ % PORT D'EVENEMENT
468
+\subsection{Port d’événement}
469
+
470
+% INSTANCIATION PORT D'EVENEMENT
471
+\subsubsection{Instanciation}
472
+ {\color{blue} Comment avez-vous instancié un port d'événement ?}\\
473
+ 
474
+ % ENVOI PORT D'EVENEMENT
475
+\subsubsection{Envoi d’un événement}
476
+ {\color{blue} Quels services ont été employés pour signaler un événement ?}
477
+
478
+% RECEPTION PORT D'EVENEMENT
479
+\subsubsection{Réception d’un événement}
480
+ {\color{blue} Comment se fait l'attente d'un événement ?}
481
+
482
+% DONNEE PARTAGEE
483
+\subsection{Donnée partagée}
484
+
485
+% INSTANCIATION DONNEE PARTAGEE
486
+\subsubsection{Instanciation}
487
+ {\color{blue} Quelle structure instancie une donnée partagée ?}
488
+
489
+% LECTURE/ECRITURE DONNEE PARTAGEE
490
+\subsubsection{Accès en lecture et écriture}
491
+ {\color{blue} Comment garantissez-vous sous Xenomai l'accès à une donnée partagée ?}
492
+
493
+% PORT D'EVENEMENT-DONNEES
494
+\subsection{Ports d’événement-données}
495
+
496
+% INSTANCIATION PORT D'EVENEMENT-DONNEES
497
+\subsubsection{Instanciation}
498
+ {\color{blue} Donnez la solution retenue pour implémenter un port d'événement-données avec Xenomai.}
499
+
500
+% ENVOI PORT D'EVENEMENT-DONNEES
501
+\subsubsection{Envoi d’une donnée}
502
+ {\color{blue} Quels services avez-vous employés pour envoyer des données ?}
503
+
504
+% RECEPTION PORT D'EVENEMENT-DONNEES
505
+\subsubsection{Réception d’une donnée}
506
+ {\color{blue} Quels services avez-vous employés pour recevoir des données ?}
507
+ 
508
+
509
+
510
+
511
+
512
+\end{document}

Loading…
Cancel
Save