MODFLOW 6  version 6.7.0.dev3
USGS Modular Hydrologic Model
gwfocmodule Module Reference

Data Types

type  gwfoctype
 @ brief Output control for GWF More...
 

Functions/Subroutines

subroutine, public oc_cr (ocobj, name_model, input_mempath, inunit, iout)
 @ brief Create GwfOcType More...
 
subroutine oc_ar (this, head, dis, dnodata)
 @ brief Allocate and read GwfOcType More...
 

Function/Subroutine Documentation

◆ oc_ar()

subroutine gwfocmodule::oc_ar ( class(gwfoctype this,
real(dp), dimension(:), intent(in), pointer, contiguous  head,
class(disbasetype), intent(in), pointer  dis,
real(dp), intent(in)  dnodata 
)
private

Setup head and budget as output control variables.

Parameters
thisGwfOcType object
[in]headmodel head
[in]dismodel discretization package
[in]dnodatano data value

Definition at line 55 of file gwf-oc.f90.

56  use constantsmodule, only: linelength
59  ! -- dummy
60  class(GwfOcType) :: this !< GwfOcType object
61  real(DP), dimension(:), pointer, contiguous, intent(in) :: head !< model head
62  class(DisBaseType), pointer, intent(in) :: dis !< model discretization package
63  real(DP), intent(in) :: dnodata !< no data value
64  ! -- local
65  integer(I4B) :: i, nocdobj, inodata
66  type(OutputControlDataType), pointer :: ocdobjptr
67  real(DP), dimension(:), pointer, contiguous :: nullvec => null()
68  character(len=LINELENGTH) :: headfile
69  type(GwfOcParamFoundType) :: found
70  !
71  ! -- Initialize variables
72  inodata = 0
73  nocdobj = 2
74  allocate (this%ocds(nocdobj))
75  do i = 1, nocdobj
76  call ocd_cr(ocdobjptr)
77  select case (i)
78  case (1)
79  call ocdobjptr%init_dbl('BUDGET', nullvec, dis, 'PRINT LAST ', &
80  'COLUMNS 10 WIDTH 11 DIGITS 4 GENERAL ', &
81  this%iout, dnodata)
82  case (2)
83  call ocdobjptr%init_dbl('HEAD', head, dis, 'PRINT LAST ', &
84  'COLUMNS 10 WIDTH 11 DIGITS 4 GENERAL ', &
85  this%iout, dnodata)
86  end select
87  this%ocds(i) = ocdobjptr
88  deallocate (ocdobjptr)
89  end do
90  !
91  ! -- Read options or set defaults if this package not on
92  if (this%input_mempath /= '') then
93  write (this%iout, '(/,1x,a,/)') 'PROCESSING OC OPTIONS'
94  call this%source_options()
95  call mem_set_value(headfile, 'HEADFILE', this%input_mempath, &
96  found%headfile)
97  if (found%headfile) then
98  call this%set_ocfile('HEAD', headfile, this%iout)
99  end if
100  write (this%iout, '(1x,a)') 'END OF OC OPTIONS'
101  end if
This module contains simulation constants.
Definition: Constants.f90:9
integer(i4b), parameter linelength
maximum length of a standard line
Definition: Constants.f90:45
Here is the call graph for this function:

◆ oc_cr()

subroutine, public gwfocmodule::oc_cr ( type(gwfoctype), pointer  ocobj,
character(len=*), intent(in)  name_model,
character(len=*), intent(in)  input_mempath,
integer(i4b), intent(in)  inunit,
integer(i4b), intent(in)  iout 
)

Create by allocating a new GwfOcType object and initializing member variables.

Parameters
ocobjGwfOcType object
[in]name_modelname of the model
[in]input_mempathinput mempath of the package
[in]inunitunit number for input
[in]ioutunit number for output

Definition at line 31 of file gwf-oc.f90.

32  ! -- dummy
33  type(GwfOcType), pointer :: ocobj !< GwfOcType object
34  character(len=*), intent(in) :: name_model !< name of the model
35  character(len=*), intent(in) :: input_mempath !< input mempath of the package
36  integer(I4B), intent(in) :: inunit !< unit number for input
37  integer(I4B), intent(in) :: iout !< unit number for output
38  !
39  ! -- Create the object
40  allocate (ocobj)
41  !
42  ! -- Allocate scalars
43  call ocobj%allocate_scalars(name_model, input_mempath)
44  !
45  ! -- Save unit numbers
46  ocobj%inunit = inunit
47  ocobj%iout = iout
Here is the caller graph for this function: