// Méthodes public List <Question> serializeQuestions() // On crée toutes les réponses, on crée toutes les questions, on les met dans la liste et on sérialise le tout. { string[] reponsesQ1 = new string [] { "3", "6", "7" }; string[] reponsesQ2 = new string[] { "La cinématique inverse est l’ensemble des rotations d’axes de liberté 𝜶, β, Ɣ … permettant de\n passer d’une position M(x,y,z) à une position M’(x’,y’,z’) dont les coordonnées et l’orientation\n sont préalablement choisies.", "Il s’agit du positionnement en face de l’objet suite à un mouvement de la base autour d’un axe\n vertical.", "La cinématique inverse est une méthode mathématique qui permet de calculer la position dans\n l’espace de l’extrémité d’un « bras » articulé à partir de la position dans laquelle se trouve\n chacune de ses articulations." }; string[] reponsesQ3 = new string[] { "C’est l’ensemble des fonctions mentales ayant pour objet la connaissance conceptuelle\n et rationnelle.", "C’est l’ensemble des techniques et algorithmes permettant de résoudre des problèmes à l’aide\n d’un ordinateur.", "C’est un ensemble de règles opératoires visant à expliciter les étapes d’un raisonnement." }; string[] reponsesQ4 = new string[] { "La reconnaissance visuelle, vision par ordinateur.", "Les systèmes experts.", "L’étude des facultés mentales humaines. ", "Les algorithmes génétiques." }; string[] reponsesQ5 = new string[] { "L’IA forte.", "L’IA faible.", "Une forme d’IA intermédiaire." }; string[] reponsesQ6 = new string[] { "Le nombre de noeuds ou de sommets qu’il possède (graphe orienté > graphe non orienté).", "Qu’il soit caractérisé par des arcs (graphe orienté) ou par des arêtes (graphe non orienté).", "Qu’à chaque relation soit obligatoirement associée une valeur (graphe orienté) ou non\n (graphe non orienté)." }; string[] reponsesQ7 = new string[] { "Il permet de calculer des probabilités conditionnelles. En fonction des observations observées,\n on calcule la probabilité des informations non observées. ", "Il permet de représenter l’ensemble des concepts propres à un domaine ainsi que les relations\n entre ces concepts pour pouvoir raisonner à propos de ces objets.", "Il permet de décrire une forme physique et les liens entre les différents éléments qui la compose." }; string[] reponsesQ8 = new string[] { "Un moteur électrique, un potentiomètre, une pince.", "Un potentiomètre, un microcontrôleur, une caméra.", "Un microcontrôleur, un capteur, un moteur électrique. ", "Un moteur électrique, un capteur, un asservissement électronique. " }; string[] reponsesQ9 = new string[] { "Jouer A est un meilleur coup que jouer B.", "Jouer B est un meilleur coup que jouer A. " }; string[] reponsesQ10 = new string[] { "Tout problème défini par un ensemble de variables et un ensemble de contraintes associées.", "Un problème prenant en compte un ensemble fini de variables Xi avec i ∈ {1, …, n}, dont les valeurs sont généralement infinies.", "Un problème défini par un ensemble de contraintes, chacune associable à un booléen.", "Un problème qui associe un ensemble de contraintes à une variable spécifique. " }; string[] reponsesQ11 = new string[] { "Oui, il s’agit du Traitement Automatique du Lagrangien des Nanorobots.", "Oui, il s’agit du Traitement Automatique du Langage Naturel. ", "Oui, il s’agit du Traitement Automatisé du Langage Naturel. ", "Non, c’est un domaine complètement à part." }; string[] reponsesQ12 = new string[] { "L’algorithme alpha-beta permet d’évaluer un nombre de noeud inférieur à celui évalué par \nl’algorithme MinMax, pour le même résultat. ", "Il traite plus efficacement les coups de l’adversaire. ", "Il évalue les noeuds dans l’ordre croissant." }; string[] reponsesQ13 = new string[] { "Une approche de solution à un problème d’optimisation. ", "Un algorithme appartenant à la famille des algorithmes évolutionnistes. ", "Une façon de ne garder que les meilleurs résultats à chaque étape de la recherche d’une solution. ", "La recherche d’une solution analytique exacte. " }; string[] reponsesQ14 = new string[] { "Vrai ", "Faux " }; string[] reponsesQ15 = new string[] { "Vrai", "Faux" }; string[] reponsesQ16 = new string[] { "Vrai", "Faux" }; string[] reponsesQ17 = new string[] { "1", "4", "9", "16" }; string[] reponsesQ18 = new string[] { "Réflexive", "Inversible", "Symétrique", "Diagonale" }; string[] reponsesQ19 = new string[] { "C’est le coût estimé entre un nœud initial et un nœud d’arrivée. ", "C’est le coût estimé entre le nœud courant et le nœud suivant. ", "C’est un concept exploité par l’algorithme de alpha-beta. " }; string[] reponsesQ20 = new string[] { "Sommets", "Etats et transitions possibles entre états", "Relations ", "Position " }; string[] reponsesQ21 = new string[] { "Vrai", "Faux" }; Question question1 = new Question("Combien de degrés de liberté sont nécessaires pour permettre à un bras UR3 de se positionner,\n de s’orienter et d’attraper un objet ?", 2, reponsesQ1); Question question2 = new Question("Comment peut-on définir la cinématique inverse ?", 0, reponsesQ2); Question question3 = new Question("Qu’est-ce que l’intelligence artificielle ?", 1, reponsesQ3); Question question4 = new Question("Laquelle de ces propositions ne constitue pas un sous-domaine de l’IA ?", 2, reponsesQ4); Question question5 = new Question("Quel type d’intelligence artificielle (IA) avons nous atteint aujourd’hui ?", 2, reponsesQ5); Question question6 = new Question("Dans le cadre de la modélisation des graphes, qu’est-ce qui distingue un graphe orienté\n d’un graphe non orienté ?", 1, reponsesQ6); Question question7 = new Question("Quel intérêt présente l’usage d’un réseau bayésien ?", 0, reponsesQ7); Question question8 = new Question("Un servo-moteur comprend trois éléments : ", 3, reponsesQ8); Question question9 = new Question("Supposons que A et B sont deux coups distincts possibles dans le cadre d'un jeu de dames.\n Les coups A ou B correspondent aux coups du joueur et les coups C aux coups de l’adversaire.\n Selon l’algorithme MinMax, quel est le meilleur coup à effectuer par le joueur, en se référant à l'arborescence suivante ? \n. ___ A: 2 ____ B: 7\n ____ C: 6 / ____ C: 7 / \n / \\ ___ A: 6 / \\____ B: 6\nA: 5 ____ / B:-2 ____ / \n \\ ___ A: 5 \\ ____ B: -2 \n \\ ____ C: 5 / \\ ___ C: -2 /\n \\____A: 1 \\____ B: 1\n", 0, reponsesQ9); Question question10 = new Question("Qu’est ce qu’un problème de satisfaction de contraintes ? ", 0, reponsesQ10); Question question11 = new Question("Le TALN est-il un sous domaine de l’IA ?", 1, reponsesQ11); Question question12 = new Question("Quelle est la spécificité de l’algorithme alpha-beta par rapport à l’algorithme MinMax ? ", 0, reponsesQ12); Question question13 = new Question("Qu’est ce n’est pas un algorithme génétique ? ", 3, reponsesQ13); Question question14 = new Question("Le but final de l’algorithme MinMax est de connaître les espérances de gain dans \nl’arborescence des coups possibles au cours d’un jeu affrontant deux joueurs. ", 1, reponsesQ14); Question question15 = new Question("Dans le cas des problèmes de satisfaction de contraintes, un problème est dit “consistant” \ns’il existe une affectation de ses variables qui vérifie toutes les contraintes du problème.", 0, reponsesQ15); Question question16 = new Question("Le fonctionnement de l’algorithme alpha-beta est défini comme suit : Si la valeur d’un fils f \nd’un noeud MAX est supérieur à la valeur courante d'un noeud MIN ancêtre, alors les frères de\n f n’ont pas besoin d’être exploré.", 0, reponsesQ16); Question question17 = new Question("Combien de nœud(s) le graphe associé à cette matrice d’adjacence possède-t-il ?\n0 1 0 0\n1 1 1 1\n0 1 0 1\n0 1 1 0\n", 1, reponsesQ17); Question question18 = new Question("Si un graphe n’est pas orienté, sa matrice d’adjacence est :", 2, reponsesQ18); Question question19 = new Question("Qu’est ce qu’un coût heuristique ?", 0, reponsesQ19); Question question20 = new Question("Lequel de ces éléments ne décrit pas un graphe ? ", 3, reponsesQ20); Question question21 = new Question("Si l’heuristique h(N) est un minorant du coût du chemin restant réel, alors A* garantit \nque le chemin trouvé est le plus court.", 0, reponsesQ21); List <Question> questions = new List <Question>(); questions.Add(question1); questions.Add(question2); questions.Add(question3); questions.Add(question4); questions.Add(question5); questions.Add(question6); questions.Add(question7); questions.Add(question8); questions.Add(question9); questions.Add(question10); questions.Add(question11); questions.Add(question12); questions.Add(question13); questions.Add(question14); questions.Add(question15); questions.Add(question16); questions.Add(question17); questions.Add(question18); questions.Add(question19); questions.Add(question20); questions.Add(question21); QuestionXML.Serialisation("ceciEstUnFichierXML.xml", questions); return(questions); }
public void deserializeQuestions(List <Question> questions) { questions = QuestionXML.CreerAPartirDuFichier("ceciEstUnFichierXML.xml"); }