Back to home page

MITgcm

 
 

    


File indexing completed on 2024-05-23 05:10:19 UTC

view on githubraw file Latest commit 82e538d8 on 2024-05-22 17:46:03 UTC
c0d1c06c15 Matt*0001 #include "BLING_OPTIONS.h"
041f4605e9 Jean*0002 #ifdef ALLOW_EXF
                0003 # include "EXF_OPTIONS.h"
                0004 #endif
c0d1c06c15 Matt*0005 
                0006 CBOP
be72e7ae9e Jean*0007       SUBROUTINE BLING_READPARMS( myThid )
c0d1c06c15 Matt*0008 
be72e7ae9e Jean*0009 C     *========================================================*
c0d1c06c15 Matt*0010 C     | subroutine bling_readparms
                0011 C     | o Initialise and read parameters for BLING model
be72e7ae9e Jean*0012 C     *========================================================*
c0d1c06c15 Matt*0013 
e0f9a7ba0b Matt*0014       IMPLICIT NONE
c0d1c06c15 Matt*0015 
                0016 C     === Global variables ===
                0017 #include "SIZE.h"
                0018 #include "EEPARAMS.h"
                0019 #include "PARAMS.h"
e0f9a7ba0b Matt*0020 #ifdef ALLOW_EXF
041f4605e9 Jean*0021 # include "EXF_PARAM.h"
9f0da36f91 Jean*0022 # include "EXF_INTERP_SIZE.h"
                0023 # include "EXF_INTERP_PARAM.h"
e0f9a7ba0b Matt*0024 #endif /* ALLOW_EXF */
c0d1c06c15 Matt*0025 #include "BLING_VARS.h"
                0026 
                0027 C     === Routine arguments ===
                0028 C     myThid    :: My Thread Id. number
                0029       INTEGER myThid
                0030 CEOP
                0031 
                0032 #ifdef ALLOW_BLING
                0033 
                0034 C     === Local variables ===
                0035 C     msgBuf    :: Informational/error message buffer
530382a175 Jean*0036 C     errCount  :: error counter
c0d1c06c15 Matt*0037 C     iUnit     :: Work variable for IO unit number
                0038       CHARACTER*(MAX_LEN_MBUF) msgBuf
530382a175 Jean*0039       INTEGER errCount
c0d1c06c15 Matt*0040       INTEGER iUnit
                0041 
                0042 C ==========================================================
                0043 C   Abiotic parameters
e0f9a7ba0b Matt*0044 C  selectBTconst :: estimates borate concentration from salinity
                0045 C     selectBTconst=1 for the default formulation of Uppströ1974) i.e.
                0046 C     the same as S/R CARBON_COEFFS
                0047 C     selectBTconst=2 for the new formulation from Lee et al (2010)
                0048 C  selectFTconst :: estimates fluoride concentration from salinity
                0049 C     selectFTconst=1 for the default formulation of Riley (1965) i.e.
                0050 C     the same as S/R CARBON_COEFFS
                0051 C     selectFTconst=2 for the new formulation from Culkin (1965)
                0052 C  selectHFconst :: sets the first dissociation constant for hydrogen
                0053 C  fluoride:
                0054 C     selectHFconst=1 for the default  Dickson and Riley (1979) i.e. the
                0055 C     same as S/R CARBON_COEFFS
                0056 C     selectHFconst=2 for the formulation of Perez and Fraga (1987)
                0057 C  selectK1K2const :: sets the first and second dissociation constants
                0058 C  of carbonic acid:
                0059 C     selectK1K2const=1 for the default formulation of Millero (1995)
                0060 C     with data from Mehrbach et al. (1973),
                0061 C          i.e. the same as S/R CARBON_COEFFS
                0062 C     selectK1K2const=2 for the formulation of Roy et al. (1993)
                0063 C     selectK1K2const=3 for the "combination" formulation of Millero
                0064 C     (1995)
                0065 C     selectK1K2const=4 for the formulation of Luecker et al. (2000)
                0066 C     selectK1K2const=5 for the formulation of Millero (2010, Mar. Fresh
                0067 C     Wat. Res.)
                0068 C     selectK1K2const=6 for the formulation of Waters, Millero, Woosley
                0069 C     (2014, Mar. Chem.)
                0070 C  selectPHsolver  :: sets the pH solver to use
                0071 C     selectPHsolver=0 for Follows et al., (2006)
                0072 C     selectPHsolver=1 for Munhoven (2013) solvesaphe general
                0073 C     selectPHsolver=2 for Munhoven (2013) solvesaphe sec
                0074 C     selectPHsolver=3 for Munhoven (2013) solvesaphe fast
c0d1c06c15 Matt*0075 C ==========================================================
                0076 
be72e7ae9e Jean*0077       NAMELIST /ABIOTIC_PARMS/
e0f9a7ba0b Matt*0078      &                      permil,
                0079      &                      Pa2Atm,
                0080      &                      epsln
                0081 #ifdef CARBONCHEM_SOLVESAPHE
                0082      & ,selectBTconst,selectFTconst,
                0083      &  selectHFconst,selectK1K2const,
                0084      &  selectPHsolver
                0085 #endif
