New URL for NEMO forge!   http://forge.nemo-ocean.eu

Since March 2022 along with NEMO 4.2 release, the code development moved to a self-hosted GitLab.
This present forge is now archived and remained online for history.
trcnam_c14.F90 in branches/2016/dev_r7012_ROBUST5_CNRS/NEMOGCM/NEMO/TOP_SRC/C14 – NEMO

source: branches/2016/dev_r7012_ROBUST5_CNRS/NEMOGCM/NEMO/TOP_SRC/C14/trcnam_c14.F90 @ 7103

Last change on this file since 7103 was 7103, checked in by cetlod, 7 years ago

new top interface : move namelist age from namelist_top to namelist_trc

File size: 5.8 KB
Line 
1MODULE trcnam_c14
2   !!======================================================================
3   !!                         ***  MODULE trcnam_c14  ***
4   !! TOP :   initialisation of some run parameters for C14 chemical model
5   !!======================================================================
6   !! History :   2.0  !  2007-12  (C. Ethe, G. Madec) from trcnam.cfc.h90
7   !! History :        !  2015 (A.Mouchet) equilibrium + transient C14
8   !!----------------------------------------------------------------------
9   !! trc_nam_c14      : C14 model initialisation
10   !!----------------------------------------------------------------------
11   USE oce_trc         ! Ocean variables
12   USE trc             ! TOP variables
13   USE sms_c14
14
15   IMPLICIT NONE
16   PRIVATE
17   !!
18   PUBLIC   trc_nam_c14   ! called by trcnam.F90 module
19   !!
20   !!----------------------------------------------------------------------
21   !! NEMO/TOP 3.3 , NEMO Consortium (2010)
22   !! $Id: trcnam_c14.F90                       $
23   !! Software governed by the CeCILL licence (NEMOGCM/NEMO_CeCILL.txt)
24   !!----------------------------------------------------------------------
25
26CONTAINS
27
28   SUBROUTINE trc_nam_c14
29      !!-------------------------------------------------------------------
30      !!                  ***  ROUTINE trc_nam_c14  ***
31      !!                 
32      !! ** Purpose :   Definition some run parameter for C14 model
33      !!
34      !! ** Method  :   Read the namc14 namelist and check the parameter
35      !!       values called at the first timestep (nittrc000)
36      !!
37      !! ** input   :   Namelist namelist_c14
38      !!----------------------------------------------------------------------
39      INTEGER :: ios                 ! Local integer output status for namelist read
40      !!
41      NAMELIST/namc14_typ/ kc14typ,rc14at, pco2at, rc14init   ! type of C14 tracer, default values of C14/C, pco2, & ocean r14
42      NAMELIST/namc14_sbc/ ln_chemh, xkwind, xdicsur          ! chem enh, wind coeff, ref DIC
43      NAMELIST/namc14_fcg/ cfileco2, cfilec14, tyrc14_beg  ! for transient exps; atm forcing
44      !!-------------------------------------------------------------------
45      !
46      ctrcnm    (jp_c14) = 'RC14'
47      ctrcln    (jp_c14) = 'Radiocarbon ratio'
48      ctrcun    (jp_c14) = '-'
49      ln_trc_ini(jp_c14) = .false.
50      !
51
52      REWIND( numtrc_ref )              ! Namelist namc14_typ in reference namelist :
53      READ  ( numtrc_ref, namc14_typ, IOSTAT = ios, ERR = 901)
54901   IF( ios /= 0 ) CALL ctl_nam ( ios , 'namc14_typ in reference namelist', lwp )
55
56      REWIND( numtrc_cfg )              ! Namelist namcfcdate in configuration namelist
57      READ  ( numtrc_cfg, namc14_typ, IOSTAT = ios, ERR = 902)
58902   IF( ios /= 0 ) CALL ctl_nam ( ios , 'namc14_typ in configuration namelist', lwp )
59      IF(lwm) WRITE ( numonr, namc14_typ )
60
61      IF(lwp) THEN                  ! control print
62         WRITE(numout,*) ' '
63         WRITE(numout,*) ' Radiocarbon C14'
64         WRITE(numout,*) ' '
65         WRITE(numout,*) ' Namelist namc14_typ'
66         WRITE(numout,*)
67         WRITE(numout,*) ' Type of C14 tracer (0=equilibrium; 1=bomb transient; 2=past transient) kc14typ = ', kc14typ
68         WRITE(numout,*) ' Default value for atmospheric C14/C (used for equil run)               rc14at  = ', rc14at
69         WRITE(numout,*) ' Default value for atmospheric pcO2 [atm] (used for equil run)          pco2at  = ', pco2at
70         WRITE(numout,*) ' Default value for initial C14/C in the ocean (used for equil run)      rc14init= ', rc14init
71         WRITE(numout,*) '  '
72      ENDIF
73
74      REWIND( numtrc_ref )              ! Namelist namc14_typ in reference namelist :
75      READ  ( numtrc_ref, namc14_sbc, IOSTAT = ios, ERR = 903)
76903   IF( ios /= 0 ) CALL ctl_nam ( ios , 'namc14_sbc in reference namelist', lwp )
77
78      REWIND( numtrc_cfg )              ! Namelist namcfcdate in configuration namelist
79      READ  ( numtrc_cfg, namc14_sbc, IOSTAT = ios, ERR = 904)
80904   IF( ios /= 0 ) CALL ctl_nam ( ios , 'namc14_sbc in configuration namelist', lwp )
81      IF(lwm) WRITE ( numonr, namc14_sbc )
82
83      IF(lwp) THEN                  ! control print
84         WRITE(numout,*) ' Namelist namc14_sbc'
85         WRITE(numout,*)
86         WRITE(numout,*) ' Chemical enhancement in piston velocity   ln_chemh = ', ln_chemh
87         WRITE(numout,*) ' Coefficient for gas exchange velocity     xkwind   = ', xkwind
88         WRITE(numout,*) ' Reference DIC concentration (mol/m3)      xdicsur  = ', xdicsur
89         WRITE(numout,*) '  '
90      ENDIF
91
92      REWIND( numtrc_ref )              ! Namelist namc14_typ in reference namelist :
93      READ  ( numtrc_ref, namc14_fcg, IOSTAT = ios, ERR = 905)
94905   IF( ios /= 0 ) CALL ctl_nam ( ios , 'namc14_fcg in reference namelist', lwp )
95
96      REWIND( numtrc_cfg )              ! Namelist namcfcdate in configuration namelist
97      READ  ( numtrc_cfg, namc14_fcg, IOSTAT = ios, ERR = 906)
98906   IF( ios /= 0 ) CALL ctl_nam ( ios , 'namc14_fcg in configuration namelist', lwp )
99      IF(lwm) WRITE ( numonr, namc14_fcg )
100
101      IF(lwp) THEN                  ! control print
102         WRITE(numout,*) ' Namelist namc14_fcg'
103         WRITE(numout,*)
104         WRITE(numout,*) ' Atmospheric co2 file ( bomb )  cfileco2   = ', TRIM( cfileco2 )
105         WRITE(numout,*) ' Atmospheric c14 file ( bomb )  cfilec14   = ', TRIM( cfilec14 )
106         WRITE(numout,*) ' Starting year of experiment    tyrc14_beg = ', tyrc14_beg
107         WRITE(numout,*) '  '
108      ENDIF
109
110      !
111      IF( kc14typ == 2)    tyrc14_beg = 1950._wp - tyrc14_beg  ! BP to AD dates
112      ! set units
113      rlam14 = LOG(2._wp) / 5730._wp / rsiyea    ! C14 decay  rate: yr^-1 --> s^-1
114      !                                          ! radiocarbon half-life is 5730 yr
115   END SUBROUTINE trc_nam_c14
116   
117   !!======================================================================
118END MODULE trcnam_c14
Note: See TracBrowser for help on using the repository browser.