49 character(len=LENLISTLABEL),
pointer :: listlabel => null()
50 character(len=LENPACKAGENAME) :: text =
''
51 character(len=LENAUXNAME),
dimension(:),
pointer, &
52 contiguous :: auxname => null()
54 contiguous :: auxname_cst => null()
55 character(len=LENBOUNDNAME),
dimension(:),
pointer, &
56 contiguous :: boundname => null()
58 contiguous :: boundname_cst => null()
61 integer(I4B),
pointer :: isadvpak => null()
62 integer(I4B),
pointer :: ibcnum => null()
63 integer(I4B),
pointer :: maxbound => null()
64 integer(I4B),
pointer :: nbound => null()
65 integer(I4B),
pointer :: ncolbnd => null()
66 integer(I4B),
pointer :: iscloc => null()
67 integer(I4B),
pointer :: naux => null()
68 integer(I4B),
pointer :: inamedbound => null()
69 integer(I4B),
pointer :: iauxmultcol => null()
70 integer(I4B),
pointer :: npakeq => null()
71 integer(I4B),
pointer :: ioffset => null()
73 integer(I4B),
dimension(:),
pointer,
contiguous :: nodelist => null()
74 integer(I4B),
dimension(:),
pointer,
contiguous :: noupdateauxvar => null()
75 real(dp),
dimension(:, :),
pointer,
contiguous :: bound => null()
76 real(dp),
dimension(:),
pointer,
contiguous :: hcof => null()
77 real(dp),
dimension(:),
pointer,
contiguous :: rhs => null()
78 real(dp),
dimension(:, :),
pointer,
contiguous :: auxvar => null()
79 real(dp),
dimension(:),
pointer,
contiguous :: simvals => null()
80 real(dp),
dimension(:),
pointer,
contiguous :: simtomvr => null()
83 integer(I4B),
pointer :: imover => null()
87 integer(I4B),
pointer :: ivsc => null()
88 real(dp),
dimension(:),
pointer,
contiguous :: condinput => null()
93 integer(I4B) :: indxconvertflux = 0
94 logical(LGP) :: allowtimearrayseries = .false.
97 integer(I4B),
pointer :: inobspkg => null()
101 integer(I4B),
pointer :: neq
102 integer(I4B),
dimension(:),
pointer,
contiguous :: ibound => null()
103 real(dp),
dimension(:),
pointer,
contiguous :: xnew => null()
104 real(dp),
dimension(:),
pointer,
contiguous :: xold => null()
105 real(dp),
dimension(:),
pointer,
contiguous :: flowja => null()
106 integer(I4B),
dimension(:),
pointer,
contiguous :: icelltype => null()
107 character(len=LENMEMPATH) :: ictmempath =
''
180 class(
bndtype),
intent(inout) :: this
181 integer(I4B),
intent(inout) :: neq
189 call tasmanager_cr(this%TasManager, dis, this%name_model, this%iout)
192 call obs_cr(this%obs, this%inobspkg)
195 write (this%iout, 1) this%filtyp, trim(adjustl(this%text)), this%inunit
196 1
format(1x, /1x, a,
' -- ', a,
' PACKAGE, VERSION 8, 2/22/2014', &
197 ' INPUT READ FROM UNIT ', i0)
200 call this%parser%Initialize(this%inunit, this%iout)
203 call this%read_options()
207 call this%tsmanager%tsmanager_df()
208 call this%tasmanager%tasmanager_df()
211 call this%read_dimensions()
214 if (this%npakeq > 0)
then
215 this%ioffset = neq - this%dis%nodes
219 neq = neq + this%npakeq
222 if (this%bnd_obs_supported())
then
223 call this%obs%obs_df(this%iout, this%packName, this%filtyp, this%dis)
224 call this%bnd_df_obs()
239 class(
bndtype),
intent(inout) :: this
240 integer(I4B),
intent(in) :: moffset
250 subroutine bnd_mc(this, moffset, matrix_sln)
252 class(
bndtype),
intent(inout) :: this
253 integer(I4B),
intent(in) :: moffset
267 class(
bndtype),
intent(inout) :: this
270 call this%obs%obs_ar()
273 call this%allocate_arrays()
276 call this%read_initial_attr()
279 if (this%imover == 1)
then
280 allocate (this%pakmvrobj)
281 call this%pakmvrobj%ar(this%maxbound, 0, this%memoryPath)
295 class(
bndtype),
intent(inout) :: this
298 integer(I4B) :: nlist
299 logical(LGP) :: isfound
300 character(len=LINELENGTH) :: line
302 character(len=*),
parameter :: fmtblkerr = &
303 &
"('Looking for BEGIN PERIOD iper. Found ', a, ' instead.')"
304 character(len=*),
parameter :: fmtlsp = &
305 &
"(1X,/1X,'REUSING ',A,'S FROM LAST STRESS PERIOD')"
306 character(len=*),
parameter :: fmtnbd = &
307 "(1X,/1X,'THE NUMBER OF ACTIVE ',A,'S (',I6, &
308 &') IS GREATER THAN MAXIMUM(',I6,')')"
312 if (this%inunit == 0)
return
315 if (this%ionper <
kper)
then
318 call this%parser%GetBlock(
'PERIOD', isfound, ierr, &
319 supportopenclose=.true., &
320 blockrequired=.false.)
324 call this%read_check_ionper()
330 this%ionper =
nper + 1
333 call this%parser%GetCurrentLine(line)
334 write (
errmsg, fmtblkerr) adjustl(trim(line))
336 call this%parser%StoreErrorUnit()
342 if (this%ionper ==
kper)
then
346 call this%TsManager%Reset(this%packName)
347 call this%TasManager%Reset(this%packName)
350 call this%dis%read_list(this%parser%line_reader, &
351 this%parser%iuactive, this%iout, &
352 this%iprpak, nlist, this%inamedbound, &
353 this%iauxmultcol, this%nodelist, &
354 this%bound, this%auxvar, this%auxname, &
355 this%boundname, this%listlabel, &
356 this%packName, this%tsManager, this%iscloc)
360 if (this%ivsc == 1)
then
361 call this%bnd_store_user_cond(nlist, this%bound, this%condinput)
368 call this%bnd_rp_ts()
371 call this%parser%terminateblock()
374 call this%copy_boundname()
377 write (this%iout, fmtlsp) trim(this%filtyp)
392 real(DP) :: begintime, endtime
396 endtime = begintime +
delt
399 call this%TsManager%ad()
400 call this%TasManager%ad()
405 call this%obs%obs_ad()
415 class(
bndtype),
intent(inout) :: this
426 if (this%imover == 1)
then
427 call this%pakmvrobj%reset()
453 subroutine bnd_fc(this, rhs, ia, idxglo, matrix_sln)
456 real(DP),
dimension(:),
intent(inout) :: rhs
457 integer(I4B),
dimension(:),
intent(in) :: ia
458 integer(I4B),
dimension(:),
intent(in) :: idxglo
466 do i = 1, this%nbound
468 rhs(n) = rhs(n) + this%rhs(i)
470 call matrix_sln%add_value_pos(idxglo(ipos), this%hcof(i))
481 subroutine bnd_fn(this, rhs, ia, idxglo, matrix_sln)
484 real(DP),
dimension(:),
intent(inout) :: rhs
485 integer(I4B),
dimension(:),
intent(in) :: ia
486 integer(I4B),
dimension(:),
intent(in) :: idxglo
501 subroutine bnd_nur(this, neqpak, x, xtemp, dx, inewtonur, dxmax, locmax)
503 class(
bndtype),
intent(inout) :: this
504 integer(I4B),
intent(in) :: neqpak
505 real(DP),
dimension(neqpak),
intent(inout) :: x
506 real(DP),
dimension(neqpak),
intent(in) :: xtemp
507 real(DP),
dimension(neqpak),
intent(inout) :: dx
508 integer(I4B),
intent(inout) :: inewtonur
509 real(DP),
intent(inout) :: dxmax
510 integer(I4B),
intent(inout) :: locmax
526 subroutine bnd_cc(this, innertot, kiter, iend, icnvgmod, cpak, ipak, dpak)
528 class(
bndtype),
intent(inout) :: this
529 integer(I4B),
intent(in) :: innertot
530 integer(I4B),
intent(in) :: kiter
531 integer(I4B),
intent(in) :: iend
532 integer(I4B),
intent(in) :: icnvgmod
533 character(len=LENPAKLOC),
intent(inout) :: cpak
534 integer(I4B),
intent(inout) :: ipak
535 real(DP),
intent(inout) :: dpak
547 class(
bndtype),
intent(inout) :: this
548 real(DP),
dimension(:),
intent(in) :: x
549 real(DP),
dimension(:),
contiguous,
intent(inout) :: flowja
550 integer(I4B),
optional,
intent(in) :: iadv
552 integer(I4B) :: imover
556 if (
present(iadv))
then
571 call this%bnd_cq_simrate(x, flowja, imover)
572 if (imover == 1)
then
573 call this%bnd_cq_simtomvr(flowja)
586 real(DP),
dimension(:),
intent(in) :: hnew
587 real(DP),
dimension(:),
intent(inout) :: flowja
588 integer(I4B),
intent(in) :: imover
592 integer(I4B) :: idiag
596 if (this%nbound > 0)
then
599 do i = 1, this%nbound
600 node = this%nodelist(i)
605 idiag = this%dis%con%ia(node)
606 if (this%ibound(node) > 0)
then
609 rrate = this%hcof(i) * hnew(node) - this%rhs(i)
611 flowja(idiag) = flowja(idiag) + rrate
615 this%simvals(i) = rrate
630 real(DP),
dimension(:),
intent(inout) :: flowja
639 if (this%nbound > 0)
then
642 do i = 1, this%nbound
643 node = this%nodelist(i)
648 if (this%ibound(node) > 0)
then
654 rrate = this%pakmvrobj%get_qtomvr(i)
663 if (fact >
done)
then
673 if (rrate >
dzero)
then
681 this%simtomvr(i) = rrate
699 type(
budgettype),
intent(inout) :: model_budget
701 character(len=LENPACKAGENAME) :: text
704 integer(I4B) :: isuppress_output
711 call model_budget%addentry(ratin, ratout,
delt, this%text, &
712 isuppress_output, this%packName)
713 if (this%imover == 1 .and. this%isadvpak == 0)
then
714 text = trim(adjustl(this%text))//
'-TO-MVR'
717 call model_budget%addentry(ratin, ratout,
delt, text, &
718 isuppress_output, this%packName)
731 integer(I4B),
intent(in) :: icbcfl
732 integer(I4B),
intent(in) :: ibudfl
746 integer(I4B),
intent(in) :: idvsave
747 integer(I4B),
intent(in) :: idvprint
761 integer(I4B),
intent(in) :: kstp
762 integer(I4B),
intent(in) :: kper
763 integer(I4B),
intent(in) :: iout
764 integer(I4B),
intent(in) :: ibudfl
778 integer(I4B),
intent(in) :: icbcfl
779 integer(I4B),
intent(in) :: ibudfl
780 integer(I4B),
intent(in) :: icbcun
781 integer(I4B),
dimension(:),
optional,
intent(in) :: imap
783 character(len=LINELENGTH) :: title
784 character(len=LENPACKAGENAME) :: text
785 integer(I4B) :: imover
788 title = trim(adjustl(this%text))//
' PACKAGE ('//trim(this%packName)// &
790 if (
present(imap))
then
792 this%outputtab, this%nbound, this%nodelist, &
793 this%simvals, this%ibound, title, this%text, &
794 this%ipakcb, this%dis, this%naux, &
795 this%name_model, this%name_model, &
796 this%name_model, this%packName, &
797 this%auxname, this%auxvar, this%iout, &
798 this%inamedbound, this%boundname, imap)
801 this%outputtab, this%nbound, this%nodelist, &
802 this%simvals, this%ibound, title, this%text, &
803 this%ipakcb, this%dis, this%naux, &
804 this%name_model, this%name_model, &
805 this%name_model, this%packName, &
806 this%auxname, this%auxvar, this%iout, &
807 this%inamedbound, this%boundname)
815 if (this%isadvpak /= 0) imover = 0
816 if (imover == 1)
then
817 text = trim(adjustl(this%text))//
'-TO-MVR'
819 title = trim(adjustl(this%text))//
' PACKAGE ('// &
820 trim(this%packName)//
') FLOW RATES TO-MVR'
822 this%outputtab, this%nbound, this%nodelist, &
823 this%simtomvr, this%ibound, title, text, &
824 this%ipakcb, this%dis, this%naux, &
825 this%name_model, this%name_model, &
826 this%name_model, this%packName, &
827 this%auxname, this%auxvar, this%iout, &
828 this%inamedbound, this%boundname)
846 call mem_deallocate(this%noupdateauxvar,
'NOUPDATEAUXVAR', this%memoryPath)
855 call mem_deallocate(this%boundname_cst,
'BOUNDNAME_CST', this%memoryPath)
857 call mem_deallocate(this%auxname_cst,
'AUXNAME_CST', this%memoryPath)
858 nullify (this%icelltype)
861 if (this%imover /= 0)
then
862 call this%pakmvrobj%da()
863 deallocate (this%pakmvrobj)
864 nullify (this%pakmvrobj)
868 if (
associated(this%inputtab))
then
869 call this%inputtab%table_da()
870 deallocate (this%inputtab)
871 nullify (this%inputtab)
875 if (
associated(this%outputtab))
then
876 call this%outputtab%table_da()
877 deallocate (this%outputtab)
878 nullify (this%outputtab)
882 if (
associated(this%errortab))
then
883 call this%errortab%table_da()
884 deallocate (this%errortab)
885 nullify (this%errortab)
908 call this%obs%obs_da()
909 call this%TsManager%da()
910 call this%TasManager%da()
913 deallocate (this%obs)
914 deallocate (this%TsManager)
915 deallocate (this%TasManager)
916 nullify (this%TsManager)
917 nullify (this%TasManager)
920 call this%NumericalPackageType%da()
936 integer(I4B),
pointer :: imodelnewton => null()
939 call this%NumericalPackageType%allocate_scalars()
946 call mem_allocate(this%isadvpak,
'ISADVPAK', this%memoryPath)
947 call mem_allocate(this%ibcnum,
'IBCNUM', this%memoryPath)
948 call mem_allocate(this%maxbound,
'MAXBOUND', this%memoryPath)
949 call mem_allocate(this%nbound,
'NBOUND', this%memoryPath)
950 call mem_allocate(this%ncolbnd,
'NCOLBND', this%memoryPath)
951 call mem_allocate(this%iscloc,
'ISCLOC', this%memoryPath)
953 call mem_allocate(this%inamedbound,
'INAMEDBOUND', this%memoryPath)
954 call mem_allocate(this%iauxmultcol,
'IAUXMULTCOL', this%memoryPath)
955 call mem_allocate(this%inobspkg,
'INOBSPKG', this%memoryPath)
958 call mem_allocate(this%imover,
'IMOVER', this%memoryPath)
964 call mem_allocate(this%npakeq,
'NPAKEQ', this%memoryPath)
965 call mem_allocate(this%ioffset,
'IOFFSET', this%memoryPath)
968 allocate (this%TsManager)
969 allocate (this%TasManager)
994 this%inewton = imodelnewton
995 imodelnewton => null()
1009 integer(I4B),
dimension(:),
pointer,
contiguous,
optional :: nodelist
1010 real(DP),
dimension(:, :),
pointer,
contiguous,
optional :: auxvar
1016 if (
present(nodelist))
then
1017 this%nodelist => nodelist
1019 call mem_allocate(this%nodelist, this%maxbound,
'NODELIST', &
1021 do j = 1, this%maxbound
1022 this%nodelist(j) = 0
1028 call mem_allocate(this%noupdateauxvar, this%naux,
'NOUPDATEAUXVAR', &
1030 this%noupdateauxvar(:) = 0
1033 call mem_allocate(this%bound, this%ncolbnd, this%maxbound,
'BOUND', &
1038 call mem_allocate(this%condinput, 0,
'CONDINPUT', this%memoryPath)
1041 call mem_allocate(this%hcof, this%maxbound,
'HCOF', this%memoryPath)
1042 call mem_allocate(this%rhs, this%maxbound,
'RHS', this%memoryPath)
1045 call mem_allocate(this%simvals, this%maxbound,
'SIMVALS', this%memoryPath)
1046 if (this%imover == 1)
then
1047 call mem_allocate(this%simtomvr, this%maxbound,
'SIMTOMVR', &
1049 do i = 1, this%maxbound
1050 this%simtomvr(i) =
dzero
1053 call mem_allocate(this%simtomvr, 0,
'SIMTOMVR', this%memoryPath)
1057 if (
present(auxvar))
then
1058 this%auxvar => auxvar
1060 call mem_allocate(this%auxvar, this%naux, this%maxbound,
'AUXVAR', &
1062 do i = 1, this%maxbound
1064 this%auxvar(j, i) =
dzero
1070 if (this%inamedbound /= 0)
then
1072 'BOUNDNAME', this%memoryPath)
1074 'BOUNDNAME_CST', this%memoryPath)
1077 'BOUNDNAME', this%memoryPath)
1079 'BOUNDNAME_CST', this%memoryPath)
1085 if (this%ictMemPath /=
'')
then
1086 call mem_setptr(this%icelltype,
'ICELLTYPE', this%ictMemPath)
1090 do j = 1, this%maxbound
1091 do i = 1, this%ncolbnd
1092 this%bound(i, j) =
dzero
1095 do i = 1, this%maxbound
1096 this%hcof(i) =
dzero
1101 call this%pak_setup_outputtab()
1123 integer(I4B),
pointer :: neq
1124 integer(I4B),
dimension(:),
pointer,
contiguous :: ibound
1125 real(DP),
dimension(:),
pointer,
contiguous :: xnew
1126 real(DP),
dimension(:),
pointer,
contiguous :: xold
1127 real(DP),
dimension(:),
pointer,
contiguous :: flowja
1131 this%ibound => ibound
1134 this%flowja => flowja
1146 class(
bndtype),
intent(inout) :: this
1148 character(len=:),
allocatable :: line
1149 character(len=LINELENGTH) :: fname
1150 character(len=LINELENGTH) :: keyword
1151 character(len=LENAUXNAME) :: sfacauxname
1152 character(len=LENAUXNAME),
dimension(:),
allocatable :: caux
1153 integer(I4B) :: lloc
1154 integer(I4B) :: istart
1155 integer(I4B) :: istop
1157 integer(I4B) :: ierr
1158 integer(I4B) :: inobs
1159 logical(LGP) :: isfound
1160 logical(LGP) :: endOfBlock
1161 logical(LGP) :: foundchildclassoption
1163 character(len=*),
parameter :: fmtflow = &
1164 &
"(4x, 'FLOWS WILL BE SAVED TO FILE: ', a, /4x, 'OPENED ON UNIT: ', I7)"
1165 character(len=*),
parameter :: fmtflow2 = &
1166 &
"(4x, 'FLOWS WILL BE SAVED TO BUDGET FILE SPECIFIED IN OUTPUT CONTROL')"
1167 character(len=*),
parameter :: fmttas = &
1168 &
"(4x, 'TIME-ARRAY SERIES DATA WILL BE READ FROM FILE: ', a)"
1169 character(len=*),
parameter :: fmtts = &
1170 &
"(4x, 'TIME-SERIES DATA WILL BE READ FROM FILE: ', a)"
1171 character(len=*),
parameter :: fmtnme = &
1177 call this%parser%GetBlock(
'OPTIONS', isfound, ierr, &
1178 supportopenclose=.true., blockrequired=.false.)
1182 write (this%iout,
'(/1x,a)')
'PROCESSING '//trim(adjustl(this%text)) &
1185 call this%parser%GetNextLine(endofblock)
1186 if (endofblock)
then
1189 call this%parser%GetStringCaps(keyword)
1190 select case (keyword)
1191 case (
'AUX',
'AUXILIARY')
1192 call this%parser%GetRemainingLine(line)
1194 call urdaux(this%naux, this%parser%iuactive, this%iout, lloc, &
1195 istart, istop, caux, line, this%text)
1197 'AUXNAME', this%memoryPath)
1199 'AUXNAME_CST', this%memoryPath)
1201 this%auxname(n) = caux(n)
1202 this%auxname_cst(n) = caux(n)
1207 write (this%iout, fmtflow2)
1208 case (
'PRINT_INPUT')
1210 write (this%iout,
'(4x,a)') &
1211 'LISTS OF '//trim(adjustl(this%text))//
' CELLS WILL BE PRINTED.'
1212 case (
'PRINT_FLOWS')
1214 write (this%iout,
'(4x,a)') trim(adjustl(this%text))// &
1215 ' FLOWS WILL BE PRINTED TO LISTING FILE.'
1217 this%inamedbound = 1
1218 write (this%iout,
'(4x,a)') trim(adjustl(this%text))// &
1219 ' BOUNDARIES HAVE NAMES IN LAST COLUMN.'
1221 call this%parser%GetStringCaps(keyword)
1222 if (trim(adjustl(keyword)) /=
'FILEIN')
then
1223 errmsg =
'TS6 keyword must be followed by "FILEIN" '// &
1227 call this%parser%GetString(fname)
1228 write (this%iout, fmtts) trim(fname)
1229 call this%TsManager%add_tsfile(fname, this%inunit)
1231 if (this%AllowTimeArraySeries)
then
1232 if (.not. this%dis%supports_layers())
then
1233 errmsg =
'TAS6 FILE cannot be used '// &
1234 'with selected discretization type.'
1238 errmsg =
'The '//trim(this%filtyp)// &
1239 ' package does not support TIMEARRAYSERIESFILE'
1241 call this%parser%StoreErrorUnit()
1243 call this%parser%GetStringCaps(keyword)
1244 if (trim(adjustl(keyword)) /=
'FILEIN')
then
1245 errmsg =
'TAS6 keyword must be followed by "FILEIN" '// &
1248 call this%parser%StoreErrorUnit()
1250 call this%parser%GetString(fname)
1251 write (this%iout, fmttas) trim(fname)
1252 call this%TasManager%add_tasfile(fname)
1253 case (
'AUXMULTNAME')
1254 call this%parser%GetStringCaps(sfacauxname)
1255 this%iauxmultcol = -1
1256 write (this%iout,
'(4x,a,a)') &
1257 'AUXILIARY MULTIPLIER NAME: ', sfacauxname
1259 call this%parser%GetStringCaps(keyword)
1260 if (trim(adjustl(keyword)) /=
'FILEIN')
then
1261 errmsg =
'OBS6 keyword must be followed by "FILEIN" '// &
1264 call this%parser%StoreErrorUnit()
1266 if (this%obs%active)
then
1267 errmsg =
'Multiple OBS6 keywords detected in OPTIONS block. '// &
1268 'Only one OBS6 entry allowed for a package.'
1271 this%obs%active = .true.
1272 call this%parser%GetString(this%obs%inputFilename)
1274 call openfile(inobs, this%iout, this%obs%inputFilename,
'OBS')
1275 this%obs%inUnitObs = inobs
1281 case (
'DEV_NO_NEWTON')
1282 call this%parser%DevOpt()
1284 write (this%iout,
'(4x,a)') &
1285 'NEWTON-RAPHSON method disabled for unconfined cells'
1289 call this%bnd_options(keyword, foundchildclassoption)
1292 if (.not. foundchildclassoption)
then
1293 write (
errmsg,
'(a,3(1x,a))') &
1294 'UNKNOWN', trim(adjustl(this%text)),
'OPTION:', trim(keyword)
1299 write (this%iout,
'(1x,a)') &
1300 'END OF '//trim(adjustl(this%text))//
' OPTIONS'
1302 write (this%iout,
'(1x,a)')
'NO '//trim(adjustl(this%text))// &
1303 ' OPTION BLOCK DETECTED.'
1307 if (this%iauxmultcol < 0)
then
1310 if (this%naux == 0)
then
1311 write (
errmsg,
'(a,2(1x,a))') &
1312 'AUXMULTNAME was specified as', trim(adjustl(sfacauxname)), &
1313 'but no AUX variables specified.'
1318 this%iauxmultcol = 0
1320 if (sfacauxname == this%auxname(n))
then
1321 this%iauxmultcol = n
1327 if (this%iauxmultcol == 0)
then
1328 write (
errmsg,
'(a,2(1x,a))') &
1329 'AUXMULTNAME was specified as', trim(adjustl(sfacauxname)), &
1330 'but no AUX variable found with this name.'
1337 call this%parser%StoreErrorUnit()
1349 class(
bndtype),
intent(inout) :: this
1351 character(len=LINELENGTH) :: keyword
1352 logical(LGP) :: isfound
1353 logical(LGP) :: endOfBlock
1354 integer(I4B) :: ierr
1357 call this%parser%GetBlock(
'DIMENSIONS', isfound, ierr, &
1358 supportopenclose=.true.)
1362 write (this%iout,
'(/1x,a)')
'PROCESSING '//trim(adjustl(this%text))// &
1365 call this%parser%GetNextLine(endofblock)
1366 if (endofblock)
exit
1367 call this%parser%GetStringCaps(keyword)
1368 select case (keyword)
1370 this%maxbound = this%parser%GetInteger()
1371 write (this%iout,
'(4x,a,i7)')
'MAXBOUND = ', this%maxbound
1373 write (
errmsg,
'(a,3(1x,a))') &
1374 'Unknown', trim(this%text),
'dimension:', trim(keyword)
1379 write (this%iout,
'(1x,a)') &
1380 'END OF '//trim(adjustl(this%text))//
' DIMENSIONS'
1382 call store_error(
'Required DIMENSIONS block not found.')
1383 call this%parser%StoreErrorUnit()
1387 if (this%maxbound <= 0)
then
1388 write (
errmsg,
'(a)')
'MAXBOUND must be an integer greater than zero.'
1394 call this%parser%StoreErrorUnit()
1399 call this%define_listlabel()
1414 class(
bndtype),
intent(inout) :: this
1415 integer(I4B),
intent(in) :: nlist
1416 real(DP),
dimension(:, :),
pointer,
contiguous,
intent(in) :: rlist
1417 real(DP),
dimension(:),
pointer,
contiguous,
intent(inout) :: condinput
1423 condinput(l) = rlist(2, l)
1435 class(
bndtype),
intent(inout) :: this
1446 class(
bndtype),
intent(inout) :: this
1447 character(len=*),
intent(inout) :: option
1448 logical(LGP),
intent(inout) :: found
1461 class(
bndtype),
intent(inout) :: this
1467 if (this%inamedbound /= 0)
then
1468 do i = 1,
size(this%boundname)
1469 this%boundname_cst(i) = this%boundname(i)
1481 class(
bndtype),
intent(inout) :: this
1483 character(len=LINELENGTH) :: title
1484 character(len=LINELENGTH) :: text
1485 integer(I4B) :: ntabcol
1488 if (this%iprflow /= 0)
then
1492 if (this%inamedbound > 0)
then
1493 ntabcol = ntabcol + 1
1497 title = trim(adjustl(this%text))//
' PACKAGE ('//trim(this%packName)// &
1499 call table_cr(this%outputtab, this%packName, title)
1500 call this%outputtab%table_df(this%maxbound, ntabcol, this%iout, &
1503 call this%outputtab%initialize_column(text, 10, alignment=
tabcenter)
1505 call this%outputtab%initialize_column(text, 20, alignment=
tableft)
1507 call this%outputtab%initialize_column(text, 15, alignment=
tabcenter)
1508 if (this%inamedbound > 0)
then
1510 call this%outputtab%initialize_column(text,
lenboundname, &
1523 class(
bndtype),
intent(inout) :: this
1538 logical(LGP) :: supported
1568 class(
bndtype),
intent(inout) :: this
1573 character(len=LENBOUNDNAME) :: bname
1574 logical(LGP) :: jfound
1576 if (.not. this%bnd_obs_supported())
return
1578 do i = 1, this%obs%npakobs
1579 obsrv => this%obs%pakobs(i)%obsrv
1583 call obsrv%ResetObsIndex()
1584 obsrv%BndFound = .false.
1586 bname = obsrv%FeatureName
1587 if (bname /=
'')
then
1593 do j = 1, this%nbound
1594 if (this%boundname(j) == bname)
then
1596 obsrv%BndFound = .true.
1597 obsrv%CurrentTimeStepEndValue =
dzero
1598 call obsrv%AddObsIndex(j)
1605 jloop:
do j = 1, this%nbound
1606 if (this%nodelist(j) == obsrv%NodeNumber)
then
1608 obsrv%BndFound = .true.
1609 obsrv%CurrentTimeStepEndValue =
dzero
1610 call obsrv%AddObsIndex(j)
1638 call this%obs%obs_bd_clear()
1641 do i = 1, this%obs%npakobs
1642 obsrv => this%obs%pakobs(i)%obsrv
1643 if (obsrv%BndFound)
then
1644 do n = 1, obsrv%indxbnds_count
1645 if (obsrv%ObsTypeId ==
'TO-MVR')
then
1646 if (this%imover == 1)
then
1647 v = this%pakmvrobj%get_qtomvr(obsrv%indxbnds(n))
1655 v = this%simvals(obsrv%indxbnds(n))
1657 call this%obs%SaveOneSimval(obsrv, v)
1660 call this%obs%SaveOneSimval(obsrv,
dnodata)
1675 call this%obs%obs_ot()
1688 class(
bndtype),
intent(inout) :: this
1698 class(*),
pointer,
intent(inout) :: obj
1699 class(
bndtype),
pointer :: res
1705 if (.not.
associated(obj))
return
1720 type(
listtype),
intent(inout) :: list
1721 class(
bndtype),
pointer,
intent(inout) :: bnd
1723 class(*),
pointer :: obj
1737 type(
listtype),
intent(inout) :: list
1738 integer(I4B),
intent(in) :: idx
1739 class(
bndtype),
pointer :: res
1741 class(*),
pointer :: obj
1744 obj => list%GetItem(idx)
1754 outputtab, nbound, nodelist, flow, ibound, &
1755 title, text, ipakcb, dis, naux, textmodel, &
1756 textpackage, dstmodel, dstpackage, &
1757 auxname, auxvar, iout, inamedbound, &
1762 integer(I4B),
intent(in) :: icbcfl
1763 integer(I4B),
intent(in) :: ibudfl
1764 integer(I4B),
intent(in) :: icbcun
1765 integer(I4B),
intent(in) :: iprflow
1766 type(
tabletype),
pointer,
intent(inout) :: outputtab
1767 integer(I4B),
intent(in) :: nbound
1768 integer(I4B),
dimension(:),
contiguous,
intent(in) :: nodelist
1769 real(dp),
dimension(:),
contiguous,
intent(in) :: flow
1770 integer(I4B),
dimension(:),
contiguous,
intent(in) :: ibound
1771 character(len=*),
intent(in) :: title
1772 character(len=*),
intent(in) :: text
1773 integer(I4B),
intent(in) :: ipakcb
1775 integer(I4B),
intent(in) :: naux
1776 character(len=*),
intent(in) :: textmodel
1777 character(len=*),
intent(in) :: textpackage
1778 character(len=*),
intent(in) :: dstmodel
1779 character(len=*),
intent(in) :: dstpackage
1780 character(len=*),
dimension(:),
intent(in) :: auxname
1781 real(dp),
dimension(:, :),
intent(in) :: auxvar
1782 integer(I4B),
intent(in) :: iout
1783 integer(I4B),
intent(in) :: inamedbound
1784 character(len=LENBOUNDNAME),
dimension(:),
contiguous :: boundname
1785 integer(I4B),
dimension(:),
optional,
intent(in) :: imap
1787 character(len=20) :: nodestr
1788 integer(I4B) :: nodeu
1789 integer(I4B) :: maxrows
1791 integer(I4B) :: node
1793 integer(I4B) :: ibinun
1794 integer(I4B) :: nboundcount
1796 real(dp),
dimension(naux) :: auxrow
1798 character(len=LENBOUNDNAME) :: bname
1801 if (iprflow /= 0)
then
1802 call outputtab%set_kstpkper(
kstp,
kper)
1807 if (ibudfl /= 0 .and. iprflow /= 0)
then
1811 maxrows = maxrows + 1
1814 if (maxrows > 0)
then
1815 call outputtab%set_maxbound(maxrows)
1817 call outputtab%set_title(title)
1821 if (ipakcb < 0)
then
1823 else if (ipakcb == 0)
then
1828 if (icbcfl == 0)
then
1833 if (ibinun /= 0)
then
1841 if (node > 0) nboundcount = nboundcount + 1
1843 call dis%record_srcdst_list_header(text, textmodel, textpackage, &
1844 dstmodel, dstpackage, naux, &
1845 auxname, ibinun, nboundcount, iout)
1849 if (nbound > 0)
then
1855 if (inamedbound > 0)
then
1856 bname = boundname(i)
1871 if (ibudfl /= 0)
then
1872 if (iprflow /= 0)
then
1875 nodeu = dis%get_nodeuser(node)
1876 call dis%nodeu_to_string(nodeu, nodestr)
1877 call outputtab%print_list_entry(i, trim(adjustl(nodestr)), &
1883 if (ibinun /= 0)
then
1885 if (
present(imap)) n2 = imap(i)
1887 auxrow(:) = auxvar(:, i)
1889 call dis%record_mf6_list_entry(ibinun, node, n2, rrate, naux, &
1890 auxrow, olconv2=.false.)
1895 if (ibudfl /= 0)
then
1896 if (iprflow /= 0)
then
1897 write (iout,
'(1x)')
1913 class(
bndtype),
intent(inout) :: this
1922 call mem_reallocate(this%condinput, this%maxbound,
'CONDINPUT', &
1924 do i = 1, this%maxbound
1925 this%condinput(i) =
dzero
1930 write (this%iout,
'(/1x,a,a)')
'VISCOSITY ACTIVE IN ', &
1931 trim(this%filtyp)//
' PACKAGE CALCULATIONS: '//trim(adjustl(this%packName))
This module contains block parser methods.
This module contains the base boundary package.
subroutine bnd_read_dimensions(this)
@ brief Read dimensions for package
logical(lgp) function bnd_obs_supported(this)
Determine if observations are supported.
subroutine bnd_ar(this)
@ brief Allocate and read method for boundary package
subroutine bnd_rp(this)
@ brief Allocate and read method for package
subroutine allocate_scalars(this)
@ brief Allocate package scalars
subroutine bnd_ot_dv(this, idvsave, idvprint)
@ brief Output advanced package dependent-variable terms.
subroutine bnd_store_user_cond(this, nlist, rlist, condinput)
@ brief Store user-specified conductances when vsc is active
subroutine bnd_ot_obs(this)
Output observations for the package.
subroutine bnd_nur(this, neqpak, x, xtemp, dx, inewtonur, dxmax, locmax)
@ brief Apply Newton-Raphson under-relaxation for package.
subroutine bnd_ot_package_flows(this, icbcfl, ibudfl)
@ brief Output advanced package flow terms.
subroutine bnd_read_options(this)
@ brief Read additional options for package
subroutine bnd_ot_model_flows(this, icbcfl, ibudfl, icbcun, imap)
@ brief Output package flow terms.
subroutine bnd_cc(this, innertot, kiter, iend, icnvgmod, cpak, ipak, dpak)
@ brief Convergence check for package.
subroutine bnd_rp_ts(this)
Assign time series links for the package.
subroutine bnd_bd_obs(this)
Save observations for the package.
subroutine bnd_options(this, option, found)
@ brief Read additional options for package
subroutine bnd_da(this)
@ brief Deallocate package memory
subroutine bnd_bd(this, model_budget)
@ brief Add package flows to model budget.
subroutine, public addbndtolist(list, bnd)
Add boundary to package list.
subroutine bnd_cq_simrate(this, hnew, flowja, imover)
@ brief Calculate simrate.
subroutine bnd_mc(this, moffset, matrix_sln)
@ brief Map boundary package connection to matrix
class(bndtype) function, pointer, public getbndfromlist(list, idx)
Get boundary from package list.
subroutine bnd_fc(this, rhs, ia, idxglo, matrix_sln)
@ brief Copy hcof and rhs terms into solution.
subroutine allocate_arrays(this, nodelist, auxvar)
@ brief Allocate package arrays
subroutine bnd_ck(this)
@ brief Check boundary package period data
subroutine pak_setup_outputtab(this)
@ brief Setup output table for package
subroutine bnd_ac(this, moffset, sparse)
@ brief Add boundary package connection to matrix
subroutine bnd_ot_bdsummary(this, kstp, kper, iout, ibudfl)
@ brief Output advanced package budget summary.
subroutine copy_boundname(this)
@ brief Copy boundnames into boundnames_cst
subroutine bnd_df_obs(this)
Define the observation types available in the package.
subroutine bnd_reset(this)
@ brief Reset bnd package before formulating
subroutine bnd_activate_viscosity(this)
Activate viscosity terms.
subroutine bnd_cq_simtomvr(this, flowja)
@ brief Calculate flow to the mover.
subroutine bnd_read_initial_attr(this)
@ brief Read initial parameters for package
subroutine, public save_print_model_flows(icbcfl, ibudfl, icbcun, iprflow, outputtab, nbound, nodelist, flow, ibound, title, text, ipakcb, dis, naux, textmodel, textpackage, dstmodel, dstpackage, auxname, auxvar, iout, inamedbound, boundname, imap)
Save and/or print flows for a package.
subroutine set_pointers(this, neq, ibound, xnew, xold, flowja)
@ brief Set pointers to model variables
subroutine bnd_rp_obs(this)
Read and prepare observations for a package.
subroutine bnd_cf(this)
@ brief Formulate the package hcof and rhs terms.
subroutine bnd_fn(this, rhs, ia, idxglo, matrix_sln)
@ brief Add Newton-Raphson terms for package into solution.
subroutine bnd_ad(this)
@ brief Advance the boundary package
class(bndtype) function, pointer, private castasbndclass(obj)
Cast as a boundary type.
subroutine bnd_cq(this, x, flowja, iadv)
@ brief Calculate advanced package flows.
subroutine define_listlabel(this)
@ brief Define the list label for the package
subroutine pack_initialize(this)
@ brief Allocate and initialize select package members
subroutine bnd_df(this, neq, dis)
@ brief Define boundary package options and dimensions
This module contains the BudgetModule.
subroutine, public rate_accumulator(flow, rin, rout)
@ brief Rate accumulator subroutine
This module contains simulation constants.
integer(i4b), parameter linelength
maximum length of a standard line
@ tabcenter
centered table column
@ tableft
left justified table column
integer(i4b), parameter lenmodelname
maximum length of the model name
integer(i4b), parameter lenpackagename
maximum length of the package name
real(dp), parameter dnodata
real no data constant
integer(i4b), parameter lenlistlabel
maximum length of a llist label
integer(i4b), parameter lenpakloc
maximum length of a package location
integer(i4b), parameter lenftype
maximum length of a package type (DIS, WEL, OC, etc.)
integer(i4b), parameter lenauxname
maximum length of a aux variable
integer(i4b), parameter lenboundname
maximum length of a bound name
real(dp), parameter dzero
real constant zero
integer(i4b), parameter maxcharlen
maximum length of char string
integer(i4b), parameter lenmempath
maximum length of the memory path
real(dp), parameter done
real constant 1
This module defines variable data types.
character(len=lenmempath) function create_mem_path(component, subcomponent, context)
returns the path to the memory object
This module contains the base numerical package type.
This module contains the derived types ObserveType and ObsDataType.
This module contains the derived type ObsType.
subroutine, public obs_cr(obs, inobs)
@ brief Create a new ObsType object
This module contains simulation methods.
subroutine, public store_error(msg, terminate)
Store an error message.
integer(i4b) function, public count_errors()
Return number of errors.
subroutine, public store_error_unit(iunit, terminate)
Store the file unit number.
This module contains simulation variables.
character(len=maxcharlen) errmsg
error message string
subroutine, public table_cr(this, name, title)
real(dp), pointer, public totimc
simulation time at start of time step
integer(i4b), pointer, public kstp
current time step number
integer(i4b), pointer, public kper
current stress period number
real(dp), pointer, public delt
length of the current time step
integer(i4b), pointer, public nper
number of stress period
subroutine, public tasmanager_cr(this, dis, modelname, iout)
Create the time-array series manager.
subroutine, public tsmanager_cr(this, iout, removeTsLinksOnCompletion, extendTsToEndOfSimulation)
Create the tsmanager.
Derived type for the Budget object.
This class is used to store a single deferred-length character string. It was designed to work in an ...
A generic heterogeneous doubly-linked list.