c0d1c06c15 Matt*0086 
                0087 C ==========================================================
                0088 C   BLING parameters
                0089 C ==========================================================
                0090 
                0091       NAMELIST /BIOTIC_PARMS/
                0092      &                     CtoN,
e0f9a7ba0b Matt*0093      &                     CtoP,
                0094      &                     NtoP,
c0d1c06c15 Matt*0095      &                     HtoC,
e0f9a7ba0b Matt*0096      &                     NO3toN,
c0d1c06c15 Matt*0097      &                     O2toN,
e0f9a7ba0b Matt*0098      &                     O2toP,
c0d1c06c15 Matt*0099      &                     CatoN,
e0f9a7ba0b Matt*0100      &                     CatoP,
c0d1c06c15 Matt*0101      &                     masstoN,
e0f9a7ba0b Matt*0102 #ifndef USE_BLING_V1
                0103      &                     Pc_0_diaz,
c0d1c06c15 Matt*0104      &                     alpha_photo,
e0f9a7ba0b Matt*0105      &                     gamma_DON,
                0106      &                     k_Fe_diaz,
                0107      &                     k_NO3,
                0108      &                     k_PtoN,
                0109      &                     k_FetoN,
                0110      &                     PtoN_min,
                0111      &                     PtoN_max,
                0112      &                     FetoN_min,
                0113      &                     FetoN_max,
                0114      &                     kappa_eppley_diaz,
                0115      &                     phi_dvm,
                0116      &                     sigma_dvm,
                0117 #ifdef USE_SIBLING
                0118      &                     k_Si,
                0119      &                     gamma_Si_0,
                0120      &                     kappa_remin_Si,
                0121      &                     wsink_Si,
00fa2d4ddd mmaz*0122      &                     SitoN_uptake_min,
                0123      &                     SitoN_uptake_max,
                0124      &                     SitoN_uptake_scale,
                0125      &                     SitoN_uptake_exp,
e0f9a7ba0b Matt*0126      &                     q_SitoN_diss,
                0127 #endif
                0128 #else
                0129      &                     alpha_max,
                0130      &                     alpha_min,
                0131      &                     gamma_biomass,
                0132      &                     k_FetoP,
                0133      &                     FetoP_max,
                0134      &                     Fe_lim_min,
                0135 #endif
                0136      &                     pivotal,
                0137      &                     Pc_0,
                0138      &                     lambda_0,
                0139      &                     resp_frac,
                0140      &                     chl_min,
c0d1c06c15 Matt*0141      &                     theta_Fe_max_hi,
                0142      &                     theta_Fe_max_lo,
                0143      &                     gamma_irr_mem,
                0144      &                     gamma_DOP,
                0145      &                     gamma_POM,
                0146      &                     k_Fe,
                0147      &                     k_O2,
                0148      &                     k_PO4,
                0149      &                     kFe_eq_lig_max,
                0150      &                     kFe_eq_lig_min,
                0151      &                     kFe_eq_lig_Femin,
be72e7ae9e Jean*0152      &                     kFe_eq_lig_irr,
c0d1c06c15 Matt*0153      &                     kFe_org,
                0154      &                     kFe_inorg,
                0155      &                     FetoC_sed,
                0156      &                     remin_min,
                0157      &                     oxic_min,
                0158      &                     ligand,
                0159      &                     kappa_eppley,
                0160      &                     kappa_remin,
                0161      &                     ca_remin_depth,
                0162      &                     phi_DOM,
                0163      &                     phi_sm,
                0164      &                     phi_lg,
                0165      &                     wsink0z,
                0166      &                     wsink0,
                0167      &                     wsinkacc,
                0168      &                     parfrac,
                0169      &                     alpfe,
                0170      &                     k0,
e0f9a7ba0b Matt*0171      &                     MLmix_max,
82e538d851 aver*0172      &                     chlsat_locTimWindow,
e0f9a7ba0b Matt*0173      &                     river_conc_po4,
                0174      &                     river_dom_to_nut
c0d1c06c15 Matt*0175 
                0176 C ==========================================================
                0177 C   BLING forcing
                0178 C ==========================================================
                0179 
                0180       NAMELIST /BLING_FORCING/
                0181      &          bling_windFile, bling_atmospFile, bling_iceFile,
54b6d6aa91 Matt*0182      &          bling_ironFile, bling_silicaFile,
                0183      &          bling_psmFile, bling_plgFile, bling_PdiazFile,
c0d1c06c15 Matt*0184      &          bling_forcingPeriod, bling_forcingCycle,
47de7c1e0e Matt*0185      &          bling_Pc_2dFile, bling_Pc_2d_diazFile,
af8f3b9ffc Matt*0186      &          bling_alpha_photo2dFile,bling_phi_DOM2dFile,
                0187      &          bling_k_Fe2dFile, bling_k_Fe_diaz2dFile,
                0188      &          bling_gamma_POM2dFile, bling_wsink0_2dFile,
