Skip to content

Commit

Permalink
feat(grb): add binary grid file reader, support grid file in fmi (WIP)
Browse files Browse the repository at this point in the history
  • Loading branch information
wpbonelli committed Jan 20, 2025
1 parent 849578f commit 0e5cbb9
Show file tree
Hide file tree
Showing 8 changed files with 309 additions and 45 deletions.
2 changes: 2 additions & 0 deletions autotest/test_prt_voronoi2.py
Original file line number Diff line number Diff line change
Expand Up @@ -175,9 +175,11 @@ def build_prt_sim(name, gwf_ws, prt_ws, targets, cell_ids):
)
gwf_budget_file = gwf_ws / f"{gwf_name}.bud"
gwf_head_file = gwf_ws / f"{gwf_name}.hds"
grb_file = gwf_ws / f"{gwf_name}.disv.grb"
flopy.mf6.ModflowPrtfmi(
prt,
packagedata=[
("GWFGRID", grb_file),
("GWFHEAD", gwf_head_file),
("GWFBUDGET", gwf_budget_file),
],
Expand Down
2 changes: 1 addition & 1 deletion doc/mf6io/mf6ivar/dfn/prt-fmi.dfn
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ type string
tagged false
reader urword
longname flow type
description is the word GWFBUDGET or GWFHEAD. If GWFBUDGET is specified, then the corresponding file must be a budget file from a previous GWF Model run.
description is the word GWFBUDGET, GWFHEAD, or GRB. If GWFBUDGET is specified, then the corresponding file must be a budget file from a previous GWF Model run. If GWFHead is specified, the file must be a head file. If GWFGRID is specified, the file must be a binary grid file.

block packagedata
name filein
Expand Down
1 change: 1 addition & 0 deletions make/makefile
Original file line number Diff line number Diff line change
Expand Up @@ -227,6 +227,7 @@ $(OBJDIR)/SourceCommon.o \
$(OBJDIR)/MemoryManagerExt.o \
$(OBJDIR)/ats.o \
$(OBJDIR)/GeomUtil.o \
$(OBJDIR)/GridFileReader.o \
$(OBJDIR)/TimeSeriesLink.o \
$(OBJDIR)/TimeSeriesFileList.o \
$(OBJDIR)/tdis.o \
Expand Down
1 change: 1 addition & 0 deletions msvs/mf6core.vfproj
Original file line number Diff line number Diff line change
Expand Up @@ -624,6 +624,7 @@
<File RelativePath="..\src\Utilities\DevFeature.f90"/>
<File RelativePath="..\src\Utilities\ErrorUtil.f90"/>
<File RelativePath="..\src\Utilities\GeomUtil.f90"/>
<File RelativePath="..\src\Utilities\GridFileReader.f90"/>
<File RelativePath="..\src\Utilities\HashTable.f90"/>
<File RelativePath="..\src\Utilities\HeadFileReader.f90"/>
<File RelativePath="..\src\Utilities\HGeoUtil.f90"/>
Expand Down
74 changes: 30 additions & 44 deletions src/Model/ModelUtilities/FlowModelInterface.f90
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@ module FlowModelInterfaceModule
use ListModule, only: ListType
use BudgetFileReaderModule, only: BudgetFileReaderType
use HeadFileReaderModule, only: HeadFileReaderType
use GridFileReaderModule, only: load_grb
use PackageBudgetModule, only: PackageBudgetType
use BudgetObjectModule, only: BudgetObjectType, budgetobject_cr_bfr

Expand All @@ -24,6 +25,7 @@ module FlowModelInterfaceModule
type(ListType), pointer :: gwfbndlist => null() !< list of gwf stress packages
integer(I4B), pointer :: iflowsupdated => null() !< flows were updated for this time step
integer(I4B), dimension(:), pointer, contiguous :: ibound => null() !< pointer to Model ibound
class(DisBaseType), pointer :: gwfdis => null() !< flow model discretization object
real(DP), dimension(:), pointer, contiguous :: gwfflowja => null() !< pointer to the GWF flowja array
real(DP), dimension(:, :), pointer, contiguous :: gwfspdis => null() !< pointer to npf specific discharge array
real(DP), dimension(:), pointer, contiguous :: gwfhead => null() !< pointer to the GWF head array
Expand All @@ -37,12 +39,13 @@ module FlowModelInterfaceModule
integer(I4B), pointer :: iubud => null() !< unit number GWF budget file
integer(I4B), pointer :: iuhds => null() !< unit number GWF head file
integer(I4B), pointer :: iumvr => null() !< unit number GWF mover budget file
integer(I4B), pointer :: iugrb => null() !< unit number binary grid file
integer(I4B), pointer :: nflowpack => null() !< number of GWF flow packages
integer(I4B), dimension(:), pointer, contiguous :: igwfmvrterm => null() !< flag to indicate that gwf package is a mover term
type(BudgetFileReaderType) :: bfr !< budget file reader
type(HeadFileReaderType) :: hfr !< head file reader
type(PackageBudgetType), dimension(:), allocatable :: gwfpackages !< used to get flows between a package and gwf
type(BudgetObjectType), pointer :: mvrbudobj => null() !< pointer to the mover budget budget object
type(BudgetObjectType), pointer :: mvrbudobj => null() !< pointer to the mover budget object
character(len=16), dimension(:), allocatable :: flowpacknamearray !< array of boundary package names (e.g. LAK-1, SFR-3, etc.)
character(len=LENVARNAME) :: depvartype = ''

Expand All @@ -66,7 +69,6 @@ module FlowModelInterfaceModule
procedure :: initialize_hfr
procedure :: read_options
procedure :: read_packagedata

end type FlowModelInterfaceType

contains
Expand Down Expand Up @@ -110,6 +112,7 @@ subroutine fmi_df(this, dis, idryinactive)
if (this%inunit /= 0) then
call this%read_options()
end if

!
! -- Read packagedata options
if (this%inunit /= 0 .and. this%flows_from_file) then
Expand Down Expand Up @@ -151,6 +154,7 @@ subroutine fmi_da(this)
use MemoryManagerModule, only: mem_deallocate
! -- dummy
class(FlowModelInterfaceType) :: this

! -- todo: finalize hfr and bfr either here or in a finalize routine
!
! -- deallocate any memory stored with gwfpackages
Expand Down Expand Up @@ -181,6 +185,7 @@ subroutine fmi_da(this)
call mem_deallocate(this%iubud)
call mem_deallocate(this%iuhds)
call mem_deallocate(this%iumvr)
call mem_deallocate(this%iugrb)
call mem_deallocate(this%nflowpack)
call mem_deallocate(this%idryinactive)
!
Expand Down Expand Up @@ -208,6 +213,7 @@ subroutine allocate_scalars(this)
call mem_allocate(this%iubud, 'IUBUD', this%memoryPath)
call mem_allocate(this%iuhds, 'IUHDS', this%memoryPath)
call mem_allocate(this%iumvr, 'IUMVR', this%memoryPath)
call mem_allocate(this%iugrb, 'IUGRB', this%memoryPath)
call mem_allocate(this%nflowpack, 'NFLOWPACK', this%memoryPath)
call mem_allocate(this%idryinactive, "IDRYINACTIVE", this%memoryPath)
!
Expand All @@ -220,6 +226,7 @@ subroutine allocate_scalars(this)
this%iubud = 0
this%iuhds = 0
this%iumvr = 0
this%iugrb = 0
this%nflowpack = 0
this%idryinactive = 1
end subroutine allocate_scalars
Expand Down Expand Up @@ -346,12 +353,12 @@ subroutine read_packagedata(this)
iapt = 0
blockrequired = .true.
!
! -- get options block
! -- get packagedata block
call this%parser%GetBlock('PACKAGEDATA', isfound, ierr, &
blockRequired=blockRequired, &
supportOpenClose=.true.)
!
! -- parse options block if detected
! -- parse packagedata block if detected
if (isfound) then
write (this%iout, '(1x,a)') 'PROCESSING FMI PACKAGEDATA'
do
Expand Down Expand Up @@ -410,6 +417,19 @@ subroutine read_packagedata(this)
call budgetobject_cr_bfr(this%mvrbudobj, 'MVT', this%iumvr, &
this%iout)
call this%mvrbudobj%fill_from_bfr(this%dis, this%iout)
case ('GWFGRID')
call this%parser%GetStringCaps(keyword)
if (keyword /= 'FILEIN') then
call store_error('GWFGRID KEYWORD MUST BE FOLLOWED BY '// &
'"FILEIN" then by filename.')
call this%parser%StoreErrorUnit()
end if
call this%parser%GetString(fname)
inunit = getunit()
call openfile(inunit, this%iout, fname, 'DATA(BINARY)', FORM, &
ACCESS, 'UNKNOWN')
this%iugrb = inunit
this%gwfdis => load_grb(this%iugrb, this%iout)
case default
write (errmsg, '(a,3(1x,a))') &
'UNKNOWN', trim(adjustl(this%text)), 'PACKAGEDATA:', trim(keyword)
Expand All @@ -421,25 +441,18 @@ subroutine read_packagedata(this)
end subroutine read_packagedata

!> @brief Initialize the budget file reader
!<
subroutine initialize_bfr(this)
! -- modules
class(FlowModelInterfaceType) :: this
! -- dummy
integer(I4B) :: ncrbud
!
! -- Initialize the budget file reader
call this%bfr%initialize(this%iubud, this%iout, ncrbud)
!
! -- todo: need to run through the budget terms
! and do some checking
! todo: need to run through the budget terms
! and do some checking
end subroutine initialize_bfr

!> @brief Advance the budget file reader
!!
!! Advance the budget file reader by reading the next chunk
!! of information for the current time step and stress period.
!!
!<
subroutine advance_bfr(this)
! -- modules
Expand Down Expand Up @@ -586,35 +599,22 @@ subroutine advance_bfr(this)
end subroutine advance_bfr

!> @brief Finalize the budget file reader
!<
subroutine finalize_bfr(this)
! -- modules
class(FlowModelInterfaceType) :: this
! -- dummy
!
! -- Finalize the budget file reader
call this%bfr%finalize()
!
end subroutine finalize_bfr

!> @brief Initialize the head file reader
!<
subroutine initialize_hfr(this)
! -- modules
class(FlowModelInterfaceType) :: this
! -- dummy
!
! -- Initialize the budget file reader
call this%hfr%initialize(this%iuhds, this%iout)
!
! -- todo: need to run through the head terms
! and do some checking
! todo: need to run through the head terms
! and do some checking
end subroutine initialize_hfr

!> @brief Advance the head file reader
!<
subroutine advance_hfr(this)
! -- modules
! modules
use TdisModule, only: kstp, kper
class(FlowModelInterfaceType) :: this
integer(I4B) :: nu, nr, i, ilay
Expand Down Expand Up @@ -705,22 +705,15 @@ subroutine advance_hfr(this)
end subroutine advance_hfr

!> @brief Finalize the head file reader
!<
subroutine finalize_hfr(this)
! -- modules
class(FlowModelInterfaceType) :: this
! -- dummy
!
! -- Finalize the head file reader
close (this%iuhds)
!
end subroutine finalize_hfr

!> @brief Initialize gwf terms from budget file
!!
!! initialize terms and figure out how many
!! different terms and packages are contained within the file
!!
!<
subroutine initialize_gwfterms_from_bfr(this)
! -- modules
Expand Down Expand Up @@ -818,7 +811,6 @@ subroutine initialize_gwfterms_from_bfr(this)
end subroutine initialize_gwfterms_from_bfr

!> @brief Initialize gwf terms from a GWF exchange
!<
subroutine initialize_gwfterms_from_gwfbndlist(this)
! -- modules
use BndModule, only: BndType, GetBndFromList
Expand Down Expand Up @@ -918,22 +910,16 @@ subroutine allocate_gwfpackages(this, ngwfterms)
end subroutine allocate_gwfpackages

!> @brief Deallocate memory in the gwfpackages array
!<
subroutine deallocate_gwfpackages(this)
! -- modules
! -- dummy
class(FlowModelInterfaceType) :: this
! -- local
integer(I4B) :: n
!
! -- initialize

do n = 1, this%nflowpack
call this%gwfpackages(n)%da()
end do
end subroutine deallocate_gwfpackages

!> @brief Find the package index for the package with the given name
!<
subroutine get_package_index(this, name, idx)
use BndModule, only: BndType, GetBndFromList
class(FlowModelInterfaceType) :: this
Expand Down
1 change: 1 addition & 0 deletions src/Model/TransportModel/tsp-fmi.f90
Original file line number Diff line number Diff line change
Expand Up @@ -351,6 +351,7 @@ subroutine gwtfmi_da(this)
call mem_deallocate(this%iubud)
call mem_deallocate(this%iuhds)
call mem_deallocate(this%iumvr)
call mem_deallocate(this%iugrb)
call mem_deallocate(this%nflowpack)
call mem_deallocate(this%idryinactive)
!
Expand Down
Loading

0 comments on commit 0e5cbb9

Please sign in to comment.