From dc5350afe526cf5a40fd14cd85d1e17829e40413 Mon Sep 17 00:00:00 2001 From: JorgSchwinger Date: Wed, 2 Aug 2023 17:26:21 +0200 Subject: [PATCH 1/2] Add file mo_boxatm.F90 making it possible to run HAMOCC with a well-mixed 1D box atmosphere for air-sea exchange of CO2 (and C-isotopes). There is currently no way to activate this option other than adding the preprocessor flag -DBOXATM in cime_config/buildcpp. --- hamocc/hamocc4bcm.F90 | 2 +- hamocc/mo_boxatm.F90 | 176 ++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 177 insertions(+), 1 deletion(-) create mode 100644 hamocc/mo_boxatm.F90 diff --git a/hamocc/hamocc4bcm.F90 b/hamocc/hamocc4bcm.F90 index f503b524..b52fb632 100644 --- a/hamocc/hamocc4bcm.F90 +++ b/hamocc/hamocc4bcm.F90 @@ -314,7 +314,7 @@ SUBROUTINE HAMOCC4BCM(kpie,kpje,kpke,kbnd,kplyear,kplmon,kplday,kldtday,& ! Update atmospheric pCO2 [ppm] #if defined(BOXATM) - CALL update_boxatm(kpie,kpje,pdlxp,pdlyp) + CALL update_boxatm(kpie,kpje,kpke,pdlxp,pdlyp,pddpo,omask) #endif #ifdef PBGC_CK_TIMESTEP diff --git a/hamocc/mo_boxatm.F90 b/hamocc/mo_boxatm.F90 new file mode 100644 index 00000000..7d5edd04 --- /dev/null +++ b/hamocc/mo_boxatm.F90 @@ -0,0 +1,176 @@ +! Copyright (C) 2018-2019 A. Moree +! Copyright (C) 2023 J. Schwinger +! +! This file is part of BLOM/iHAMOCC. +! +! BLOM is free software: you can redistribute it and/or modify it under the +! terms of the GNU Lesser General Public License as published by the Free +! Software Foundation, either version 3 of the License, or (at your option) +! any later version. +! +! BLOM is distributed in the hope that it will be useful, but WITHOUT ANY +! WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS +! FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for +! more details. +! +! You should have received a copy of the GNU Lesser General Public License +! along with BLOM. If not, see https://www.gnu.org/licenses/. + + +module mo_boxatm +!****************************************************************************** +! A. Moree, *GFI, Bergen* Oct 2019 +! +! +! Modified +! -------- +! A. Moree, *GFI, Bergen* 2019-10 +! - 14C source added to atmosphere as the sum of all 14C loss (decay) +! +! J. Schwinger, *NORCE, Bergen* 2023-08-02 +! - ported into NorESM2 code, no functional changes +! +! +! Purpose +! ------- +! - This module contains the routine update_boxatm for updating a +! 1-D/scalar/box atmosphere +! +! +! Description +! ----------- +! The global sum of the air-sea C fluxes is calculated, then converted to ppm +! and added to the global atmospheric concentration. For C14, an atmospheric +! production term corresponding to the total decay in the ocean (plus sediment +! if activated) is assumed. +! +! +!****************************************************************************** + +contains + + +subroutine update_boxatm(kpie,kpje,kpke,pdlxp,pdlyp,pddpo,omask) +!****************************************************************************** + use mod_xc, only: mnproc,nbdy,ips,xcsum + use mo_control_bgc, only: io_stdo_bgc + use mo_carbch, only: atmflx, atm + use mo_param1_bgc, only: iatmco2 +#ifdef cisonew + use mo_param1_bgc, only: iatmc13,iatmc14,isco214,idet14,icalc14,idoc14, & + iphy14,izoo14,ipowc14,issso14,isssc14 + use mo_carbch, only: c14dec, ocetra + use mo_biomod, only: rcar +#ifndef sedbypass + use mo_sedmnt, only: seddw,porwat,porsol +#endif +#endif + + implicit none + + INTEGER,intent(in) :: kpie,kpje,kpke + REAL, intent(in) :: pdlxp(kpie,kpje),pdlyp(kpie,kpje) + REAL, intent(in) :: pddpo(kpie,kpje,kpke),omask(kpie,kpje) + + REAL, PARAMETER :: pg2ppm = 1.0/2.13 ! conversion factor PgC -> ppm CO2 + + INTEGER :: i,j,k + REAL :: ztmp1(1-nbdy:kpie+nbdy,1-nbdy:kpje+nbdy) + REAL :: co2flux, co2flux_ppm +#ifdef cisonew + REAL :: ztmp2(1-nbdy:kpie+nbdy,1-nbdy:kpje+nbdy) + REAL :: co213flux, co213flux_ppm + REAL :: co214flux, co214flux_ppm + REAL :: totc14dec, vol +#endif + + co2flux = 0.0 + + ! Calculate global total air-sea flux [kmol] + ztmp1(:,:) = 0.0 + DO j=1,kpje + DO i=1,kpie + ztmp1(i,j) = atmflx(i,j,iatmco2)*pdlxp(i,j)*pdlyp(i,j) ![kmol CO2/ m2] * [m] * [m] + ENDDO + ENDDO + + CALL xcsum(co2flux,ztmp1,ips) + + ! Convert global CO2 flux to ppm + co2flux_ppm = co2flux*12.*1.e-12*pg2ppm ! [kmol C] -> [ppm] + + ! Update atmospheric pCO2 + DO j=1,kpje + DO i=1,kpie + atm(i,j,iatmco2)=atm(i,j,iatmco2) + co2flux_ppm + ENDDO + ENDDO + +#ifdef cisonew + co213flux = 0.0 + co214flux = 0.0 + + ! Calculate global total air-sea flux for C isotopes [kmol] + ztmp1(:,:) = 0.0 + ztmp2(:,:) = 0.0 + DO j=1,kpje + DO i=1,kpie + ztmp1(i,j) = atmflx(i,j,iatmc13)*pdlxp(i,j)*pdlyp(i,j) ![kmol 13CO2/ m2] * [m] * [m] + ztmp2(i,j) = atmflx(i,j,iatmc14)*pdlxp(i,j)*pdlyp(i,j) ![kmol 14CO2/ m2] * [m] * [m] + ENDDO + ENDDO + + CALL xcsum(co213flux,ztmp1,ips) + CALL xcsum(co214flux,ztmp2,ips) + + ! Convert global CO2 isotope fluxes to ppm isotope fluxes + co213flux_ppm = co213flux*13.*1.e-12*pg2ppm*12./13. ! [kmol 13CO2] -> [ppm] + co214flux_ppm = co214flux*14.*1.e-12*pg2ppm*12./14. ! [kmol 14CO2] -> [ppm] + + ! Calculate sum of 14C decay. Only decay in ocean, so only ocean tracers. + totc14dec = 0.0 + ztmp1(:,:) = 0.0 + DO k=1,kpke + DO j=1,kpje + DO i=1,kpie + vol = pdlxp(i,j)*pdlyp(i,j)*pddpo(i,j,k)*omask(i,j) ! ocean volume + ztmp1(i,j) = ztmp1(i,j)+ocetra(i,j,k,isco214)*vol*(1.0-c14dec) + ztmp1(i,j) = ztmp1(i,j)+ocetra(i,j,k,idet14) *vol*(1.0-c14dec)*rcar + ztmp1(i,j) = ztmp1(i,j)+ocetra(i,j,k,icalc14)*vol*(1.0-c14dec) + ztmp1(i,j) = ztmp1(i,j)+ocetra(i,j,k,idoc14) *vol*(1.0-c14dec)*rcar + ztmp1(i,j) = ztmp1(i,j)+ocetra(i,j,k,iphy14) *vol*(1.0-c14dec)*rcar + ztmp1(i,j) = ztmp1(i,j)+ocetra(i,j,k,izoo14) *vol*(1.0-c14dec)*rcar +#ifndef sedbypass + vol = seddw(k)*pdlxp(i,j)*pdlyp(i,j)*porwat(k)*omask(i,j) ! porewater volume + ztmp1(i,j) = ztmp1(i,j)+powtra(i,j,k,ipowc14) *vol*(1.0-c14dec) + vol = seddw(k)*pdlxp(i,j)*pdlyp(i,j)*porsol(k)*omask(i,j) ! sediment volume + ztmp1(i,j) = ztmp1(i,j)+sedlay(i,j,k,issso14) *vol*(1.0-c14dec)*rcar + ztmp1(i,j) = ztmp1(i,j)+sedlay(i,j,k,isssc14) *vol*(1.0-c14dec) +#endif + ENDDO + ENDDO + ENDDO + + CALL xcsum(totc14dec,ztmp1,ips) + + ! Update atmospheric p13CO2 and p14CO2 + DO j=1,kpje + DO i=1,kpie + atm(i,j,iatmc13)=atm(i,j,iatmc13) + co213flux_ppm + atm(i,j,iatmc14)=atm(i,j,iatmc14) + co214flux_ppm + atm(i,j,iatmc14)=atm(i,j,iatmc14) + totc14dec*14.*1.e-12*pg2ppm*12./14. ! add 14C decay (ppm) + ENDDO + ENDDO + + IF (mnproc.eq.1) THEN + WRITE(io_stdo_bgc,*) 'Boxatm fluxes (ppm)' + WRITE(io_stdo_bgc,*) ' ' + WRITE(io_stdo_bgc,*) 'co213flux_ppm: ',co213flux_ppm + WRITE(io_stdo_bgc,*) 'co214flux_ppm: ',co214flux_ppm + WRITE(io_stdo_bgc,*) 'totc14dec (ppm): ',(totc14dec*14.*1.e-12*pg2ppm*12./14.) + ENDIF +#endif /* cisonew */ + +end subroutine update_boxatm + +end module mo_boxatm From 1e1000393273d480dd2e1ea6b35ccf0efa867820 Mon Sep 17 00:00:00 2001 From: JorgSchwinger Date: Thu, 3 Aug 2023 07:06:53 +0200 Subject: [PATCH 2/2] Updated meson.build --- hamocc/meson.build | 1 + hamocc/mo_boxatm.F90 | 7 ++++--- 2 files changed, 5 insertions(+), 3 deletions(-) diff --git a/hamocc/meson.build b/hamocc/meson.build index cc6b7433..a2c29190 100644 --- a/hamocc/meson.build +++ b/hamocc/meson.build @@ -22,6 +22,7 @@ sources += files( 'mo_apply_oafx.F90', 'mo_bgcmean.F90', 'mo_biomod.F90', + 'mo_boxatm.F90', 'mo_carbch.F90', 'mo_chemcon.F90', 'mo_clim_swa.F90', diff --git a/hamocc/mo_boxatm.F90 b/hamocc/mo_boxatm.F90 index 7d5edd04..cbcc9cee 100644 --- a/hamocc/mo_boxatm.F90 +++ b/hamocc/mo_boxatm.F90 @@ -163,11 +163,12 @@ subroutine update_boxatm(kpie,kpje,kpke,pdlxp,pdlyp,pddpo,omask) ENDDO IF (mnproc.eq.1) THEN + WRITE(io_stdo_bgc,*) ' ' WRITE(io_stdo_bgc,*) 'Boxatm fluxes (ppm)' + WRITE(io_stdo_bgc,*) ' co213flux_ppm: ',co213flux_ppm + WRITE(io_stdo_bgc,*) ' co214flux_ppm: ',co214flux_ppm + WRITE(io_stdo_bgc,*) ' totc14dec (ppm): ',(totc14dec*14.*1.e-12*pg2ppm*12./14.) WRITE(io_stdo_bgc,*) ' ' - WRITE(io_stdo_bgc,*) 'co213flux_ppm: ',co213flux_ppm - WRITE(io_stdo_bgc,*) 'co214flux_ppm: ',co214flux_ppm - WRITE(io_stdo_bgc,*) 'totc14dec (ppm): ',(totc14dec*14.*1.e-12*pg2ppm*12./14.) ENDIF #endif /* cisonew */