e0f9a7ba0b Matt*0189      &          bling_phi_sm2dFile,bling_phi_lg2dFile,
                0190      &          bling_pCO2,
                0191      &          river_conc_po4, river_dom_to_nut
                0192 #ifdef ALLOW_EXF
                0193      &         ,apco2file, apco2startdate1, apco2startdate2,
041f4605e9 Jean*0194      &          apco2RepCycle, apco2period, apco2StartTime,
530382a175 Jean*0195      &          exf_inscal_apco2, exf_outscal_apco2, apco2const,
079948e6a6 Matt*0196      &          apco2_exfremo_intercept, apco2_exfremo_slope
                0197 #ifdef USE_EXF_INTERPOLATION
e0f9a7ba0b Matt*0198      &         ,apco2_lon0, apco2_lon_inc, apco2_lat0, apco2_lat_inc,
079948e6a6 Matt*0199      &          apco2_nlon, apco2_nlat, apco2_interpMethod
                0200 #endif /* USE_EXF_INTERPOLATION */
e0f9a7ba0b Matt*0201 #endif /* ALLOW_EXF */
c0d1c06c15 Matt*0202 
                0203 C ==========================================================
e0f9a7ba0b Matt*0204 C   secperday        :: Seconds in a day = 24*60*60
                0205 C   permil           :: Set carbon mol/m3 <---> mol/kg conversion factor
                0206 C                       Default permil = 1024.5 kg/m3
                0207 C   Pa2Atm           :: Conversion factor for atmospheric pressure from EXF
cab777d667 Matt*0208 C                       1 Atm = 1.01325e5 Pa = 1013.25 mb
e0f9a7ba0b Matt*0209 C   epsln            :: A very small number
                0210 C   CtoN             :: Carbon to nitrogen ratio in organic matter
                0211 C   CtoP             :: Carbon to phosphorus ratio in organic matter
                0212 C   NtoP             :: Nitrogen to phosphorus ratio in organic matter
                0213 C   HtoC             :: Reduced hydrogen to carbon ratio in organic matter
                0214 C   NO3toN           :: Nitrate to organic nitrogen ratio for denitrification
                0215 C   O2toN            :: Oxygen to nitrogen for biological activity
                0216 C   O2toP            :: Oxygen to phosphorus for biological activity
                0217 C   CatoN            :: Calcium to nitrogen uptake by small phyto
                0218 C   CatoP            :: Calcium to phosphorus uptake by small phyto
                0219 C   masstoN          :: Organic matter mass to nitrogen ratio
                0220 C   pivotal          :: Pivotal phytoplankton biomass, for grazing law
                0221 C                       [mol P m-3  or  mol N m-3]
cab777d667 Matt*0222 C   Pc_0             :: Maximum phytoplankton carbon-specific growth rate at 0C
                0223 C   Pc_0_diaz        :: Maximum diazotroph carbon-specific growth rate at 0C
e0f9a7ba0b Matt*0224 C   lambda_0         :: Total mortality rate constant
                0225 C   resp_frac        :: Fraction of production that is respired
                0226 C   chl_min          :: Minimum chl concentration allowed (for numerical stability)
                0227 C   alpha_photo      :: Quantum yield under low light, Fe-replete
                0228 C                       [g C g Chl-1 m2 W-1 s-1]
                0229 C   alpha_max        :: Quantum yield under low light, abundant iron
                0230 C   alpha_min        :: Quantum yield under low light, iron limited
                0231 C   theta_Fe_max_hi  :: Maximum Chl:C ratio when iron-replete
                0232 C   theta_Fe_max_lo  :: Maximum Chl:C ratio when iron-limited
                0233 C   gamma_irr_mem    :: Photoadaptation timescale
                0234 C   gamma_DON        :: Dissolved organic nitrogen decay timescale
                0235 C   gamma_DOP        :: Dissolved organic phosphorus decay timescale
                0236 C   gamma_POM        :: Particulate Organic Matter decay timescale
                0237 C   gamma_biomass    :: Biomass adjustment time scale
                0238 C   gamma_Si_0       :: Opal dissolution timescale
                0239 C   k_Fe             :: Iron half-saturation concentration
                0240 C   k_Fe_diaz        :: Iron half-saturation concentration for diazotrophs
                0241 C   k_O2             :: Oxygen half-saturation concentration for aerobic respiration
                0242 C   k_PO4            :: Phosphate half-saturation concentration
                0243 C   k_NO3            :: Nitrate half-saturation concentration
                0244 C   k_Si             :: Silicate half-saturation concentration
                0245 C   k_PtoN           :: Phosphate half-saturation concentration for uptake ratio
                0246 C   k_FetoN          :: Iron half-saturation concentration for uptake ratio
                0247 C   k_FetoP          :: Iron half-saturation concentration for uptake ratio
                0248 C   kFe_eq_lig_max   :: Maximum light-dependent iron ligand stability constant
                0249 C   kFe_eq_lig_min   :: Minimum light-dependent iron ligand stability constant
                0250 C   kFe_eq_lig_Femin :: Low-iron threshold for ligand stability constant
                0251 C   kFe_eq_lig_irr   :: Irradiance scaling for iron ligand stability constant
                0252 C   kFe_org          :: Iron scavenging, 1st order
                0253 C   kFe_inorg        :: Iron scavenging, 2nd order
                0254 C   PtoN_max         :: Phosphorus to Nitrogen uptake ratio maximum
                0255 C   PtoN_min         :: Phosphorus to Nitrogen uptake ratio minimum
                0256 C   FetoN_max        :: Iron to Nitrogen uptake ratio maximum
                0257 C   FetoN_min        :: Iron to Nitrogen uptake ratio minimum
                0258 C   FetoC_sed        :: Iron released per organic carbon delivery to sediments
                0259 C   FetoP_max        :: Iron to Phosphorus uptake ratio maximum
                0260 C   Fe_lim_min       :: Minimum iron limitation
