J-0
00m
00j
00h
00min
00s

Version interactive avec LaTeX compilé

Centrale Option Informatique MP 2013

Notez ce sujet en cliquant sur l'étoile
0.0(0 votes)
Logo centrale
2025_08_29_b16e51aaa15c143a87d1g
Les candidats indiqueront en tête de leur copie le langage de programmation choisi (Pascal ou Caml). Les candidats ayant choisi Caml devront donner le type de chaque fonction écrite. Les candidats travaillant en Pascal pourront écrire des fonctions ou des procédures.

I Arbres de décision

Un arbre de décision est un arbre binaire dans lequel :
  • un nœud interne est associé à une variable, parmi un ensemble de variables ;
  • une feuille est associée à un booléen (vrai ou faux).
Si chaque variable de l'ensemble reçoit une valeur booléenne, un tel arbre permet de prendre une décision en parcourant l'arbre:
  • on part de la racine ;
  • quand on arrive sur un nœud interne (racine comprise), on regarde quelle est la valeur de la variable associée au nœud : si elle vaut vrai on poursuit le parcours dans le sous-arbre gauche, sinon on poursuit le parcours dans le sous-arbre droit ;
  • quand on arrive sur une feuille, le booléen associé constitue la décision.
Conventionnellement, on représente l'arête menant au sous-arbre pour le «cas vrai» en trait plein ; l'arête menant au sous-arbre «cas faux » en pointillés. Schématiquement, un arbre est structuré comme indiqué ci-dessous à gauche.
Le schéma de droite ci-dessus illustre l'exemple : un module de cours est validé si l'examen est réussi ( ), ou sinon, si l'étudiant a été assidu en cours (a) et qu'il réussit un examen de rattrapage ( ). Cela revient à définir la validation du module par la formule logique .
On envisage une représentation simple d'un arbre de décision, à l'aide d'un tableau. On numérote les nœuds : la racine reçoit le numéro 0 , les autres nœuds sont numérotés arbitrairement par des entiers consécutifs à partir de 1. On crée un tableau contenant autant de cases que de nœuds, indicé à partir de 0 . La case d'indice contient soit un triplet (nom de variable, numéro du fils gauche, numéro du fils droit) si le nœud numéro est un nœud interne, soit un booléen si le nœud numéro est une feuille.
En Caml, on définit le type :
type noeud =
    Feuille of bool
    | Decision of string * int * int;;
Un arbre de décision est donc représenté par un vecteur de nœuds (type noeud vect).
En Pascal :
type SorteNoeud = (Feuille, Decision);
type Noeud = record
    sorte: SorteNoeud;
    variable: string; (* Utilisé si sorte = Decision *)
    g, d: integer; (* Utilisés si sorte = Decision *)
    valeurFeuille: boolean; (* Utilisé si sorte = Feuille *)
end;
En Pascal un arbre de décision contenant nœuds sera donc de type array [ ] of Noeud.
I. - Définir une variable monAD représentant l'arbre de décision illustré précédemment.
Dans les deux questions suivantes, on veut faire déterminer une décision en fournissant une valuation des variables, c'est-à-dire la liste des seules variables qui sont vraies dans l'évaluation.
I.B - Définir une fonction eval_var qui, étant donnés le nom d'une variable (string) et une liste (Caml) ou un tableau (Pascal) des seules variables vraies, renvoie un booléen correspondant à la valuation de la variable indiquée.
I. - Définir une fonction eval qui, étant donnés un arbre de décision et une liste (Caml) ou un tableau (Pascal) des seules variables vraies, renvoie un booléen correspondant à la décision finale.

II Diagrammes de décision

On souhaite compacter la représentation en mémoire des arbres de décision. Si plusieurs sous-arbres sont identiques, on n'a pas envie de les stocker plusieurs fois.
En raisonnant sur la représentation informatique des arbres de décision, on voit assez facilement une façon de procéder : si les arbres de numéros et sont identiques, on peut (par exemple) au niveau du parent de indiquer comme numéro de fils au lieu de et ainsi éliminer de la représentation.
Ce faisant, on ne représente plus un arbre (car a maintenant deux parents), mais un graphe orienté: on parle de diagrammes de décision. Néanmoins aucune connaissance particulière en théorie des graphes n'est requise pour aborder ce problème. On dira qu'il existe un arc de vers et on le notera avec (pour vrai ou faux), selon que l'arc est suivi dans le cas où est vrai (précédemment : fils gauche) ou dans le cas où est faux (précédemment : fils droit). Lorsque , on note .
Exemple : l'expression admet (entre autres) les diagrammes de décision ci-dessous.

