source: trunk/NEMOGCM/NEMO/TOP_SRC/PISCES/SED/sedchem.F90 @ 4528

Last change on this file since 4528 was 3443, checked in by cetlod, 9 years ago

branch:2012/dev_r3438_LOCEAN15_PISLOB : 1st step of the merge, see ticket #972

File size: 22.8 KB
Line 
1MODULE sedchem
2
3#if defined key_sed 
4   !!======================================================================
5   !!                        ***  Module sedchem  ***
6   !! sediment :   Variable for chemistry of the CO2 cycle
7   !!======================================================================
8   !!   modules used
9   USE sed     ! sediment global variable
10   USE sedarr
11
12   !! * Accessibility
13   PUBLIC sed_chem   
14
15   !! * Module variables
16   REAL(wp) :: &
17      salchl = 1./1.80655 , & ! conversion factor for salinity --> chlorinity (Wooster et al. 1969)
18      calcon = 1.03E-2        ! mean calcite concentration [Ca2+] in sea water [mole/kg solution]
19
20   REAL(wp) :: &              ! coeff. for 1. dissoc. of carbonic acid (Millero, 1995)   
21      c10 = 3670.7   , &
22      c11 = 62.008   , &
23      c12 = 9.7944   , &
24      c13 = 0.0118   , &
25      c14 = 0.000116
26
27   REAL(wp) :: &              ! coeff. for 2. dissoc. of carbonic acid (Millero, 1995)   
28      c20 = 1394.7   , &
29      c21 = 4.777    , &
30      c22 = 0.       , &
31      c23 = 0.0184   , &
32      c24 = 0.000118
33
34   REAL(wp) :: &              ! coeff. for 1. dissoc. of boric acid (Dickson and Goyet, 1994)
35      cb0  = -8966.90, &
36      cb1  = -2890.53, &
37      cb2  = -77.942 , &
38      cb3  = 1.728   , &
39      cb4  = -0.0996 , &
40      cb5  = 148.0248, &
41      cb6  = 137.1942, &
42      cb7  = 1.62142 , &
43      cb8  = -24.4344, &
44      cb9  = -25.085 , &
45      cb10 = -0.2474 , &
46      cb11 = 0.053105
47
48   REAL(wp) :: &             ! borat constants
49      bor1 = 0.000232, &
50      bor2 = 1./10.811
51
52   REAL(wp) :: &             ! constants for calculate concentrations
53      st1  = 0.14     , &    ! for sulfate (Morris & Riley 1966)
54      st2  = 1./96.062, &
55      ks0  = 141.328  , &
56      ks1  = -4276.1  , &
57      ks2  = -23.093  , &
58      ks3  = -13856.  , &
59      ks4  = 324.57   , &
60      ks5  = -47.986  , &
61      ks6  = 35474.   , &
62      ks7  = -771.54  , &
63      ks8  = 114.723  , &
64      ks9  = -2698.   , &
65      ks10 = 1776.    , &
66      ks11 = 1.       , &
67      ks12 = -0.001005 
68
69   REAL(wp) :: &             ! constants for calculate concentrations
70      ft1  = 0.000067   , &  ! fluorides (Dickson & Riley 1979 )
71      ft2  = 1./18.9984 , &
72      kf0  = -12.641    , &
73      kf1  = 1590.2     , &
74      kf2  = 1.525      , &
75      kf3  = 1.0        , &
76      kf4  =-0.001005
77
78   REAL(wp) :: &             ! coeff. for dissoc. of water (Dickson and Riley, 1979 )
79      cw0 = -13847.26  , &
80      cw1 = 148.9802   , &
81      cw2 = -23.6521   , &
82      cw3 = 118.67     , &
83      cw4 = -5.977     , &
84      cw5 = 1.0495     , &
85      cw6 = -0.01615
86 
87   REAL(wp) :: &             ! coeff. for dissoc. of phosphate (Millero (1974)
88      cp10 = 115.54    , &
89      cp11 = -4576.752 , &
90      cp12 = -18.453   , &
91      cp13 = -106.736  , &
92      cp14 = 0.69171   , &
93      cp15 = -0.65643  , &
94      cp16 = -0.01844  , &
95      cp20 = 172.1033  , &
96      cp21 = -8814.715 , &
97      cp22 = -27.927   , &
98      cp23 = -160.340  , &
99      cp24 = 1.3566    , &
100      cp25 = 0.37335   , &
101      cp26 = -0.05778  , &
102      cp30 = -18.126   , &
103      cp31 = -3070.75  , &
104      cp32 = 17.27039  , &
105      cp33 = 2.81197   , &
106      cp34 = -44.99486 , &
107      cp35 = -0.09984
108
109   REAL(wp) :: &             ! coeff. for dissoc. of silicates (Millero (1974) 
110      cs10 = 117.40    , & 
111      cs11 = -8904.2   , & 
112      cs12 = -19.334   , & 
113      cs13 = -458.79   , & 
114      cs14 = 3.5913    , & 
115      cs15 = 188.74    , & 
116      cs16 = -1.5998   , & 
117      cs17 = -12.1652  , & 
118      cs18 = 0.07871   , & 
119      cs19 = 0.        , & 
120      cs20 = 1.        , & 
121      cs21 = -0.001005
122
123   REAL(wp) :: &            ! coeff. for apparent solubility equilibrium
124      ! akcc1 = -34.452 , & ! of calcite (Ingle,1975,  1800, eq. 6)
125      ! akcc2 = -39.866 , & 
126      ! akcc3 = 110.21  , & 
127      ! akcc4 = -7.5752E-6 
128      akcc1 = -171.9065 , &    ! Millero et al. 1995 from Mucci 1983
129      akcc2 = -0.077993 , & 
130      akcc3 = 2839.319  , & 
131      akcc4 = 71.595    , & 
132      akcc5 = -0.77712  , & 
133      akcc6 = 0.0028426 , & 
134      akcc7 = 178.34    , & 
135      akcc8 = -0.07711  , & 
136      akcc9 = 0.0041249
137
138   REAL(wp) :: &                 ! universal gas constant
139      rgas = 83.145              ! bar.cm3/(mol.K) or R=8.31451 J/(g.mol.K)
140
141
142   ! coeff. for seawater pressure correction (millero 95)     
143   REAL(wp), DIMENSION(8)  :: & 
144      devk1, devk2, devk3, devk4, devk5
145
146   DATA devk1/ -25.5   , -15.82    , -29.48  , -25.60    , -48.76    , -14.51   , -23.12   , -26.57   /   
147   DATA devk2/ 0.1271  , -0.0219   , 0.1622  , 0.2324    , -0.5304   , 0.1211   ,  0.1758  , 0.2020   /   
148   DATA devk3/ 0.      , 0.        , 2.608E-3, -3.6246E-3, 0.        , -0.321E-3, -2.647E-3, -3.042E-3/   
149   DATA devk4/-3.08E-3 , 1.13E-3   , -2.84E-3, -5.13E-3  , -11.76E-3 , -2.67E-3 , -5.15E-3 , -4.08E-3 /   
150   DATA devk5/0.0877E-3, -0.1475E-3, 0.      , 0.0794E-3 , -0.3692E-3, 0.0427E-3,  0.09E-3 , 0.0714E-3/
151
152
153   ! coeff. for density of sea water (Millero & Poisson 1981)
154   REAL(wp), DIMENSION(5)  :: Adsw                       
155   DATA Adsw/8.24493E-1, -4.0899E-3, 7.6438E-5 , -8.246E-7, 5.3875E-9 /
156
157   REAL(wp), DIMENSION(3)  :: Bdsw 
158   DATA Bdsw / -5.72466E-3, 1.0227E-4, -1.6546E-6 /
159
160   REAL(wp)  :: Cdsw = 4.8314E-4
161
162   REAL(wp), DIMENSION(6)  :: Ddsw                   
163   DATA Ddsw / 999.842594 , 6.793952E-2 , -9.095290E-3, 1.001685E-4, -1.120083E-6, 6.536332E-9/
164
165CONTAINS
166
167   SUBROUTINE sed_chem( kt )
168      !!----------------------------------------------------------------------
169      !!                   ***  ROUTINE sed_chem  ***
170      !!
171      !! ** Purpose :   set chemical constants
172      !!
173      !!   History :
174      !!        !  04-10  (N. Emprin, M. Gehlen )  Original code
175      !!        !  06-04  (C. Ethe)  Re-organization
176      !!----------------------------------------------------------------------
177      !!* Arguments
178      INTEGER, INTENT(in) :: kt                     ! time step
179
180#if ! defined key_sed_off
181      INTEGER  :: ji, jj, ikt
182      REAL(wp) :: ztkel, ztc, ztc2, zpres, ztr 
183      REAL(wp) :: zsal, zsal2, zsqrt, zsal15 
184      REAL(wp) :: zis, zis2, zisqrt         
185      REAL(wp) :: zdens0, zaw, zbw, zcw   
186      REAL(wp) :: zbuf1, zbuf2 
187      REAL(wp) :: zcpexp, zcpexp2
188      REAL(wp) :: zck1p, zck2p, zck3p, zcksi   
189      REAL(wp), ALLOCATABLE, DIMENSION(:,:,:) ::   zchem_data
190
191#endif
192      !!----------------------------------------------------------------------
193
194      IF( MOD( kt - 1, nfreq ) /= 0 ) RETURN
195
196      WRITE(numsed,*) ' Getting Chemical constants from tracer model at time kt = ', kt
197      WRITE(numsed,*) ' '
198
199
200#if defined key_sed_off
201      CALL sed_chem_off
202#else
203      ! reading variables
204      ALLOCATE( zchem_data(jpi,jpj,6) )   ;   zchem_data(:,:,:) = 0.
205
206      DO jj = 1,jpj
207         DO ji = 1, jpi
208            ikt = mbkt(ji,jj) 
209            IF ( tmask(ji,jj,ikt) == 1 ) THEN
210               zchem_data(ji,jj,1) = ak13 (ji,jj,ikt)
211               zchem_data(ji,jj,2) = ak23 (ji,jj,ikt)
212               zchem_data(ji,jj,3) = akb3 (ji,jj,ikt)
213               zchem_data(ji,jj,4) = akw3 (ji,jj,ikt)
214               zchem_data(ji,jj,5) = aksp (ji,jj,ikt)
215               zchem_data(ji,jj,6) = borat(ji,jj,ikt)
216            ENDIF
217         ENDDO
218      ENDDO
219
220      CALL pack_arr ( jpoce, ak1s  (1:jpoce), zchem_data(1:jpi,1:jpj,1), iarroce(1:jpoce) )
221      CALL pack_arr ( jpoce, ak2s  (1:jpoce), zchem_data(1:jpi,1:jpj,2), iarroce(1:jpoce) )
222      CALL pack_arr ( jpoce, akbs  (1:jpoce), zchem_data(1:jpi,1:jpj,3), iarroce(1:jpoce) )
223      CALL pack_arr ( jpoce, akws  (1:jpoce), zchem_data(1:jpi,1:jpj,4), iarroce(1:jpoce) )
224      CALL pack_arr ( jpoce, aksps (1:jpoce), zchem_data(1:jpi,1:jpj,5), iarroce(1:jpoce) )
225      CALL pack_arr ( jpoce, borats(1:jpoce), zchem_data(1:jpi,1:jpj,6), iarroce(1:jpoce) )
226
227      DEALLOCATE( zchem_data )
228
229      DO ji = 1, jpoce
230         ztkel   = temp(ji) + 273.16
231         ztc     = temp(ji)
232         ztc2    = ztc * ztc
233         zpres   = press(ji)
234         ! zqtt    = ztkel * 0.01
235         zsal    = salt(ji)
236         zsal2   = zsal * zsal 
237         zsqrt   = SQRT( zsal )
238         zsal15  = zsqrt * zsal
239         zlogt   = LOG( ztkel )
240         ztr     = 1./ ztkel
241         ! zis=ionic strength (ORNL/CDIAC-74, DOE 94,Dickson and Goyet)
242         zis     = 19.924 * zsal / ( 1000. - 1.005 * zsal )
243         zis2    = zis * zis
244         zisqrt  = SQRT( zis )
245
246         ! Density of Sea Water - F(temp,sal) [kg/m3]
247         zdens0 =  Ddsw(1) + Ddsw(2) * ztc + Ddsw(3) * ztc2 &
248                  + Ddsw(4) * ztc * ztc2 + Ddsw(5) * ztc2 * ztc2 &
249                  + Ddsw(6) * ztc * ztc2 * ztc2
250         zaw =  Adsw(1) + Adsw(2) * ztc + Adsw(3)* ztc2 + Adsw(4) * ztc * ztc2 &
251              + Adsw(5) * ztc2 * ztc2
252         zbw =  Bdsw(1) + Bdsw(2) * ztc + Bdsw(3) * ztc2
253         zcw =  Cdsw
254         densSW(ji) = zdens0 + zaw * zsal + zbw * zsal15 + zcw * zsal * zsal
255         densSW(ji) = densSW(ji) * 1E-3   ! to get dens in [kg/l]
256
257         ! FORMULA FOR CPEXP AFTER EDMOND AND GIESKES (1970)
258         ! (REFERENCE TO CULBERSON AND PYTKOQICZ (1968) AS MADE IN BROECKER ET AL. (1982)
259         ! IS INCORRECT; HERE RGAS IS TAKEN TENFOLD TO CORRECT FOR THE NOTATION OF pres  IN
260         ! DBAR INSTEAD OF BAR AND THE EXPRESSION FOR CPEXP IS MULTIPLIED BY LN(10.)
261         ! TO ALLOW USE OF EXP-FUNCTION WITH BASIS E IN THE FORMULA FOR AKSPP
262         ! (CF. EDMOND AND GIESKES (1970), P. 1285 AND P. 1286 (THE SMALL FORMULA ON P. 1286
263         ! IS RIGHT AND CONSISTENT WITH THE SIGN IN PARTIAL MOLAR VOLUME CHANGE AS SHOWN ON P. 1285)
264         !-----------------------------------------------------------------------------------------
265         zcpexp  = zpres / ( rgas*ztkel )
266         zcpexp2 = zpres * zcpexp
267
268         ! For Phodphates (phosphoric acid) (DOE 1994)
269         !----------------------------------------------
270         zck1p = cp10 + cp11*ztr + cp12*zlogt + ( cp13*ztr + cp14 ) * zsqrt &
271            &      + ( cp15*ztr + cp16 ) * zsal
272         zck2p = cp20 + cp21*ztr + cp22*zlogt + ( cp23*ztr + cp24 ) * zsqrt &
273            &      + ( cp25*ztr + cp26 ) * zsal
274         zck3p = cp30 + cp31*ztr + ( cp32*ztr + cp33 ) *  zsqrt &
275            &      + ( cp34*ztr + cp35 ) * zsal
276
277         ! For silicates (DOE 1994) change to mol/kg soln) (OCMIP)
278         !--------------------------------------------------------
279         zcksi = cs10 + cs11*ztr + cs12*zlogt + ( cs13*ztr + cs14) * zisqrt &
280            &      + ( cs15*ztr + cs16 ) * zis &
281            &      + ( cs17*ztr + cs18 ) * zis2 &
282            &      + LOG( 1. + cs19*zsal ) + LOG( cs20 + cs21*zsal )
283
284
285         !K1, K2 of carbonic acid, KB of boric acid, KW (H2O)
286         !---------------------------------------------------
287         zak1p  = EXP ( zck1p  )
288         zak2p  = EXP ( zck2p  )
289         zak3p  = EXP ( zck3p  )
290         zaksil = EXP ( zcksi  )
291
292         zbuf1       = - ( devk1(3) + devk2(3)*ztc + devk3(3)*ztc2 )
293         zbuf2       = 0.5 * ( devk4(3) + devk5(3)*ztc )
294         aksis(ji)     = zaksil * EXP( zbuf1*zcpexp + zbuf2*zcpexp2 )
295
296         zbuf1       = - ( devk1(6) + devk2(6)*ztc + devk3(6)*ztc2 )
297         zbuf2       = 0.5 * ( devk4(6) + devk5(6)*ztc )
298         ak1ps(ji)   = zak1p * EXP( zbuf1*zcpexp + zbuf2*zcpexp2 )
299 
300         zbuf1       = - ( devk1(7) + devk2(7)*ztc + devk3(7)*ztc2 )
301         zbuf2       = 0.5 * ( devk4(7) + devk5(7)*ztc )
302         ak2ps(ji)   = zak2p * EXP( zbuf1*zcpexp + zbuf2*zcpexp2 )
303
304         zbuf1       = - ( devk1(8) + devk2(8)*ztc + devk3(8)*ztc2 )
305         zbuf2       = 0.5 * ( devk4(8) + devk5(8)*ztc )
306         ak3ps(ji)   = zak3p * EXP( zbuf1*zcpexp + zbuf2*zcpexp2 )
307
308         ak12s  (ji) = ak1s (ji) * ak2s (ji)
309         ak12ps (ji) = ak1ps(ji) * ak2ps(ji)
310         ak123ps(ji) = ak1ps(ji) * ak2ps(ji) * ak3ps(ji)
311
312         calcon2(ji) = 0.01028 * ( salt(ji) / 35. ) * densSW(ji)
313      ENDDO
314
315       
316#endif
317
318   END SUBROUTINE sed_chem
319
320#if defined key_sed_off
321
322   SUBROUTINE sed_chem_off
323      !!----------------------------------------------------------------------
324      !!                   ***  ROUTINE sed_chem_off  ***
325      !!                   
326      !! ** Purpose :   compute chemical constants
327      !!
328      !!   History :
329      !!        !  04-10  (N. Emprin, M. Gehlen )  Original code
330      !!        !  06-04  (C. Ethe)  Re-organization
331      !!---------------------------------------------------------------------- 
332      !! * Local declarations
333      INTEGER :: ji
334
335      REAL(wp) ::  ztkel, ztc, ztc2, zpres, ztr 
336      REAL(wp) ::  zsal, zsal2, zsqrt, zsal15   
337      REAL(wp) ::  zis, zis2, zisqrt           
338      REAL(wp) ::  zdens0, zaw, zbw, zcw       
339      REAL(wp) ::  zchl, zst, zft, zbuf1, zbuf2 
340      REAL(wp) ::  zcpexp, zcpexp2             
341      REAL(wp) ::  zckb, zck1, zck2, zckw       
342      REAL(wp) ::  zck1p, zck2p, zck3p, zcksi   
343      REAL(wp) ::  zak1, zak2, zakb, zakw             
344      REAL(wp) ::  zaksp0, zksp, zks, zkf 
345
346
347      ! CHEMICAL CONSTANTS - DEEP OCEAN
348      !-------------------------------------
349      ! [chem constants]=mol/kg solution (or (mol/kg sol)2 for akws and aksp)
350
351      DO ji = 1, jpoce
352         ztkel   = temp(ji) + 273.16
353         ztc     = temp(ji)
354         ztc2    = ztc * ztc
355         zpres   = press(ji)
356         ! zqtt    = ztkel * 0.01
357         zsal    = salt(ji)
358         zsal2   = zsal * zsal 
359         zsqrt   = SQRT( zsal )
360         zsal15  = zsqrt * zsal
361         zlogt   = LOG( ztkel )
362         ztr     = 1./ ztkel
363         ! zis=ionic strength (ORNL/CDIAC-74, DOE 94,Dickson and Goyet)
364         zis     = 19.924 * zsal / ( 1000. - 1.005 * zsal )
365         zis2    = zis * zis
366         zisqrt  = SQRT( zis )
367
368
369         ! Density of Sea Water - F(temp,sal) [kg/m3]
370         zdens0 =  Ddsw(1) + Ddsw(2) * ztc + Ddsw(3) * ztc2 &
371                  + Ddsw(4) * ztc * ztc2 + Ddsw(5) * ztc2 * ztc2 &
372                  + Ddsw(6) * ztc * ztc2 * ztc2
373         zaw =  Adsw(1) + Adsw(2) * ztc + Adsw(3)* ztc2 + Adsw(4) * ztc * ztc2 &
374              + Adsw(5) * ztc2 * ztc2
375         zbw =  Bdsw(1) + Bdsw(2) * ztc + Bdsw(3) * ztc2
376         zcw =  Cdsw
377         densSW(ji) = zdens0 + zaw * zsal + zbw * zsal15 + zcw * zsal * zsal
378         densSW(ji) = densSW(ji) * 1E-3   ! to get dens in [kg/l]
379
380
381         ! FORMULA FOR CPEXP AFTER EDMOND AND GIESKES (1970)
382         ! (REFERENCE TO CULBERSON AND PYTKOQICZ (1968) AS MADE IN BROECKER ET AL. (1982)
383         ! IS INCORRECT; HERE RGAS IS TAKEN TENFOLD TO CORRECT FOR THE NOTATION OF pres  IN
384         ! DBAR INSTEAD OF BAR AND THE EXPRESSION FOR CPEXP IS MULTIPLIED BY LN(10.)
385         ! TO ALLOW USE OF EXP-FUNCTION WITH BASIS E IN THE FORMULA FOR AKSPP
386         ! (CF. EDMOND AND GIESKES (1970), P. 1285 AND P. 1286 (THE SMALL FORMULA ON P. 1286
387         ! IS RIGHT AND CONSISTENT WITH THE SIGN IN PARTIAL MOLAR VOLUME CHANGE AS SHOWN ON P. 1285)
388         !-----------------------------------------------------------------------------------------
389         zcpexp  = zpres / ( rgas*ztkel )
390         zcpexp2 = zpres * zcpexp
391
392
393         ! chlorinity (WOOSTER ET AL., 1969)
394         !---------------------------------------
395         zchl = zsal * salchl
396
397         ! total sulfate concentration [mol/kg soln]
398         ! --------------------------------------
399         zst = st1 * zchl * st2
400
401         ! total fluoride concentration [mol/kg soln]
402         ! --------------------------------------
403         zft = ft1 * zchl * ft2
404
405         ! dissociation constant for carbonate (Mehrback 74 - Dickson & Millero 87)
406         !---------------------------------------------------------------------------
407         zck1 = c10*ztr - c11 + c12*zlogt - c13*zsal + c14*zsal2
408         zck2 = c20*ztr + c21 - c22*zlogt - c23*zsal + c24*zsal2
409
410         ! dissociation constant for sulfates (Dickson 1990)
411         !--------------------------------------------------
412         zks = EXP(  ks0 + ks1*ztr + ks2*zlogt &
413            &    + ( ks3*ztr + ks4 + ks5*zlogt ) * zisqrt &
414            &    + ( ks6*ztr + ks7 + ks8*zlogt ) * zis    &
415            &    +   ks9*ztr*zis*zisqrt + ks10*ztr*zis2   &
416            &    +   LOG( ks11 + ks12*zsal ) )
417
418         ! dissociation constant for fluorides (Dickson and Riley 79)
419         !--------------------------------------------------
420         zkf = EXP( kf0 + kf1*ztr + kf2*zisqrt + LOG( kf3 + kf4*zsal ) )
421
422         ! dissociation constant for borates (Doe 94)
423         !--------------------------------------------------
424         zckb = (  cb0 + cb1*zsqrt + cb2*zsal + cb3*zsal15 + cb4*zsal2) * ztr &
425            &  + ( cb5 + cb6*zsqrt + cb7*zsal) &
426            &  + ( cb8 + cb9*zsqrt + cb10*zsal) * zlogt &
427            &  +   cb11*zsqrt*ztkel + LOG( ( 1. + zst/zks + zft/zkf ) / ( 1. + zst/zks ) ) 
428
429         ! PKW (H2O) (DICKSON AND RILEY, 1979)
430         !--------------------------------------
431         zckw =   cw0*ztr + cw1 + cw2*zlogt &
432            & +( cw3*ztr + cw4 + cw5*zlogt )* zsqrt + cw6*zsal
433         
434         ! For Phodphates (phosphoric acid) (DOE 1994)
435         !----------------------------------------------
436         zck1p = cp10 + cp11*ztr + cp12*zlogt + ( cp13*ztr + cp14 ) * zsqrt &
437            &      + ( cp15*ztr + cp16 ) * zsal
438         zck2p = cp20 + cp21*ztr + cp22*zlogt + ( cp23*ztr + cp24 ) * zsqrt &
439            &      + ( cp25*ztr + cp26 ) * zsal
440         zck3p = cp30 + cp31*ztr + ( cp32*ztr + cp33 ) *  zsqrt &
441            &      + ( cp34*ztr + cp35 ) * zsal
442
443         ! For silicates (DOE 1994) change to mol/kg soln) (OCMIP)
444         !--------------------------------------------------------
445         zcksi = cs10 + cs11*ztr + cs12*zlogt + ( cs13*ztr + cs14) * zisqrt &
446            &      + ( cs15*ztr + cs16 ) * zis &
447            &      + ( cs17*ztr + cs18 ) * zis2 &
448            &      + LOG( 1. + cs19*zsal ) + LOG( cs20 + cs21*zsal )
449
450         ! apparent solublity product K'SP of calcite in seawater
451         ! (S=27-43, T=2-25 DEG C) AT pres =0 (INGLE, 1975, EQ. 6)
452         ! prob: olivier a log = ln et C. Heize a LOG10(sal)
453         ! aksp0 = 1.E-7*(akcc1+akcc2*sal**(1./3.)+akcc3*log(sal)+akcc4*tkel*tkel)
454         ! aksp0 = 1.E-7*(akcc1+akcc2*sal**(1./3.)+akcc3*log10(sal)+akcc4*tkel*tkel)
455         !--------------------------------------------------------------------
456         zaksp0 = akcc1 + akcc2*ztkel + akcc3*ztr + akcc4 * LOG10(ztkel) &
457            &  + ( akcc5 + akcc6*ztkel+ akcc7*ztr ) * zsqrt &
458            &  +  akcc8*zsal + akcc9*zsal15
459
460         !K1, K2 of carbonic acid, KB of boric acid, KW (H2O)
461         !---------------------------------------------------
462         zak1   = 10**( -zck1  )
463         zak2   = 10**( -zck2  )
464         zakb   = EXP ( zckb   ) 
465         zakw   = EXP ( zckw   )
466         zksp   = 10**( zaksp0 )
467
468
469
470         ! KB of boric acid, K1,K2 of carbonic acid pressure correction
471         ! after Culberson and  AND Pytkowicz (1968) (CF. BROECKER ET AL., 1982) Millero 95
472         !--------------------------------------------------------------------------------
473         zbuf1       = - ( devk1(1) + devk2(1)*ztc + devk3(1)*ztc2 )
474         zbuf2       = 0.5 * ( devk4(1) + devk5(1)*ztc )
475         ak1s(ji)    = zak1 * EXP( zbuf1*zcpexp + zbuf2*zcpexp2 )
476
477         zbuf1       = -( devk1(2) + devk2(2)*ztc + devk3(2)*ztc2 )
478         zbuf2       = 0.5 * ( devk4(2) + devk5(2)*ztc )
479         ak2s(ji)    = zak2 * EXP( zbuf1*zcpexp + zbuf2*zcpexp2 )
480
481         zbuf1       = - ( devk1(3) + devk2(3)*ztc + devk3(3)*ztc2 )
482         zbuf2       = 0.5 * ( devk4(3) + devk5(3) * ztc )
483         akbs(ji)    = zakb * EXP( zbuf1*zcpexp + zbuf2*zcpexp2 )
484
485         zbuf1       = - ( devk1(4) + devk2(4)*ztc + devk3(4)*ztc2 )
486         zbuf2       = 0.5 * ( devk4(4) + devk5(4)*ztc )
487         akws(ji)    = zakw * EXP( zbuf1*zcpexp + zbuf2*zcpexp2 )
488
489
490         ! APPARENT SOLUBILITY PRODUCT K''SP OF CALCITE (OR ARAGONITE)
491         ! AS FUNCTION OF PRESSURE FOLLWING EDMOND AND GIESKES (1970)
492         ! (P. 1285) AND BERNER (1976)
493         !-----------------------------------------------------------------
494         ! aksp(ji) = aksp0*exp(zcpexp*(devks-devkst*tc))
495         ! or following Mucci
496         zbuf1      = - ( devk1(5) + devk2(5)*ztc + devk3(5)*ztc2 )
497         zbuf2      = 0.5 *( devk4(5) + devk5(5)*ztc )
498         aksps(ji)   = zksp * EXP( zbuf1*zcpexp + zbuf2*zcpexp2 )
499
500         ! For Phodphates (phosphoric acid) (DOE 1994)
501         !----------------------------------------------
502         zck1p = cp10 + cp11*ztr + cp12*zlogt + ( cp13*ztr + cp14 ) * zsqrt &
503            &      + ( cp15*ztr + cp16 ) * zsal
504         zck2p = cp20 + cp21*ztr + cp22*zlogt + ( cp23*ztr + cp24 ) * zsqrt &
505            &      + ( cp25*ztr + cp26 ) * zsal
506         zck3p = cp30 + cp31*ztr + ( cp32*ztr + cp33 ) *  zsqrt &
507            &      + ( cp34*ztr + cp35 ) * zsal
508
509         ! For silicates (DOE 1994) change to mol/kg soln) (OCMIP)
510         !--------------------------------------------------------
511         zcksi = cs10 + cs11*ztr + cs12*zlogt + ( cs13*ztr + cs14) * zisqrt &
512            &      + ( cs15*ztr + cs16 ) * zis &
513            &      + ( cs17*ztr + cs18 ) * zis2 &
514            &      + LOG( 1. + cs19*zsal ) + LOG( cs20 + cs21*zsal )
515
516
517         !K1, K2 of carbonic acid, KB of boric acid, KW (H2O)
518         !---------------------------------------------------
519         zak1p  = EXP ( zck1p  )
520         zak2p  = EXP ( zck2p  )
521         zak3p  = EXP ( zck3p  )
522         zaksil = EXP ( zcksi  )
523
524         zbuf1       = - ( devk1(3) + devk2(3)*ztc + devk3(3)*ztc2 )
525         zbuf2       = 0.5 * ( devk4(3) + devk5(3)*ztc )
526         aksis(ji)     = zaksil * EXP( zbuf1*zcpexp + zbuf2*zcpexp2 )
527
528         zbuf1       = - ( devk1(6) + devk2(6)*ztc + devk3(6)*ztc2 )
529         zbuf2       = 0.5 * ( devk4(6) + devk5(6)*ztc )
530         ak1ps(ji)   = zak1p * EXP( zbuf1*zcpexp + zbuf2*zcpexp2 )
531 
532         zbuf1       = - ( devk1(7) + devk2(7)*ztc + devk3(7)*ztc2 )
533         zbuf2       = 0.5 * ( devk4(7) + devk5(7)*ztc )
534         ak2ps(ji)   = zak2p * EXP( zbuf1*zcpexp + zbuf2*zcpexp2 )
535
536         zbuf1       = - ( devk1(8) + devk2(8)*ztc + devk3(8)*ztc2 )
537         zbuf2       = 0.5 * ( devk4(8) + devk5(8)*ztc )
538         ak3ps(ji)   = zak3p * EXP( zbuf1*zcpexp + zbuf2*zcpexp2 )
539
540         ! total borat concentration. [mol/l]
541         ! or from Millero 1995 [mol/l] : borat(l) = 0.000416_8*(sal/35._8)*densSW(l)
542         ! --------------------------------------------------------------------------
543         borats(ji) = bor1 * zchl * bor2 * densSW(ji)
544
545         ak12s  (ji) = ak1s (ji) * ak2s (ji)
546         ak12ps (ji) = ak1ps(ji) * ak2ps(ji)
547         ak123ps(ji) = ak1ps(ji) * ak2ps(ji) * ak3ps(ji)
548
549         calcon2(ji) = 0.01028 * ( zsal / 35. ) * densSW(ji)
550
551      ENDDO
552
553   END SUBROUTINE sed_chem_off
554
555#endif
556
557#else
558   !!======================================================================
559   !! MODULE sedchem  :   Dummy module
560   !!======================================================================
561CONTAINS
562   SUBROUTINE sed_chem( kt )         ! Empty routine
563      INTEGER, INTENT(in) :: kt
564      WRITE(*,*) 'trc_stp: You should not have seen this print! error?', kt
565   END SUBROUTINE sed_chem
566
567   !!======================================================================
568
569#endif
570
571END MODULE sedchem
Note: See TracBrowser for help on using the repository browser.