00fa2d4ddd mmaz*0261 C   SitoN_uptake_max :: Silica to Nitrogen uptake ratio maximum
                0262 C   SitoN_uptake_min :: Silica to Nitrogen uptake ratio minimum
                0263 C   SitoN_uptake_scale:: Scale factor for Silica to Nitrogen uptake ratio
                0264 C   SitoN_uptake_exp :: Exponent for Silica to Nitrogen uptake ratio
e0f9a7ba0b Matt*0265 C   remin_min        :: Minimum remineralization under anoxia
                0266 C   oxic_min         :: Anaerobic respiration threshold
                0267 C   ligand           :: Iron ligand concentration
                0268 C   kappa_eppley     :: Temperature dependence of growth
cab777d667 Matt*0269 C   kappa_eppley_diaz:: Temperature dependence of growth for diazotrophs
e0f9a7ba0b Matt*0270 C   kappa_remin      :: Temperature dependence for particle fractionation
                0271 C   kappa_remin_Si   :: Temperature dependence for silica
                0272 C   ca_remin_depth   :: CaCO3 dissolution length scale (subject to omega)
                0273 C   q_SitoN_diss     :: Stoichiometric role in opal dissolution, following TOPAZ
                0274 C   phi_DOM          :: Fraction of uptake/consumption that becomes DOM
cab777d667 Matt*0275 C   phi_sm           :: Fraction of small phytoplankton biomass converted to detritus
                0276 C   phi_lg           :: Fraction of large phytoplankton biomass converted to detritus
e0f9a7ba0b Matt*0277 C   phi_dvm          :: Fraction of particate production exported by animals
                0278 C   sigma_dvm        :: Standard deviation of vertical migrator resting depth range
                0279 C   wsink0           :: Sinking rate at surface
                0280 C   wsink0z          :: Depth to which sinking rate remains constant
                0281 C   wsinkacc         :: Sinking rate acceleration with depth
                0282 C   wsink_si         :: Opal sinking velocity
                0283 C   parfrac          :: Fraction of Qsw available for photosynthesis
                0284 C   alpfe            :: Solubility of aeolian iron
                0285 C   k0               :: Light attentuation coefficient
                0286 C   MLmix_max        :: Maximum depth over which light and biomass can be mixed
                0287 C   river_conc_po4   :: Phosphate concentration in river runoff
                0288 C   river_dom_to_nut :: DOM to PO4 ratio in river runoff
82e538d851 aver*0289 C   chlsat_locTimWindow(1:2) :: local-time window (in h) for
                0290 C                       satellite-equivalent chlorophyll diagnostic (and cost)
e0f9a7ba0b Matt*0291 
c0d1c06c15 Matt*0292       _RL secperday
e0f9a7ba0b Matt*0293 #ifdef ALLOW_EXF
                0294 #ifdef USE_EXF_INTERPOLATION
079948e6a6 Matt*0295       INTEGER j
e0f9a7ba0b Matt*0296 #endif /* USE_EXF_INTERPOLATION */
                0297 #endif /* ALLOW_EXF */
c0d1c06c15 Matt*0298 
                0299       _BEGIN_MASTER(myThid)
530382a175 Jean*0300       errCount = 0
c0d1c06c15 Matt*0301 
                0302 C ==========================================================
                0303 C     Default values
                0304 
                0305       secperday            = 86400. _d 0
                0306       permil               = 1. _d 0 / 1024.5 _d 0
                0307       Pa2Atm               = 1.01325 _d 5
e0f9a7ba0b Matt*0308       epsln                = 1. _d -30
                0309 #ifdef CARBONCHEM_SOLVESAPHE
                0310        selectBTconst   = 1
                0311        selectFTconst   = 1
                0312        selectHFconst   = 1
                0313        selectK1K2const = 1
                0314        selectPHsolver  = 0
                0315 #endif
                0316 
c0d1c06c15 Matt*0317       CtoN                 = 6.75 _d 0
e0f9a7ba0b Matt*0318       CtoP                 = 106. _d 0
                0319       NtoP                 = 16. _d 0
