MODFLOW 6  version 6.6.0.dev0
USGS Modular Hydrologic Model
ncexportcreatemodule Module Reference

This module contains the NCExportCreateModule. More...

Functions/Subroutines

subroutine create_nc_export (export_model, num_model)
 create model netcdf export type More...
 
subroutine create_export_pkglist (pkglist, loaders, iout)
 
subroutine, public nc_export_create ()
 initialize netcdf model export type More...
 

Detailed Description

This module creates derived model netcdf export objects. It is dependent on netcdf libraries.

Function/Subroutine Documentation

◆ create_export_pkglist()

subroutine ncexportcreatemodule::create_export_pkglist ( type(listtype), intent(inout)  pkglist,
type(modeldynamicpkgstype), intent(in), pointer  loaders,
integer(i4b), intent(in)  iout 
)

Definition at line 140 of file NCExportCreate.f90.

141  use listmodule, only: listtype
148  type(ListType), intent(inout) :: pkglist
149  type(ModelDynamicPkgsType), pointer, intent(in) :: loaders
150  integer(I4B), intent(in) :: iout
151  class(DynamicPkgLoadBaseType), pointer :: dynamic_pkg
152  class(AsciiDynamicPkgLoadBaseType), pointer :: rp_loader
153  type(ExportPackageType), pointer :: export_pkg
154  integer(I4B), pointer :: export_arrays
155  class(*), pointer :: obj
156  logical(LGP) :: found
157  integer(I4B) :: n
158  !
159  ! -- create list of in scope loaders
160  allocate (export_arrays)
161  !
162  do n = 1, loaders%pkglist%Count()
163  !
164  ! -- initialize export arrays option
165  export_arrays = 0
166  !
167  dynamic_pkg => loaders%get(n)
168  !
169  ! -- update export arrays option
170  call mem_set_value(export_arrays, 'EXPORT_NC', &
171  dynamic_pkg%mf6_input%mempath, found)
172  !
173  if (export_arrays > 0 .and. dynamic_pkg%readasarrays) then
174  select type (dynamic_pkg)
175  type is (mf6filedynamicpkgloadtype)
176  !
177  rp_loader => dynamic_pkg%rp_loader
178  !
179  select type (rp_loader)
180  type is (boundgridinputtype)
181  ! -- create the export object
182  allocate (export_pkg)
183  call export_pkg%init(rp_loader%mf6_input, &
184  rp_loader%bound_context%mshape, &
185  rp_loader%param_names, rp_loader%nparam)
186  obj => export_pkg
187  call pkglist%add(obj)
188  !
189  end select
190  end select
191  end if
192  end do
193  !
194  ! -- cleanup
195  deallocate (export_arrays)
This module contains the AsciiInputLoadTypeModule.
This module contains the IdmMf6FileModule.
Definition: IdmMf6File.f90:10
This module contains the InputLoadTypeModule.
This module contains the Mf6FileGridInputModule.
base abstract type for ascii source dynamic load
MF6File dynamic loader type.
Definition: IdmMf6File.f90:39
Base abstract type for dynamic input loader.
type for storing a dynamic package load list
A generic heterogeneous doubly-linked list.
Definition: List.f90:14
Ascii grid based dynamic loader type.
Here is the caller graph for this function:

◆ create_nc_export()

subroutine ncexportcreatemodule::create_nc_export ( type(exportmodeltype), intent(inout), pointer  export_model,
class(numericalmodeltype), intent(in), pointer  num_model 
)
private

Definition at line 30 of file NCExportCreate.f90.

