/[MITgcm]/MITgcm/pkg/autodiff/adcommon.h
ViewVC logotype

Diff of /MITgcm/pkg/autodiff/adcommon.h

Parent Directory Parent Directory | Revision Log Revision Log | View Revision Graph Revision Graph | View Patch Patch

revision 1.1 by heimbach, Fri Sep 28 04:18:58 2001 UTC revision 1.19 by jmc, Mon Oct 8 23:50:53 2007 UTC
# Line 1  Line 1 
1    C $Header$
2    C $Name$
3    
4  CBOP  C--   These common blocks are extracted from the
5  C     !ROUTINE: adcommon.h  C--   automatically created tangent linear code.
6  C     !INTERFACE:  C--   You need to make sure that they are up-to-date
7  C     include "adcommon.h "  C--   (i.e. in right order), and customize them
8  C     !DESCRIPTION: \bv  C--   accordingly.
9  C     *==========================================================*  C--
10  C     | CPP_EEMACROS.h                                              C--   heimbach@mit.edu 11-Jan-2001
11  C     *==========================================================*  
12  C--   | common blocks of adjoint variables extracted from  #ifdef ALLOW_AUTODIFF_MONITOR
13  C     | TAMC-/TAF- generated code for use in adjoint support;  
14  C     | Make sure that adjoint common blocks below are up-to-date  #include "PACKAGES_CONFIG.h"
15  C     | w.r.t. current adjoint code.  
16  C     *==========================================================*  #ifdef ALLOW_EXF
17  C     | CPP_EEMACROS.h                                              # include "EXF_OPTIONS.h"
18  C     *==========================================================*  #endif
19  C     \ev  #ifdef ALLOW_SEAICE
20  CEOP  # include "SEAICE_OPTIONS.h"
21    #endif
22        common /addynvars_r/  
23       &                     adetan, adetanm1,  
24       &                     aduvel, advvel, adwvel,        common /addynvars_r/
25       &                     adtheta, adsalt,       &                     adetan,
26       &                     adgu, adgv, adgt, adgs,       &                     aduvel, advvel, adwvel,
27         &                     adtheta, adsalt,
28         &                     adgu, adgv, adgt, adgs,
29       &                     adgunm1, adgvnm1, adgtnm1, adgsnm1       &                     adgunm1, adgvnm1, adgtnm1, adgsnm1
30        _RL adetan(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)        _RL adetan(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
       _RL adetanm1(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)  
31        _RL adgs(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)        _RL adgs(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
32        _RL adgsnm1(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)        _RL adgsnm1(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
33        _RL adgt(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)        _RL adgt(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
# Line 39  CEOP Line 42  CEOP
42        _RL advvel(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)        _RL advvel(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
43        _RL adwvel(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)        _RL adwvel(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
44    
45        common /addynvars_cd/        common /addynvars_r_2/
46         &                     adetah
47          _RL adetah(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
48    
49    #ifdef ALLOW_CD_CODE
50          common /addynvars_cd/
51       &                      aduveld, advveld,       &                      aduveld, advveld,
52       &                      adunm1, advnm1,       &                       adetanm1,
53       &                      adgucd, adgvcd       &                      adunm1, advnm1
54        _RL aduveld(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)        _RL aduveld(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
55        _RL advveld(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)        _RL advveld(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
56          _RL adetanm1(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
57        _RL adunm1(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)        _RL adunm1(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
58        _RL advnm1(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)        _RL advnm1(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
59        _RL adgucd(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)  #endif
       _RL adgvcd(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)  
60    
61        common /adffields/        COMMON /adffields_fu/ adfu
62       &                   adfu, adfv, adqnet, adempmr, adsst, adsss        COMMON /adffields_fv/ adfv
63        _RL adfu(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)        COMMON /adffields_Qnet/ adQnet
64        _RL adfv(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)        COMMON /adffields_Qsw/ adQsw
65        _RL adqnet(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)        COMMON /adffields_dQdT/ addQdT
66        _RL adempmr(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)        COMMON /adffields_EmPmR/ adEmPmR
67        _RL adsst(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)        COMMON /adffields_saltFlux/ adsaltFlux
68        _RL adsss(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)        COMMON /adffields_SST/ adSST
69          COMMON /adffields_SSS/ adSSS
70  #ifdef ALLOW_TR10_CONTROL        COMMON /adffields_lambdaThetaClimRelax/ adlambdaThetaClimRelax
71        common /adtr1_r/        COMMON /adffields_lambdaSaltClimRelax/ adlambdaSaltClimRelax
72       &                 adtr1, adgtr1, adgtr1nm1  #ifdef ATMOSPHERIC_LOADING
73        _RL adgtr1(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)        COMMON /adffields_pload/ adpload
74        _RL adgtr1nm1(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)        COMMON /adffields_sIceLoad/ adsIceLoad
       _RL adtr1(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)  
75  #endif  #endif
76    
77  #ifdef ALLOW_DIFFKR_CONTROL        _RS  adfu       (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
78        common /addynvars_diffkr/        _RS  adfv       (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
79       &                          addiffkr        _RS  adQnet     (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
80        _RL addiffkr(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)        _RS  adQsw      (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
81          _RS  addQdT     (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
82          _RS  adEmPmR    (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
83          _RS  adsaltFlux (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
84          _RS  adSST      (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
85          _RS  adSSS      (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
86          _RS  adlambdaThetaClimRelax
87         &    (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
88          _RS  adlambdaSaltClimRelax
89         &    (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
90    #ifdef ATMOSPHERIC_LOADING
91          _RS  adpload    (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
92          _RS  adsIceLoad (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
93  #endif  #endif
94    
95    #ifdef ALLOW_DIFFKR_CONTROL
96          COMMON /ADDYNVARS_DIFFKR/
97         &                       addiffKr
98          _RL  addiffKr (1-OLx:sNx+OLx,1-OLy:sNy+OLy,Nr,nSx,nSy)
99    #endif
100  #ifdef ALLOW_KAPGM_CONTROL  #ifdef ALLOW_KAPGM_CONTROL
101        common /addynvars_kapgm/        COMMON /ADDYNVARS_KAPGM/
102       &                          adkapgm       &                       adkapgm
103        _RL adkapgm(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)        _RL  adkapgm (1-OLx:sNx+OLx,1-OLy:sNy+OLy,Nr,nSx,nSy)
104    #endif
105    #ifdef ALLOW_BOTTOMDRAG_CONTROL
106          COMMON /ADDYNVARS_BOTTOMDRAG/
107         &                adbottomdragfld
108          _RL  adbottomdragfld (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
109  #endif  #endif
110    #if (defined (ALLOW_EDTAUX_CONTROL) || defined (ALLOW_EDTAUY_CONTROL))
111          double precision adeddytaux(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,
112         $nsy)
113          double precision adeddytauy(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,
114         $nsy)
115          common /adedtauffields/ adeddytaux, adeddytauy
116    
117    #endif
118    
119    #ifdef ALLOW_EXF
120          _RL adhflux(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
121          _RL adsflux(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
122          common /adexf_hsflux_r/ adhflux, adsflux
123          _RL adustress(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
124          _RL advstress(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
125          common /adexf_stress_r/ adustress, advstress
126    # ifdef ALLOW_ATM_TEMP
127          _RL adatemp     (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
128          _RL adaqh       (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
129          _RL adlwflux    (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
130          _RL adprecip    (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
131          common /adexf_atm_temp_r/ adatemp, adaqh, adlwflux, adprecip
132    # endif
133    # ifdef ALLOW_ATM_WIND
134          _RL aduwind     (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
135          _RL advwind     (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
136          common /adexf_atm_wind_r/ aduwind, advwind
137    # endif
138    # ifdef ALLOW_DOWNWARD_RADIATION
139          _RL adswdown    (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
140          _RL adlwdown    (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
141          common /adexf_rad_down_r/
142         &     adswdown, adlwdown
143    # endif
144    # ifdef ALLOW_CLIMSST_RELAXATION
145          _RL adclimsst(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
146          common /adexf_clim_sst_r/ adclimsst
147    # endif
148    # ifdef ALLOW_CLIMSSS_RELAXATION
149          _RL adclimsss(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
150          common /adexf_clim_sss_r/ adclimsss
151    # endif
152    #endif
153    
154    #ifdef ALLOW_SEAICE
155          _RL adarea(1-olx:snx+olx,1-oly:sny+oly,3,nsx,nsy)
156          common /adseaice_dynvars_1/ adarea
157    c
158          _RL adheff(1-olx:snx+olx,1-oly:sny+oly,3,nsx,nsy)
159          _RL adhsnow(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
160          common /adseaice_trans/ adheff, adhsnow
161    # ifdef SEAICE_ALLOW_DYNAMICS
162          _RL aduice(1-olx:snx+olx,1-oly:sny+oly,3,nsx,nsy)
163          _RL advice(1-olx:snx+olx,1-oly:sny+oly,3,nsx,nsy)
164          common /adseaice_dynvars_2/ aduice, advice
165    # endif
166    #endif
167    
168    #ifdef ALLOW_DEPTH_CONTROL
169          _RL adr_low_control(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
170          _RL adhfacc(1-olx:snx+olx,1-oly:sny+oly,1:nr,nsx,nsy)
171          _RL adhfacs(1-olx:snx+olx,1-oly:sny+oly,1:nr,nsx,nsy)
172          _RL adhfacw(1-olx:snx+olx,1-oly:sny+oly,1:nr,nsx,nsy)
173          _RL adrecip_hfacc(1-olx:snx+olx,1-oly:sny+oly,1:nr,nsx,nsy)
174          _RL adrecip_hfacs(1-olx:snx+olx,1-oly:sny+oly,1:nr,nsx,nsy)
175          _RL adrecip_hfacw(1-olx:snx+olx,1-oly:sny+oly,1:nr,nsx,nsy)
176          common /adgrid_r/ adr_low_control,
177         &                  adrecip_hfacc, adrecip_hfacw, adrecip_hfacs
178          common /adgrid_r_c/ adhfacc
179          common /adgrid_r_s/ adhfacs
180          common /adgrid_r_w/ adhfacw
181    #endif /* ALLOW_DEPTH_CONTROL */
182    
183    #endif /* ALLOW_AUTODIFF_MONITOR */

Legend:
Removed from v.1.1  
changed lines
  Added in v.1.19

  ViewVC Help
Powered by ViewVC 1.1.22