c0d1c06c15 Matt*0320       HtoC                 = 48. _d 0 / 106. _d 0
be72e7ae9e Jean*0321       NO3toN               = CtoN * (1. _d 0 + 0.25 _d 0 * HtoC)
c0d1c06c15 Matt*0322      &                        * 0.8 _d 0 + 0.6 _d 0
e0f9a7ba0b Matt*0323       O2toN                = CtoN * (1. _d 0 + 0.25 _d 0 * HtoC)
                0324      &                        + 2. _d 0
                0325       O2toP                = 150. _d 0
c0d1c06c15 Matt*0326       CatoN                = CtoN * 0.015 _d 0
e0f9a7ba0b Matt*0327       CatoP                = 106.0 _d 0 * 0.015 _d 0
c0d1c06c15 Matt*0328       masstoN              = CtoN * 12.001 _d 0
e0f9a7ba0b Matt*0329 #ifndef USE_BLING_V1
c0d1c06c15 Matt*0330       pivotal              = 1.9 _d -3 / 1028. _d 0 / CtoN / permil
                0331       Pc_0                 = 1.7 _d -5
                0332       Pc_0_diaz            = 0.01 _d -5
be72e7ae9e Jean*0333       alpha_photo          = 0.7 _d -5 * 2.77 _d 18 / 6.022 _d 17
c0d1c06c15 Matt*0334       gamma_DON            = 0.25 _d 0 / (365.25 _d 0 * secperday)
                0335       gamma_DOP            = 0.5 _d 0 / (365.25 _d 0 * secperday)
e0f9a7ba0b Matt*0336       PtoN_min             = 1. / 28.
                0337       PtoN_max             = 1. / 9.
                0338       FetoN_min            = 2. _d -6 * 6.75
                0339       FetoN_max            = 25. _d -6 * 6.75
cab777d667 Matt*0340       k_Fe                 = 1.6 _d -10 / permil
c0d1c06c15 Matt*0341       k_Fe_diaz            = 7. _d -10 / permil
                0342       k_NO3                = 2. _d -6 / permil
cab777d667 Matt*0343       k_PO4                = 1. _d -8 / permil
be72e7ae9e Jean*0344       k_PtoN               = 1.5 _d -6 / permil
                0345       k_FetoN              = 8. _d -10 / permil
e0f9a7ba0b Matt*0346       remin_min            = 0.15 _d 0
                0347       kappa_eppley_diaz    = 0.18 _d 0
                0348       sigma_dvm            = 40.0 _d 0
                0349       phi_dvm              = 0.2 _d 0
                0350 #ifdef USE_SIBLING
                0351       k_Si                 = 2.0 _d -6 / permil
                0352       gamma_Si_0           = 0.05 / secperday
                0353       kappa_remin_Si       = 0.075
                0354       wsink_Si             = 100. / secperday
6ffd1aa797 Jean*0355       SitoN_uptake_min     = 4
                0356       SitoN_uptake_max     = 1
00fa2d4ddd mmaz*0357       SitoN_uptake_scale   = 0.6
                0358       SitoN_uptake_exp     = 3.887
e0f9a7ba0b Matt*0359       q_SitoN_diss         = 1.0 _d 0
                0360 #endif
                0361 #else
                0362       pivotal              = 1.9 _d -3 / 1028. _d 0 / CtoP / permil
                0363       Pc_0                 = 1 _d -5
                0364       alpha_max            = 1.6 _d -5 * 2.77 _d 18 / 6.022 _d 17
                0365       alpha_min            = 0.4 _d -5 * 2.77 _d 18 / 6.022 _d 17
                0366       gamma_biomass        = 0.5 _d 0 / secperday
                0367       gamma_DOP            = 0.25 _d 0 / (365.25 _d 0 * secperday)
                0368       k_Fe                 = 8. _d -10 / permil
                0369       k_PO4                = 1. _d -7 / permil
                0370       k_FetoP              = 7. _d -6 * CtoP
                0371       FetoP_max            = 28. _d -6 * CtoP
                0372       Fe_lim_min           = 0. _d 0
                0373       remin_min            = 0.3 _d 0
                0374 #endif
                0375       lambda_0             = 0.19 _d 0 / secperday
                0376       resp_frac            = 0. _d 0
                0377       chl_min              = 1. _d -5
                0378       theta_Fe_max_hi      = 0.04 _d 0
                0379       theta_Fe_max_lo      = 0.01 _d 0
                0380       gamma_irr_mem        = 1. _d 0 / secperday
                0381       gamma_POM            = 0.12 _d 0 / secperday
                0382       k_O2                 = 20. _d -6 / permil
c0d1c06c15 Matt*0383       kFe_eq_lig_max       = 8.0 _d 10 * permil
                0384       kFe_eq_lig_min       = 8.0 _d 9 * permil
                0385       kFe_eq_lig_Femin     = 0.05 _d -9 / permil
                0386       kFe_eq_lig_irr       = 0.1 _d 0
                0387       kFe_org              = 0.5 _d 0 / secperday * permil**(0.58)
                0388       kFe_inorg            = 1. _d 3 / secperday * permil**(0.5)