36  type(ExportModelType), pointer, intent(inout) :: export_model
37  class(NumericalModelType), pointer, intent(in) :: num_model
38  class(Mesh2dDisExportType), pointer :: ugrid_dis
39  class(Mesh2dDisvExportType), pointer :: ugrid_disv
40  class(DisNCStructuredType), pointer :: structured_dis
41  class(DisBaseType), pointer :: disbase
42  !
43  select case (export_model%disenum)
44  case (dis)
45  ! -- allocate nc structured grid export object
46  if (export_model%nctype == netcdf_ugrid) then
47  !
48  ! -- allocate nc structured grid export object
49  allocate (ugrid_dis)
50  !
51  ! -- set dis base type
52  disbase => num_model%dis
53  select type (disbase)
54  type is (distype)
55  ugrid_dis%dis => disbase
56  end select
57  !
58  ! -- set dynamic loaders
59  call create_export_pkglist(ugrid_dis%pkglist, export_model%loaders, &
60  export_model%iout)
61  !
62  ! -- initialize export object
63  call ugrid_dis%init(export_model%modelname, export_model%modeltype, &
64  export_model%modelfname, export_model%disenum, &
65  netcdf_ugrid, export_model%iout)
66  !
67  ! -- define export object
68  call ugrid_dis%df()
69  !
70  ! -- set base pointer
71  export_model%nc_export => ugrid_dis
72  else if (export_model%nctype == netcdf_structured) then
73  !
74  ! -- allocate nc structured grid export object
75  allocate (structured_dis)
76  !
77  ! -- set dis base type
78  disbase => num_model%dis
79  select type (disbase)
80  type is (distype)
81  structured_dis%dis => disbase
82  end select
83  !
84  ! -- set dynamic loaders
85  call create_export_pkglist(structured_dis%pkglist, export_model%loaders, &
86  export_model%iout)
87  !
88  ! -- initialize export object
89  call structured_dis%init(export_model%modelname, export_model%modeltype, &
90  export_model%modelfname, export_model%disenum, &
91  netcdf_structured, export_model%iout)
92  !
93  ! -- define export object
94  call structured_dis%df()
95  !
96  ! -- set base pointer
97  export_model%nc_export => structured_dis
98  end if
99  case (disv)
100  if (export_model%nctype == netcdf_ugrid) then
101  ! -- allocate nc structured grid export object
102  allocate (ugrid_disv)
103  !
104  ! -- set dis base type
105  disbase => num_model%dis
106  select type (disbase)
107  type is (disvtype)
108  ugrid_disv%disv => disbase
109  end select
110  !
111  ! -- set dynamic loaders
112  call create_export_pkglist(ugrid_disv%pkglist, export_model%loaders, &
113  export_model%iout)
114  !
115  ! -- initialize export object
116  call ugrid_disv%init(export_model%modelname, export_model%modeltype, &
117  export_model%modelfname, export_model%disenum, &
118  netcdf_ugrid, export_model%iout)
119  !
120  ! -- define export object
121  call ugrid_disv%df()
122  !
123  ! -- set base pointer
124  export_model%nc_export => ugrid_disv
125  else
126  errmsg = 'DISV model discretization only &
127  &supported as UGRID NetCDF export. &
128  &Model='//trim(export_model%modelname)//'.'
129  call store_error(errmsg)
130  call store_error_filename(export_model%modelfname)
131  end if
132  case default
133  errmsg = 'Unsupported discretization for NetCDF model export. &
134  &Model='//trim(export_model%modelname)//'.'
135  call store_error(errmsg)
136  call store_error_filename(export_model%modelfname)
137  end select
This module contains the DisNCStructuredModule.
This module contains the MeshDisModelModule.
Definition: DisNCMesh.f90:8
This module contains the MeshDisvModelModule.
Definition: DisvNCMesh.f90:8
This module contains the NCModelExportModule.
Definition: NCModel.f90:8
@, public netcdf_structured
netcdf structrured export
Definition: NCModel.f90:33
@, public netcdf_ugrid
netcdf mesh export
Definition: NCModel.f90:32
Here is the call graph for this function:
Here is the caller graph for this function:

◆ nc_export_create()

subroutine, public ncexportcreatemodule::nc_export_create

Definition at line 200 of file NCExportCreate.f90.

202  use listsmodule, only: basemodellist
204  integer(I4B) :: n
205  type(ExportModelType), pointer :: export_model
206  class(NumericalModelType), pointer :: num_model
207  integer(I4B) :: im
208  !
209  do n = 1, export_models%Count()
210  ! -- set pointer to export model
211  export_model => get_export_model(n)
212  if (export_model%nctype /= netcdf_undef) then
213  !
214  ! -- netcdf export is active identify model
215  do im = 1, basemodellist%Count()
216  !
217  ! -- set model pointer
218  num_model => getnumericalmodelfromlist(basemodellist, im)
219  if (num_model%name == export_model%modelname .and. &
220  num_model%macronym == export_model%modeltype) then
221  !
222  ! -- allocate and initialize nc export model
223  call create_nc_export(export_model, num_model)
224  exit
225  !
226  end if
227  end do
228  end if
229  end do
type(listtype), public basemodellist
Definition: mf6lists.f90:16
@, public netcdf_undef
undefined netcdf export type
Definition: NCModel.f90:31
class(numericalmodeltype) function, pointer, public getnumericalmodelfromlist(list, idx)
Here is the call graph for this function:
Here is the caller graph for this function: