Topic outline

  • Cet espace de cours est dédié à l'UE "Projet Math-informatique" en L1 LDD.

    Le but de cette UE est de découvrir la démarche de modélisation d'un problème scientifique grâce à l'outil informatique et, en particulier, le logiciel SageMath (en python). Les séances prendront la forme de TP puis amèneront à la réalisation d'un projet autour d'une question de recherche.

    Le cours se décompose en deux activités principales :

    • Les TP : 30% de la note finale
    • Le Projet : rapport de mi-semestre 30% de la note finale + projet / exposé 40% de la note finale
    • Besoin d'aide ? Questions / Réponses, Suggestions Open Forum
      Not available unless: Your Last name is not empty
  • TP SageMath

    Les TP se font de façon individuelle

    Au cours du semestre, vous aurez à réaliser 5 TP que vous pourrez faire principalement pendant les séances et compléter chez vous. Tous les TP sont à rendre pour la fin du semestre, cependant il est conseillé de réaliser les TP lors des premières séances avant le mois de mars (car ensuite, vous serez pris par le projet).

    Note

    Seuls les TP avancés et le TP3 seront notés. Vous obtiendrez une note globale sur 20 qui compte pour 30% de la note finale de l'UE.

    Quels TP dois-je faire et quand ?

    Il y a 3 TP obligatoires, à faire dans l'ordre :

    • TP1 : introduction à SageMath
    • TP2 : programmation python
    • TP3 : SageMath et résolution d'équations

    Un TP ne correspond pas à une séance ! Faites-les dans l'ordre et passez au suivant quand vous avez terminé.

    Il faut ensuite choisir 2 TP Avancés parmi les 3 sujets suivants :

    • Géologie
    • Chemins Récursifs
    • Jeu de dés

    Vous devrez nous rendre les 2 TP Avancés que vous aurez choisi de traiter, et serez évalués pour 30% de votre note finale sur ces rendus.

    Comment faire les TP ?

    Les TP sont à réaliser sur l'environnement MyDocker "JupyterLab et SageMath" voir la section Instructions TP pour les détails

    Comment rendre les TP ?

    Nous avons mis en place un système de sauvegarde sur gitlab comme au premier semestre, voir la Section Instruction pour les détails.

    Comment choisir les TP Avancés ?

    Ces TP sont basés sur des problèmes mathématiques et permettent de mettre en oeuvre les notions vues dans les TP1, 2 et 3. En fonction du projet que vous avez choisi, certains TP avancés peuvent être plus intéressants que d'autres, cependant, le choix n'est pas imposé.

    Conseil de TP avancé en fonction du projet (pas d'obligation) :

    • Si vous faites les projets Labyrinthe ou Tétris, je vous conseille de réaliser le TP "Chemins Récursifs" (+ 1 autre)
    • Si vous faites les projets Jeu de la vie ou Planètes, je vous conseille de réaliser le TP "Géologie" (+ 1 autre)
    • Si vous faites le projet Champion's League, je vous conseille de choisir le TP "Jeu de dés" (+ 1 autre)
    • Pas de conseil particulier si vous faites le projet Nénuphars !

    Vous pouvez aussi commencer les 3 sujets et voir lesquels vous intéressent le plus. Vous pouvez même réaliser les 3 sujets en entier ! Pour la note, nous garderons les deux meilleurs TP avancés que vous aurez réalisés.

  • Projet

    Groupes de Projet

    Entre 2 et 4 par groupe (s'il y a trop de groupes de 2 sur un même projet, des fusions en groupes de 4 seront à envisager)

    Dates clés

    • Rendu des rapports de mi-projets (première partie du sujet) : date à venir
    • Exposé de fin de projets : Lundi 28 avril

    Choix du projet / groupe

    Les projets se font par groupes de 2 à 4 étudiants. La première partie (rapport de mi-projet) est un rendu écrit (sous la forme d'un fichier pdf) à faire en groupe.

    Réalisation du projet

    La première partie du projet correspond à un rapport de groupe à rendre (voir la section Rapport de mi-projet). Les sujets sont disponibles et vous pouvez les récupérer sur le serveur MyDocker (voir la Section Instructions TP pour les détails sur la connexion) en lançant la commande suivante depuis le dossier ProjetMathInfo.

    ./course.py fetch Projet
    

    Cette commande crée un dossier Projet sur le Jupyter Lab qui contient en particulier la liste des sujets. Surtout, c'est un espace sur lequel vous pouvez créer vos propres notebook Jupyter SageMath pour travailler sur le projet.

    Si vous avez un compte Paris-Saclay créé avant le piratage vous pouvez ensuite sauver votre projet au fur et à mesure avec la commande :

    Depuis le dossier Projet

    git add monFichier
    

    Puis pour sauver, depuis le dossier ProjetMathInfo

    ./course.py submit Projet MonGroupe
    

    Travail en groupe : par défaut, chaque étudiant a son propre espace Projet même si les projets se font en groupe. Le serveur Jupyter Lab ne permet pas directement le travail collaboratif sur un même dossier / notebook. Cependant, après la première soumission sur gitlab vous pouvez donner accès à votre projet aux autres membres du groupes (voir le menu sur la gauche "Settings > Members"). Cela permet aux autres membres de voir le code que vous avez soumis sur gitlab. (Encore une fois, ne fonctionne que si vous avez un accès avec un compte Paris-Saclay)

    Conseil : Nous vous conseillons de travailler chacun individuellement sur votre répertoire Projet sur le serveur jupyter et de le sauver régulièrement sur gitlab en faisant des "submit". Puis comme expliqué ci-dessus, nous vous conseillons de donner accès à votre projet gitlab aux autres membres du groupe. Ainsi, même si chacun a son espace, vous pouvez facilement échanger des bouts de code et voir ce qui a été fait par les autres membres du groupe.

  • Instructions TP

    En Résumé

    Depuis le dossier ProjetMathInfo (voir Mise en place) sur le serveur MyDocker avec environnement "Jupyterlab et SageMath" :

    • En début de séance, récupérer le TP en cours : ./course.py fetch NomDuTP
    • En fin de séance et à la fin de chaque TP si vous avez un compte Paris-Saclay : ./course.py submit NomDuTP MonGroupe

    Si vous avez seulement un compte @etu et pas un compte Paris-Saclay pré-piratage, l'identifiant à entrer pour récupérer le TP est "anonymous"

    Environnement de travail

    Vous pouvez travailler :

    Sur le service Jupypter Lab hébergé sur MyDocker mis à disposition par l'université. Ainsi vous avez accès en ligne, depuis n'importe quel ordinateur, à l'ensemble des logiciels requis pour les TP.

    Nos TP sont basés principalement sur deux logiciels SageMath et Jupyter qui sont tous les deux des logiciels libres.

    Connexion au serveur

    1. Connectez vous sur ce lien avec "CONNEXION ÉTUDIANTS PARIS-SACLAY" et vos identifiants prenom.nom@etu-upsaclay.fr
    2. Demander un environnement pour JupyterLab et SageMath

    Attention Il existe plusieurs environnements MyDocker. Vous devez choisir l'environnement qui correspond au cours sinon les bons logiciels ne seront pas installés. Cependant, vous avez les même fichiers quels que soit l'environnement. L'environnement dont nous avons besoin est JupyterLab et SageMath ce n'est pas le même que l'environnement du cours Prog Modulaire ni de Sciences de données.

    1. Cliquez sur "Connexion à l'interface" en dessous de "Jupyterlab"

    Vous obtenez un navigateur sur les fichiers de votre dossier personnel sur ce serveur. Cet espace personnel est maintenu quel que soit l'environnement.

    Mise en place (premier TP)

    Ouvrez un terminal sur Jupyter Lab (bouton + en haut à gauche) puis tapez les commandes :

    cd ~
    git clone https://gitlab.dsi.universite-paris-saclay.fr/projetmathinfo/ComputerLab ~/ProjetMathInfo
    

    Récupérer un TP

    Depuis un terminal, allez dans le dossier ProjetMathInfo en tapant

    cd ProjetMathInfo
    

    Ensuite, lancez la commande correspondant au TP que vous voulez récupérer :

    ./course.py fetch TP1
    
    ./course.py fetch TP2
    
    ./course.py fetch TP3
    
    ./course.py fetch TP_CheminsRecursifs
    
    ./course.py fetch TP_Des
    
    ./course.py fetch TP_Geologie
    

    Identifiant: anonymous (ceux qui ont des identifiants Paris-Saclay pré piratage peuvent aussi les utiliser)

    Une fois le TP récupéré, vous trouverez la feuille Jupyter dans le dossier correspondant sur votre serveur. Vous pouvez réaliser le TP directement sur le serveur.

    Soumettre le TP

    Cette partie ne fonctionne que pour les étudiants qui ont accès à un compte Paris-Saclay obtenu avant le piratage (inscription en juillet). Pour les autres, nous mettrons en place d'autres solutions pour rendre les TP

    En fin de séance, pensez à "soumettre" votre TP, c'est-à-dire à l'enregistrer sur le serveur gitlab. Cela vous permet de :

    • sauver votre travail en cas de problème sur le serveur Jupyter
    • rendre votre travail accessible à votre enseignant

    La commande pour sauvegarder un TP sur gitlab est la suivante :

    ./course.py submit TP1 MonGroupe
    

    (remplacez TP1 par le nom du TP que vous sauvegardez et MonGroupe par LDDIM1 ou LDDIM2)

    Attention ! Vérifiez bien que l'envoi du TP a fonctionné. Vous devez voir le message suivant

    INFO:travo:- Soumission effectuée. Vous pouvez consulter votre dépôt:
    

    Vous pouvez vérifier sur le lien que la soumission a fonctionné, c'est-à-dire que le fichier est bien à jour sur gitlab (ce lien ne fonctionne que si vous êtes connectés sur le réseau de l'université). En particulier, vous devez voir l'envoi que vous avez fait depuis "l’activité" du projet gitlab ou dans la liste des "commits"

    Installer l'environnement de travail chez vous

    Cette partie est réservée aux étudiantes et étudiants qui souhaitent directement travailler sur leur propre machine sans passer par le serveur jupyter en ligne.

    J'ai testé les instructions sur une machine sous Linux. Je ne sais pas si tout fonctionne sur les autres Systèmes d'exploitations (en particulier sous Windows) . En suivant les instructions jusqu'au bout, vous obtenez une copie de l'environnement de travail avec la commande ./course.

    Si ça ne fonctionne pas, vous pouvez aussi vous contenter d'installer le logiciel SageMath. Vous n'aurez simplement pas accès à la commande pour faire des fetch / submit mais vous pouvez télécharger / uploader les fiches depuis le serveur jupyter ou gitlab.

    Etape 1 : Installation de miniconda (si pas déjà fait au premier semestre)

    Suivez les instructions de https://conda.io/miniconda.html . Sous linux, ce sera, dans un terminal:

    wget https://repo.continuum.io/miniconda/Miniconda3-latest-Linux-x86_64.sh
    bash Miniconda3-latest-Linux-x86_64.sh
    

    À la fin de l’installation, le script modifie votre .bashrc pour rajouter conda dans votre PATH. Il faut ouvrir un nouveau terminal pour que cela prenne effet. Essayez, par exemple:

    conda list
    

    Etape 2 : Téléchargement du dépôt git du cours

    Le dépot contient très peu de choses : principalement un script pour installer les logiciels

    git clone https://gitlab.dsi.universite-paris-saclay.fr/projetmathinfo/ComputerLab ProjetMathInfo
    

    (cette étape n'est possible pour l'instant que si vous êtes connectés depuis l'université, l'accès au serveur gitlab depuis l'extérieur devrait être rétabli bientôt)

    Etape 3 : Installation des logiciels

    En étant dans le sous-répertoire ProjetMathInfo/binder

    conda env create
    

    Pour mettre à jour les logiciels, dans le sous-répertoire ProjetMathInfo/binder

    conda env update
    

    Utilisation des logiciels

    À l’ouverture du terminal, il faudra activer l’environnement projet-math-info

    source activate projet-math-info
    

    Ensuite vous pouvez suivre les instructions habituelles depuis votre dossier local ProjetMathInfo

  • Rapport de mi projet

    Le rapport de mi-projet est à rendre sous forme d'un document PDF : un document par groupe contenant les noms de l'ensemble des membres. C'est une mise en contexte mathématique du sujet choisi. Il doit comporter les réponses aux questions de la première partie ainsi qu'une présentation générale du sujet.

    Le rapport peut être rédigé en français ou en anglais. Vous pouvez utiliser un outil de rédaction mathématique comme LaTeX, sans obligation.

    Il sera évalué sur 45 points : 15 points pour la présentation générale et 30 points pour les questions.

    Voilà le barème pour les 15 points de présentation générale :

    • Introduction (2 points) : Présentation du problème, explication des enjeux, pourquoi est-ce intéressant pour un projet math-info ?
    • Conclusion (2 points) : Recul sur les résultats obtenus, ouverture sur la partie 2 : qu'est-ce qu'il reste à faire ? Comment les réponses de la partie 1 vont-elle aider ?
    • Transitions (2 points) : Le rapport contient des transitions entre les questions permettant d'en comprendre l'intérêt, et comment elles sont liées entre elles.
    • Qualité de rédaction (2 points) : Qualité de la langue et des tournures de phrase, formalisme mathématique rigoureux, exposition claire des arguments.
    • Mise en page (2 points) : Mise en page professionnelle, utilisation de titres / sections claires.
    • Illustrations (3 points) : Des figures propres et parlantes accompagnent le texte pour illustrer les raisonnements des preuves, ou bien donner des exemples.