e0f9a7ba0b Matt*0389       FetoC_sed            = 1. _d -4
c0d1c06c15 Matt*0390       oxic_min             = 1. _d -6 / permil
                0391       Ligand               = 1. _d -9 / permil
                0392       kappa_eppley         = 0.063 _d 0
be72e7ae9e Jean*0393       kappa_remin          = -0.032 _d 0
c0d1c06c15 Matt*0394       ca_remin_depth       = 1343. _d 0
                0395       phi_DOM              = 0.1 _d 0
                0396       phi_sm               = 0.18 _d 0
                0397       phi_lg               = 1. _d 0
                0398       wsink0               = 16. _d 0 / secperday
e0f9a7ba0b Matt*0399       wsink0z              = 80. _d 0
c0d1c06c15 Matt*0400       wsinkacc             = 0.05 _d 0 / secperday
                0401       parfrac              = 0.4 _d 0
                0402       alpfe                = 0.01 _d 0
                0403       k0                   = 0.04 _d 0
e0f9a7ba0b Matt*0404       MLmix_max            = 200.0 _d 0
82e538d851 aver*0405       chlsat_locTimWindow(1) = 12.0 _d 0
                0406       chlsat_locTimWindow(2) = 13.5 _d 0
e0f9a7ba0b Matt*0407 
                0408       bling_windFile         = ' '
                0409       bling_atmospFile       = ' '
                0410       bling_iceFile          = ' '
                0411       bling_ironFile         = ' '
                0412       bling_silicaFile       = ' '
                0413       bling_psmFile          = ' '
                0414       bling_plgFile          = ' '
                0415       bling_pdiazFile        = ' '
47de7c1e0e Matt*0416       bling_Pc_2dFile        = ' '
                0417       bling_Pc_2d_diazFile   = ' '
                0418       bling_alpha_photo2dFile= ' '
                0419       bling_k_Fe2dFile       = ' '
                0420       bling_k_Fe_diaz2dFile  = ' '
af8f3b9ffc Matt*0421       bling_gamma_POM2dFile  = ' '
                0422       bling_wsink0_2dFile    = ' '
                0423       bling_phi_DOM2dFile    = ' '
                0424       bling_phi_sm2dFile     = ' '
                0425       bling_phi_lg2dFile     = ' '
c0d1c06c15 Matt*0426 
e0f9a7ba0b Matt*0427       bling_pCO2             = 278. _d -6
                0428       river_conc_po4         = 0.007 _d 0
                0429       river_dom_to_nut       = 0. _d 0
                0430 
                0431 #ifdef ALLOW_EXF
                0432       apco2startdate1         = 0
                0433       apco2startdate2         = 0
                0434       apco2StartTime          = UNSET_RL
                0435       apco2period             = 0.0 _d 0
                0436       apco2RepCycle           = repeatPeriod
                0437       apco2const              = 0.0 _d 0
079948e6a6 Matt*0438       apco2_exfremo_intercept = 0.0 _d 0
e0f9a7ba0b Matt*0439       apco2_exfremo_slope     = 0.0 _d 0
                0440       apco2file               = ' '
                0441       exf_inscal_apco2        =  1. _d 0
                0442       exf_outscal_apco2       =  1. _d 0
079948e6a6 Matt*0443 #ifdef USE_EXF_INTERPOLATION
530382a175 Jean*0444 C--   set default input location to match (in case of simple Lat-Long grid)
079948e6a6 Matt*0445 C     model grid cell-center position (leading to trivial interpolation)
e0f9a7ba0b Matt*0446       apco2_lon0         = inp_lon0
                0447       apco2_lat0         = inp_lat0
9f0da36f91 Jean*0448       apco2_nlon         = inp_gNx
                0449       apco2_nlat         = inp_gNy
e0f9a7ba0b Matt*0450       apco2_lon_inc      = inp_dLon
079948e6a6 Matt*0451       DO j=1,MAX_LAT_INC
9f0da36f91 Jean*0452         apco2_lat_inc(j) = inp_dLat(j)
079948e6a6 Matt*0453       ENDDO
8125504ce6 Matt*0454       apco2_interpMethod = 1
079948e6a6 Matt*0455 #endif /* USE_EXF_INTERPOLATION */
e0f9a7ba0b Matt*0456 #endif /* ALLOW_EXF */
c0d1c06c15 Matt*0457 
be72e7ae9e Jean*0458 C     default periodic forcing to same as for physics
e0f9a7ba0b Matt*0459       bling_forcingPeriod = externForcingPeriod
                0460       bling_forcingCycle  = externForcingCycle
