From 09d21f347408f4d471e73534b60796c6a5f377cd Mon Sep 17 00:00:00 2001 From: Joseph Hughes Date: Tue, 17 Dec 2024 17:29:02 -0600 Subject: [PATCH] fix(csub): CSUB observations Make mf6io and code consistent. Closes #1447 --- doc/Common/gwf-csubobs.tex | 20 ++++---- doc/mf6io/mf6io.tex | 2 +- src/Model/GroundWaterFlow/gwf-csub.f90 | 66 ++++++++++++++------------ 3 files changed, 46 insertions(+), 42 deletions(-) diff --git a/doc/Common/gwf-csubobs.tex b/doc/Common/gwf-csubobs.tex index 8d718c45a8f..8cda8cd940c 100644 --- a/doc/Common/gwf-csubobs.tex +++ b/doc/Common/gwf-csubobs.tex @@ -25,20 +25,20 @@ CSUB & coarse-thickness & cellid & -- & thickness of coarse-grained materials in a GWF cell. \\ CSUB & thickness-cell & cellid & -- & total thickness of coarse-grained materials and all interbeds in a GWF cell. \\ -CSUB & theta & icsubno & -- & porosity of a interbed . \\ +CSUB & theta & icsubno or boundname & -- & porosity of a interbed or group of interbeds. \\ CSUB & coarse-theta & cellid & -- & porosity of coarse-grained materials in a GWF cell. \\ CSUB & theta-cell & cellid & -- & thickness-weighted porosity of coarse-grained materials and all interbeds in a GWF cell. \\ -CSUB & delay-flowtop & icsubno & -- & Flow between the groundwater system and a delay interbed across the top of the interbed. \\ -CSUB & delay-flowbot & icsubno & -- & Flow between the groundwater system and a delay interbed across the bottom of the interbed. \\ +CSUB & delay-flowtop & icsubno or boundname & -- & Flow between the groundwater system and a delay interbed or group of interbeds across the top of the interbed(s). \\ +CSUB & delay-flowbot & icsubno or boundname & -- & Flow between the groundwater system and a delay interbed or group of interbeds across the bottom of the interbed(s). \\ -CSUB & delay-head & icsubno & idcellno & head in interbed delay cell idcellno (1 $<=$ idcellno $<=$ NDELAYCELLS). The NODATA value is reported for steady-state stress periods. \\ -CSUB & delay-gstress & icsubno & idcellno & geostatic stress in interbed delay cell idcellno (1 $<=$ idcellno $<=$ NDELAYCELLS). The NODATA value is reported for steady-state stress periods. \\ -CSUB & delay-estress & icsubno & idcellno & effective stress in interbed delay cell idcellno (1 $<=$ idcellno $<=$ NDELAYCELLS). The NODATA value is reported for steady-state stress periods. \\ -CSUB & delay-preconstress & icsubno & idcellno & preconsolidation stress in interbed delay cell idcellno (1 $<=$ idcellno $<=$ NDELAYCELLS). The NODATA value is reported for steady-state stress periods. \\ -CSUB & delay-compaction & icsubno & idcellno & compaction in interbed delay cell idcellno (1 $<=$ idcellno $<=$ NDELAYCELLS). \\ -CSUB & delay-thickness & icsubno & idcellno & thickness of interbed delay cell idcellno (1 $<=$ idcellno $<=$ NDELAYCELLS). \\ -CSUB & delay-theta & icsubno & idcellno & porosity of interbed delay cell idcellno (1 $<=$ idcellno $<=$ NDELAYCELLS). \\ +CSUB & delay-head & icsubno or boundname & idcellno & head in interbed or group of interbeds in delay cell idcellno (1 $<=$ idcellno $<=$ NDELAYCELLS). The NODATA value is reported for steady-state stress periods. \\ +CSUB & delay-gstress & icsubno or boundname & idcellno & geostatic stress in interbed or group of interbeds in delay cell idcellno (1 $<=$ idcellno $<=$ NDELAYCELLS). The NODATA value is reported for steady-state stress periods. \\ +CSUB & delay-estress & icsubno or boundname & idcellno & effective stress in interbed or group of interbeds in delay cell idcellno (1 $<=$ idcellno $<=$ NDELAYCELLS). The NODATA value is reported for steady-state stress periods. \\ +CSUB & delay-preconstress & icsubno or boundname & idcellno & preconsolidation stress in interbed or group of interbeds in delay cell idcellno (1 $<=$ idcellno $<=$ NDELAYCELLS). The NODATA value is reported for steady-state stress periods. \\ +CSUB & delay-compaction & icsubno or boundname & idcellno & compaction in interbed or group of interbeds in delay cell idcellno (1 $<=$ idcellno $<=$ NDELAYCELLS). \\ +CSUB & delay-thickness & icsubno or boundname & idcellno & thickness of interbed or group of interbeds in delay cell idcellno (1 $<=$ idcellno $<=$ NDELAYCELLS). \\ +CSUB & delay-theta & icsubno or boundname & idcellno & porosity of interbed or group of interbeds in delay cell idcellno (1 $<=$ idcellno $<=$ NDELAYCELLS). \\ CSUB & preconstress-cell & cellid & -- & preconsolidation stress in a GWF cell containing at least one interbed. The NODATA value is reported for steady-state stress periods. diff --git a/doc/mf6io/mf6io.tex b/doc/mf6io/mf6io.tex index 2172bac78db..d3461616dd5 100644 --- a/doc/mf6io/mf6io.tex +++ b/doc/mf6io/mf6io.tex @@ -73,7 +73,7 @@ \renewcommand\labelitemi{\tiny$\bullet$} \renewcommand{\cooperator} -{the \textusgs\ Water Availability and Use Science Program} +{Water Availability and Use Science Program} \renewcommand{\reporttitle} {MODFLOW 6 -- Description of Input and Output} diff --git a/src/Model/GroundWaterFlow/gwf-csub.f90 b/src/Model/GroundWaterFlow/gwf-csub.f90 index c8aba18c1fa..bb1174e73b6 100644 --- a/src/Model/GroundWaterFlow/gwf-csub.f90 +++ b/src/Model/GroundWaterFlow/gwf-csub.f90 @@ -6790,22 +6790,22 @@ subroutine csub_df_obs(this) ! ! -- Store obs type and assign procedure pointer ! for interbed ske observation type. - call this%obs%StoreObsType('ske', .true., indx) + call this%obs%StoreObsType('ske', .false., indx) this%obs%obsData(indx)%ProcessIdPtr => csub_process_obsID ! ! -- Store obs type and assign procedure pointer ! for interbed sk observation type. - call this%obs%StoreObsType('sk', .true., indx) + call this%obs%StoreObsType('sk', .false., indx) this%obs%obsData(indx)%ProcessIdPtr => csub_process_obsID ! ! -- Store obs type and assign procedure pointer ! for ske-cell observation type. - call this%obs%StoreObsType('ske-cell', .true., indx) + call this%obs%StoreObsType('ske-cell', .false., indx) this%obs%obsData(indx)%ProcessIdPtr => csub_process_obsID ! ! -- Store obs type and assign procedure pointer ! for sk-cell observation type. - call this%obs%StoreObsType('sk-cell', .true., indx) + call this%obs%StoreObsType('sk-cell', .false., indx) this%obs%obsData(indx)%ProcessIdPtr => csub_process_obsID ! ! -- Store obs type and assign procedure pointer @@ -6820,17 +6820,17 @@ subroutine csub_df_obs(this) ! ! -- Store obs type and assign procedure pointer ! for total-compaction observation type. - call this%obs%StoreObsType('interbed-compaction', .true., indx) + call this%obs%StoreObsType('interbed-compaction', .false., indx) this%obs%obsData(indx)%ProcessIdPtr => csub_process_obsID ! ! -- Store obs type and assign procedure pointer ! for inelastic-compaction observation type. - call this%obs%StoreObsType('inelastic-compaction', .true., indx) + call this%obs%StoreObsType('inelastic-compaction', .false., indx) this%obs%obsData(indx)%ProcessIdPtr => csub_process_obsID ! ! -- Store obs type and assign procedure pointer ! for inelastic-compaction observation type. - call this%obs%StoreObsType('elastic-compaction', .true., indx) + call this%obs%StoreObsType('elastic-compaction', .false., indx) this%obs%obsData(indx)%ProcessIdPtr => csub_process_obsID ! ! -- Store obs type and assign procedure pointer @@ -6840,22 +6840,22 @@ subroutine csub_df_obs(this) ! ! -- Store obs type and assign procedure pointer ! for inelastic-compaction-cell observation type. - call this%obs%StoreObsType('inelastic-compaction-cell', .true., indx) + call this%obs%StoreObsType('inelastic-compaction-cell', .false., indx) this%obs%obsData(indx)%ProcessIdPtr => csub_process_obsID ! ! -- Store obs type and assign procedure pointer ! for elastic-compaction-cell observation type. - call this%obs%StoreObsType('elastic-compaction-cell', .true., indx) + call this%obs%StoreObsType('elastic-compaction-cell', .false., indx) this%obs%obsData(indx)%ProcessIdPtr => csub_process_obsID ! ! -- Store obs type and assign procedure pointer ! for compaction-cell observation type. - call this%obs%StoreObsType('compaction-cell', .true., indx) + call this%obs%StoreObsType('compaction-cell', .false., indx) this%obs%obsData(indx)%ProcessIdPtr => csub_process_obsID ! ! -- Store obs type and assign procedure pointer ! for interbed thickness observation type. - call this%obs%StoreObsType('thickness', .true., indx) + call this%obs%StoreObsType('thickness', .false., indx) this%obs%obsData(indx)%ProcessIdPtr => csub_process_obsID ! ! -- Store obs type and assign procedure pointer @@ -6870,7 +6870,7 @@ subroutine csub_df_obs(this) ! ! -- Store obs type and assign procedure pointer ! for interbed theta observation type. - call this%obs%StoreObsType('theta', .true., indx) + call this%obs%StoreObsType('theta', .false., indx) this%obs%obsData(indx)%ProcessIdPtr => csub_process_obsID ! ! -- Store obs type and assign procedure pointer @@ -6880,7 +6880,7 @@ subroutine csub_df_obs(this) ! ! -- Store obs type and assign procedure pointer ! for theta-cell observation type. - call this%obs%StoreObsType('theta-cell', .true., indx) + call this%obs%StoreObsType('theta-cell', .false., indx) this%obs%obsData(indx)%ProcessIdPtr => csub_process_obsID ! ! -- Store obs type and assign procedure pointer @@ -7355,20 +7355,20 @@ subroutine csub_process_obsID(obsrv, dis, inunitobs, iout) if (obsrv%ObsTypeId == 'CSUB' .or. & obsrv%ObsTypeId == 'INELASTIC-CSUB' .or. & obsrv%ObsTypeId == 'ELASTIC-CSUB' .or. & - obsrv%ObsTypeId == 'SK' .or. & - obsrv%ObsTypeId == 'SKE' .or. & - obsrv%ObsTypeId == 'THETA' .or. & - obsrv%ObsTypeId == 'THICKNESS' .or. & - obsrv%ObsTypeId == 'INTERBED-COMPACTION' .or. & - obsrv%ObsTypeId == 'INELASTIC-COMPACTION' .or. & - obsrv%ObsTypeId == 'ELASTIC-COMPACTION' .or. & - obsrv%ObsTypeId == 'DELAY-HEAD' .or. & - obsrv%ObsTypeId == 'DELAY-GSTRESS' .or. & - obsrv%ObsTypeId == 'DELAY-ESTRESS' .or. & - obsrv%ObsTypeId == 'DELAY-PRECONSTRESS' .or. & - obsrv%ObsTypeId == 'DELAY-COMPACTION' .or. & - obsrv%ObsTypeId == 'DELAY-THICKNESS' .or. & - obsrv%ObsTypeId == 'DELAY-THETA' .or. & + ! obsrv%ObsTypeId == 'SK' .or. & + ! obsrv%ObsTypeId == 'SKE' .or. & + ! obsrv%ObsTypeId == 'THETA' .or. & + ! obsrv%ObsTypeId == 'THICKNESS' .or. & + ! obsrv%ObsTypeId == 'INTERBED-COMPACTION' .or. & + ! obsrv%ObsTypeId == 'INELASTIC-COMPACTION' .or. & + ! obsrv%ObsTypeId == 'ELASTIC-COMPACTION' .or. & + ! obsrv%ObsTypeId == 'DELAY-HEAD' .or. & + ! obsrv%ObsTypeId == 'DELAY-GSTRESS' .or. & + ! obsrv%ObsTypeId == 'DELAY-ESTRESS' .or. & + ! obsrv%ObsTypeId == 'DELAY-PRECONSTRESS' .or. & + ! obsrv%ObsTypeId == 'DELAY-COMPACTION' .or. & + ! obsrv%ObsTypeId == 'DELAY-THICKNESS' .or. & + ! obsrv%ObsTypeId == 'DELAY-THETA' .or. & obsrv%ObsTypeId == 'DELAY-FLOWTOP' .or. & obsrv%ObsTypeId == 'DELAY-FLOWBOT') then call extract_idnum_or_bndname(string, icol, istart, istop, nn1, bndname) @@ -7388,16 +7388,20 @@ subroutine csub_process_obsID(obsrv, dis, inunitobs, iout) obsrv%ObsTypeId == 'DELAY-THETA') then call extract_idnum_or_bndname(string, icol, istart, istop, nn2, bndname) if (nn2 == NAMEDBOUNDFLAG) then - obsrv%FeatureName = bndname - ! -- reset nn1 - nn1 = nn2 + write (errmsg, '(3a)') & + "BOUNDNAME cannot be specified for CSUB package '", & + trim(obsrv%ObsTypeId), "' observation type." + call store_error(errmsg) + ! obsrv%FeatureName = bndname + ! ! -- reset nn1 + ! nn1 = nn2 else obsrv%NodeNumber2 = nn2 end if end if end if ! - ! -- store reach number (NodeNumber) + ! -- store observation location (NodeNumber) obsrv%NodeNumber = nn1 end subroutine csub_process_obsID