GOTM - General Ocean Turbulence Model
Introduction
GOTM (General Ocean Turbulence Model) est un modèle libre qui simule les processus physique d'une colonne d'eau lacustre ou océanique en solutionnant les équations du transport moyen et turbulent sur la verticale. Il a été développé à l'origine par Hans Burchard, Karsten Bolding, Manuel Ruiz-Villareal et Pierre-Philippe Mathieu et hébergé à l'Institute of Oceanography in Hambourg d'où l'on peut obtenir le code source (www.gotm.net). Depuis 2008, Dany Dumont et plusieurs étudiants et collaborateurs ont utilisé ce code riche et versatile dans plusieurs projets. Pour faciliter la collaboration interne et pour tirer parti des modifications apportées, une branche du code gotm-4.0.0 a été déposée dans un dépôt svn sur les serveurs du LASSO (ISMER) sous le nom de gotm_ismer. Ce dépôt a été créé afin de partager et de documenter à l'interne les avancées faites par chacun. Lorsque le code évolue significativement, les modifications sont proposées à l'équipe de développeurs qui les incorporent dans la version officielle, profitant ainsi à toute la communauté GOTM.
Guide d'utilisation
Obtenir le code gotm_ismer
Le code gotm_ismer est en fait une copie du code gotm-4.0.0 qui a subit quelques modifications somme toute assez superficielles associées aux modèles biogéochimiques. Dans un futur pas très lointain, l'objectif est de migrer vers FABM (Framework for Aquatic Biogeochemical Models), un code traitant les modèles biogéochimiques de manière modulaire et donc beaucoup plus flexible, couplés à gotm-4.1.
Pour obtenir le code gotm_ismer, vous devez d'abord avoir obtenu un accès à demeter. Ensuite, vous devez créer un répertoire de travail dans lequel le code sera téléchargé. Ce répertoire sera la racine du code. Le nom gotm_ismer est fortement suggéré afin de faciliter la portabilité du code.
mkdir gotm_ismer cd gotm_ismer
Accédez à ce répertoire et exécutez la commande suivante:
svn co http://demeter.uqar.ca/svn/gotm_ismer/trunk .
Si le téléchargement a été effectué avec succès, vous devriez retrouver les répertoires suivants:
compilers/ ! Contient les informations permettant de compiler le modèle sur votre ordinateur doc/ ! Documentation originale LaTeX include/ ! Définitions de pré-compilation nml/ ! Modèles de namelists (fichiers de contrôle ou de paramétrage des simulations) scripts/ ! Fonctions et scripts pertinents src/ ! Code source templates/ ! Modèles de routines test_cases/ ! Cas test
Compiler le code
La compilation du code consiste à lire, interpréter, lier et condenser les routines fortran dans un fichier exécutable ou programme dont on se servira pour exécuter le modèle. Le code source se trouve dans le répertoire src/ qui contient les routines fortran (.F90) qui sont classées dans des sous-répertoires représentant certaines sections du code.
gotm/ ! Contient le programme principal. observations/ ! ... meanflow/ ! ... airsea/ ! ... turbulence/ ! ... util/ ! ... extras/ ! ...
Rules.make
Le répertoire src/ contient également le fichier Makefile, qui fixe les règles de compilation qui ne doivent pas être modifiées (à moins que vous ne décidiez de faire certaines modifications avancées au code), et le fichier Rules.make.template qui contient les règles de compilation et les variables d'environnement propres à l'utilisateur et qui elles doivent être modifiées par l'utilisateur. Pour effectuer cette étape, faite une copie du fichier modèle Rules.make.template en le nommant Rules.make.
cp Rules.make.template Rules.make
Modifiez ensuite les variables d'environnement en fonction de votre profil et de votre plate-forme. L'exemple suivant s'applique au serveur brandypot:
- Spécifier le compilateur à utiliser. Cette variable servira à pointer vers un fichier compiler.$FORTRAN_COMPILER qui doit exister et se trouver dans le répertoire compilers/:
FORTRAN_COMPILER=IFORT
- Indiquer l'emplacement des librairies NetCDF:
NETCDFINC = /opt/local/netcdf-3.6.1/include NETCDFLIBDIR = /opt/local/lib
- Déterminer quelles portions du code vous voulez compiler. Dans l'exemple suivant, le code correspondant aux modules sediment et seagrass (qu'on retrouve dans le répertoire src/extras/) ne sera pas compilé alors que le module bio et le module netcdf, qui permet de sauvegarder les sorties du modèle en format NetCDF, le sera:
# What do we include in this compilation NetCDF=true SEDIMENT=false SEAGRASS=false BIO=true
Une fois le fichier Rules.make correctement modifié, vous pouvez compiler le code en faisant:
make realclean make
À la fin de la compilation, l'exécutable gotm_prod_IFORT est créé. Le terme prod indique que la compilation a été faite en mode production, option que l'on détermine dans le fichier Rules.make (l'autre option disponible est debug), et le terme IFORT indique qu'elle a été réalisée avec le compilateur ifort utilisant le fichier de configuration compilers/compiler.IFORT. En cas de problème, consultez la page dépannage.
Configurer une expérience
Si vous arrivez à compiler le code avec succès, c'est que vous êtes maintenant prêts à construire votre propre expérience. Vous pouvez pour cela vous inspirer des cas test (voir prochaine section), ou bien suivre les indications de cette section. Mettre en place une expérience nécessite d'abord de créer un répertoire de travail à partir duquel vous exécuterai le modèle. La pratique commune est de mettre toutes vos expérience (vous risquez d'en faire plus d'une) dans un répertoire exp/ que vous pouvez créer dans un endroit où vous avez suffisamment d'espace disque. Sur brandypot, il est commun d'utiliser la partition /sas/usagers pour y mettre ce répertoire, comme par exemple /sas/usagers/dumoda01/gotm/exp. Afin de simplifier l'exécution du code, il est conseillé de faire un lien symbolique de exp/ dans /home/dumoda01/gotm_ismer en faisant la commande:
cd gotm_ismer ln -s /sas/usagers/dumoda01/gotm/exp .
De cette manière, le répertoire sera accessible aisément à partir du répertoire racine, mais les données parfois volumineuses seront stockées dans un endroit où il y a suffisamment d'espace. Dans exp/, créez un répertoire portant le nom de votre expérience (ex. potter_cove_1/). À ce stade-ci, vous avez besoin de trois ingrédients principaux pour réaliser votre expérience: 1) l'exécutable (gotm_prod_IFORT, que vous avez déjà), 2) des fichiers de paramètres namelist (*.nml) et 3) des fichiers intrants (*.dat).
La façon la plus sûre d'obtenir le premier est de créer une lien symbolique de l'exécutable se trouvant dans src/ dans le répertoire de l'expérience:
cd potter_cove_1 ln -s /home/dumoda01/gotm_ismer/src/gotm_prod_IFORT .
De cette façon, toute modification au code sera prise en compte automatiquement. Les fichiers namelist correspondant à la dernière version du code sont situés dans le répertoire gotm_ismer/nml/. Chaque fichier contient plusieurs namelists associées aux routines du code dont certains paramètres peuvent être affectés. Les namelists permettent de modifier des variables ou des paramètres sans avoir à recompiler le code. Chacun des paramètres sont documentés dans les fichiers. Certains fichiers sont obligatoires alors que d'autres dépendent des modules que l'on désire utiliser. En voici la liste complète:
# Mandatory namelist files gotmrun.nml gotmmean.nml gotmturb.nml airsea.nml obs.nml kpp.nml # Module-dependent namelist files bio.nml bio_fasham.nml bio_npzd.nml bio_iow.nml
C'est à travers les namelist que l'on gère les intrants au modèle. Par exemple, on peut demander au modèle de lire les variables météorologiques ou des profils de température et de salinité à partir de fichiers. Dans un tel cas, il faut donc fournir ces fichiers et ce dans un format texte spécifique. C'est le troisième et dernier ingrédient à mettre dans la soupe. Pour de l'aide sur la façon de formater ces fichiers, consultez le fichier GOTM_HOWTO_observations.txt situé dans le répertoire racine. Les sections suivantes décrivent différentes façon de générer ces fichiers selon l'origine des données.
meteo.dat
Tel qu'indiqué dans GOTM_HOWTO_observations.txt, le fichier meteo.dat doit être formaté de la manière suivante:
1957-09-01 00:00:00 2.46 6.80 1011.1 12.13 10.20 0.61 1957-09-01 06:00:00 0.46 6.32 1011.2 13.85 11.04 0.63 1957-09-01 12:00:00 -0.16 6.20 1010.8 15.38 10.72 0.88 1957-09-01 18:00:00 -0.56 4.41 1010.2 13.56 10.50 0.83 1957-09-02 00:00:00 1.83 3.43 1009.8 13.31 10.65 0.40 1957-09-02 06:00:00 3.70 6.76 1009.1 13.08 10.86 1.00 1957-09-02 12:00:00 5.24 7.13 1009.5 14.33 12.49 0.98 1957-09-02 18:00:00 5.67 8.07 1009.7 15.06 12.09 0.71 1957-09-03 00:00:00 5.15 6.46 1010.4 14.68 12.88 0.83 1957-09-03 06:00:00 1.17 3.47 1010.4 14.78 13.42 0.69 ...
Exécuter en mode batch
Les scripts batch_airsea.sh et batch_bio.sh permettent de lancer en série plusieurs simulations avec des valeurs de paramètres différents. Le script batch_airsea.sh permet de faire varier les forçages en surface alors que batch_bio.sh permet de varier les paramètres des modèles biologiques. Ils sont situés dans le répertoire gotm_ismer/scripts/shell/.
batch_bio.sh
Ce script prend en argument le nom du modèle biologique sui sera utilisé, tel que spécifié dans bio.nml. Par exemple, si on utilise le modèle de Fasham (bio_model=4), on écrit:
./batch_bio.sh fasham
Si le répertoire gotm_ismer/script/shell est dans votre PATH, vous pouvez appeler le script sans le ./:
batch_bio.sh fasham
Deux fichiers sont nécessaires, bio_$model.mal et gotmrun.mal, qui sont en fait les fichiers namelists qui seront lus par le script pour générer les .nml correspond qui eux seront utilisés par le modèle. Dans gotmrun.mal, le paramètre qui spécifie le nom du fichier de sortie out doit être experiment_name. Dans bio_$model.mal ($model est l'argument du script, e.g. fasham, npzd ou ismer), les paramètres dont on veut varier les valeurs pour chacune des simulation de la batch doivent prendre les valeurs param1, param2, param3, etc. Vous pouvez attribuer ces valeurs à autant de paramètres que vous le voulez. Une fois que ce choix est fait, vous devrez modifier le script batch_bio.sh pour tenir compte de ces choix.
Pour illustrer cette étape, procédons par un exemple. Supposons qu'on veuille faire ving-cinq simulations en variant deux paramètres, vp et alpha qui prendront chacun cinq valeurs différentes. Ceci doit être spécifié de la manière suivante:
# Parameters for the biological model vp="0.02 0.08 0.24 0.48 0.72" alpha="0.01 0.04 0.16 0.32 0.48"
Ensuite, il faut ajuster la portion suivante du script afin de respecter le nombre de paramètres:
count=0 for a in $vp do for b in $alpha do count=`expr $count + 1` count=`expr 000$count | tail -8c` echo $count if [ -f bio_fasham.nml ] then rm -f bio_fasham.nml fi cat bio_fasham.mal | sed \ -e "s/param1/$a/g" \ -e "s/param2/$b/g" \ > bio_fasham.nml if [ -f bio_fasham.nml ] then echo " bio_fasham.nml created" fi if [ -f gotmrun.nml ] then rm -f gotmrun.nml fi cat gotmrun.mal | sed \ -e "s/experiment_name/$count/g" \ > gotmrun.nml if [ -f gotmrun.nml ] then echo " gotmrun.nml created" fi strt=`date +%H:%M:%S` echo " started at "$strt ./gotm_prod_IFORT >& $count.out end=`date +%H:%M:%S` echo " ended at "$end done done
Dans cet exemple, le fichier bio_fasham.mal devra contenir les ligne suivantes:
... vp = param1 alpha = param2 ...
batch_airsea.sh
À venir ...
Cas test
À venir ...
Visualisation des résultats
Pour visualiser les sorties du modèle, le logiciel Ferret constitue une option extrêmement intéressante. Ce programme permet de produire des figures très simplement en tenant compte des méta-données contenues dans les fichiers NetCDF. Pour se familiariser avec le logiciel et obtenir de l'aide, consultez le site [1]. Dans cette section sont présentés des exemples de scripts permettant de visualiser des quantités importantes pour l'interprétation d'une simulation couplée. Les scripts ferret (*.jnl) sont en fait une liste de commandes Ferret qu'on peut exécuter avec la commande suivante:
ferret -gif -script scriptname.jnl
L'option -gif dit à ferret de ne pas afficher les figures à l'écran pendant l'exécution du script. Les figures seront plutôt produites et sauvegardées par la commande
frame/file=figure.gif
qui apparaît dans le script. Voici donc quelques exemples appliqués à une simulation couplée représentant le golfe d'Amundsen avec le modèle biologique de type Fasham et al. (1990).