/[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.24 - (hide annotations) (download)
Mon Aug 9 16:05:22 2010 UTC (13 years, 9 months ago) by gforget
Branch: MAIN
CVS Tags: checkpoint62k, checkpoint62j, checkpoint62n, checkpoint62m, checkpoint62l
Changes since 1.23: +16 -5 lines
File MIME type: text/plain
Storage directives allowing the use of
Adam-Bashforth-3 time stepping in adjoint.

1 gforget 1.24 C $Header: /u/gcmpack/MITgcm/pkg/autodiff/adcommon.h,v 1.23 2009/10/22 12:35:51 mlosch 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.11 #ifdef ALLOW_SEAICE
20     # include "SEAICE_OPTIONS.h"
21     #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.5 #ifdef ALLOW_CD_CODE
61 jmc 1.19 common /addynvars_cd/
62 heimbach 1.1 & aduveld, advveld,
63 jmc 1.19 & adetanm1,
64 heimbach 1.8 & adunm1, advnm1
65 heimbach 1.1 _RL aduveld(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
66     _RL advveld(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
67 heimbach 1.3 _RL adetanm1(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
68 heimbach 1.1 _RL adunm1(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
69     _RL advnm1(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,nsy)
70 heimbach 1.5 #endif
71 heimbach 1.3
72 heimbach 1.16 COMMON /adffields_fu/ adfu
73     COMMON /adffields_fv/ adfv
74     COMMON /adffields_Qnet/ adQnet
75     COMMON /adffields_Qsw/ adQsw
76     COMMON /adffields_dQdT/ addQdT
77     COMMON /adffields_EmPmR/ adEmPmR
78     COMMON /adffields_saltFlux/ adsaltFlux
79     COMMON /adffields_SST/ adSST
80     COMMON /adffields_SSS/ adSSS
81     COMMON /adffields_lambdaThetaClimRelax/ adlambdaThetaClimRelax
82     COMMON /adffields_lambdaSaltClimRelax/ adlambdaSaltClimRelax
83     #ifdef ATMOSPHERIC_LOADING
84     COMMON /adffields_pload/ adpload
85     COMMON /adffields_sIceLoad/ adsIceLoad
86     #endif
87    
88     _RS adfu (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
89     _RS adfv (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
90     _RS adQnet (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
91     _RS adQsw (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
92     _RS addQdT (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
93     _RS adEmPmR (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
94     _RS adsaltFlux (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
95     _RS adSST (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
96     _RS adSSS (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
97     _RS adlambdaThetaClimRelax
98     & (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
99     _RS adlambdaSaltClimRelax
100     & (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
101     #ifdef ATMOSPHERIC_LOADING
102     _RS adpload (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
103     _RS adsIceLoad (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
104     #endif
105 heimbach 1.4
106 heimbach 1.6 #ifdef ALLOW_DIFFKR_CONTROL
107     COMMON /ADDYNVARS_DIFFKR/
108     & addiffKr
109     _RL addiffKr (1-OLx:sNx+OLx,1-OLy:sNy+OLy,Nr,nSx,nSy)
110 jmc 1.19 #endif
111 heimbach 1.17 #ifdef ALLOW_KAPGM_CONTROL
112     COMMON /ADDYNVARS_KAPGM/
113     & adkapgm
114     _RL adkapgm (1-OLx:sNx+OLx,1-OLy:sNy+OLy,Nr,nSx,nSy)
115     #endif
116 gforget 1.20 #ifdef ALLOW_KAPREDI_CONTROL
117     COMMON /ADDYNVARS_KAPREDI/
118     & adkapredi
119     _RL adkapredi (1-OLx:sNx+OLx,1-OLy:sNy+OLy,Nr,nSx,nSy)
120     #endif
121 gforget 1.18 #ifdef ALLOW_BOTTOMDRAG_CONTROL
122     COMMON /ADDYNVARS_BOTTOMDRAG/
123     & adbottomdragfld
124     _RL adbottomdragfld (1-OLx:sNx+OLx,1-OLy:sNy+OLy,nSx,nSy)
125 jmc 1.19 #endif
126 gforget 1.21 #ifdef ALLOW_EDDYPSI_CONTROL
127     double precision adeddypsix(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,
128 heimbach 1.7 $nsy)
129 gforget 1.21 double precision adeddypsiy(1-olx:snx+olx,1-oly:sny+oly,nr,nsx,
130 heimbach 1.7 $nsy)
131 gforget 1.21 common /adeddypsiffields/ adeddypsix, adeddypsiy
132 heimbach 1.7
133     #endif
134 heimbach 1.6
135 heimbach 1.5 #ifdef ALLOW_EXF
136     _RL adhflux(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
137     _RL adsflux(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
138     common /adexf_hsflux_r/ adhflux, adsflux
139     _RL adustress(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
140     _RL advstress(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
141     common /adexf_stress_r/ adustress, advstress
142 heimbach 1.10 # ifdef ALLOW_ATM_TEMP
143 heimbach 1.5 _RL adatemp (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
144     _RL adaqh (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
145     _RL adlwflux (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
146     _RL adprecip (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
147     common /adexf_atm_temp_r/ adatemp, adaqh, adlwflux, adprecip
148     # endif
149     # ifdef ALLOW_ATM_WIND
150     _RL aduwind (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
151     _RL advwind (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
152     common /adexf_atm_wind_r/ aduwind, advwind
153     # endif
154 heimbach 1.10 # ifdef ALLOW_DOWNWARD_RADIATION
155     _RL adswdown (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
156     _RL adlwdown (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
157     common /adexf_rad_down_r/
158     & adswdown, adlwdown
159     # endif
160 heimbach 1.12 # ifdef ALLOW_CLIMSST_RELAXATION
161     _RL adclimsst(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
162     common /adexf_clim_sst_r/ adclimsst
163     # endif
164     # ifdef ALLOW_CLIMSSS_RELAXATION
165     _RL adclimsss(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
166     common /adexf_clim_sss_r/ adclimsss
167     # endif
168 heimbach 1.5 #endif
169    
170 heimbach 1.11 #ifdef ALLOW_SEAICE
171 mlosch 1.23 _RL adarea (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
172     _RL adheff (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
173     _RL adhsnow (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
174     _RL aduice (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
175     _RL advice (1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
176     common /adseaice_dynvars_1/
177     & adarea, adheff, adhsnow, aduice, advice
178 heimbach 1.11 #endif
179    
180 heimbach 1.15 #ifdef ALLOW_DEPTH_CONTROL
181     _RL adr_low_control(1-olx:snx+olx,1-oly:sny+oly,nsx,nsy)
182     _RL adhfacc(1-olx:snx+olx,1-oly:sny+oly,1:nr,nsx,nsy)
183     _RL adhfacs(1-olx:snx+olx,1-oly:sny+oly,1:nr,nsx,nsy)
184     _RL adhfacw(1-olx:snx+olx,1-oly:sny+oly,1:nr,nsx,nsy)
185     _RL adrecip_hfacc(1-olx:snx+olx,1-oly:sny+oly,1:nr,nsx,nsy)
186     _RL adrecip_hfacs(1-olx:snx+olx,1-oly:sny+oly,1:nr,nsx,nsy)
187     _RL adrecip_hfacw(1-olx:snx+olx,1-oly:sny+oly,1:nr,nsx,nsy)
188 jmc 1.19 common /adgrid_r/ adr_low_control,
189 heimbach 1.15 & adrecip_hfacc, adrecip_hfacw, adrecip_hfacs
190     common /adgrid_r_c/ adhfacc
191     common /adgrid_r_s/ adhfacs
192     common /adgrid_r_w/ adhfacw
193     #endif /* ALLOW_DEPTH_CONTROL */
194    
195 heimbach 1.4 #endif /* ALLOW_AUTODIFF_MONITOR */

  ViewVC Help
Powered by ViewVC 1.1.22