II.A - Créer une fonction (Caml) ou procédure (Pascal) redirige à trois paramètres - un diagramme ainsi que deux indices et - qui supprime le nœud dans le graphe et transforme tous les arcs en arcs . Les cases du tableau qui deviennent inoccupées sont remplies avec la valeur spéciale Vide.
Pour ce faire en Caml on complète :
type noeud =
        Feuille of bool
    | Decision of string * int * int
    | Vide;;
De même en Pascal on ajoute une sorte de nœuds (le type Noeud lui-même reste inchangé) :
type SorteNoeud = (Feuille, Decision, Vide);
Pour transformer un arbre en diagramme sans répétition, on applique deux règles de simplification.
  • Élimination: Si pour un nœud on a alors on élimine et on transforme les arcs en .

    est transformé en
  • Isomorphisme : Soit et deux nœuds, . Si ce sont des feuilles avec valeur ou si ce sont des nœuds internes tels que variable et et alors on élimine et on transforme les en .
est transformé en
est transformé en
II.B - Créer une fonction trouve_elimination, prenant en paramètre un diagramme et renvoyant l'indice d'un nœud pouvant être supprimé par élimination, s'il en existe un. Sinon, elle doit renvoyer -1 .
II. - De même, créer une fonction trouve_isomorphisme, prenant en paramètre un diagramme, et renvoyant un couple d'indices correspondant à deux nœuds pouvant être simplifiés par isomorphisme, s'il en existe un. Sinon, elle doit renvoyer le couple .
Les candidats qui composent en Caml peuvent directement manipuler des couples. Les candidats qui composent en Pascal créeront une procédure recevant en paramètres deux variables entières transmises par référence :
procedure trouve_isomorphisme(diagramme: array of noeud; var i, j: integer);
On dit que le diagramme est sous forme réduite s'il n'existe pas de nœuds différents qui correspondent à la même formule logique.
II.D - Prouver l'assertion suivante :
Un diagramme est sous forme réduite si, et seulement si, ni la règle d'élimination ni la règle d'isomorphisme ne peuvent lui être appliquées.
II.E - Créer une fonction sans résultat (Caml) ou une procédure (Pascal) appelée reduit, prenant en paramètre un diagramme, qui détecte les deux simplifications possibles, effectue les redirections correspondantes, jusqu'à ce qu'il ne soit possible de faire aucune simplification supplémentaire.
On obtient à ce stade une représentation du diagramme simplifié sous forme d'un tableau dans lequel certaines cases ne sont plus utilisées : elles sont marquées Vide.

III Diagrammes de décision ordonnés

Nous nous intéressons maintenant à la construction d'arbres de décision à partir de formules logiques.
Étant données des formules logiques et , on définit l'opérateur par :
III.A - Soient et des formules logiques quelconques. Montrer que les trois formules logiques suivantes
peuvent s'écrire en utilisant uniquement les constantes 0 (faux), 1 (vrai), l'opérateur défini précédemment et les variables et .
III. B - Montrer que .
III. - Déduire de ce qui précède une méthode systématique de construction d'un arbre de décision à partir d'une formule logique quelconque.
III.D - Soient une variable booléenne et une formule logique. Que vaut ?
Un diagramme de décision est dit ordonné si, pour un ordre donné entre les variables , alors tout chemin partant de la racine vers les feuilles parcourt les variables dans cet ordre.
La fonction booléenne représentée par un diagramme de décision est notée .
La méthode de construction d'un arbre de décision imaginée en III.C ne respecte pas forcément un certain ordre des variables. Dans cette partie nous proposons une autre méthode de construction, un ordre étant donné a priori.
Pour une variable , une expression et une fonction booléenne , on note la fonction déduite de en remplaçant toutes les occurrences de par .
III. - Que vaut ?
III.F - En déduire une méthode de construction d'un diagramme de décision réduit ordonné à partir d'une fonction booléenne sur un ensemble ordonné de variables.
III. - Montrer que pour toute fonction booléenne de variables ordonnées , il existe un unique diagramme de décision réduit ordonné tel que .
III.H - À l'aide de ce qui précède, donner une méthode simple permettant de décider de l'égalité entre deux fonctions booléennes portant sur le même ensemble de variables.
III.I - Comment déterminer facilement si une formule logique est une tautologie ?

