Difference between revisions of "Nemo"
Line 58: | Line 58: | ||
===AGRIF package=== | ===AGRIF package=== | ||
− | AGRIF is designed to create fine regional grids (child grids) in a form that NEMO can read in from a coarse NEMO global grid. The idea is to run the fine grid '''with''' the global grid to provide local increased resolution where the model needs it. | + | AGRIF is designed to create fine regional grids (child grids) in a form that NEMO can read in from a coarse NEMO global grid. The idea is to run the fine grid '''with''' the global grid to provide local increased resolution where the model needs it. It is possible to genrate the child bathymetry by interpolating from the global bathymetry '''and''' high resolution topography. It blends the coarse and fine resolutions over a few cells at the edges of the child grid. It also creates input files for the child grid from the global input files. |
− | You can download the source code (Nesting_tools_NEMO.tar) and the user's manual (doc_nesting_tools.pdf) from the NEMO website. The manual tells you how to untar and make the executable files, run the executables and gives some theory about the interpolation schemes. The executables are create_coordinates.exe, create_bathy.exe, create_data.exe and create_restart.exe. | + | You can download the source code (Nesting_tools_NEMO.tar) and the user's manual (doc_nesting_tools.pdf) from the NEMO website. The manual tells you how to untar and make the executable files, run the executables and gives some theory about the interpolation schemes. The executables are |
+ | * <code>create_coordinates.exe </code> generates the longitude, latitude and metrics for the child grid, | ||
+ | * <code>create_bathy.exe </code> generates the bathymetry, | ||
+ | * <code>create_data.exe </code> generates the necessary input files (nav_lon and nav_lat in the child files aren't correct but NEMO doesn't use them) and | ||
+ | * <code>create_restart.exe </code> interpolates the global restart file to the child grid. | ||
+ | |||
+ | These executables use one namelist. AGRIF provides an example namelist, pacifique_tropical, in Nesting_tools/bin. | ||
==Open boundary conditions== | ==Open boundary conditions== |
Revision as of 11:24, 5 February 2008
Welcome to the Bristol Nemo Page!
Here are a few tips and comments based on Bristol's experiences compiling and running NEMO. Hopefully, you will find some useful.
Please take a look the official NEMO webpage before continuing with this page.
Model Compilation
In the steps below, I'm assuming that you are interested in the ORCA2_LIM version of the model.
If you follow the steps described on the official NEMO webpage, you will be able to download and compile the model, with one caveat. When using newer versions of the NetCDF libraries--such as v3.6.2 installed on the Quest cluster--you will need to change line 210 of modipsl/util/AA_make.gdef to "NCDF_INC = /usr/local/netcdf/3.6.2/pgi-251/include" and line 211 to "NCDF_LIB = -L/usr/local/netcdf/3.6.2/pgi-251/lib -lnetcdf -lnetcdff".
Running the Model
Nemo provides a test case, ORCA2_LIM, for a global ocean run coupled with the sea-ice model. The run simulates one year. The configuration for ORCA2_LIM is downloaded through CVS when getting Nemo and the necessary forcing files are provided through a link on the Nemo website or can be copied from ~ggdaqw/NEMO_forcing as detailed below.
The instructions for running the model are not so clear. You will need two things to run the model; (i) some forcing files; and (ii) a run script. Assuming you are running on the Quest cluster, you can obtain forcing files for an example job by copying the directory ~ggdagw/NEMO_forcing and it's contents to you home directory. If you adopt the same directory name, you will be able to use this runscript. Place the runscript into the directory modipsl/config/ORCA2_LIM/EXP00. I named it Job_EXP.new. You will need to create the directory "$DUMP2HOLD/NEMO" in your home directory to collect the output. You can submit the job by typing "qsub Job_EXP.new", check whether it is running using "showq", and obviously look in the output directory.
Projects using Nemo at Bristol
Mediterranean Sea
Sediment cores recovered from the Mediterranean Sea reveal distinct layers of organic rich material thought to be associated with deep water anoxia, caused by either a shut down in deep water circulation, an increase in productivity, or both. One of the ways this could have happened is by a large increase in fresh water runoff into the basin. We intend to use a Mediterranean configuration of NEMO to study how point sources of freshwater, represented by low delta-18-O, are circulated around the Mediterranean, and compare the modeled distribution with records of delta-18-O during these "Mediterranean Anoxic Events".
Amundsen Sea
Thinning of the Pine Island Glacier, West Antarctica, has been observed during the 1990s. It has been suggested that relatively warm water at the base of the ice shelf has triggered the thinning. The source of and mechanism driving this warm water is unknown.
We are constructing a regional model of the Amunsden Sea using Nemo to investigate ocean circulation close to Pine Island Bay. Input data at the sea surface and at the open boundaries are constructed using output data from the OCCAM global ocean model.
Regional model
How to set up a regional model starting from the ORCA2_LIM test case:
- Create a new configuration for the regional model.
- In directory modipsl/config/ create a new directory AMUNDSEN, for example, and copy the contents of the ORCA2_LIM directory into AMUNDSEN.
- Edit file fait_config in modipsl/modeles/UTIL/. Add
\n AMUNDSEN
toLIST =
and add the lineset -A DIR_AMUNSDEN OPA_SRC C1D_SRC NST_SRC
.
- Change CPP keys by editing BB_make.ldef in modipsl/config/AMUNDSEN/scripts/. Remove
key_orca_r2
since you're not running a global model and addkey_obc
to invoke open boundary conditions instead. - TIP: modify tradmp.F90 in modipsl/modeles/NEMO/OPA_SRC/TRA/. Replace the line
if (cp_cfg=="orca" .AND. (ndmp > 0 .OR. ndmp==-1)) then
withif (ndmp > 0 .OR. ndmp==-1) then
. If you don't make the change you'll get the error messagetra_dmp: You should not have seen this print error?
. With this change you can apply tracer damping as in the ORCA configurations (i.e. global models for various resolutions) without special treatment for particular areas such as the Mediterranean or the Red Sea that are grid dependent. - Set the new domain resolution in par_oce.F90 in modipsl/modeles/NEMO/OPA_SRC/. Parameters for the resolution are
jpidta
andjpjdta
. - Set parameters in obc_oce.F90 and obc_par.F90 in modipsl/modeles/NEMO/OPA_SRC/OBC/.
- obc_oce.F90:
nbobc
is the number of open boundaries, i.e. set to 1, 2, 3 or 4. - obc_par.F90: set logical parameter
lp_obc_east
to.true.
if open boundary conditions are to be applied to part or all of the eastern face of the domain. Alterjpjed
and/orjpjef
if the open boundary covers only part of the eastern face. Similarly forlp_obc_west
,jpjwd
,jpjwf
,lp_obc_north
,jpind
,jpinf
andlp_obc_south
,jpisd
,jpisf
.
- obc_oce.F90:
- In the input file namelist set
n_cla
to 0. Assuming you have no closed seas, i.e. Mediterranean and Red Sea in ORCA2. - Generate input data from the ORCA2_LIM test case files using the AGRIF package.
Bathymetry
There are some pre-processing packages available on the NEMO website. I don't recommend using the bathymetry package OPABAT. It uses idl and fortran routines contained in IDL_OPABAT3.tar. The instructions are in French and some of the files are missing. Instead, use the AGRIF nesting tools. The instructions are clear and the package also interpolates the input files from the ORCA2_LIM test case.
AGRIF package
AGRIF is designed to create fine regional grids (child grids) in a form that NEMO can read in from a coarse NEMO global grid. The idea is to run the fine grid with the global grid to provide local increased resolution where the model needs it. It is possible to genrate the child bathymetry by interpolating from the global bathymetry and high resolution topography. It blends the coarse and fine resolutions over a few cells at the edges of the child grid. It also creates input files for the child grid from the global input files.
You can download the source code (Nesting_tools_NEMO.tar) and the user's manual (doc_nesting_tools.pdf) from the NEMO website. The manual tells you how to untar and make the executable files, run the executables and gives some theory about the interpolation schemes. The executables are
create_coordinates.exe
generates the longitude, latitude and metrics for the child grid,create_bathy.exe
generates the bathymetry,create_data.exe
generates the necessary input files (nav_lon and nav_lat in the child files aren't correct but NEMO doesn't use them) andcreate_restart.exe
interpolates the global restart file to the child grid.
These executables use one namelist. AGRIF provides an example namelist, pacifique_tropical, in Nesting_tools/bin.
Open boundary conditions
Wiki example
This text is very imprtant. This is less so.
Listen very carefully, I shall say this only once:
- put kettle on
- find mug
- add water to tea bag--in mug!
- slurp
- read
- slurp
can be done in any order
An external link is a search engine
A link to another wiki page is the genie project