Ci-dessous, les différences entre deux révisions de la page.
Les deux révisions précédentesRévision précédenteProchaine révision | Révision précédente | ||
documentation:tutorials:build:fortran [2015/02/20 10:50] – [Compilation et d'exécution d'un programme (Fortran)] ltaulell | documentation:tutorials:build:fortran [2023/01/13 09:34] (Version actuelle) – supprimée ccalugar | ||
---|---|---|---|
Ligne 1: | Ligne 1: | ||
- | ====== Compilation et d' | ||
- | {INLINE_TOC} | ||
- | ===== Langage Fortran 90, code séquentiel ===== | ||
- | |||
- | Le programme [[documentation: | ||
- | |||
- | ====Compilation du programme :==== | ||
- | |||
- | **Définition de l' | ||
- | |||
- | * définition de l' | ||
- | <code bash> | ||
- | source / | ||
- | source / | ||
- | module use / | ||
- | module load Base/psmn | ||
- | module load intel/ | ||
- | </ | ||
- | |||
- | * définition de l' | ||
- | |||
- | < | ||
- | source / | ||
- | </ | ||
- | |||
- | < | ||
- | source / | ||
- | </ | ||
- | |||
- | * définition de l' | ||
- | <code bash> | ||
- | source / | ||
- | source / | ||
- | module use / | ||
- | module load Base/psmn | ||
- | module load intel/ | ||
- | </ | ||
- | |||
- | * définition de l' | ||
- | |||
- | < | ||
- | source / | ||
- | </ | ||
- | |||
- | <code bash> | ||
- | source / | ||
- | </ | ||
- | |||
- | * vérification de la version du compilateur | ||
- | < | ||
- | ifort --version | ||
- | ifort (IFORT) 14.0.1 20131008 | ||
- | </ | ||
- | |||
- | **Compilation** : | ||
- | |||
- | < | ||
- | ifort -o SommeVecVecSEQ.f90.exe SommeVecVecSEQ.f90 (avec intel) | ||
- | </ | ||
- | |||
- | < | ||
- | gfortran -o SommeVecVecSEQ.f90.exe SommeVecVecSEQ.f90 (avec gnu) | ||
- | </ | ||
- | |||
- | Le fichier binaire (exécutable) '' | ||
- | ====Exécution du programme :==== | ||
- | |||
- | === Exécution sur le serveur de compilation : === | ||
- | |||
- | < | ||
- | ./ | ||
- | </ | ||
- | |||
- | Le résultat est affiché a l' | ||
- | |||
- | < | ||
- | Les deux vecteurs : | ||
- | |||
- | A = 1 | ||
- | |||
- | B = 9 | ||
- | |||
- | Le vecteur somme : | ||
- | |||
- | C = | ||
- | </ | ||
- | |||
- | === Exécution sur le cluster : === | ||
- | |||
- | |||
- | On utilise un script de soumission [[documentation: | ||
- | |||
- | C'est le script de soumission qui configure l' | ||
- | |||
- | '' | ||
- | |||
- | < | ||
- | qsub batch.csh | ||
- | Your job 769504 (" | ||
- | qstat | ||
- | |||
- | job-ID | ||
- | ----------------------------------------------------------------------------------------------------------------- | ||
- | | ||
- | </ | ||
- | |||
- | * La sortie de l' | ||
- | * La sortie erreur (erreur standard) est redirigée dans le fichier '' | ||
- | | ||
- | < | ||
- | cat batch.csh.o769504 | ||
- | |||
- | Les deux vecteurs : | ||
- | A = 1 | ||
- | B = 9 | ||
- | Le vecteur somme : | ||
- | C = | ||
- | </ | ||
- | |||
- | ===== Langage Fortran 90, code parallèle ===== | ||
- | |||
- | Le programme [[documentation: | ||
- | |||
- | ==== Compilation du programme : ==== | ||
- | |||
- | === Définition de l' | ||
- | |||
- | |||
- | * définition de l' | ||
- | <code bash> | ||
- | source / | ||
- | module use / | ||
- | module load Base/psmn | ||
- | |||
- | module load openmpi/ | ||
- | </ | ||
- | |||
- | * définition de l' | ||
- | <code bash> | ||
- | source / | ||
- | module use / | ||
- | module load Base/psmn | ||
- | |||
- | module load openmpi/ | ||
- | </ | ||
- | |||
- | * définition de l' | ||
- | < | ||
- | source / | ||
- | </ | ||
- | |||
- | < | ||
- | source / | ||
- | </ | ||
- | |||
- | |||
- | * définition de l' | ||
- | <code bash> | ||
- | source / | ||
- | </ | ||
- | |||
- | * Vérification | ||
- | < | ||
- | mpif90 -showme | ||
- | |||
- | ifort -I/ | ||
- | </ | ||
- | |||
- | === Compilation : === | ||
- | |||
- | |||
- | < | ||
- | mpif90 -o SommeVecVecPAR.f90.exe SommeVecVecPAR.f90 (avec intel) | ||
- | </ | ||
- | |||
- | < | ||
- | mpif90 -o SommeVecVecPAR.f90.exe SommeVecVecPAR.f90 (avec gnu) | ||
- | </ | ||
- | |||
- | |||
- | Le fichier binaire (exécutable) '' | ||
- | |||
- | ====Exécution du programme :==== | ||
- | |||
- | === Exécution sur le serveur de compilation : === | ||
- | |||
- | < | ||
- | mpirun -np 2 ./ | ||
- | </ | ||
- | |||
- | Le résultat est affiché a l' | ||
- | |||
- | < | ||
- | LES DEUX VECTEURS : | ||
- | A = 1 | ||
- | B = 9 | ||
- | |||
- | LES DEUX VECTEURS LOCAUX : | ||
- | Je suis le proc 0 parmi 2 processus | ||
- | A local ( proc 0 ) = 1 | ||
- | B local ( proc 0 ) = 9 | ||
- | Je suis le proc 1 parmi 2 processus | ||
- | A local ( proc 1 ) = 6 | ||
- | B local ( proc 1 ) = 4 | ||
- | LE VECTEUR SOMME LOCAL : | ||
- | C local ( proc 1 ) = | ||
- | C local ( proc 0 ) = | ||
- | LE VECTEUR SOMME : | ||
- | C = | ||
- | </ | ||
- | |||
- | === Exécution sur le cluster : === | ||
- | |||
- | |||
- | On utilise un script de soumission [[documentation: | ||
- | |||
- | |||
- | C'est le script de soumission qui configure l' | ||
- | |||
- | '' | ||
- | |||
- | < | ||
- | qsub batch.csh | ||
- | Your job 772030 (" | ||
- | </ | ||
- | |||
- | < | ||
- | qstat | ||
- | |||
- | job-ID | ||
- | ----------------------------------------------------------------------------------------------------------------- | ||
- | | ||
- | |||
- | qstat | ||
- | |||
- | job-ID | ||
- | ----------------------------------------------------------------------------------------------------------------- | ||
- | | ||
- | </ | ||
- | |||
- | La sortie de l' | ||
- | |||
- | < | ||
- | cat batch.csh.o772030 | ||
- | |||
- | / | ||
- | LES DEUX VECTEURS : | ||
- | A = 1 | ||
- | B = 9 | ||
- | LES DEUX VECTEURS LOCAUX : | ||
- | Je suis le proc 0 parmi 2 processus | ||
- | A local ( proc 0 ) = 1 | ||
- | B local ( proc 0 ) = 9 | ||
- | LE VECTEUR SOMME LOCAL : | ||
- | C local ( proc 0 ) = | ||
- | LE VECTEUR SOMME : | ||
- | C = | ||
- | Je suis le proc 1 parmi 2 processus | ||
- | A local ( proc 1 ) = 6 | ||
- | B local ( proc 1 ) = 4 | ||
- | C local ( proc 1 ) = | ||
- | </ |