IV Circuits logiques

On sait que toute fonction booléenne peut se mettre sous forme normale disjonctive: s'écrit comme une disjonction (un ou) de mintermes, sachant qu'un minterme est une conjonction (un et) entre toutes les variables de , chacune d'entre elles pouvant éventuellement être niée.
Par exemple, s'écrit en forme normale disjonctive : ( ). C'est une disjonction de trois mintermes.
IV.A - Pour une fonction booléenne , évaluer le nombre de portes logiques nécessaires à sa réalisation directe à partir de sa forme normale disjonctive, en fonction du nombre de variables de .
On appelle multiplexeur à deux entrées un circuit logique qui recopie sur sa sortie l'une de ses deux entrées, ou , en fonction de la valeur (resp. 0 ou 1) d'un signal de commande .

IV.B - Donner la table de vérité du multiplexeur à deux entrées.
IV.C - Donner un schéma pour réaliser le multiplexeur à deux entrées à partir de portes logiques élémentaires.
IV.D - Donner une méthode simple permettant de déterminer un circuit logique réalisant la fonction booléenne représentée par un diagramme de décision.

V Automates

On s'intéresse dans cette partie aux combinaisons booléennes d'équations linéaires sur les entiers. Par exemple, avec deux variables, la résolution du système ou de . Les combinaisons logiques peuvent être traitées par l'arbre de décision précédent. On veut construire des automates permettant de résoudre les équations linéaires. Dans le cas général, pour un entier positif, ces équations à variables peuvent s'écrire sous la forme avec , , et dénotant le produit scalaire usuel entre deux vecteurs. On note et on prend comme alphabet l'ensemble . Un mot
représente le vecteur d'entiers naturels tel que pour tout .
On note le vecteur d'entiers et le mot de associé à ce vecteur d'entiers. On rappelle que représente la concaténation entre deux mots.
- Résoudre le système . Écrire le mot correspondant.
Étant donnée une équation linéaire , on souhaite construire un automate qui reconnaisse seulement les mots correspondant aux solutions de l'équation.
- Soit un mot de longueur au moins égale à 2 que l'on écrit sous la forme ', où est une lettre et un mot. Montrer que est solution de l'équation si et seulement si est un entier pair et ' est solution de l'équation ', pour une valeur de ' que l'on précisera.
On peut donc ainsi construire l'automate. Les états sont indexés par les valeurs accessibles. On ajoute un état «rebut» noté . À partir d'un état , pour toutes les lettres de l'alphabet , on crée les états , s'ils n'existent pas encore et les transitions ( ), si est un entier pair (la valeur de étant le de la question précédente) ou les transitions ( ) sinon.
- Préciser, en le justifiant l'état initial de l'automate , ainsi que le (les) état(s) final(aux).
- Montrer que l'on construit ainsi un nombre fini d'états de l'automate .
- Donner un algorithme permettant de déterminer s'il existe des solutions de l'équation . Justifier que cet algorithme se termine.
Construire l'automate pour l'équation : . Donner également le tableau indiquant les transitions: en ligne les états accessibles ; en colonne les différentes lettres de l'alphabet (dans l'ordre lexical précisé ci-dessous) ; chaque case du tableau contient l'état atteint par lecture de la lettre à partir de l'état correspondant.

Pour éviter de surcharger le dessin de l'automate, on pourra ne pas représenter les transitions vers

l'état .
On définit l'ordre lexical sur les lettres de l'alphabet par : si et sont dans l'alphabet, on a ou et .
- En déduire toutes les solutions du problème avec et .
V.H - Comment peut-on modifier l'automate précédent pour prendre en compte les quantificateurs du premier ordre, c'est-à-dire des formules comme ?
Centrale Option Informatique MP 2013 - Version Web LaTeX | WikiPrépa | WikiPrépa