c0d1c06c15 Matt*0461 
                0462       WRITE(msgBuf,'(A)') ' BLING_READPARMS: opening data.bling'
                0463       CALL PRINT_MESSAGE( msgBuf, standardMessageUnit,
                0464      I                    SQUEEZE_RIGHT, myThid )
                0465 
                0466       CALL OPEN_COPY_DATA_FILE( 'data.bling', 'BLING_READPARMS',
                0467      O                          iUnit, myThid )
                0468 
                0469 C--   Read parameters from open data file:
                0470 
                0471 C-    Abiotic parameters
                0472       READ(UNIT=iUnit,NML=ABIOTIC_PARMS)
                0473 
                0474 C-    BLING parameters
                0475       READ(UNIT=iUnit,NML=BIOTIC_PARMS)
                0476 
                0477 C-    forcing filenames and parameters
                0478       READ(UNIT=iUnit,NML=BLING_FORCING)
                0479 
                0480       WRITE(msgBuf,'(A)')
                0481      &   ' BLING_READPARMS: finished reading data.BLING'
                0482       CALL PRINT_MESSAGE( msgBuf, standardMessageUnit,
                0483      I                    SQUEEZE_RIGHT, myThid )
                0484 
                0485 C--   Close the open data file
7a77863887 Mart*0486 #ifdef SINGLE_DISK_IO
c0d1c06c15 Matt*0487       CLOSE(iUnit)
7a77863887 Mart*0488 #else
                0489       CLOSE(iUnit,STATUS='DELETE')
                0490 #endif /* SINGLE_DISK_IO */
c0d1c06c15 Matt*0491 
e0f9a7ba0b Matt*0492       iUnit = standardMessageUnit
                0493 C Record the solver to calculate pH and evaluate surface ocean pCO2
                0494 #ifdef CARBONCHEM_SOLVESAPHE
                0495       IF ( selectPHsolver.GT.0 ) THEN
                0496          WRITE(msgBuf,'(A)')
                0497      &  'Using Munhoven (2013) Solvesaphe for pH/pCO2'
                0498          CALL PRINT_MESSAGE(msgBuf,iUnit,SQUEEZE_RIGHT,myThid)
                0499       ELSEIF ( selectPHsolver.EQ.0 ) THEN
                0500          WRITE(msgBuf,'(A)')
                0501      &  'Using Follows et al. (2006) for pH/pCO2'
                0502          CALL PRINT_MESSAGE(msgBuf,iUnit,SQUEEZE_RIGHT,myThid)
                0503       ENDIF
                0504 #endif
c0d1c06c15 Matt*0505 
e0f9a7ba0b Matt*0506 C Record which carbonate coefficients are used and which pH/pCO2 solver
                0507 #ifdef CARBONCHEM_SOLVESAPHE
                0508       WRITE(msgBuf,'(A)')
                0509      &  'Using Munhoven (2013) Solvesaphe carbon coefficients'
                0510       CALL PRINT_MESSAGE(msgBuf,iUnit,SQUEEZE_RIGHT,myThid)
                0511 C Munhoven (2013)'s "Solvesaphe" coefficients have several options:
                0512       IF ( selectK1K2const.EQ.1 ) THEN
                0513          WRITE(msgBuf,'(A)')
                0514      &  'Using Millero (1995)/Mehrbach K1 and K2 coefficients'
                0515          CALL PRINT_MESSAGE(msgBuf,iUnit,SQUEEZE_RIGHT,myThid)
                0516       ELSEIF ( selectK1K2const.EQ.2 ) THEN
                0517          WRITE(msgBuf,'(A)')
                0518      &  'Using Roy et al. (1993) K1 and K2 coefficients'
                0519          CALL PRINT_MESSAGE(msgBuf,iUnit,SQUEEZE_RIGHT,myThid)
                0520       ELSEIF ( selectK1K2const.EQ.3 ) THEN
                0521          WRITE(msgBuf,'(A)')
                0522      &  'Using Millero (1995) "consensus" K1 and K2 coefficients'
                0523          CALL PRINT_MESSAGE(msgBuf,iUnit,SQUEEZE_RIGHT,myThid)
                0524       ELSEIF ( selectK1K2const.EQ.4 ) THEN
                0525          WRITE(msgBuf,'(A)')
                0526      &  'Using Luecker et al. (2000) K1 and K2 coefficients'
                0527          CALL PRINT_MESSAGE(msgBuf,iUnit,SQUEEZE_RIGHT,myThid)
                0528       ELSEIF ( selectK1K2const.EQ.5 ) THEN
                0529          WRITE(msgBuf,'(A)')
                0530      &  'Using Millero et al. (2010) K1 and K2 coefficients'
                0531          CALL PRINT_MESSAGE(msgBuf,iUnit,SQUEEZE_RIGHT,myThid)
                0532       ELSEIF ( selectK1K2const.EQ.6 ) THEN
                0533          WRITE(msgBuf,'(A)')
                0534      &  'Using Waters et al. (2014) K1 and K2 coefficients'
                0535          CALL PRINT_MESSAGE(msgBuf,iUnit,SQUEEZE_RIGHT,myThid)
                0536       ENDIF
                0537       IF ( selectHFconst.EQ.1 ) THEN
                0538          WRITE(msgBuf,'(A)')
                0539      &  'Using Dickson and Riley (1979) KF coefficient'
                0540          CALL PRINT_MESSAGE(msgBuf,iUnit,SQUEEZE_RIGHT,myThid)
                0541       ELSEIF ( selectHFconst.EQ.2 ) THEN
                0542          WRITE(msgBuf,'(A)')
                0543      &  'Using Perez and Fraga (1987) KF coefficient'
                0544          CALL PRINT_MESSAGE(msgBuf,iUnit,SQUEEZE_RIGHT,myThid)
                0545       ENDIF
                0546       IF ( selectBTconst.EQ.1 ) THEN
                0547          WRITE(msgBuf,'(A)')
                0548      & 'Using Uppstrom (1974) BT estimation from salinity'
                0549          CALL PRINT_MESSAGE(msgBuf,iUnit,SQUEEZE_RIGHT,myThid)
                0550       ELSEIF ( selectBTconst.EQ.2 ) THEN
                0551          WRITE(msgBuf,'(A)')
                0552      &  'Using Lee et al (2010) BT estimation from salinity'
                0553          CALL PRINT_MESSAGE(msgBuf,iUnit,SQUEEZE_RIGHT,myThid)
                0554       ENDIF
                0555       IF ( selectFTconst.EQ.1 ) THEN
                0556          WRITE(msgBuf,'(A)')
                0557      &  'Using Riley (1965) FT estimation from salinity'
                0558          CALL PRINT_MESSAGE(msgBuf,iUnit,SQUEEZE_RIGHT,myThid)
                0559       ELSEIF ( selectBTconst.EQ.2 ) THEN
                0560          WRITE(msgBuf,'(A)')
                0561      &  'Using Culkin (1965) FT estimation from salinity'
                0562          CALL PRINT_MESSAGE(msgBuf,iUnit,SQUEEZE_RIGHT,myThid)
                0563       ENDIF
                0564 #else
                0565 C OCMIP2 Coefficients from S/R CARBON_COEFFS in CARBON_CHEM.F
                0566       WRITE(msgBuf,'(A)')
                0567      &  'Using Millero (1995)/Mehrbach K1 and K2 coefficients'
                0568       CALL PRINT_MESSAGE(msgBuf,iUnit,SQUEEZE_RIGHT,myThid)
                0569       WRITE(msgBuf,'(A)')
                0570      &  'Using Dickson and Riley (1979) KF coefficient'
                0571       CALL PRINT_MESSAGE(msgBuf,iUnit,SQUEEZE_RIGHT,myThid)
                0572       WRITE(msgBuf,'(A)')
                0573      &  'Using Uppstrom (1974) BT estimation from salinity'
                0574       CALL PRINT_MESSAGE(msgBuf,iUnit,SQUEEZE_RIGHT,myThid)
                0575       WRITE(msgBuf,'(A)')
                0576      &  'Using Riley (1965) FT estimation from salinity'
                0577       CALL PRINT_MESSAGE(msgBuf,iUnit,SQUEEZE_RIGHT,myThid)
