Bienvenue dans ce projet d'informatique du Bachelor 2 à l'EPFL, en section physique.
Projet réalisé par Delphine Martres et Damien Korber.
Jusqu'où avez-vous été ? qu'est-ce que vous avez fait/pas fait ?
Nous avons été jusqu'au bout du projet, c'est-à-dire jusqu'à P13 compris.
Nous avons réalisé l'ensemble des oscillateurs du complément mathématique, à l'exceptions des pendules reliés par un ressort et l'oscillateur DeuxRessort, dû à un manque de temps. Une analyse des oscillateurs implémentés est disponible plus bas.
Nous avons implémenté tous les intégrateurs énoncés dans le complément mathématique, c-à-d Euler-Cromer, Newmark et Runge-Kutta d'ordre 4. Un comparatif est disponible plus bas.
Nous avons également un espace des phases fonctionnel. Nous avons également implémenté une touche pour changer l'oscillateur associé à l'espace des phases pendant la simulation graphique.
Avez-vous une version graphique ? Si oui, avec quelle bibliothèque graphique (Qt (quelle version ?), WxWidget, SDL, Glut, autre [précisez]) ?
Oui, nous avons une version graphique.
Nous utilisons qmake 3.1 et Qt 5.10 pour ce projet. Le programme fonctionne peut-être avec d'autres version, mais nous n'avons pas testé. De plus, nous avons testé le programme sur les OS suivants:
- MacOS 10.13.4
- Kubuntu 16.04
- Machine virtuelle de l'EPFL (25 mai)
Combien d'heures en moyenne par personne estimez vous avoir passé par semaine sur le projet ? (essayez d'être objectif : n'oubliez pas qu'au début vous n'avez peut être pas fait grand chose, comptez sur 14 semaines, i.e. la première semaine incluse, ne comptez pas le cours ni les exercices hors projet, n'oubliez pas de diviser le total par 2 car je veux une estimation moyenne par personne.)
Nous estimons, en moyenne et par personne, une implication d'une petite dizaine d'heures par semaine. Cependant, nous avons fait attention à ne pas prendre trop de temps sur les autres branches. Ainsi, nous avons essentiellement travaillé sur nos temps libres (soirs du week-end et vendredi dès midi essentiellement).
La simulation visuelle
Le point central de ce projet est évidemment la simulation visuelle. Nous vous proposons de compiler et exécuter le programme dans Qt_GL. Quand vous y êtes, vous pouvez vous balader dans l'espace et admirer les oscillateurs. Un petit point supplémentaire, plus un ressort est étiré ou le support du pendule de torsion est tendu, plus le fil devient rouge.
L'espace des phases
Lors de l'execution de la version graphique du projet, l'espace des phases peut-être affiché en appuyant sur P. On peut donc y voir une représentation de la vitesse en fonction du temps de l'oscillateur sélectionné. Pour changer d'oscillateur dessiné, rien de plus simple ! Il suffit d'appuyer sur O, et un nouvel oscillateur est dessiné. Remarquez qu'il commence à dessiner l'espace de phase là au moment ou vous avez cliqué. En effet, nous n'avons qu'un espace de phase à la fois. Lors d'un changement d'oscillateur, nous effaçons les positions conservées dans la phase. Pour changer l'oscillateur dessiné par défaut, suivre les instructions se trouvant dans la fonction GLWidget::initSys()
.
La boussole
Il est très facile de se perdre dans la simulation visuelle. Du coup, nous avons implémenté une boussole directement sur Qt. (trois axes de l'espace affectés par les rotations mais pas les translations) Nous en sommes fiers, parce que ce n'était pas facile à faire. Par défaut, elle devrait être activée. Mais si ce n'est pas le cas, ou si vous voulez désactiver cette boussole, appuyez sur la touche B. Elle suit vos mouvements dans l'espace.
Le changement de point de vue
Nous n'étions pas d'accord sur la façon de se déplacer dans l'espace. Nous avons donc implémenté un toggle permettant de switcher entre une vue à la première personne (on "est" la caméra) et une vue à la troisième personne (on fixe un point dans l'espace). Pour changer de point de vue, appuyez sur V.
Le changement d'intégrateur en cours d'execution
Dans la simulation graphique, il est possible de changer d'intégrateur en cours d'exécution. Par défaut, l'intégrateur de Runge-Kutta d'ordre 4 est utilisé, mais vous pouvez changer d'intégrateur en cours de route. Pour cela, appuyez sur:
-
1 - pour utiliser Euler-Cromer;
-
2 - pour utiliser Newmark;
-
3 - pour utiliser Runge-Kutta d'ordre 4.
Un message indiquant un changement d'intégrateur sera affiché dans le terminal.
Remarque: le texte affiché après est l'adresse de l'intégrateur actuel.
La documentation
Pour ne pas se perdre dans le projet, nous avons utilisé Doxygen pour générér la documentation automatiquement. Pour plus d'informations à ce sujet, se référer à la section "Générer la documentation".
Le mode debug
Pour vérifier le bon fonctionnement des oscillateurs exécutés durant la simulation visuelle, nous avons implémenté un mode debug. Lors de l'exécution, appuyez sur § pour (dés)activer le mode debug. Les informations s'afficheront dans le terminal.
- Préambule
- Informations concernant le projet.
- Les quelques points intéressants du projet.
- Table des matières
- Introduction
- Guide de compilation
- Ce qui est compilable
- Compiler sur MacOS et Linux
- Compiler tous les sous-projet fonctionnels
- Générer la documentation
- Guide d'utilisation
- Les touches.
- Analyse
- Les intégrateurs
- Les oscillateurs
- Le pendule simple
- Le ressort simple
- La chute
- Le pendule de torsion
- Le chariot
- Le pendule double non amorti.
- Le Pendule-Ressort non amorti.
Le but de ce projet est la réalisation d'un programme pouvant simuler des oscillateurs couplés. Nous avons réalisé quelques preset d'oscillateurs, mais le programme se veut suffisamment souple pour ajouter de nouveaux oscillateurs.
Nous offrons une simulation textuelle, ainsi qu'une simulation visuelle, utilisant Qt et OpenGL.
Pour compiler le programme dans sa version actuelle, rien de plus simple, suivez ce tutoriel et tout devrait bien se passer.
Nous avons plusieurs parties du projet qui compilent.
La simulation visuelle
Elle se trouve dans exerciceP10/Qt_GL/
et est fonctionnelle.
La simulation textuelle
Elle se trouve dans exerciceP10/text/
et est fonctionnelle.
Les fichiers tests
La plupart des fichiers tests ne fonctionnent plus, car ils sont trop vieux, et que nous les avons pas actualisés. Néanmoins, il reste deux tests qui compilent encore. Il s'agit de phase (exerciceP10/general/phase/
) et de vecteur (exerciceP10/general/vecteur/
).
Pour compiler sur MacOS et Linux, il suffit de se rendre à la racine du projet, et de faire ces commandes.
qmake # Génère un Makefile permetant de compiler le projet.
make # Compile le projet en suivant les instructions du Makefile.
Ainsi, on compile tout ce qui est fonctionnel dans ce projet.
Remarque: Il est possible de se rendre dans chaque dossier fonctionnel, et d'y exécuter ces commandes. Ainsi, on peut compiler les projets séparément.
Pour exécuter ce qu'on vient de compiler, il suffit de se rendre dans le dossier de ce qu'on veut tester (c.f. Voir "Ce qui est compilable") et lancer la commande:
./$NOM_DE_EXECUTABLE # Lance l'exécutable demandé.
où $NOM_DE_EXECUTABLE
est le... nom de l'exécutable.
La documentation est générée automatiquement par Doxygen.
Génération et lecture
Pour générer la documentation, allez à la racine du projet (là où se trouve le README), et exécutez cette commande: doxygen doxyfile
.
La documentation ainsi générée se trouve dans docs/
. Pour la documentation html, ouvrez docs/html/index.html
. Pour la documentation en latex, exécutez make
dans le dossier docs/latex
.
Remarque: la documentation en latex n'est ni maintenue, ni testée.
Dans cette section, nous vous expliquons comment utiliser ce projet. Concernant la simulation textuelle, il n'y a rien à savoir, donc nous nous intéressons à la simulation visuelle.
Remarque: Ce programme est adapté pour un clavier Suisse, c'est à dire un clavier QWERTZ.
Déplacements
Action | Touche associée |
---|---|
Avancer | w ou pageUp |
Reculer | s ou pageDown |
Translater sur la droite | d |
Translater sur la gauche | a |
Appliquer une rotation dans le sens trigonométrique | q |
Appliquer une rotation dans le sens horaire | e |
Translater vers le haut | r |
Translater vers le bas | f |
Tourner vers la droite |
|
Tourner vers la gauche |
|
Tourner vers le haut |
|
Tourner vers le bas |
|
Réinitialiser à la position originale | home ou h |
Autres commandes.
Action | Touche associée |
---|---|
(Dés)activation de la boussole | b |
(Dés)activation du mode debug dans le terminal | § |
(Dés)activation de la mise en pause de la simulation | space |
Changement de la vue (première ou troisième personne) | v |
Activation de l'intégrateur d'Euler-Cromer | 1 |
Activation de l'intégrateur de Newmark | 2 |
Activation de l'intégrateur de Runge-Kutta d'ordre 4 | 3 |
(Dés)activation de l'espace de phase | p |
Dessine l'oscillateur suivant dans l'espace des phases | o |
Nous avons effectué quelques petites analyse de nos différentes implémentations.
Nous avons implémentés les trois intégrateurs proposés. L'intégrateur d'Euler-Cromer, de Newmark, et de Runge-Kutta à l'ordre 4. Nous avons donc testé une chute libre de conditions initiales
Nous remarquons que, effectivement, l'intégrateur d'Euler-Cromer est moins bon que les autres. Il est certes plus simple à implémenter et moins coûteux en ressources, mais il est bien moins précis.
De plus, nous notons que l'intégrateur de Newmark et l'intégrateur de Runge-Kutta d'ordre 4 ont quasiment la même précision ! Sur le graphe, ils sont confondus.
Nous avons implémenté un certaine nombre d'oscillateurs, et nous avons effectué quelques tests pour voir leur bon fonctionnement.
Tous les tests ci-dessous sont effectué avec l'intégrateur de Runge-Kutta d'ordre 4.
Conditions initiales
- Masse = 1
- Longueur = 2
- Viscosité = 0.1
- Position = {M_PI/2}
- Vitesse = {0.0}
- Origine = {0.0, 0.0, 0.0}
- Direction principale = {1.0, 0.0, 0.0}
Schéma
Nous remarquons que l'évolution du pendule se passe comme prévu. Il est amorti et tend vers un minimum.
Conditions initiales
- Masse = 0.25
- Élasticité = 0.5
- Viscosité = 0.02
- Position = {0.18}
- Vitesse = {0.0}
- Origine = {0.0, 0.0, 0.0}
- Direction principale = {0.8, 0.0, 0.6}
Schéma
![Graphique d'évolution d'un ressort à ces conditions initiales](annexes/graphRessort.png) Nous remarquons que l'évolution du ressort se passe comme prévu. Il est amorti et tend vers un minimum.Conditions initiales
- Masse = 1
- Position = {0.0, 1.0}
- Vitesse = {1.0, 2.0}
- Origine = {0.0, 1.0}
- Direction principale = {0.0, 1.0}
Schéma
Nous remarquons que l'évolution de la chute se passe comme prévu. Elle continue à chuter à accélération constante.
Conditions initiales
- Moment d'inertie = 1
- Constante de torsion = 1
- Friction = 0.05
- Position = {M_PI/4}
- Vitesse = {0.0}
- Origine = {0.0, 0.0, 0.0}
- Direction principale = {1.0, 0.0, 0.0}
Schéma
Nous remarquons que l'évolution du pendule de torsion se passe comme prévu. Il est amorti et tend vers un minimum.
Conditions initiales
- Masse du chariot = 1
- Masse du pendule = 1
- Longueur du pendule = 1.5
- Élasticité = 0.1
- Viscosité du chariot = 0.1
- Viscosité du pendule = 0.1
- Position = {1.0, M_PI/3}
- Vitesse = {0.0, 0.0}
- Origine = {0.0, 0.0, 0.0}
- Direction principale = {1.0, 0.0, 0.0}
Schéma
Nous remarquons que l'évolution du chariot se passe comme prévu. Il est amorti et tend vers un minimum.
Conditions initiales
- Masse 1 = 1
- Masse 2 = 1
- Longueur 1 = 1.5
- Longueur 2 = 0.1
- Position = {M_PI/3, M_PI/3}
- Vitesse = {0.0, 0.0}
- Origine = {0.0, 0.0, 0.0}
Schéma
Nous remarquons que l'évolution du pendule double non amorti se passe comme prévu. Comme il n'est pas ralenti, il continue à l'infini et est plus ou moins périodique.
Conditions initiales
- Masse = 2
- Longueur = 1
- Raideur = 5
- Position = {1.0, 0.0}
- Vitesse = {0.0, 0.0}
- Origine = {0.0, 0.0, 0.0}
Schéma
Nous remarquons que l'évolution du pendule-ressort non-amorti semble se passer comme prévu.