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

Version interactive avec LaTeX compilé

CCINP Informatique Commune TSI 2020

Notez ce sujet en cliquant sur l'étoile
0.0(0 votes)
Logo ccinp
2025_08_29_5d74a70ba54cefb370d7g

ÉPREUVE SPÉCIFIQUE - FILIÈRE TSI

INFORMATIQUE

Mercredi 6 mai : 8 h-11 h

N.B. : le candidat attachera la plus grande importance à la clarté, à la précision et à la concision de la rédaction. Si un candidat est amené à repérer ce qui peut lui sembler être une erreur d'énoncé, il le signalera sur sa copie et devra poursuivre sa composition en expliquant les raisons des initiatives qu'il a été amené à prendre.

RAPPEL DES CONSIGNES

  • Utiliser uniquement un stylo noir ou bleu foncé non effaçable pour la rédaction de votre composition ; d'autres couleurs, excepté le vert, peuvent être utilisées, mais exclusivement pour les schémas et la mise en évidence des résultats.
  • Ne pas utiliser de correcteur.
  • Écrire le mot FIN à la fin de votre composition.

Les calculatrices sont interdites

Le sujet est composé de trois parties, toutes indépendantes.

Seul le document réponse est à rendre.

Le sujet comporte :
  • le texte du sujet et une annexe, 7 pages,
  • le Document Réponse (DR) à rendre en fin d'épreuve, 12 pages.
Important : vous pouvez utiliser les fonctions des questions précédentes, même si vous ne les avez pas toutes démontrées.
Vous devez répondre directement sur le Document Réponse, soit à l'emplacement prévu pour la réponse lorsque celle-ci implique une rédaction, soit en complétant les différents programmes en langage Python.

Autour du séquençage du génome

Dans ce sujet, on s'intéresse à la recherche d'un motif dans une molécule d'ADN. Une molécule d'ADN est constituée de deux brins complémentaires, qui sont un long enchaînement de nucléotides de quatre types différents désignés par les lettres et G . Les deux brins sont complémentaires : "en face" d'un 'A', il y a toujours un 'T' et "en face" d'un 'C', il y a toujours un ' '. Pour simplifier le sujet, on va considérer qu'une molécule d'ADN est une chaîne de caractères sur l'alphabet (on s'intéresse donc seulement à un des deux brins). On parlera de séquence d'ADN.

Partie I - Génération d'une séquence d'ADN