c0d1c06c15 Matt*0578 #endif
                0579 
530382a175 Jean*0580       IF ( errCount.GE.1 ) THEN
                0581        WRITE(msgBuf,'(A,I3,A)')
                0582      &     'BLING_READPARMS: detected', errCount,' fatal error(s)'
                0583        CALL PRINT_ERROR( msgBuf, myThid )
                0584        CALL ALL_PROC_DIE( 0 )
                0585        STOP 'ABNORMAL END: S/R BLING_READPARMS'
                0586       ENDIF
                0587 
e0f9a7ba0b Matt*0588 #ifdef CARBONCHEM_SOLVESAPHE
                0589       IF ( selectHFconst.GT.2 .OR. selectBTconst.GT.2
                0590      & .OR. selectFTconst.GT.2 ) THEN
                0591         WRITE(msgBuf,'(A)')
                0592      &    'BLING_READPARMS: selectHF, selectBT or selectFT > 2'
                0593         CALL PRINT_ERROR( msgBuf, myThid )
                0594         STOP 'ABNORMAL END: S/R BLING_READPARMS: solvesaphe_const error'
                0595       ELSEIF ( selectK1K2const.GT.6 ) THEN
                0596         WRITE(msgBuf,'(A)')
                0597      &    'BLING_READPARMS: selectK1K2const > 6 '
                0598         CALL PRINT_ERROR( msgBuf, myThid )
                0599         STOP 'ABNORMAL END: S/R BLING_READPARMS: solvesaphe_const error'
                0600       ELSEIF ( selectPHsolver.GT.3 ) THEN
                0601         WRITE(msgBuf,'(A)')
                0602      &    'BLING_READPARMS: selectPHsolver > 3 '
                0603         CALL PRINT_ERROR( msgBuf, myThid )
                0604         STOP 'ABNORMAL END: S/R BLING_READPARMS: select pH solver error'
                0605       ENDIF
                0606 #endif
                0607 
c0d1c06c15 Matt*0608       _END_MASTER(myThid)
                0609 
                0610 C--   Everyone else must wait for the parameters to be loaded
                0611       _BARRIER
                0612 
                0613 #endif /* ALLOW_BLING */
                0614 
                0615       RETURN
                0616       END