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

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

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


Revision 1.27 - (hide annotations) (download)
Thu Jun 16 22:49:15 2011 UTC (12 years, 11 months ago) by heimbach
Branch: MAIN
CVS Tags: checkpoint62z, checkpoint63, checkpoint63a
Changes since 1.26: +24 -7 lines
File MIME type: text/plain
Add adjoint monitor output for packages exf, seaice

1 heimbach 1.27 C $Header: /u/gcmpack/MITgcm/pkg/autodiff/adcommon.h,v 1.26 2011/02/24 07:30:42 heimbach Exp $
2 jmc 1.19 C $Name: $
3    
4 heimbach 1.5 C-- These common blocks are extracted from the
5     C-- automatically created tangent linear code.
6     C-- You need to make sure that they are up-to-date
7     C-- (i.e. in right order), and customize them
8     C-- accordingly.
9     C--
10     C-- heimbach@mit.edu 11-Jan-2001
11 heimbach 1.4
12     #ifdef ALLOW_AUTODIFF_MONITOR
13    
14 heimbach 1.10 #include "PACKAGES_CONFIG.h"
15    
16     #ifdef ALLOW_EXF
17     # include "EXF_OPTIONS.h"
18     #endif
19 heimbach 1.27 c#ifdef ALLOW_SEAICE
20     c# include "SEAICE_OPTIONS.h"
21     c#endif
22 heimbach 1.10
23 heimbach 1.13
24     common /addynvars_r/
25 heimbach 1.14 & adetan,
26 heimbach 1.13 & aduvel, advvel, adwvel,
27 jmc 1.19 & adtheta, adsalt,
28     & adgu, adgv, adgt, adgs,
29 gforget 1.24 #ifdef ALLOW_ADAMSBASHFORTH_3
30     & adgunm, adgvnm, adgtnm, adgsnm
31     #else
32 heimbach 1.13 & adgunm1, adgvnm1, adgtnm1, adgsnm1
33 gforget 1.24 #endif
34 heimbach 1.1 _RL adetan(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
35     _RL adgs(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)
37     _RL adgu(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)
39     _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)
41     _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)
43     _RL adwvel(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
44 gforget 1.24 #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 heimbach 1.1
56 heimbach 1.14 common /addynvars_r_2/
57     & adetah
58     _RL adetah(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
59    
60 heimbach 1.26 #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 heimbach 1.5 #ifdef ALLOW_CD_CODE
68 jmc 1.19 common /addynvars_cd/
69 heimbach 1.1 & aduveld, advveld,
70 jmc 1.19 & adetanm1,
71 heimbach 1.8 & adunm1, advnm1
72 heimbach 1.1 _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)
74 heimbach 1.3 _RL adetanm1(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
75 heimbach 1.1 _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)
77 heimbach 1.5 #endif
78 heimbach 1.3
79 heimbach 1.16 COMMON /adffields_fu/ adfu
80     COMMON /adffields_fv/ adfv
81     COMMON /adffields_Qnet/ adQnet
82     COMMON /adffields_Qsw/ adQsw
83     COMMON /adffields_dQdT/ addQdT
84     COMMON /adffields_EmPmR/ adEmPmR
85     COMMON /adffields_saltFlux/ adsaltFlux
86     COMMON /adffields_SST/ adSST
87     COMMON /adffields_SSS/ adSSS
88     COMMON /adffields_lambdaThetaClimRelax/ adlambdaThetaClimRelax
89     COMMON /adffields_lambdaSaltClimRelax/ adlambdaSaltClimRelax
90     #ifdef ATMOSPHERIC_LOADING
91     COMMON /adffields_pload/ adpload
92     COMMON /adffields_sIceLoad/ adsIceLoad
93     #endif
94    
95     _RS adfu (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
96     _RS adfv (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
97     _RS adQnet (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
98     _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
112 heimbach 1.4
113 heimbach 1.6 #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 jmc 1.19 #endif
118 heimbach 1.17 #ifdef ALLOW_KAPGM_CONTROL
119     COMMON /ADDYNVARS_KAPGM/
120     & adkapgm
121     _RL adkapgm (1-OLx:sNx+OLx,1-OLy:sNy+OLy,Nr,nSx,nSy)
122     #endif
123 gforget 1.20 #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 gforget 1.18 #ifdef ALLOW_BOTTOMDRAG_CONTROL
129     COMMON /ADDYNVARS_BOTTOMDRAG/
130     & adbottomdragfld
131     _RL adbottomdragfld (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
132 jmc 1.19 #endif
133 gforget 1.21 #ifdef ALLOW_EDDYPSI_CONTROL
134     double precision adeddypsix(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,
135 heimbach 1.7 $nsy)
136 gforget 1.21 double precision adeddypsiy(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,
137 heimbach 1.7 $nsy)
138 gforget 1.21 common /adeddypsiffields/ adeddypsix, adeddypsiy
139 heimbach 1.7
140     #endif
141 heimbach 1.6
142 heimbach 1.5 #ifdef ALLOW_EXF
143 heimbach 1.27
144 heimbach 1.5 _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 heimbach 1.27 c
148 heimbach 1.5 _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 heimbach 1.27 c
152     _RL adwspeed(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
153     common /adexf_wspeed_r/ adwspeed
154    
155 heimbach 1.10 # ifdef ALLOW_ATM_TEMP
156 heimbach 1.5 _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 heimbach 1.27 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 heimbach 1.5 # 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 heimbach 1.10 # 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 heimbach 1.12 # 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 heimbach 1.27
187     #endif /* ALLOW_EXF */
188 heimbach 1.5
189 heimbach 1.11 #ifdef ALLOW_SEAICE
190 mlosch 1.23 _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 heimbach 1.27 # 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 heimbach 1.11
204 gforget 1.25 #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 heimbach 1.15 #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 jmc 1.19 common /adgrid_r/ adr_low_control,
220 heimbach 1.15 & 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 heimbach 1.4 #endif /* ALLOW_AUTODIFF_MONITOR */

  ViewVC Help
Powered by ViewVC 1.1.22