MODFLOW 6  version 6.7.0.dev0
USGS Modular Hydrologic Model
tspocmodule Module Reference

Data Types

type  tspoctype
 @ brief Output control More...
 

Functions/Subroutines

subroutine, public oc_cr (ocobj, name_model, inunit, iout)
 @ brief Create TspOcType More...
 
subroutine oc_ar (this, depvar, dis, dnodata, dvname)
 @ brief Allocate and read TspOcType More...
 

Function/Subroutine Documentation

◆ oc_ar()

subroutine tspocmodule::oc_ar ( class(tspoctype this,
real(dp), dimension(:), intent(in), pointer, contiguous  depvar,
class(disbasetype), intent(in), pointer  dis,
real(dp), intent(in)  dnodata,
character(len=*), intent(in)  dvname 
)
private

Setup dependent variable (e.g., concentration or temperature) and budget as output control variables.

Parameters
thisTspOcType object
[in]depvarmodel concentration
[in]dvnamename of dependent variable solved by generalized transport model (concentration, temperature)
[in]dismodel discretization package
[in]dnodatano data value

Definition at line 57 of file tsp-oc.f90.

58  ! -- dummy
59  class(TspOcType) :: this !< TspOcType object
60  real(DP), dimension(:), pointer, contiguous, intent(in) :: depvar !< model concentration
61  character(len=*), intent(in) :: dvname !< name of dependent variable solved by generalized transport model (concentration, temperature)
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  !
69  ! -- Initialize variables
70  inodata = 0
71  nocdobj = 2
72  allocate (this%ocds(nocdobj))
73  do i = 1, nocdobj
74  call ocd_cr(ocdobjptr)
75  select case (i)
76  case (1)
77  call ocdobjptr%init_dbl('BUDGET', nullvec, dis, 'PRINT LAST ', &
78  'COLUMNS 10 WIDTH 11 DIGITS 4 GENERAL ', &
79  this%iout, dnodata)
80  case (2)
81  call ocdobjptr%init_dbl(trim(dvname), depvar, dis, 'PRINT LAST ', &
82  'COLUMNS 10 WIDTH 11 DIGITS 4 GENERAL ', &
83  this%iout, dnodata)
84  end select
85  this%ocds(i) = ocdobjptr
86  deallocate (ocdobjptr)
87  end do
88  !
89  ! -- Read options or set defaults if this package not on
90  if (this%inunit > 0) then
91  call this%read_options()
92  end if
Here is the call graph for this function:

◆ oc_cr()

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

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

Parameters
ocobjTspOcType object
[in]name_modelname of the model
[in]inunitunit number for input
[in]ioutunit number for output

Definition at line 30 of file tsp-oc.f90.

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