/[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.29 by heimbach, Thu Aug 18 09:10:26 2011 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  c#ifdef ALLOW_SEAICE
20  CEOP  c# include "SEAICE_OPTIONS.h"
21    c#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    #ifdef ALLOW_ADAMSBASHFORTH_3
30         &                     adgunm, adgvnm, adgtnm, adgsnm
31    #else
32       &                     adgunm1, adgvnm1, adgtnm1, adgsnm1       &                     adgunm1, adgvnm1, adgtnm1, adgsnm1
33    #endif
34        _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)  
35        _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)
       _RL adgsnm1(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)  
36        _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)
       _RL adgtnm1(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)  
37        _RL adgu(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)        _RL adgu(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
       _RL adgunm1(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)  
38        _RL adgv(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)        _RL adgv(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
       _RL adgvnm1(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)  
39        _RL adsalt(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)        _RL adsalt(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
40        _RL adtheta(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)        _RL adtheta(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
41        _RL aduvel(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)        _RL aduvel(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
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    #ifdef ALLOW_ADAMSBASHFORTH_3    
45          _RL adgtnm(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy,2)
46          _RL adgsnm(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy,2)
47          _RL adgunm(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy,2)
48          _RL adgvnm(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy,2)
49    #else
50          _RL adgtnm1(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
51          _RL adgsnm1(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
52          _RL adgunm1(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
53          _RL adgvnm1(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
54    #endif
55    
56          common /addynvars_r_2/
57         &                     adetah
58          _RL adetah(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
59    
60    #ifdef ALLOW_AUTODIFF_MONITOR_DIAG
61          common /addynvars_diag/
62         &                     adtotphihyd, adrhoinsitu
63          _RL adrhoinsitu(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
64          _RL adtotphihyd(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
65    #endif
66    
67        common /addynvars_cd/  #ifdef ALLOW_CD_CODE
68          common /addynvars_cd/
69       &                      aduveld, advveld,       &                      aduveld, advveld,
70       &                      adunm1, advnm1,       &                       adetanm1,
71       &                      adgucd, adgvcd       &                      adunm1, advnm1
72        _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)
73        _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)
74          _RL adetanm1(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
75        _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)
76        _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)
77        _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)  
78    
79        common /adffields/        COMMON /adffields_fu/ adfu
80       &                   adfu, adfv, adqnet, adempmr, adsst, adsss        COMMON /adffields_fv/ adfv
81        _RL adfu(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)        COMMON /adffields_Qnet/ adQnet
82        _RL adfv(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)        COMMON /adffields_Qsw/ adQsw
83        _RL adqnet(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)        COMMON /adffields_dQdT/ addQdT
84        _RL adempmr(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)        COMMON /adffields_EmPmR/ adEmPmR
85        _RL adsst(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)        COMMON /adffields_saltFlux/ adsaltFlux
86        _RL adsss(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)        COMMON /adffields_SST/ adSST
87          COMMON /adffields_SSS/ adSSS
88  #ifdef ALLOW_TR10_CONTROL        COMMON /adffields_lambdaThetaClimRelax/ adlambdaThetaClimRelax
89        common /adtr1_r/        COMMON /adffields_lambdaSaltClimRelax/ adlambdaSaltClimRelax
90       &                 adtr1, adgtr1, adgtr1nm1  #ifdef ATMOSPHERIC_LOADING
91        _RL adgtr1(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)        COMMON /adffields_pload/ adpload
92        _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)  
93  #endif  #endif
94    
95  #ifdef ALLOW_DIFFKR_CONTROL        _RS  adfu       (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
96        common /addynvars_diffkr/        _RS  adfv       (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
97       &                          addiffkr        _RS  adQnet     (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
98        _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)
99          _RS  addQdT     (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
100          _RS  adEmPmR    (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
101          _RS  adsaltFlux (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
102          _RS  adSST      (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
103          _RS  adSSS      (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
104          _RS  adlambdaThetaClimRelax
105         &    (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
106          _RS  adlambdaSaltClimRelax
107         &    (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
108    #ifdef ATMOSPHERIC_LOADING
109          _RS  adpload    (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
110          _RS  adsIceLoad (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
111  #endif  #endif
112    
113    #ifdef ALLOW_DIFFKR_CONTROL
114          COMMON /ADDYNVARS_DIFFKR/
115         &                       addiffKr
116          _RL  addiffKr (1-OLx:sNx+OLx,1-OLy:sNy+OLy,Nr,nSx,nSy)
117    #endif
118  #ifdef ALLOW_KAPGM_CONTROL  #ifdef ALLOW_KAPGM_CONTROL
119        common /addynvars_kapgm/        COMMON /ADDYNVARS_KAPGM/
120       &                          adkapgm       &                       adkapgm
121        _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)
122  #endif  #endif
123    #ifdef ALLOW_KAPREDI_CONTROL
124          COMMON /ADDYNVARS_KAPREDI/
125         &                       adkapredi
126          _RL  adkapredi (1-OLx:sNx+OLx,1-OLy:sNy+OLy,Nr,nSx,nSy)
127    #endif
128    #ifdef ALLOW_BOTTOMDRAG_CONTROL
129          COMMON /ADDYNVARS_BOTTOMDRAG/
130         &                adbottomdragfld
131          _RL  adbottomdragfld (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
132    #endif
133    #ifdef ALLOW_EDDYPSI_CONTROL
134          double precision adeddypsix(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,
135         $nsy)
136          double precision adeddypsiy(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,
137         $nsy)
138          common /adeddypsiffields/ adeddypsix, adeddypsiy
139    
140    #endif
141    
142    #ifdef ALLOW_EXF
143    
144          _RL adhflux(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
145          _RL adsflux(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
146          common /adexf_hsflux_r/ adhflux, adsflux
147    c
148          _RL adustress(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
149          _RL advstress(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
150          common /adexf_stress_r/ adustress, advstress
151    c
152          _RL adwspeed(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
153          common /adexf_wspeed_r/ adwspeed
154    
155    # ifdef ALLOW_ATM_TEMP
156          _RL adatemp     (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
157          _RL adaqh       (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
158          _RL adlwflux    (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
159          _RL adprecip    (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
160          common /adexf_atm_temp_r/ adatemp, adaqh, adlwflux,
161         & adprecip
162    #  ifdef SHORTWAVE_HEATING
163          _RL adswflux    (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
164          common /adexf_swflux_r/ adswflux
165    #  endif
166    # endif
167    # ifdef ALLOW_ATM_WIND
168          _RL aduwind     (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
169          _RL advwind     (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
170          common /adexf_atm_wind_r/ aduwind, advwind
171    # endif
172    # ifdef ALLOW_DOWNWARD_RADIATION
173          _RL adswdown    (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
174          _RL adlwdown    (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
175          common /adexf_rad_down_r/
176         &     adswdown, adlwdown
177    # endif
178    # ifdef ALLOW_CLIMSST_RELAXATION
179          _RL adclimsst(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
180          common /adexf_clim_sst_r/ adclimsst
181    # endif
182    # ifdef ALLOW_CLIMSSS_RELAXATION
183          _RL adclimsss(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
184          common /adexf_clim_sss_r/ adclimsss
185    # endif
186    
187    #endif /* ALLOW_EXF */
188    
189    #ifdef ALLOW_SEAICE
190          _RL adarea  (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
191          _RL adheff  (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
192          _RL adhsnow (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
193          _RL aduice  (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
194          _RL advice  (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
195          common /adseaice_dynvars_1/
196         &     adarea, adheff, adhsnow, aduice, advice
197    # ifdef SEAICE_VARIABLE_SALINITY
198          _RL adhsalt (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
199          common /seaice_salinity_r/
200         &     adhsalt
201    # endif
202    #endif /* ALLOW_SEAICE */
203    
204    #ifdef ALLOW_GGL90
205          _RL adggl90tke     (1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
206          _RL adggl90diffkr  (1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
207          common /adggl90_fields/
208         &     adggl90tke, adggl90diffkr
209    #endif
210    
211    #ifdef ALLOW_DEPTH_CONTROL
212          _RL adr_low_control(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
213          _RL adhfacc(1-olx:snx+olx,1-oly:sny+oly,1:nr,nsx,nsy)
214          _RL adhfacs(1-olx:snx+olx,1-oly:sny+oly,1:nr,nsx,nsy)
215          _RL adhfacw(1-olx:snx+olx,1-oly:sny+oly,1:nr,nsx,nsy)
216          _RL adrecip_hfacc(1-olx:snx+olx,1-oly:sny+oly,1:nr,nsx,nsy)
217          _RL adrecip_hfacs(1-olx:snx+olx,1-oly:sny+oly,1:nr,nsx,nsy)
218          _RL adrecip_hfacw(1-olx:snx+olx,1-oly:sny+oly,1:nr,nsx,nsy)
219          common /adgrid_r/ adr_low_control,
220         &                  adrecip_hfacc, adrecip_hfacw, adrecip_hfacs
221          common /adgrid_r_c/ adhfacc
222          common /adgrid_r_s/ adhfacs
223          common /adgrid_r_w/ adhfacw
224    #endif /* ALLOW_DEPTH_CONTROL */
225    
226    #endif /* ALLOW_AUTODIFF_MONITOR */

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

  ViewVC Help
Powered by ViewVC 1.1.22