Diferencia entre revisiones de «EMU»

De Wikicima
 
(No se muestran 23 ediciones intermedias del mismo usuario)
Línea 1: Línea 1:
Here we describe the installation and use of the [https://github.com/ECCO-GROUP/ECCO-EIS/tree/main/emu ECCO] model in CIMA-IFAECI's hydra HPC
Here we describe the installation and use of the [https://github.com/ECCO-GROUP/ECCO-EIS/tree/main/emu ECCO] model in CIMA-IFAECI's hydra HPC


= Installation =
= Installation pre-compiled Singularity =
We are going to follow the instructions from the [https://ecco-summer-school.github.io/ecco-2025/tutorials/EMU/EMU_Installation.html 2025 ECCO summer school - EMU Installation], specifically to install the tools by our selves following these [https://github.com/ECCO-GROUP/ECCO-EIS/blob/main/emu/README_setup instructions].
 
First we look into the right GIThub repository, being
<PRE style="shell">
https://github.com/ECCO-GROUP/ECCO-EIS/tree/main/emu
</PRE>
 
We are going to install the model for all hydra users. So, our <CODE>$INSTALLDIR</CODE> will be:
<PRE style="shell">
INSTALLDIR=/share/EMU_Singularity
</PRE>
 
Obtaining the code and installing <CODE>$INSTALLDIR</CODE> (we are going to use [NASA https://ecco.jpl.nasa.gov/drive/ Earthdata] user: ''lluisfita'' (using its WebDAV password). '''NOTE:''' MIT certificate is not well set-up, we needed to modify the script to keep going. To get the WebDAV password log into NASA Earthdata.
 
<PRE style="shell">
cd $INSTALLDIR
wget https://raw.githubusercontent.com/ECCO-GROUP/ECCO-EIS/main/emu/emu_setup.sh
chmod +x ./emu_setup.sh
./emu_setup.sh
 
------------------------------------------------------------------------------
This script sets up EMU, a collection of computational tools for analyzing
the ECCO model (flux-forced version of ECCO Version 4 Release 4). The Tools
include the following;
 
  1) Sampling (samp); Evaluates state time-series from model output.
  2) Forward Gradient (fgrd); Computes model's forward gradient.
  3) Adjoint (adj); Computes model's adjoint gradient.
  4) Convolution (conv); Evaluates adjoint gradient decomposition.
  5) Tracer (trc); Computes passive tracer evolution.
  6) Budget (budg); Evaluates budget time-series from model output.
  7) Modified Simulation (msim); Re-runs model with modified input.
  8) Attribution (atrb); Evaluates state time-series by control type.
  9) Auxiliary (aux): Generates user input files for other EMU tools.
 
************************
This script will install EMU's Programs (~1GB), its User Interface (~2MB),
and download its Input Files (~1TB) to user-specified directories.
 
Users should not move or alter these directories or their files unless
noted otherwise (e.g., conforming batch scripts pbs_*.sh for the host
system, installed in the User Interface directory). Once installed,
any user of the host system should be able to utilize the installed files
and programs; Separate installations for different users are not necessary.
 
Installation requires obtaining a NASA Earthdata account for downloading
files from https://ecco.jpl.nasa.gov/drive/. Enter your Earthdata
username and WebDAV password (not your Earthdata password) at the prompts
below. The WebDAV password can be found at this URL after logging in with
your Earthdata username and Earthdata password, or click the 'Back to
WebDAV Credentials' button when browsing files at the URL.
 
See the README file that will be installed in the User Interface directory
for details of EMU, including instructions on how to use it.
************************
 
Press ENTER key to continue ...
 
 
----------------------
Enter your Earthdata username: lluisfita
Enter your WebDAV password (*NOT* Earthdata password): LX7SPsj9N8U8puZA5whS
 
 
----------------------
Enter directory name (emu_dir) to download and set up EMU's Programs (~1 GB)
or press the ENTER key to use EMU's default (emu_dir under the present directory) ... ?
 
 
EMU's Programs will be installed in
/share/EMU/emu_dir
 
----------------------
Enter directory name (emu_userinterface_dir) to install EMU's User Interface
(~2 MB) or press the ENTER key to use EMU's default (emu_userinterface_dir
under the present directory) ... ?
 
 
EMU's User Interface will be installed in
/share/EMU/emu_userinterface_dir
 
----------------------
Enter directory name (emu_input_dir) to download up to 1.1 TB of EMU's Input
Files or press the ENTER key to use EMU's default (emu_input_dir under the
present directory) .... ?
 
 
EMU's Input Files will be downloaded to
/share/EMU/emu_input_dir
 
************************
NOTE: See *.log files in /share/EMU/emu_dir/temp_setup should this script fail.
************************
 
----------------------
EMU's Programs can be installed in two different ways;
  1) Compiling source code on host (native)
  2) Using Singularity image (singularity)
 
Option 1) requires a TAF license to derive the MITgcm adjoint used by EMU's
Adjoint Tool. Option 2) has compiled versions of the code in
containerized form that do not require a separate TAF license to use.
 
Enter choice for type of EMU implementation ... (1 or 2)?
2
 
**********************
Command singularity not found.
Singularity must be available on host system to proceed.
Aborting emu_setup.sh ...
</PRE>
 
