source: CONFIG/UNIFORM/v6/LMDZOR_v6.2/compile_lmdzor.sh @ 4932

Last change on this file since 4932 was 4932, checked in by jgipsl, 4 years ago

Updated experience LMDZ/clim_360d for new method of setting output files for LMDZ (forgotten when LMDZOR experiments were done) and small cleaning.

  • Property svn:executable set to *
File size: 10.9 KB
Line 
1#!/bin/bash
2#set -vx
3# Default options
4#
5#
6#
7date
8#### 1  Set up the compiling options
9#### Define some directories
10submitdir=$( pwd )
11modipsl=$submitdir/../..
12arch_path=$submitdir/ARCH
13
14#### Set default options
15# Optimization mode
16# optmode=prod/dev/debug
17optmode=prod
18# Resolution of LMDZ in regular mode
19resol_atm=144x142x79
20# Also compile ce0l subprogram to LMDZ (y/n)
21ce0l=y
22
23# fcm_arch
24fcm_arch=default
25# Default values to be overritten
26parallel=mpi_omp
27export fcm_arch parallel xios
28full_flag=""
29full_xios=""
30full_lmdz=""
31full_orch=""
32
33# Default netcdf_lib is used for XIOS but can be change by argument
34netcdf_lib=""
35
36# Output text file for compilation of each component
37datestr=`LC_ALL=C date +"%Y%m%dT%H%M"`
38outfile=$submitdir/out_compile_lmdzor.$datestr
39echo > $outfile
40echo; echo "Text output from compilation will be stored in file out_compile_lmdzor.$datestr"; echo 
41
42#### Read arguments
43# Loop over all arguments to modify default set up
44while (($# > 0)) ; do
45    case $1 in
46        "-h") cat <<end_help
47########################################################################
48# Usage of the script compile_lmdzor.sh
49#
50########################################################################
51
52./compile_config [Options]
53
54Options: -full, -resol_atm, -debug, -dev, -prod(default)
55
56Example 1: Default compilation of LMDZ-ORCHIDEE with XIOS and IOIPSL
57./compile_lmdzor.sh
58
59Example 2: Compile in debug mode
60./compile_lmdzor.sh -debug
61
62Example 3: Default compilation with full recompilation of all components
63./compile_lmdzor.sh -full
64
65Example 4: Compilation of LMDZ in regular lat-lon for other dimensions (default: 144x142x79)
66The dimension can be changed to any other 3d dimension.
67./compile_lmdzor.sh -resol_atm 96x95x79
68
69end_help
70exit;;
71        "-parallel")        parallel=$2 ; shift ; shift ;;
72        "-arch")            fcm_arch="$2" ; shift ; shift ;;
73        "-xios")            xios="$2" ; shift ; shift ;;
74        "-debug")           optmode=debug ; shift ;;
75        "-dev")             optmode=dev ; shift ;;
76        "-prod")            optmode=prod ; shift ;;
77        "-resol_atm")       resol_atm=$2 ; shift ; shift ;;
78        "CE0L")             ce0l=y ; shift ;;
79        "-full")            full_flag="-full"; full_xios="--full" ; full_lmdz="-full" ; full_orch="-full" ; shift ;;
80        "-full_xios")       full_xios="--full" ; shift ;;  # Note only full_xios is using double dash: --full
81        "-full_lmdz")       full_lmdz="-full"  ; shift ;;
82        "-full_orch")       full_orch="-full"  ; shift ;;
83        "-netcdf_lib_seq")  netcdf_lib="--netcdf_lib netcdf4_seq"; shift ;;
84        *)                  echo "unknown option "$1" , exiting..." ; exit
85    esac
86done
87
88echo "Following options are set in current compiling:" >> $outfile 
89echo "   resol_atm=${resol_atm}" >> $outfile 
90echo "   ce0l=${ce0l}" >> $outfile 
91echo "   optmode = $optmode, parallel = $parallel, fcm_arch = $fcm_arch " >> $outfile 
92echo "   full_flag=$full_flag, full_xios=$full_xios, full_lmdz=$full_lmdz, full_orch=$full_orch" >> $outfile 
93echo >> $outfile
94
95### Read host dependent default values
96### These variables will not be changed if they were set as argument
97###./host.sh $host
98# Later : Following lines should be set in host.sh file
99# begin host.sh
100if [ $fcm_arch == default ] ; then
101    # Find out current host and source specific paths and commands for the host
102    case $( hostname -s ) in
103        jean-zay*)
104            fcm_arch=X64_JEANZAY;;
105        irene*)
106            fcm_arch=X64_IRENE;;
107        asterix*|obelix*)
108            fcm_arch=ifort_LSCE;;
109        ciclad*|climserv*)
110            fcm_arch=ifort_CICLAD;;
111        *)
112            echo Current host is not known. You must use option -arch to specify which architecuture files to use.
113            echo Exit now.
114            exit
115    esac
116fi
117
118# Set a link to arch.env if arch-${fcm_arch}.env file exist for current fcm_arch.
119# The link arch.env is also set in config.card and will be used by libIGCM to ensure the same running environnement.
120if [ -f ARCH/arch-${fcm_arch}.env ] ; then
121    echo >> $outfile
122    echo "The file ARCH/arch-${fcm_arch}.env will now be sourced with modules needed for compilation for all components."
123    echo "Note that this new environement might be kept after compilation." 
124    echo "If this is the case, source again your personal environment after compilation. "
125    echo " Personal module list before sourcing of ARCH/arch.env file:"    >> $outfile 
126    module list   >> $outfile 2>&1
127
128    # Make a link to this file, to be used also in config.card
129    rm -f ARCH/arch.env
130    ln -s arch-${fcm_arch}.env ARCH/arch.env
131
132    # Source the file
133    source ARCH/arch.env   >> $outfile 2>&1
134    echo >> $outfile 
135    echo " New module list after sourcing of ARCH/arch.env file:"    >> $outfile 
136    module list   >> $outfile 2>&1
137fi
138
139#### 2 Do the compilation
140## 2.1 Compile ioipsl
141cd $modipsl/modeles/IOIPSL
142echo; echo "NOW COMPILE IOIPSL"
143echo >> $outfile ; echo " NOW COMPILE IOIPSL"   >> $outfile 
144
145# Check if compilation with fcm is included in IOIPSL
146if [ ! -f makeioipsl_fcm ] ; then
147  echo "The file makeiopsl_fcm do not exist. Probably this is not the right version of IOIPSL."
148  echo "Version of IOIPSL with fcm compilation is needed to compile with this script. Stop now."
149  exit
150fi
151
152echo ./makeioipsl_fcm -$optmode -parallel -arch ${fcm_arch} -arch_path $arch_path -j 8 $full_flag   >> $outfile 
153     ./makeioipsl_fcm -$optmode -parallel -arch ${fcm_arch} -arch_path $arch_path -j 8 $full_flag   >> $outfile 2>&1
154# Test if compiling succeded
155if [[ $? != 0 ]] ; then
156    echo "THERE IS A PROBLEM IN IOIPSL COMPILATION - STOP"
157    exit
158fi
159
160## 2.2 Compile xios
161cd $modipsl/modeles/XIOS
162echo; echo "NOW COMPILE XIOS"
163echo >> $outfile ; echo " NOW COMPILE XIOS"   >> $outfile 
164echo ./make_xios --$optmode --arch $fcm_arch --arch_path $arch_path ${netcdf_lib} --job 4 $full_xios   >> $outfile 
165     ./make_xios --$optmode --arch $fcm_arch --arch_path $arch_path ${netcdf_lib} --job 4 $full_xios   >> $outfile 2>&1
166# Test if compiling succeded
167if [[ $? != 0 ]] ; then
168    echo "THERE IS A PROBLEM IN XIOS COMPILATION - STOP"
169    exit
170fi
171# Move executables to modipsl/bin
172if [ -f $modipsl/modeles/XIOS/bin/xios_server.exe ] ; then
173    mv $modipsl/modeles/XIOS/bin/xios_server.exe $modipsl/bin/xios_server_${optmode}.exe
174else
175    echo "THERE IS A PROBLEM IN XIOS COMPILATION EXECUTABLE MISSING - STOP"
176    exit
177fi
178
179
180## 2.3 Compile orchidee
181cd $modipsl/modeles/ORCHIDEE
182echo; echo "NOW COMPILE ORCHIDEE"
183echo >> $outfile ; echo " NOW COMPILE ORCHIDEE"   >> $outfile 
184
185echo    ./makeorchidee_fcm -j 8 -xios -parallel $parallel -$optmode -arch ${fcm_arch} -arch_path $arch_path $full_orch -driver   >> $outfile 
186        ./makeorchidee_fcm -j 8 -xios -parallel $parallel -$optmode -arch ${fcm_arch} -arch_path $arch_path $full_orch -driver    >> $outfile 2>&1
187# Test if compiling finished
188if [[ $? != 0 ]] ; then
189    echo "THERE IS A PROBLEM IN ORCHIDEE COMPILATION - STOP"
190    exit
191fi
192
193# Rename executables to contain $optmode
194if [ -f $modipsl/bin/orchidee_ol ] ; then mv $modipsl/bin/orchidee_ol  $modipsl/bin/orchidee_ol_${optmode} ; fi
195if [ -f $modipsl/bin/orchideedriver ] ; then mv $modipsl/bin/orchideedriver  $modipsl/bin/orchideedriver_${optmode} ; fi
196
197
198## 2.4 Compile LMDZ for regular latlon configuration
199cd $modipsl/modeles/LMDZ
200# Compile LMDZ regular lat-lon executable
201echo; echo "NOW COMPILE LMDZ REGULAR LAT-LON MODE. Resolution = ${resol_atm}"
202echo >> $outfile ; echo " NOW COMPILE LMDZ REGULAR LAT-LON MODE. Resolution = ${resol_atm}"   >> $outfile 
203
204# Check if the compilation of LMDZ was previsouly interupted prematured.
205# In that case, the files dimension.h and .lock exist. If the files exist, they are here removed to avoid makelmdz_fcm
206# to ask question and wait for interactivly answer from the user.
207if [ -f libf/grid/dimensions.h ] || [ -f .lock ] ; then
208  echo >> $outfile
209  echo " WARNING!! The file LMDZ/libf/grid/dimension.h and/or the LMDZ/.lock exist. "   >> $outfile
210  echo "           This means that the compilation is either currently on going in another terminal was previous interupted before the end."   >> $outfile
211  echo "           The files dimension.h and .lock will now be removed. "   >> $outfile
212  echo >> $outfile
213  rm -f libf/grid/dimensions.h
214  rm -f .lock
215fi
216
217echo ./makelmdz_fcm -d ${resol_atm} -p lmd -rrtm true -$optmode -mem -parallel $parallel -io xios -v orchidee2.1 -arch $fcm_arch -arch_path $arch_path -j 8 $full_lmdz gcm    >> $outfile 
218./makelmdz_fcm -d ${resol_atm} -p lmd -rrtm true -$optmode -mem -parallel $parallel -io xios -v orchidee2.1 -arch $fcm_arch -arch_path $arch_path -j 8 $full_lmdz gcm    >> $outfile 2>&1
219# Test if compiling finished
220if [[ $? != 0 ]] ; then
221    echo "THERE IS A PROBLEM IN LMDZ REGULAR LATLON COMPILATION - STOP"
222    exit
223fi
224
225# Move executables to modipsl/bin folder
226echo >> $outfile
227echo "Move gcm.e executable to modipsl/bin" >> $outfile
228echo ls -lrt $modipsl/modeles/LMDZ/bin   >> $outfile
229ls -lrt $modipsl/modeles/LMDZ/bin  >> $outfile
230echo >> $outfile
231
232# Find executable suffix
233if [ $parallel == seq ] || [ $parallel == none ] ; then
234    suffix=_${resol_atm}_phylmd_seq_orch.e
235else
236    suffix=_${resol_atm}_phylmd_para_mem_orch.e
237fi
238echo gcm suffix = $suffix
239
240if [ -f $modipsl/modeles/LMDZ/bin/gcm${suffix} ] ;  then
241    mv $modipsl/modeles/LMDZ/bin/gcm${suffix} $modipsl/bin/gcm_${resol_atm}_${optmode}.e
242else
243    echo "ERROR gcm${suffix} executable does not exist." 
244    echo "THERE IS A PROBLEM IN LMDZ REGULAR LATLON COMPILATION - STOP"
245    exit
246fi 
247
248
249# Compile ce0l initialization program for LMDZ regular lat-lon exectuable
250if [ $ce0l == y ] ; then
251    echo; echo "NOW COMPILE CE0L OF LMDZ. Resolution = ${resol_atm}"
252    echo >> $outfile ; echo " NOW COMPILE CE0L OF LMDZ. Resolution = ${resol_atm}"   >> $outfile 
253   
254    echo ./makelmdz_fcm -d ${resol_atm} -p lmd -rrtm true -$optmode -mem -parallel $parallel -io xios -v orchidee2.1 -arch $fcm_arch -arch_path $arch_path -j 8 $full_lmdz ce0l    >> $outfile 
255    ./makelmdz_fcm -d ${resol_atm} -p lmd -rrtm true -$optmode -mem -parallel $parallel -io xios -v orchidee2.1 -arch $fcm_arch -arch_path $arch_path -j 8 $full_lmdz ce0l    >> $outfile 2>&1
256    # Test if compiling finished
257    if [[ $? != 0 ]] ; then
258        echo "THERE IS A PROBLEM IN CE0L (LMDZ) REGULAR LATLON COMPILATION - STOP"
259        exit
260    fi
261
262   
263    # Move executables to modipsl/bin folder
264    echo >> $outfile
265    echo "Move ce0l.e executable to modipsl/bin" >> $outfile
266    echo ls -lrt $modipsl/modeles/LMDZ/bin   >> $outfile
267    ls -lrt $modipsl/modeles/LMDZ/bin  >> $outfile
268    echo >> $outfile
269    echo ce0l suffix = $suffix
270
271    if [ -f $modipsl/modeles/LMDZ/bin/ce0l${suffix} ] ;  then
272        mv $modipsl/modeles/LMDZ/bin/ce0l${suffix} $modipsl/bin/ce0l_${resol_atm}_${optmode}.e
273    else
274        echo "ERROR ce0l${suffix} executable does not exist." 
275        echo "THERE IS A PROBLEM IN CE0L (LMDZ) REGULAR LATLON COMPILATION - STOP"
276        exit
277    fi 
278fi
279
280
281echo >>$outfile ; echo "ALL COMPILING FINISHED" >> $outfile
282echo ls -lrt modipsl/bin >> $outfile
283ls -lrt $modipsl/bin >> $outfile
284
285echo; echo "ALL COMPILING FINISHED" ; echo
286echo "Executables are found in modipsl/bin"
287echo "Check that executable names correspond with the name set in config.card before launching the job"
288echo ls -lrt modipsl/bin
289ls -lrt $modipsl/bin
290
291date
292
293exit
Note: See TracBrowser for help on using the repository browser.