| 1 |
heimbach |
1.1 |
Starting a configuration for OpenAD |
| 2 |
|
|
19-Aug-2005, heimbach@mit.edu, utke@mcs.anl.gov, cnh@mit.edu |
| 3 |
|
|
############################################################ |
| 4 |
|
|
|
| 5 |
|
|
This experiment is derived from global_ocean.90x40x15, |
| 6 |
|
|
but excludes packages gmredi, kpp. |
| 7 |
|
|
|
| 8 |
|
|
STEP 1: |
| 9 |
|
|
###### |
| 10 |
|
|
To bypass incomplete canonicalizer, convert COMMON blocks to MODULES. |
| 11 |
|
|
Successfully completed. |
| 12 |
|
|
The built process needed to be modified, and some routines |
| 13 |
|
|
needed changes. Most changes were commited to default routines, |
| 14 |
|
|
the remaining changes are kept in code/ for now. |
| 15 |
|
|
|
| 16 |
|
|
To build: |
| 17 |
|
|
-------- |
| 18 |
|
|
o short version: |
| 19 |
|
|
--------------- |
| 20 |
|
|
make makefile ; make depend ; make cb2m ; make makefile ; make small_f ; make allmods ; make |
| 21 |
|
|
|
| 22 |
|
|
o long version: |
| 23 |
|
|
-------------- |
| 24 |
|
|
# (chdir to built/; assume we are in built/) |
| 25 |
|
|
# |
| 26 |
|
|
# generate makefile using ifort and modified genmake2 in ../code/ |
| 27 |
|
|
../code/genmake2 -of ../../../tools/build_options/linux_ia32_ifort -mods ../code |
| 28 |
|
|
# |
| 29 |
|
|
# make dependencies |
| 30 |
|
|
make depend |
| 31 |
|
|
# |
| 32 |
|
|
# invoke script to convert COMMON block headers to MODULE headers |
| 33 |
|
|
# converts FILE.h to FILE_mod.h which uses newi module FILE_mod.F90 |
| 34 |
|
|
make cb2m |
| 35 |
|
|
# |
| 36 |
|
|
# re-generate makefile which takes into account newly created files |
| 37 |
|
|
# FILE_mod.h, FILE_mod.F90 |
| 38 |
|
|
make makefile |
| 39 |
|
|
# |
| 40 |
|
|
# make .f, .f90 |
| 41 |
|
|
make small_f |
| 42 |
|
|
# |
| 43 |
|
|
# first compile all module files .f90 |
| 44 |
|
|
make allmods |
| 45 |
|
|
# |
| 46 |
|
|
# compile everything else |
| 47 |
|
|
make |
| 48 |
|
|
|
| 49 |
|
|
To clean: |
| 50 |
|
|
-------- |
| 51 |
|
|
# Since soft links get overwritten, for now do: |
| 52 |
|
|
make CLEAN ; rm *.F *.F90 *.h |
| 53 |
|
|
|
| 54 |
|
|
to run: |
| 55 |
|
|
------ |
| 56 |
|
|
# paremeter files are in input/ |
| 57 |
|
|
ln -s ../input/* . |
| 58 |
|
|
# initial and forcing fields are elsewhere; |
| 59 |
|
|
# get these from verif. exp. global_ocean.90x40x15/input/*.bin |
| 60 |
|
|
ln -s ../../global_ocean.90x40x15/input/*.bin . |
| 61 |
|
|
./mitgcmuv >! output.txt |
| 62 |
|
|
|
| 63 |
|
|
STEP 2: |
| 64 |
|
|
###### |
| 65 |
|
|
Generate code for AD-related routines. |
| 66 |
|
|
|
| 67 |
|
|
Similar to step 1, but look in code_ad/ instead of code/ |
| 68 |
|
|
|
| 69 |
|
|
To build: |
| 70 |
|
|
-------- |
| 71 |
|
|
o short version: |
| 72 |
|
|
--------------- |
| 73 |
|
|
|
| 74 |
|
|
../code_ad/genmake2 -of ../../../tools/build_options/linux_ia32_ifort -adof ../../../tools/adjoint_options/adjoint_f95 -mods ../code_ad |
| 75 |
|
|
|
| 76 |
|
|
make adall |
| 77 |
|
|
|
| 78 |
heimbach |
1.2 |
STEP 3: |
| 79 |
|
|
###### |
| 80 |
|
|
Compare reference outputs. |
| 81 |
|
|
|
| 82 |
heimbach |
1.3 |
------------------ |
| 83 |
|
|
SINGLE-LAYER SETUP: _openad, _taf |
| 84 |
|
|
------------------ |
| 85 |
|
|
|
| 86 |
heimbach |
1.2 |
# uncompress outputs in results_... directories: |
| 87 |
|
|
gunzip ../results_shallow_*/output.txt.gz |
| 88 |
|
|
|
| 89 |
|
|
# extract gradients from TAF-generated adjoint: |
| 90 |
|
|
grep grad-res ../results_shallow_taf/output.txt |
| 91 |
|
|
|
| 92 |
|
|
# extract gradients from OpenAD-generated adjoint: |
| 93 |
|
|
grep ' salt/theta ' ../results_shallow_openad/output.txt |
| 94 |
|
|
|
| 95 |
|
|
The two positions tested via gradient checks (results_shallow_taf) are |
| 96 |
|
|
(i,j,k) = (43,2,1) and (44,2,1) |
| 97 |
|
|
Find corresponding locations in ' salt/theta ' output |
| 98 |
|
|
(which outputs whole theta, salt gradient) |
| 99 |
heimbach |
1.1 |
|
| 100 |
heimbach |
1.3 |
------------------ |
| 101 |
|
|
15-LAYER-SETUP : _openad2, _taf2 |
| 102 |
|
|
------------------ |
| 103 |
|
|
|
| 104 |
|
|
first working setup of 05-Aug-2006 ran for 12 timesteps |
| 105 |
|
|
on itrda.acesgrid.org under |
| 106 |
|
|
/net/ds-06/scratch-0/utke/cvs/MITgcm/verification/OpenAD/run_ph_baroclin/ |
| 107 |
|
|
uses Atlantic heat transport cost function; |
| 108 |
|
|
|
| 109 |
|
|
* OpenAD output is in results_shallow_openad2/ |
| 110 |
|
|
grep ' salt/theta ' ../results_shallow_openad2/output.txt |
| 111 |
|
|
|
| 112 |
|
|
* TAF output is in results_shallow_taf2/ |
| 113 |
|
|
grep grad-res ../results_shallow_taf2/output.txt |
| 114 |
|
|
|
| 115 |
|
|
The positions tested via gradient checks (results_shallow_taf2) are |
| 116 |
|
|
(i,j,k) = (78,26,1) |
| 117 |
|
|
|
| 118 |
|
|
------------------ |
| 119 |
|
|
15-LAYER-SETUP WITH GMREDI: _openad3, _taf3 |
| 120 |
|
|
------------------ |
| 121 |
|
|
|
| 122 |
|
|
not yet run. |