= Installation from source code =
We are going to follow the instructions from the [https://ecco-summer-school.github.io/ecco-2025/tutorials/EMU/EMU_Installation.html 2025 ECCO summer school - EMU Installation], specifically to install the tools by our selves following these [https://github.com/ECCO-GROUP/ECCO-EIS/blob/main/emu/README_setup instructions].
We are going to follow the instructions from the [https://ecco-summer-school.github.io/ecco-2025/tutorials/EMU/EMU_Installation.html 2025 ECCO summer school - EMU Installation], specifically to install the tools by our selves following these [https://github.com/ECCO-GROUP/ECCO-EIS/blob/main/emu/README_setup instructions].


Línea 14: Línea 127:
</PRE>
</PRE>


Obtaining the code and installing <CODE>$INSTALLDIR</CODE> (we are going to use [NASA https://ecco.jpl.nasa.gov/drive/ Earthdata] user: ''lluisfita'' (using its WebDAV password). **NOTE:** MIT certificate is not well set-up, we needed to modify the script to keep going
Obtaining the code and installing <CODE>$INSTALLDIR</CODE> (we are going to use [NASA https://ecco.jpl.nasa.gov/drive/ Earthdata] user: ''lluisfita'' (using its WebDAV password). '''NOTE:''' MIT certificate is not well set-up, we needed to modify the script to keep going. To get the WebDAV password log into NASA Earthdata.
 
== MIT certificate issues ==
The MIT certificate set-up to download the emu codes provides the following message
<PRE style="shell">
$ wget --no-check-certificate --spider --user="lluisfita" --password="[pwd]"
https://ecco.jpl.nasa.gov/drive/files/Version4/Release4/other/flux-forced
Spider mode enabled. Check if remote file exists.
--2025-06-23 12:34:57--
https://ecco.jpl.nasa.gov/drive/files/Version4/Release4/other/flux-forced
Resolving ecco.jpl.nasa.gov (ecco.jpl.nasa.gov)... 128.149.52.112
Connecting to ecco.jpl.nasa.gov
(ecco.jpl.nasa.gov)|128.149.52.112|:443... connected.
WARNING: The certificate of 'ecco.jpl.nasa.gov' is not trusted.
WARNING: The certificate of 'ecco.jpl.nasa.gov' doesn't have a known issuer.
HTTP request sent, awaiting response... 401 Unauthorized
Authentication selected: Basic realm="ECCO_Drive"
Connecting to ecco.jpl.nasa.gov
(ecco.jpl.nasa.gov)|128.149.52.112|:443... connected.
WARNING: The certificate of 'ecco.jpl.nasa.gov' is not trusted.
WARNING: The certificate of 'ecco.jpl.nasa.gov' doesn't have a known issuer.
HTTP request sent, awaiting response... 200 OK
Length: 13420 (13K) [text/html]
Remote file exists and could contain further links,
but recursion is disabled -- not retrieving.
</PRE>
Including <CODE>--no-check-certificate</CODE> into the wget inside <CODE>emu_setup.sh</CODE> allows to download the data
 
<PRE style="shell">
<PRE style="shell">
cd $INSTALLDIR
cd $INSTALLDIR
Línea 214: Línea 354:
< #source /usr/local/lib/global.profile
< #source /usr/local/lib/global.profile
< #source ${nativedir}/set_modules.sh
< #source ${nativedir}/set_modules.sh
< source /opt/load-libs.sh 1
< #source /opt/load-libs.sh 1
---
---
> source /usr/local/lib/global.profile
> source /usr/local/lib/global.profile
Línea 220: Línea 360:
</PRE>
</PRE>


These modifications are not working, because the code is being downloaded at each time. Therefore, we modify <CODE>emu_setup.sh</CODE> in order to avoid re-downloading the code, if it is already there. (see next point)
These modifications are not working, because the code is being downloaded at each time. Therefore, we modify <CODE>emu_setup.sh</CODE> in order to avoid re-downloading the code, if it is already there. (see next point).
 
This is not working, since <CODE>/opt/load-libs.sh</CODE> has a misconfiguration, which provokes to upload emu's script into the source, instead of the right configuration. Therefor, we must pre-upload configuration environment before compiling/downloading EMU. In hydra to upload :
<PRE style="shell">
$ source /opt/load-libs.sh 1
The following libraries, compiled with Intel 2021.4.0 compilers, were loaded:
* MPICH 3.4.2
* NetCDF 4
* HDF5 1.10.5
* JASPER 2.0.33
</PRE>
We need to define system variables in order to be able to compile the code
<PRE style="shell">
$ nc-config --all
(...)
  --has-nczarr    -> yes
 
  --prefix        -> /opt/netcdf/netcdf-4/intel/2021.4.0
  --includedir    -> /opt/netcdf/netcdf-4/intel/2021.4.0/include
  --libdir        -> /opt/netcdf/netcdf-4/intel/2021.4.0/lib
  --version      -> netCDF 4.8.1
$ export NETCDF=/opt/netcdf/netcdf-4/intel/2021.4.0
$ which mpif90
/opt/mpich/mpich-3.4.2/intel/2021.4.0/bin/mpif90
$ export MPI_ROOT=/opt/mpich/mpich-3.4.2/intel/2021.4.0
$ export MPI=true
</PRE>


== /share/EMU/emu_dir/temp_setup/download_emu_source.log ==
== /share/EMU/emu_dir/temp_setup/download_emu_source.log ==
Línea 240: Línea 406:
<      echo "  Code has already previously been cloned... removing the pre-existing one" > "$log_file"  
<      echo "  Code has already previously been cloned... removing the pre-existing one" > "$log_file"  
   2>> "$log_file"
   2>> "$log_file"
<      rm -rf emu_dir/WORKDIR
<      rm -rf ${emu_dir}/WORKDIR
<    else
<    else
548d544
548d544
<    fi
<    fi
</PRE>
Compilation failed. Looking to the <CODE>emu_dir/temp_setup/emu_compile_mdl.log </CODE>
== Failed compilation: Compilation's environment ==
Compilation error says:
<PRE style="shell">
$ cat emu_dir/temp_setup/emu_compile_mdl.log
(...)
profiles_init_ncfile.f(406): remark #15009: profiles_init_ncfile_ has been
  targeted for automatic cpu dispatch
tracers_correction_step.f(385): remark #15009: tracers_correction_step_ has
  been targeted for automatic cpu dispatch
ptracers_reset.f(483): remark #15009: ptracers_reset_ has been targeted for
  automatic cpu dispatch
ld: /tmp/ipo_ifortCaY5f31.o: in function `diagnostics_calc_phivel_.V':
ipo_out1.f:(.text+0x3011c): undefined reference to `mpi_allreduce_'
ld: ipo_out1.f:(.text+0x30336): undefined reference to `mpi_allreduce_'
ld: /tmp/ipo_ifortJ3swBq1.o: in function `diagnostics_calc_phivel_.A':
(...)
ipo_out2.f:(.text.hot000a3+0xc30): undefined reference to `mpi_allreduce_'
ld: ipo_out2.f:(.text.hot000a3+0xdd5): undefined reference to `mpi_allreduce_'
ld: ipo_out2.f:(.text.hot000a3+0xecf): undefined reference to `mpi_allreduce_'
ld: /tmp/ipo_ifortmsrIiB2.o: in function `all_proc_die_':
ipo_out2.f:(.text.hot000af+0x266): undefined reference to `mpi_finalize_'
ld: /tmp/ipo_ifortmsrIiB2.o: in function `stop_if_error_':
ipo_out2.f:(.text.hot000b1+0x129b): undefined reference to `mpi_allreduce_'
make[1]: *** [Makefile:2183: mitgcmuv] Error 1
make[1]: Leaving directory '/share/EMU/emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/build_trc'
make: *** [Makefile:2179: fwd_exe_target] Error 2
</PRE>
Compilation is performed via the <CODE>emu_dir/emu/native/emu_compile_mdl.sh</CODE> script, which includes the following compilation
<PRE>
(...)
echo " "
echo "COMPILING offline tracer model ADJOINT -----------------------------------"
echo " "
if [ $new_compilation -eq 0 ]; then
    mkdir build_trc_ad
    cd build_trc_ad
#    ../../../tools/genmake2 -mods=../code_offline_ptracer
  -optfile=../../../tools/build_options/linux_amd64_ifort+mpi_ice_nas -mpi
    ../../../tools/genmake2 -mods=../code_offline_ptracer
  -optfile=../code/linux_amd64_ifort+mpi_ice_nas -mpi
    make depend
</PRE>
Looking for the environment file
<PRE style="shell">
$ find ./ -name linux_amd64_ifort+mpi_ice_nas
./emu_dir/WORKDIR/MITgcm/tools/build_options/linux_amd64_ifort+mpi_ice_nas
./emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/code/linux_amd64_ifort+mpi_ice_nas
./emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/code_offline_ptracer/
  linux_amd64_ifort+mpi_ice_nas
</PRE>
=== linux_amd64_ifort+mpi_ice_nas ===
We found multiple pre-defined files, we will need to adapt them to CIMA's hydra and try to keep them even after downloading from GIT repository
<PRE style="shell">
$ cat ./emu_dir/WORKDIR/MITgcm/tools/build_options/linux_amd64_ifort+mpi_ice_nas
(...)
LIBS='-L/nasa/sgi/mpt/2.14r19/lib -lmpi -L/nasa/netcdf/4.0/lib -lnetcdf'
INCLUDES='-I/nasa/sgi/mpt/2.14r19/include -I/nasa/netcdf/4.0/include'
</PRE>
<PRE style="shell">
$ cat ./emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/code/linux_amd64_ifort+mpi_ice_nas
(...)
LIBS=''
if [ -n "$MPI_ROOT" -a "x$MPI" = xtrue ] ; then
    if [ -z "$MPI_INC_DIR" ]; then
      MPI_INC_DIR="${MPI_ROOT}/include"
    fi
    LIBS="$LIBS -L${MPI_ROOT}/lib -lmpi"
fi
if [ -n "$MPI_INC_DIR" -a "x$MPI" = xtrue ] ; then
    INCLUDES="$INCLUDES -I${MPI_INC_DIR}"
    #INCLUDEDIRS="$INCLUDEDIRS $MPI_INC_DIR"
    #- used for parallel (MPI) DIVA
</PRE>
<PRE style="shell">
cat ./emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/code_offline_ptracer/
  linux_amd64_ifort+mpi_ice_nas
(...)
INCLUDES=''
LIBS=''
if [ -n "$MPI_ROOT" -a "x$MPI" = xtrue ] ; then
    if [ -z "$MPI_INC_DIR" ]; then
      MPI_INC_DIR="${MPI_ROOT}/include"
    fi
    LIBS="$LIBS -L${MPI_ROOT}/lib -lmpi"
fi
if [ -n "$MPI_INC_DIR" -a "x$MPI" = xtrue ] ; then
    INCLUDES="$INCLUDES -I${MPI_INC_DIR}"
    #INCLUDEDIRS="$INCLUDEDIRS $MPI_INC_DIR"
</PRE>
File <CODE>code/linux_amd64_ifort+mpi_ice_nas</CODE> contains the compilation environment with the definition of multiple environment variables:
<PRE>
#! /usr/bin/env bash
(...)
FC=ifort
CC=icc
CPP='/lib/cpp -traditional -P'
DEFINES='-DWORDLENGTH=4 -DINTEL_COMMITQQ'
F90FIXEDFORMAT='-fixed -Tf'
EXTENDED_SRC_FLAG='-132'
(...)
F90FLAGS=$FFLAGS
F90OPTIM=$FOPTIM
INCLUDEDIRS=''
INCLUDES=''
LIBS=''
if [ -n "$MPI_ROOT" -a "x$MPI" = xtrue ] ; then
    if [ -z "$MPI_INC_DIR" ]; then
                          MPI_INC_DIR="${MPI_ROOT}/include"
    fi
    LIBS="$LIBS -L${MPI_ROOT}/lib -lmpi"
fi
if [ -n "$MPI_INC_DIR" -a "x$MPI" = xtrue ] ; then
    INCLUDES="$INCLUDES -I${MPI_INC_DIR}"
    #INCLUDEDIRS="$INCLUDEDIRS $MPI_INC_DIR"
    #- used for parallel (MPI) DIVA
    MPIINCLUDEDIR="$MPI_INC_DIR"
    #MPI_HEADER_FILES='mpif.h mpiof.h'
fi
if [ "x$NETCDF" != x ] ; then
    INCLUDES="$INCLUDES -I${NETCDF}/include"
    #INCLUDEDIRS="$INCLUDEDIRS ${NETCDF}/include"
    LIBS="$LIBS -L${NETCDF}/lib"
fi
</PRE>
CIMA's hydra does not have defined environment variables like <CODE>$MPI_ROOT, $MPI, ...</CODE> will be necessarily be defined on purpose after uploading the compilation environment.
Only the file in <CODE>linux_amd64_ifort+mpi_ice_nas</CODE> in <CODE>emu_dir/WORKDIR/MITgcm/tools/build_options/</CODE>, has library paths from NASA HPCs, we need to create a generalized one to make it work.
<PRE STYLE="shell">
$ cp ./emu_dir/WORKDIR/MITgcm/tools/build_options/linux_amd64_ifort+mpi_ice_nas linux_amd64_ifort+mpi_ice_nas_generic
$ diff linux_amd64_ifort+mpi_ice_nas_generic ./emu_dir/WORKDIR/MITgcm/tools/build_options/linux_amd64_ifort+mpi_ice_nas
20,21c20,21
< LIBS='-L${MPI_ROOT}/lib -lmpi -L${NETCDF}/lib -lnetcdf'
< INCLUDES='-I${MPI_ROOT}/include -I${NETCDF}/include'
---
> LIBS='-L/nasa/sgi/mpt/2.14r19/lib -lmpi -L/nasa/netcdf/4.0/lib -lnetcdf'
> INCLUDES='-I/nasa/sgi/mpt/2.14r19/include -I/nasa/netcdf/4.0/include'
33c33
<    FOPTIM='-O2 -fp-model precise -axCORE-AVX2 -xSSE4.2 -traceback -ftz'
---
>    FOPTIM='-O2 -ipo -fp-model precise -axCORE-AVX2 -xSSE4.2 -traceback -ftz'
$ cp emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/code/linux_amd64_ifort+mpi_ice_nas ./linux_amd64_ifort+mpi_ice_nas_generic_V4r4
$ diff linux_amd64_ifort+mpi_ice_nas_generic_V4r4 emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/code/linux_amd64_ifort+mpi_ice_nas
46c46
<    FOPTIM='-O2 -fp-model precise -align -axCORE-AVX2 -xSSE4.2 -traceback -ftz'
---
>    FOPTIM='-O2 -ipo -fp-model precise -align -axCORE-AVX2 -xSSE4.2 -traceback -ftz'
$ cp emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/code_offline_ptracer/linux_amd64_ifort+mpi_ice_nas ./linux_amd64_ifort+mpi_ice_nas_generic_V4r4_offline
$ diff linux_amd64_ifort+mpi_ice_nas_generic_V4r4_offline emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/code_offline_ptracer/linux_amd64_ifort+mpi_ice_nas
46c46
<    FOPTIM='-O2 -fp-model precise -align -axCORE-AVX2 -xSSE4.2 -traceback -ftz'
---
>    FOPTIM='-O2 -ipo -fp-model precise -align -axCORE-AVX2 -xSSE4.2 -traceback -ftz'
</PRE>
Inside <CODE>emu_dir/emu/native/emu_compile_mdl.sh</CODE> we modify it to use the generic version of the environment file
<PRE style="shell">
$ diff emu_dir/emu/native/emu_compile_mdl_orig.sh emu_dir/emu/native/emu_compile_mdl.sh
(...)
104a105,112
> # Generalizing compilation....
> cp ${emu_dir}/WORKDIR/MITgcm/tools/build_options/linux_amd64_ifort+mpi_ice_nas ${emu_dir}/WORKDIR/MITgcm/tools/build_options/linux_amd64_ifort+mpi_ice_nas_orig
> cp ${emu_dir}/../linux_amd64_ifort+mpi_ice_nas_generic ${emu_dir}/WORKDIR/MITgcm/tools/build_options/linux_amd64_ifort+mpi_ice_nas
> cp ${emu_dir}/WORKDIR/MITgcm/V4r4/flux-forced/code/linux_amd64_ifort+mpi_ice_nas ${emu_dir}/WORKDIR/MITgcm/V4r4/flux-forced/code/linux_amd64_ifort+mpi_ice_nas_orig
> cp ${emu_dir}/../linux_amd64_ifort+mpi_ice_nas_generic_V4r4 ${emu_dir}/WORKDIR/MITgcm/V4r4/flux-forced/code/linux_amd64_ifort+mpi_ice_nas
> cp ${emu_dir}/WORKDIR/MITgcm/V4r4/flux-forced/code_offline_ptracer/linux_amd64_ifort+mpi_ice_nas ${emu_dir}/WORKDIR/MITgcm/V4r4/flux-forced/code_offline_ptracer/linux_amd64_ifort+mpi_ice_nas_orig
> cp ${emu_dir}/../linux_amd64_ifort+mpi_ice_nas_generic_V4r4_offline ${emu_dir}/WORKDIR/MITgcm/V4r4/flux-forced/code_offline_ptracer/linux_amd64_ifort+mpi_ice_nas
>
(...)
</PRE>
Still after all these modifications, Makefile still uses -ipo compilation flag. Removing it directly from the Makefiles
<PRE style="shell">
$ cp /share/EMU/emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/build_trc/Makefile ./Makefile_V4r4_NOipo
$ diff Makefile_V4r4_NOipo /share/EMU/emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/build_trc/Makefile
75c75
< FOPTIM = -O2 -fp-model precise -align -axCORE-AVX2 -xSSE4.2 -traceback -ftz
---
> FOPTIM = -O2 -ipo -fp-model precise -align -axCORE-AVX2 -xSSE4.2 -traceback -ftz
78c78
< F90OPTIM = -O2 -fp-model precise -align -axCORE-AVX2 -xSSE4.2 -traceback -ftz
---
> F90OPTIM = -O2 -ipo -fp-model precise -align -axCORE-AVX2 -xSSE4.2 -traceback -ftz
</PRE>
Adding it into the compiling script to be used
<PRE style="shell">
$ diff emu_dir/emu/native/emu_compile_mdl_orig.sh emu_dir/emu/native/emu_compile_mdl.sh
(...)
126a136,138
> cp /share/EMU/emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/build_trc/Makefile /share/EMU/emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/build_trc/Makefile_orig
> cp ${emu_dir}/../Makefile_V4r4_NOipo /share/EMU/emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/build_trc/Makefile
126a138
>
</PRE>
</PRE>


= Use =
= Use =

Revisión actual - 18:00 10 jul 2025

Here we describe the installation and use of the ECCO model in CIMA-IFAECI's hydra HPC

Installation pre-compiled Singularity

We are going to follow the instructions from the 2025 ECCO summer school - EMU Installation, specifically to install the tools by our selves following these instructions.

First we look into the right GIThub repository, being

https://github.com/ECCO-GROUP/ECCO-EIS/tree/main/emu

We are going to install the model for all hydra users. So, our $INSTALLDIR will be:

INSTALLDIR=/share/EMU_Singularity

Obtaining the code and installing $INSTALLDIR (we are going to use [NASA https://ecco.jpl.nasa.gov/drive/ Earthdata] user: lluisfita (using its WebDAV password). NOTE: MIT certificate is not well set-up, we needed to modify the script to keep going. To get the WebDAV password log into NASA Earthdata.

cd $INSTALLDIR
wget https://raw.githubusercontent.com/ECCO-GROUP/ECCO-EIS/main/emu/emu_setup.sh
chmod +x ./emu_setup.sh
./emu_setup.sh

------------------------------------------------------------------------------
 This script sets up EMU, a collection of computational tools for analyzing
 the ECCO model (flux-forced version of ECCO Version 4 Release 4). The Tools 
 include the following;

   1) Sampling (samp); Evaluates state time-series from model output.
   2) Forward Gradient (fgrd); Computes model's forward gradient.
   3) Adjoint (adj); Computes model's adjoint gradient.
   4) Convolution (conv); Evaluates adjoint gradient decomposition.
   5) Tracer (trc); Computes passive tracer evolution.
   6) Budget (budg); Evaluates budget time-series from model output.
   7) Modified Simulation (msim); Re-runs model with modified input.
   8) Attribution (atrb); Evaluates state time-series by control type.
   9) Auxiliary (aux): Generates user input files for other EMU tools.

************************
 This script will install EMU's Programs (~1GB), its User Interface (~2MB), 
 and download its Input Files (~1TB) to user-specified directories. 

 Users should not move or alter these directories or their files unless 
 noted otherwise (e.g., conforming batch scripts pbs_*.sh for the host 
 system, installed in the User Interface directory). Once installed, 
 any user of the host system should be able to utilize the installed files 
 and programs; Separate installations for different users are not necessary. 

 Installation requires obtaining a NASA Earthdata account for downloading 
 files from https://ecco.jpl.nasa.gov/drive/. Enter your Earthdata 
 username and WebDAV password (not your Earthdata password) at the prompts 
 below. The WebDAV password can be found at this URL after logging in with 
 your Earthdata username and Earthdata password, or click the 'Back to 
 WebDAV Credentials' button when browsing files at the URL.

 See the README file that will be installed in the User Interface directory 
 for details of EMU, including instructions on how to use it.
************************

Press ENTER key to continue ... 


----------------------
Enter your Earthdata username: lluisfita
Enter your WebDAV password (*NOT* Earthdata password): LX7SPsj9N8U8puZA5whS


----------------------
Enter directory name (emu_dir) to download and set up EMU's Programs (~1 GB) 
or press the ENTER key to use EMU's default (emu_dir under the present directory) ... ?


EMU's Programs will be installed in 
/share/EMU/emu_dir

----------------------
Enter directory name (emu_userinterface_dir) to install EMU's User Interface
(~2 MB) or press the ENTER key to use EMU's default (emu_userinterface_dir 
under the present directory) ... ?


EMU's User Interface will be installed in 
/share/EMU/emu_userinterface_dir

----------------------
Enter directory name (emu_input_dir) to download up to 1.1 TB of EMU's Input 
Files or press the ENTER key to use EMU's default (emu_input_dir under the 
present directory) .... ? 


EMU's Input Files will be downloaded to 
/share/EMU/emu_input_dir

************************
NOTE: See *.log files in /share/EMU/emu_dir/temp_setup should this script fail.
************************

----------------------
EMU's Programs can be installed in two different ways;
   1) Compiling source code on host (native) 
   2) Using Singularity image (singularity)

Option 1) requires a TAF license to derive the MITgcm adjoint used by EMU's 
Adjoint Tool. Option 2) has compiled versions of the code in 
containerized form that do not require a separate TAF license to use.

Enter choice for type of EMU implementation ... (1 or 2)?
2

**********************
Command singularity not found.
Singularity must be available on host system to proceed.
Aborting emu_setup.sh ... 

Installation from source code

We are going to follow the instructions from the 2025 ECCO summer school - EMU Installation, specifically to install the tools by our selves following these instructions.

First we look into the right GIThub repository, being

https://github.com/ECCO-GROUP/ECCO-EIS/tree/main/emu

We are going to install the model for all hydra users. So, our $INSTALLDIR will be:

INSTALLDIR=/share/EMU

Obtaining the code and installing $INSTALLDIR (we are going to use [NASA https://ecco.jpl.nasa.gov/drive/ Earthdata] user: lluisfita (using its WebDAV password). NOTE: MIT certificate is not well set-up, we needed to modify the script to keep going. To get the WebDAV password log into NASA Earthdata.

MIT certificate issues

The MIT certificate set-up to download the emu codes provides the following message

$ wget --no-check-certificate --spider --user="lluisfita" --password="[pwd]"
https://ecco.jpl.nasa.gov/drive/files/Version4/Release4/other/flux-forced
Spider mode enabled. Check if remote file exists.
--2025-06-23 12:34:57--
https://ecco.jpl.nasa.gov/drive/files/Version4/Release4/other/flux-forced
Resolving ecco.jpl.nasa.gov (ecco.jpl.nasa.gov)... 128.149.52.112
Connecting to ecco.jpl.nasa.gov
(ecco.jpl.nasa.gov)|128.149.52.112|:443... connected.
WARNING: The certificate of 'ecco.jpl.nasa.gov' is not trusted.
WARNING: The certificate of 'ecco.jpl.nasa.gov' doesn't have a known issuer.
HTTP request sent, awaiting response... 401 Unauthorized
Authentication selected: Basic realm="ECCO_Drive"
Connecting to ecco.jpl.nasa.gov
(ecco.jpl.nasa.gov)|128.149.52.112|:443... connected.
WARNING: The certificate of 'ecco.jpl.nasa.gov' is not trusted.
WARNING: The certificate of 'ecco.jpl.nasa.gov' doesn't have a known issuer.
HTTP request sent, awaiting response... 200 OK
Length: 13420 (13K) [text/html]
Remote file exists and could contain further links,
but recursion is disabled -- not retrieving.

Including --no-check-certificate into the wget inside emu_setup.sh allows to download the data

cd $INSTALLDIR
wget https://raw.githubusercontent.com/ECCO-GROUP/ECCO-EIS/main/emu/emu_setup.sh
chmod +x ./emu_setup.sh
./emu_setup.sh

------------------------------------------------------------------------------
 This script sets up EMU, a collection of computational tools for analyzing
 the ECCO model (flux-forced version of ECCO Version 4 Release 4). The Tools 
 include the following;

   1) Sampling (samp); Evaluates state time-series from model output.
   2) Forward Gradient (fgrd); Computes model's forward gradient.
   3) Adjoint (adj); Computes model's adjoint gradient.
   4) Convolution (conv); Evaluates adjoint gradient decomposition.
   5) Tracer (trc); Computes passive tracer evolution.
   6) Budget (budg); Evaluates budget time-series from model output.
   7) Modified Simulation (msim); Re-runs model with modified input.
   8) Attribution (atrb); Evaluates state time-series by control type.
   9) Auxiliary (aux): Generates user input files for other EMU tools.

************************
 This script will install EMU's Programs (~1GB), its User Interface (~2MB), 
 and download its Input Files (~1TB) to user-specified directories. 

 Users should not move or alter these directories or their files unless 
 noted otherwise (e.g., conforming batch scripts pbs_*.sh for the host 
 system, installed in the User Interface directory). Once installed, 
 any user of the host system should be able to utilize the installed files 
 and programs; Separate installations for different users are not necessary. 

 Installation requires obtaining a NASA Earthdata account for downloading 
 files from https://ecco.jpl.nasa.gov/drive/. Enter your Earthdata 
 username and WebDAV password (not your Earthdata password) at the prompts 
 below. The WebDAV password can be found at this URL after logging in with 
 your Earthdata username and Earthdata password, or click the 'Back to 
 WebDAV Credentials' button when browsing files at the URL.

 See the README file that will be installed in the User Interface directory 
 for details of EMU, including instructions on how to use it.
************************

Press ENTER key to continue ... 


----------------------
Enter your Earthdata username: lluisfita
Enter your WebDAV password (*NOT* Earthdata password): LX7SPsj9N8U8puZA5whS


----------------------
Enter directory name (emu_dir) to download and set up EMU's Programs (~1 GB) 
or press the ENTER key to use EMU's default (emu_dir under the present directory) ... ?


EMU's Programs will be installed in 
/share/EMU/emu_dir

----------------------
Enter directory name (emu_userinterface_dir) to install EMU's User Interface
(~2 MB) or press the ENTER key to use EMU's default (emu_userinterface_dir 
under the present directory) ... ?


EMU's User Interface will be installed in 
/share/EMU/emu_userinterface_dir

----------------------
Enter directory name (emu_input_dir) to download up to 1.1 TB of EMU's Input 
Files or press the ENTER key to use EMU's default (emu_input_dir under the 
present directory) .... ? 


EMU's Input Files will be downloaded to 
/share/EMU/emu_input_dir

************************
NOTE: See *.log files in /share/EMU/emu_dir/temp_setup should this script fail.
************************

----------------------
EMU's Programs can be installed in two different ways;
   1) Compiling source code on host (native) 
   2) Using Singularity image (singularity)

Option 1) requires a TAF license to derive the MITgcm adjoint used by EMU's 
Adjoint Tool. Option 2) has compiled versions of the code in 
containerized form that do not require a separate TAF license to use.

Enter choice for type of EMU implementation ... (1 or 2)?
1

Implementation type choice is 1

----------------------
EMU uses batch scripts to run some of its tools in PBS (Portable 
Batch System). The PBS commands in these shell scripts (pbs_*.sh),
installed in EMU's User Interface directory (emu_userinterface_dir)
/share/EMU/emu_userinterface_dir
may need to be revised for different batch systems and/or different hosts. 
Alternatively, these shell scripts can be run interactively if sufficient 
resources are available.

Enter the command for submitting batch jobs (e.g., qsub, sbatch, 
bsub <, condor_submit, msub) or press the ENTER key to have EMU 
run its batch scripts interactively ... ?
qsub

Command to submit EMU's batch job scripts will be: qsub

----------------------
EMU's Input Files total 1.1 TB, of which (directory)
   175 GB (emu_ref) is needed by Sampling, Forward Gradient, Adjoint, Tracer, Budget, and Attribution
   195 GB (forcing) is needed by Forward Gradient, Adjoint, Modified Simultion
   380 GB (state_weekly) is needed by Tracer
   290 GB (emu_msim) is needed by Attribution
   (Convolution Tool uses results of the Adjoint Tool and files downloaded by default.)

Choose among the following to download ... 
   0) All Input Files (1.1 TB) 
   1) Files (~175 GB) needed for Sampling and Budget Tools
   2) Files (~195 GB) needed for Modified Simultion Tools
   3) Files (~370 GB) needed for Adjoint and Forward Gradient Tool
   4) Files (~465 GB) needed for Attribution Tool
   5) Files (~555 GB) needed for Tracer Tool
or press the ENTER key to skip this step, which can take a while
(~13 hours if downloading all input files.) 

EMU's Input Files can be downloaded later with shell script
   /share/EMU/emu_userinterface_dir/emu_input_setup.sh 
See 
   /share/EMU/emu_userinterface_dir/README_input_setup 
for additional detail, including options to download the input
in batch mode.

Enter Input Files download choice ... ?
0


----------------------
Choose number of CPU cores (nproc) for running MITgcm.
Choose among the following nproc ... 

13
36
48
68
72
96
192
360

Enter choice for nproc ... ?
48


Number of CPU cores to be used for MITgcm: 48

**********************
 End of user input for EMU setup 
 Rest of this script is conducted without user input.

----------------------
Download and compiling EMU on host system in directory 
/share/EMU/emu_dir


----------------------
Download and compiling MITgcm and its adjoint in 
/share/EMU/emu_dir/emu/exe/nproc
This can take a while (~30 minutes). 
Progress can be monitored in file  /share/EMU/emu_dir/temp_setup/emu_compile_mdl.log
  tail /share/EMU/emu_dir/temp_setup/emu_compile_mdl.log 

Now we will work in solving the problems found in the log files, always looking into the newest file in emu_dir/temp_setup

/share/EMU/emu_dir/temp_setup/emu_compile_mdl.log

emu_dir/emu/native/emu_compile_mdl.sh: line 106: /usr/local/lib/global.profile: No such file or directory

Inside emu_dir/emu/native/emu_compile_mdl.sh we found the following lines, where the compilation environment is set-up


# Get the directory containing the script (full path to emu/native)
nativedir=$(dirname "$script_path")
(...)
# 7) Load module for compilation. 
source /usr/local/lib/global.profile
source ${nativedir}/set_modules.sh

In CIMA's hydra there is not /usr/local/lib/global.profile. File ${nativedir}/set_modules.sh assumes the existence of modules. hydra does not have modules, it uses on-purpose scripts to set-up compilation environment... Wea are going to adapt emu_compile_mdl.sh to hydra characteristics

$ cp emu_dir/emu/native/emu_compile_mdl.sh emu_dir/emu/native/emu_compile_mdl_orig.sh
$ vim emu_dir/emu/native/emu_compile_mdl.sh
$ diff emu_dir/emu/native/emu_compile_mdl.sh emu_dir/emu/native/emu_compile_mdl_orig.sh
106,108c106,107
< #source /usr/local/lib/global.profile
< #source ${nativedir}/set_modules.sh
< #source /opt/load-libs.sh 1
---
> source /usr/local/lib/global.profile
> source ${nativedir}/set_modules.sh

These modifications are not working, because the code is being downloaded at each time. Therefore, we modify emu_setup.sh in order to avoid re-downloading the code, if it is already there. (see next point).

This is not working, since /opt/load-libs.sh has a misconfiguration, which provokes to upload emu's script into the source, instead of the right configuration. Therefor, we must pre-upload configuration environment before compiling/downloading EMU. In hydra to upload :

$ source /opt/load-libs.sh 1
The following libraries, compiled with Intel 2021.4.0 compilers, were loaded:
* MPICH 3.4.2
* NetCDF 4
* HDF5 1.10.5
* JASPER 2.0.33

We need to define system variables in order to be able to compile the code

$ nc-config --all
(...)
  --has-nczarr    -> yes

  --prefix        -> /opt/netcdf/netcdf-4/intel/2021.4.0
  --includedir    -> /opt/netcdf/netcdf-4/intel/2021.4.0/include
  --libdir        -> /opt/netcdf/netcdf-4/intel/2021.4.0/lib
  --version       -> netCDF 4.8.1
$ export NETCDF=/opt/netcdf/netcdf-4/intel/2021.4.0
$ which mpif90
/opt/mpich/mpich-3.4.2/intel/2021.4.0/bin/mpif90
$ export MPI_ROOT=/opt/mpich/mpich-3.4.2/intel/2021.4.0
$ export MPI=true

/share/EMU/emu_dir/temp_setup/download_emu_source.log

After solving this problem, setup shell abruptly stops without any message. However we found in emu_dir/temp_setup/download_emu_source.log

$ cat ./emu_dir/temp_setup/download_emu_source.log
Cloning into 'ECCO-EIS'...
mv: cannot move 'ECCO-EIS/emu' to './emu': Directory not empty

In the previous attempt we already cloned the code, therefore we are going to make sure, that we remove the folder before the clone is made, again modifying scripts, this time emu_setup.sh:

$ cp emu_setup.sh emu_setup_orig.sh
$ vim emu_setup.sh 
$ diff emu_setup.sh emu_setup_orig.sh
539,541d538
<     if test -d emu; then
<       echo "  Code has already previously been cloned... removing the pre-existing one" > "$log_file" 
  2>> "$log_file"
<       rm -rf ${emu_dir}/WORKDIR
<     else
548d544
<     fi

Compilation failed. Looking to the emu_dir/temp_setup/emu_compile_mdl.log

Failed compilation: Compilation's environment

Compilation error says:

$ cat emu_dir/temp_setup/emu_compile_mdl.log 
(...)
profiles_init_ncfile.f(406): remark #15009: profiles_init_ncfile_ has been 
  targeted for automatic cpu dispatch
tracers_correction_step.f(385): remark #15009: tracers_correction_step_ has 
  been targeted for automatic cpu dispatch
ptracers_reset.f(483): remark #15009: ptracers_reset_ has been targeted for 
  automatic cpu dispatch
ld: /tmp/ipo_ifortCaY5f31.o: in function `diagnostics_calc_phivel_.V':
ipo_out1.f:(.text+0x3011c): undefined reference to `mpi_allreduce_'
ld: ipo_out1.f:(.text+0x30336): undefined reference to `mpi_allreduce_'
ld: /tmp/ipo_ifortJ3swBq1.o: in function `diagnostics_calc_phivel_.A':

(...)
ipo_out2.f:(.text.hot000a3+0xc30): undefined reference to `mpi_allreduce_'
ld: ipo_out2.f:(.text.hot000a3+0xdd5): undefined reference to `mpi_allreduce_'
ld: ipo_out2.f:(.text.hot000a3+0xecf): undefined reference to `mpi_allreduce_'
ld: /tmp/ipo_ifortmsrIiB2.o: in function `all_proc_die_':
ipo_out2.f:(.text.hot000af+0x266): undefined reference to `mpi_finalize_'
ld: /tmp/ipo_ifortmsrIiB2.o: in function `stop_if_error_':
ipo_out2.f:(.text.hot000b1+0x129b): undefined reference to `mpi_allreduce_'
make[1]: *** [Makefile:2183: mitgcmuv] Error 1
make[1]: Leaving directory '/share/EMU/emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/build_trc'
make: *** [Makefile:2179: fwd_exe_target] Error 2

Compilation is performed via the emu_dir/emu/native/emu_compile_mdl.sh script, which includes the following compilation

(...)
echo " " 
echo "COMPILING offline tracer model ADJOINT -----------------------------------"
echo " "
if [ $new_compilation -eq 0 ]; then
    mkdir build_trc_ad
    cd build_trc_ad
#    ../../../tools/genmake2 -mods=../code_offline_ptracer 
  -optfile=../../../tools/build_options/linux_amd64_ifort+mpi_ice_nas -mpi
    ../../../tools/genmake2 -mods=../code_offline_ptracer 
  -optfile=../code/linux_amd64_ifort+mpi_ice_nas -mpi
    make depend

Looking for the environment file

$ find ./ -name linux_amd64_ifort+mpi_ice_nas
./emu_dir/WORKDIR/MITgcm/tools/build_options/linux_amd64_ifort+mpi_ice_nas
./emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/code/linux_amd64_ifort+mpi_ice_nas
./emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/code_offline_ptracer/
  linux_amd64_ifort+mpi_ice_nas

linux_amd64_ifort+mpi_ice_nas

We found multiple pre-defined files, we will need to adapt them to CIMA's hydra and try to keep them even after downloading from GIT repository

$ cat ./emu_dir/WORKDIR/MITgcm/tools/build_options/linux_amd64_ifort+mpi_ice_nas 
(...)
LIBS='-L/nasa/sgi/mpt/2.14r19/lib -lmpi -L/nasa/netcdf/4.0/lib -lnetcdf'
INCLUDES='-I/nasa/sgi/mpt/2.14r19/include -I/nasa/netcdf/4.0/include'
$ cat ./emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/code/linux_amd64_ifort+mpi_ice_nas
(...)
LIBS=''

if [ -n "$MPI_ROOT" -a "x$MPI" = xtrue ] ; then
    if [ -z "$MPI_INC_DIR" ]; then
      MPI_INC_DIR="${MPI_ROOT}/include"
    fi
    LIBS="$LIBS -L${MPI_ROOT}/lib -lmpi"
fi

if [ -n "$MPI_INC_DIR" -a "x$MPI" = xtrue ] ; then
    INCLUDES="$INCLUDES -I${MPI_INC_DIR}"
    #INCLUDEDIRS="$INCLUDEDIRS $MPI_INC_DIR"
    #- used for parallel (MPI) DIVA
cat ./emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/code_offline_ptracer/
  linux_amd64_ifort+mpi_ice_nas
(...)
INCLUDES=''
LIBS=''

if [ -n "$MPI_ROOT" -a "x$MPI" = xtrue ] ; then
    if [ -z "$MPI_INC_DIR" ]; then
      MPI_INC_DIR="${MPI_ROOT}/include"
    fi
    LIBS="$LIBS -L${MPI_ROOT}/lib -lmpi"
fi

if [ -n "$MPI_INC_DIR" -a "x$MPI" = xtrue ] ; then
    INCLUDES="$INCLUDES -I${MPI_INC_DIR}"
    #INCLUDEDIRS="$INCLUDEDIRS $MPI_INC_DIR"

File code/linux_amd64_ifort+mpi_ice_nas contains the compilation environment with the definition of multiple environment variables:

#! /usr/bin/env bash

(...)
FC=ifort
CC=icc

CPP='/lib/cpp -traditional -P'
DEFINES='-DWORDLENGTH=4 -DINTEL_COMMITQQ'
F90FIXEDFORMAT='-fixed -Tf'
EXTENDED_SRC_FLAG='-132'
(...)

F90FLAGS=$FFLAGS
F90OPTIM=$FOPTIM

INCLUDEDIRS=''
INCLUDES=''
LIBS=''

if [ -n "$MPI_ROOT" -a "x$MPI" = xtrue ] ; then
    if [ -z "$MPI_INC_DIR" ]; then
                           MPI_INC_DIR="${MPI_ROOT}/include"
    fi
    LIBS="$LIBS -L${MPI_ROOT}/lib -lmpi"
fi

if [ -n "$MPI_INC_DIR" -a "x$MPI" = xtrue ] ; then
    INCLUDES="$INCLUDES -I${MPI_INC_DIR}"
    #INCLUDEDIRS="$INCLUDEDIRS $MPI_INC_DIR"
    #- used for parallel (MPI) DIVA
    MPIINCLUDEDIR="$MPI_INC_DIR"
    #MPI_HEADER_FILES='mpif.h mpiof.h'
fi

if [ "x$NETCDF" != x ] ; then
    INCLUDES="$INCLUDES -I${NETCDF}/include"
    #INCLUDEDIRS="$INCLUDEDIRS ${NETCDF}/include"
    LIBS="$LIBS -L${NETCDF}/lib"
fi

CIMA's hydra does not have defined environment variables like $MPI_ROOT, $MPI, ... will be necessarily be defined on purpose after uploading the compilation environment.

Only the file in linux_amd64_ifort+mpi_ice_nas in emu_dir/WORKDIR/MITgcm/tools/build_options/, has library paths from NASA HPCs, we need to create a generalized one to make it work.

$ cp ./emu_dir/WORKDIR/MITgcm/tools/build_options/linux_amd64_ifort+mpi_ice_nas linux_amd64_ifort+mpi_ice_nas_generic
$ diff linux_amd64_ifort+mpi_ice_nas_generic ./emu_dir/WORKDIR/MITgcm/tools/build_options/linux_amd64_ifort+mpi_ice_nas
20,21c20,21
< LIBS='-L${MPI_ROOT}/lib -lmpi -L${NETCDF}/lib -lnetcdf'
< INCLUDES='-I${MPI_ROOT}/include -I${NETCDF}/include'
---
> LIBS='-L/nasa/sgi/mpt/2.14r19/lib -lmpi -L/nasa/netcdf/4.0/lib -lnetcdf'
> INCLUDES='-I/nasa/sgi/mpt/2.14r19/include -I/nasa/netcdf/4.0/include'
33c33
<     FOPTIM='-O2 -fp-model precise -axCORE-AVX2 -xSSE4.2 -traceback -ftz'
---
>     FOPTIM='-O2 -ipo -fp-model precise -axCORE-AVX2 -xSSE4.2 -traceback -ftz'

$ cp emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/code/linux_amd64_ifort+mpi_ice_nas ./linux_amd64_ifort+mpi_ice_nas_generic_V4r4
$ diff linux_amd64_ifort+mpi_ice_nas_generic_V4r4 emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/code/linux_amd64_ifort+mpi_ice_nas
46c46
<     FOPTIM='-O2 -fp-model precise -align -axCORE-AVX2 -xSSE4.2 -traceback -ftz'
---
>     FOPTIM='-O2 -ipo -fp-model precise -align -axCORE-AVX2 -xSSE4.2 -traceback -ftz'

$ cp emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/code_offline_ptracer/linux_amd64_ifort+mpi_ice_nas ./linux_amd64_ifort+mpi_ice_nas_generic_V4r4_offline
$ diff linux_amd64_ifort+mpi_ice_nas_generic_V4r4_offline emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/code_offline_ptracer/linux_amd64_ifort+mpi_ice_nas
46c46
<     FOPTIM='-O2 -fp-model precise -align -axCORE-AVX2 -xSSE4.2 -traceback -ftz'
---
>     FOPTIM='-O2 -ipo -fp-model precise -align -axCORE-AVX2 -xSSE4.2 -traceback -ftz'

Inside emu_dir/emu/native/emu_compile_mdl.sh we modify it to use the generic version of the environment file

$ diff emu_dir/emu/native/emu_compile_mdl_orig.sh emu_dir/emu/native/emu_compile_mdl.sh 
(...)
104a105,112
> # Generalizing compilation....
> cp ${emu_dir}/WORKDIR/MITgcm/tools/build_options/linux_amd64_ifort+mpi_ice_nas ${emu_dir}/WORKDIR/MITgcm/tools/build_options/linux_amd64_ifort+mpi_ice_nas_orig
> cp ${emu_dir}/../linux_amd64_ifort+mpi_ice_nas_generic ${emu_dir}/WORKDIR/MITgcm/tools/build_options/linux_amd64_ifort+mpi_ice_nas
> cp ${emu_dir}/WORKDIR/MITgcm/V4r4/flux-forced/code/linux_amd64_ifort+mpi_ice_nas ${emu_dir}/WORKDIR/MITgcm/V4r4/flux-forced/code/linux_amd64_ifort+mpi_ice_nas_orig
> cp ${emu_dir}/../linux_amd64_ifort+mpi_ice_nas_generic_V4r4 ${emu_dir}/WORKDIR/MITgcm/V4r4/flux-forced/code/linux_amd64_ifort+mpi_ice_nas
> cp ${emu_dir}/WORKDIR/MITgcm/V4r4/flux-forced/code_offline_ptracer/linux_amd64_ifort+mpi_ice_nas ${emu_dir}/WORKDIR/MITgcm/V4r4/flux-forced/code_offline_ptracer/linux_amd64_ifort+mpi_ice_nas_orig
> cp ${emu_dir}/../linux_amd64_ifort+mpi_ice_nas_generic_V4r4_offline ${emu_dir}/WORKDIR/MITgcm/V4r4/flux-forced/code_offline_ptracer/linux_amd64_ifort+mpi_ice_nas
> 
(...)

Still after all these modifications, Makefile still uses -ipo compilation flag. Removing it directly from the Makefiles

$ cp /share/EMU/emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/build_trc/Makefile ./Makefile_V4r4_NOipo
$ diff Makefile_V4r4_NOipo /share/EMU/emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/build_trc/Makefile 
75c75
< FOPTIM = -O2 -fp-model precise -align -axCORE-AVX2 -xSSE4.2 -traceback -ftz 
---
> FOPTIM = -O2 -ipo -fp-model precise -align -axCORE-AVX2 -xSSE4.2 -traceback -ftz 
78c78
< F90OPTIM = -O2 -fp-model precise -align -axCORE-AVX2 -xSSE4.2 -traceback -ftz
---
> F90OPTIM = -O2 -ipo -fp-model precise -align -axCORE-AVX2 -xSSE4.2 -traceback -ftz

Adding it into the compiling script to be used

$ diff emu_dir/emu/native/emu_compile_mdl_orig.sh emu_dir/emu/native/emu_compile_mdl.sh 
(...)
126a136,138
> cp /share/EMU/emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/build_trc/Makefile /share/EMU/emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/build_trc/Makefile_orig
> cp ${emu_dir}/../Makefile_V4r4_NOipo /share/EMU/emu_dir/WORKDIR/MITgcm/V4r4/flux-forced/build_trc/Makefile
126a138
> 

Use