On considère la chaîne de caractère seq='ATCGTACGTACG'.
Q1. Que renvoie la commande seq [3] ? Que renvoie la commande seq [2:6] ?
Les fonctions que nous allons construire par la suite devront prendre en paramètre une chaîne de caractères ne contenant que des ' ', ' ', ' ' et ' ' (ceci correspond à une séquence d' ADN). Nous allons commencer par construire aléatoirement une séquence d'ADN.
Pour générer aléatoirement une séquence d'ADN composée de caractères, on utilisera le principe suivant.
  1. On commence par créer une chaîne de caractères vide.
  2. Puis on tire aléatoirement chiffres compris entre 1 et 4 et
  • si on obtient un 1, alors on ajoute un 'A' à notre chaîne de caractères;
  • si on obtient un 2, alors on ajoute un 'C' à notre chaîne de caractères;
  • si on obtient un 3, alors on ajoute un 'G' à notre chaîne de caractères;
  • si on obtient un 4, alors on ajoute un 'T' à notre chaîne de caractères.
  1. On renvoie la chaîne de caractères ainsi construite.
Q2. Écrire une fonction generation() qui prend en paramètre un entier et qui renvoie une chaîne de caractères aléatoires de longueur ne contenant que des 'A', 'C', 'G' et 'T'. On pourra utiliser les fonctions random() ou randint() détaillées en annexe.
Q3. Que fait la fonction mystere(seq) qui prend en argument une séquence d'ADN'seq' (une chaîne de caractères ne contenant que des 'A', 'C', 'G' et 'T')? Le code de la fonction mystere() se trouve dans le DR 3.
Q4. Quelle est la complexité de la fonction mystere()? Donner le nom de la variable permettant de montrer la terminaison de l'algorithme (on justifiera le raisonnement).

Partie II - Recherche d'un motif

Soit une chaîne de caractères 'ACTGGTCACT', on appelle sous-chaîne de caractères de S une suite de caractères incluse dans S . Par exemple, 'TGG' est une sous-chaîne de S mais 'TAG' n'est pas une sous-chaîne de S .
Il s'agit d'une problématique classique en informatique, qui répond aux besoins de nombreuses applications.
On trouve plus de 100 algorithmes différents pour cette même tâche, les plus célèbres datant des années 1970, mais plus de la moitié ont moins de 10 ans.
Dans cette partie, nous allons d'abord nous intéresser à l'algorithme naïf (sous-partie II.1), puis à deux autres algorithmes : l'algorithme de Knuth-Morris-Pratt (sous-partie II.2), et un algorithme utilisant une structure de liste (sous-partie II.3) et enfin, aux fonctions de hachage (sous-partie II.4).
Les différentes sous-parties sont indépendantes.

II. 1 - Algorithme naïf

Principe de l'algorithme naïf

On parcourt la chaîne. À chaque étape, on regarde si on a trouvé le bon motif. Si ce n'est pas le cas, on recommence avec l'élément suivant de la chaîne de caractères.
Cet algorithme a une complexité en avec , la taille de la chaîne de caractère et , la taille du motif.
Q5. Écrire une fonction recherche() qui à une sous-chaîne de caractères M et une chaîne de caractères renvoie -1 si n'est pas dans , et la position de la première lettre de la chaîne de caractères M si M est présente dans S.
Cet algorithme doit correspondre à l'algorithme naïf.
Q6. Combien faut-il d'opérations pour chercher un motif de 50 caractères dans une séquence d'ADN en utilisant l'algorithme naïf ? On supposera qu'une séquence d'ADN est composée de caractères.
En combien de temps un ordinateur réalisant opérations par seconde fait-il ce calcul?
En génétique, on utilise des algorithmes de recherche pour identifier les similarités entre deux séquences d'ADN. Pour cela, on procède de la manière suivante :
  • découper la première séquence d'ADN en morceaux de taille 50;
  • rechercher chaque morceau dans la deuxième séquence d'ADN.
Q7. En utilisant les calculs précédents, combien de temps faut-il pour un ordinateur réalisant opérations par seconde pour comparer deux séquences d'ADN avec l'algorithme naïf? Vous semble-t-il intéressant d'utiliser l'algorithme de recherche naïf?

II. 2 - Algorithme de Knuth-Morris-Pratt (1970)

Lorsqu'un échec a lieu dans l'algorithme naïf, c'est-à-dire lorsqu'un caractère du motif est différent du caractère correspondant dans la séquence d'ADN, la recherche reprend à la position suivante en repartant au début du motif. Si le caractère qui a provoqué l'échec n'est pas au début du motif, cette recherche commence par comparer une partie du motif avec une partie de la séquence d'ADN qui a déjà été comparée avec le motif. L'idée de départ de l'algorithme de Knuth-Morris-Pratt est d'éviter ces comparaisons inutiles. Pour cela, une fonction annexe qui recherche le plus long préfixe d'un motif qui soit aussi un suffixe de ce motif est utilisée.
Avant d'étudier l'algorithme de Knuth-Morris-Pratt (sous-partie II.2.b) nous allons définir les notions de préfixe et suffixe (sous-partie II.2.a).

II.2.a Préfixe et suffixe

Un préfixe d'un motif est un motif , différent de , qui est un début de .
Par exemple, 'mo' et 'm' sont des préfixes de 'mot', mais 'o' n'est pas un préfixe de 'mot' .
Un suffixe d'un motif est un motif , différent de , qui est une fin de .
Par exemple, 'ot' et 't' sont des suffixes de 'mot', mais 'mot' n'est pas un suffixe de 'mot'.
Q8. Donner tous les préfixes et les suffixes du motif 'ACGTAC'.
Q9. Quel est le plus grand préfixe de 'ACGTAC' qui soit aussi un suffixe?
Quel est le plus grand préfixe de 'ACAACA' qui soit aussi un suffixe?

II.2.b Algorithme de Knuth-Morris-Pratt

Nous rappelons que l'algorithme de Knuth-Morris-Pratt (KMP) est une fonction de recherche qui utilise une fonction annexe prenant en argument une chaîne de caractères M dont on notera la longueur .
Cette fonction annexe, appelée fonctionannexe(), doit permettre, pour chaque lettre à la position i , de trouver le plus grand sous-mot de M qui finit par la lettre (c'est donc le plus grand suffixe de ) qui soit aussi un préfixe de M .
Le code de fonctionannexe() se trouve à la question Q11 du DR 6.
Q10. Quel est le type de la sortie de la fonction fonctionannexe()?
Q11. Une ou des erreurs de syntaxe s'est (se sont) glissée(s) dans la fonction fonctionannexe(). Identifier la ou les erreur(s) et corriger la fonction pour qu'il n'y ait plus de message d'erreur quand on compile la fonction.
Q12. Décrire l'exécution de la fonction fonctionannexe() lorsque M='ACAACA' en précisant sur le DR 6, pour les six premiers tours dans la boucle while, à la sortie de la boucle, le contenu des variables : et .
Q13. Expliquer et commenter les groupements de lignes de l'algorithme KMP donnés dans le DR 7.

II. 3 - Algorithme utilisant la structure de liste

Une autre possibilité pour chercher un motif dans une chaîne de caractères (ou séquence d'ADN) est de construire une liste contenant tous les sous-motifs de notre chaîne, triés par ordre alphabétique, puis de faire la recherche dans cette liste.
Par exemple, à la chaîne 'CATCG', on peut lui associer la liste :
['C','A','T','G','CA','AT','TC','CG','CAT','ATC','TCG','CATC','ATCG','CATCG'] que l'on peut ensuite trier pour obtenir la liste :
['A','AT','ATC','ATCG','C','CA','CAT','CATC','CATCG','CG','G','T','TC','TCG'].
La première étape de cette méthode est donc de trier une liste.
Q14. Écrire une fonction triinsertion() de tri par insertion d'une liste de nombres.
Q15. Comment peut-on adapter la fonction triinsertion() à une liste de chaîne de caractères?
Après avoir obtenu une liste triée, on peut faire une recherche dichotomique dans cette nouvelle liste.
Q16. Écrire une fonction recherchedichotomique() de recherche dichotomique dans une liste de nombres triés.
Quel est l'intérêt de ce type d'algorithme (on parlera de complexité)?

II. 4 - Fonction de hachage et évaluation de polynôme

II.4.a Fonction de hachage, algorithme de Karp-Rabin

Certains algorithmes, comme l'algorithme de Karp-Rabin (1987), utilisent une fonction de hachage qui à un motif renvoie une valeur numérique.
Voici un exemple de fonction de hachage :
  • à chaque caractère de l'alphabet, on associe une valeur. Ici, on va associer à 'A' la valeur 0 , à 'C' la valeur 1, à 'G' la valeur 2 et à 'T' la valeur 3. Pour un motif de taille , on obtient donc une suite de chiffre . Par exemple, à la chaîne 'TAGC', on lui associe la suite de chiffre 3021;
  • cette suite de chiffre est considérée comme l'écriture d'un entier en base , où est le nombre de caractères présents dans l'alphabet. On a donc ici ;
  • on calcule ensuite cet entier en base 10 (on calcule donc );
  • puis on calcule le reste de la division euclidienne de ce nombre par 13.
Q17. On ne considère que des motifs de taille 3. Que renvoie la fonction de hachage avec les motifs 'CCC', 'ACG', 'GAG'? On détaillera les calculs.
Dans cette fonction de hachage, nous avons besoin de transformer un entier en base en un entier en base 10 . On remarque que l'on peut éventuellement faire ce calcul en évaluant un polynôme.

II.4.b Évaluation de polynôme, Algorithme de Hörner

Dans cette sous-partie, nous allons nous intéresser à l'évaluation d'un polynôme et de son coût lorsque l'on compte les multiplications, les additions et les affectations comme des opérations unitaires.
Soit un polynôme, il sera représenté par la liste .
Q18. Écrire une fonction ayant pour paramètre un polynôme (donc une liste de nombres ) et un nombre . Cette fonction doit renvoyer la valeur de en , c'est-à-dire calculant :
En admettant que le calcul de utilise multiplications, on trouve une complexité quadratique. On peut être plus astucieux en utilisant l'algorithme de Hörner qui se base sur l'égalité suivante :
Plus précisément, pour évaluer en , on commence par calculer , puis on multiplie le résultat par et on ajoute , etc. On trouvera alors une complexité linéaire.
Q19. Écrire une fonction itérative hornerit() ayant pour paramètres un polynôme , sous forme de liste, ainsi qu'un réel , et renvoyant en utilisant l'algorithme de Hörner.
Q20. Compléter la fonction hornerrec() pour avoir une fonction récursive qui évalue un polynôme en utilisant l'algorithme de Hörner.

Partie III - Collection Française de Bactéries Phytopathogènes

La Collection Française de Bactéries Phytopathogènes (CFBP) possède deux bases de données :
  • l'une, appelée Echantillon, qui permet de stocker les différents échantillons d'ADN;
  • l'autre, appelée Sequence, qui permet de mémoriser quelle personne est responsable de l'obtention de la séquence (i.e. de l'extraction d'un gène particulier dans les différents échantillons d'ADN).
    Des extraits des tables Echantillon et Sequence sont données par les tableaux 1 et 2.
Echantillon
ADN Genre Espèce Sous-espèce
309 Pseudomonas syringae morsprunorum
3589 Pseudomonas syringae vignae
Tableau 1 - Table recensant toutes les séquences d'ADN dont dispose la CFBP
Sequence
Code Date ADN Gène Protocole Employé
A 309 gyrB Spilker Dupont
B 2028 recA Cesbron and Manceau Martin
AGZ 2028 leuS Deletoile Martin
Tableau 2 - Table recensant tous les travaux réalisés à la CFBP en mars 2018
Q21. Définir le but et le résultat de la requête(1), écrite en SQL :
SELECT count(*) FROM Sequence WHERE Date='01-03-2018'
Q22. Écrire en SQL la requête(2), donnée en algèbre relationnel :
è
Q23. Écrire en SQL la requête(3) qui permet d'obtenir la liste des espèces étudiées par M. Martin le 10 mars 2018.
Q24. Écrire en SQL la requête(4) permettant d'obtenir le nombre d'échantillons prélevés par chaque employé.

ANNEXE - Librairie numpy

random() : génère un nombre pseudo-aléatoire compris entre 0 et 1 .
: génère un entier aléatoire tel que .

FIN


J. 201173

Autour du séquençage du génome

Document Réponse

Q1

seq='ATCGTACGTACG'
seq[3]
Que renvoie cette commande Python?
seq='ATCGTACGTACG'
seq[2:6]
Que renvoie cette commande Python?

NE RIEN ÉCRIRE DANS CE CADRE

Q2

1 def generation(n):
2 seq =
Q3
def mystere(seq):
    $a, b, c, d=0,0,0,0$
    i = len(seq)-1
    while $\mathrm{i}>=0$ :
        if seq[i]=='A':
            a += 1
            i -= 1
        elif seq[i]=='C':
            b += 1
            i -= 1
        elif seq[i]=='G':
            C $+=1$
            i -= 1
        else:
            d += 1
            i -= 1
    return $\left[a_{*} 100 / l e n(s e q), b_{*} 100 / l e n(s e q), c_{*} 100 / l e n(s e q), d_{*} 100 / l e n(s e q)\right]$
Réponse :

Q4

Q4
Complexité
Terminaison : nom de la variable :
justification :



Q5

1 def recherche(M,T):

Q6

Nombre d'opérations pour chercher un motif de 50 caractères :
Temps mis par l'ordinateur :

Q7

Temps pour comparer deux séquences d'ADN :
Est-ce intéressant d'utiliser cette méthode?


J. 201173

Q8

Préfixes de 'ACGTAC' :
Suffixes de 'ACGTAC' :

Q9

Plus grand préfixe de 'ACGTAC' qui soit aussi un suffixe :
Plus grand préfixe de 'ACAACA' qui soit aussi un suffixe :

Q10

Type de la variable en sortie :

Q11

Corriger la fonction suivante pour qu'il n'y ait plus de message d'erreur quand on compile la fonction.
def fonctionannexe(M):
    F=[0]
    i=1
    j=0
    while i <m :
        if M[i]=M[j] :
            F.append(j+1)
            i=i+1
            j=j+1
        else
            if j>0 :
                j=F[j-1]
            else:
                F.append(0)
                i=i+1
    return F

Q12

Initialisation :
Fin du premier passage dans la boucle while : . . ;
Fin du deuxième passage dans la boucle while : . ;
Fin du troisième passage dans la boucle while : ; ; . ;
Fin du quatrième passage dans la boucle while : . ;
Fin du cinquième passage dans la boucle while : ; ; . ;
Fin du sixième passage dans la boucle while : . ;
Algorithme KMP :
def KMP(M,T):
    F=fonctionannexe(M)
    i=0
    j=0
    while i < len(T) :
        if T[i]==M[j]:
            if j==len(M)-1:
                return(i-j)
            else:
                i=i+1
                j=j+1
        else:
            if j > 0:
                j=F[j-1]
            else:
                i=i+1
    return -1
Explication de la ligne 2 :

Explication des lignes 3 et 4 :

Quelles lignes correspondent au cas où on a trouvé le mot?
Que fait le programme dans ce cas ?

Quelles lignes correspondent au cas où on a trouvé deux lettres identiques?

Que fait le programme dans ce cas?

Quelles lignes correspondent au cas où on a trouvé deux lettres différentes?

Que fait le programme dans ce cas ?

Q14
1 def triinsertion(L):
Q15





J. 201173
Q16
1 def recherchedichotomique(a,L):
Intérêt de ce type d'algorithme :

h('CCC') :

h('ACG') :

h('GAG') :
Q18
1 def eval(P,b):
1 def hornerit(P, b):
Q20
1 def hornerrec(P,b):
2 if
if
return
3
4 else:
5
6

s1 = P[0:len(P)-1]
7
return

Q21

But de la requête(1) :
Requête(2) =
Q23
Requête(3) =
Q24
Requête(4)
CCINP Informatique Commune TSI 2020 - Version Web LaTeX | WikiPrépa | WikiPrépa