MODFLOW 6  version 6.7.0.dev2
USGS Modular Hydrologic Model
particlemodule::particletype Type Reference

Particle tracked by the PRT model. More...

Collaboration diagram for particlemodule::particletype:
Collaboration graph

Public Member Functions

procedure, public destroy => destroy_particle
 
procedure, public get_model_coords
 
procedure, public transform => transform_coords
 
procedure, public reset_transform
 

Public Attributes

character(len=lenboundname), public name = ''
 optional particle name More...
 
integer(i4b), public imdl
 index of model the particle originated in More...
 
integer(i4b), public iprp
 index of release package the particle is from More...
 
integer(i4b), public irpt
 index of release point the particle is from More...
 
integer(i4b), public ip
 index of particle in the particle list More...
 
integer(i4b), public istopweaksink
 weak sink option (0: do not stop, 1: stop) More...
 
integer(i4b), public istopzone
 stop zone number More...
 
integer(i4b), public idrymeth
 dry tracking method More...
 
integer(i4b), dimension(max_level), public itrdomain
 tracking domain indices More...
 
integer(i4b), dimension(max_level), public iboundary
 tracking domain boundary indices More...
 
integer(i4b), public icp
 previous cell number (reduced) More...
 
integer(i4b), public icu
 user cell number More...
 
integer(i4b), public ilay
 grid layer More...
 
integer(i4b), public izone
 current zone number More...
 
integer(i4b), public izp
 previous zone number More...
 
integer(i4b), public istatus
 tracking status More...
 
real(dp), public x
 x coordinate More...
 
real(dp), public y
 y coordinate More...
 
real(dp), public z
 z coordinate More...
 
real(dp), public trelease
 release time More...
 
real(dp), public tstop
 stop time More...
 
real(dp), public ttrack
 time tracked so far More...
 
real(dp), public xorigin
 x origin for coordinate transformation from model to local More...
 
real(dp), public yorigin
 y origin for coordinate transformation from model to local More...
 
real(dp), public zorigin
 z origin for coordinate transformation from model to local More...
 
real(dp), public sinrot
 sine of rotation angle for coordinate transformation from model to local More...
 
real(dp), public cosrot
 cosine of rotation angle for coordinate transformation from model to local More...
 
real(dp), public extol
 tolerance for iterative solution of particle exit location and time in generalized Pollock's method More...
 
logical(lgp), public transformed
 whether coordinates have been transformed from model to local More...
 
logical(lgp), public advancing
 whether particle is still being tracked for current time step More...
 
integer(i4b), public ifrctrn
 whether to force solving the particle with the ternary method More...
 
integer(i4b), public iexmeth
 method for iterative solution of particle exit location and time in generalized Pollock's method More...
 
integer(i4b), public iextend
 whether to extend tracking beyond the end of the simulation More...
 
integer(i4b), public icycwin
 cycle detection window size More...
 
type(listtype), pointer, public history
 history of particle positions (for cycle detection) More...
 

Detailed Description

Record-type to conveniently shuffle a particle's state to/from storage before/after its trajectory is solved for each time step.

Particle coordinates may be local to the cell or global/model. Routines are provided to convert a particle's global coordinates to/from cell-local coordinates for tracking through cell subdomains.

Particles are identified by composite key, i.e., combinations of properties imdl, iprp, irpt, and trelease. An optional label may be provided, but need not be unique

Definition at line 56 of file Particle.f90.

Member Function/Subroutine Documentation

◆ destroy()

procedure, public particlemodule::particletype::destroy

Definition at line 97 of file Particle.f90.

◆ get_model_coords()

procedure, public particlemodule::particletype::get_model_coords

Definition at line 98 of file Particle.f90.

◆ reset_transform()

procedure, public particlemodule::particletype::reset_transform

Definition at line 100 of file Particle.f90.

◆ transform()

procedure, public particlemodule::particletype::transform

Definition at line 99 of file Particle.f90.

Member Data Documentation

◆ advancing

logical(lgp), public particlemodule::particletype::advancing

Definition at line 90 of file Particle.f90.

90  logical(LGP), public :: advancing !< whether particle is still being tracked for current time step

◆ cosrot

real(dp), public particlemodule::particletype::cosrot

Definition at line 87 of file Particle.f90.

87  real(DP), public :: cosrot !< cosine of rotation angle for coordinate transformation from model to local

◆ extol

real(dp), public particlemodule::particletype::extol

Definition at line 88 of file Particle.f90.

88  real(DP), public :: extol !< tolerance for iterative solution of particle exit location and time in generalized Pollock's method

◆ history

type(listtype), pointer, public particlemodule::particletype::history

Definition at line 95 of file Particle.f90.

95  type(ListType), public, pointer :: history !< history of particle positions (for cycle detection)

◆ iboundary

integer(i4b), dimension(max_level), public particlemodule::particletype::iboundary

Definition at line 70 of file Particle.f90.

70  integer(I4B), public :: iboundary(MAX_LEVEL) !< tracking domain boundary indices

◆ icp

integer(i4b), public particlemodule::particletype::icp

Definition at line 71 of file Particle.f90.

71  integer(I4B), public :: icp !< previous cell number (reduced)

◆ icu

integer(i4b), public particlemodule::particletype::icu

Definition at line 72 of file Particle.f90.

72  integer(I4B), public :: icu !< user cell number

◆ icycwin

integer(i4b), public particlemodule::particletype::icycwin

Definition at line 94 of file Particle.f90.

94  integer(I4B), public :: icycwin !< cycle detection window size

◆ idrymeth

integer(i4b), public particlemodule::particletype::idrymeth

Definition at line 67 of file Particle.f90.

67  integer(I4B), public :: idrymeth !< dry tracking method

◆ iexmeth

integer(i4b), public particlemodule::particletype::iexmeth

Definition at line 92 of file Particle.f90.

92  integer(I4B), public :: iexmeth !< method for iterative solution of particle exit location and time in generalized Pollock's method

◆ iextend

integer(i4b), public particlemodule::particletype::iextend

Definition at line 93 of file Particle.f90.

93  integer(I4B), public :: iextend !< whether to extend tracking beyond the end of the simulation

◆ ifrctrn

integer(i4b), public particlemodule::particletype::ifrctrn

Definition at line 91 of file Particle.f90.

91  integer(I4B), public :: ifrctrn !< whether to force solving the particle with the ternary method

◆ ilay

integer(i4b), public particlemodule::particletype::ilay

Definition at line 73 of file Particle.f90.

73  integer(I4B), public :: ilay !< grid layer

◆ imdl

integer(i4b), public particlemodule::particletype::imdl

Definition at line 60 of file Particle.f90.

60  integer(I4B), public :: imdl !< index of model the particle originated in

◆ ip

integer(i4b), public particlemodule::particletype::ip

Definition at line 63 of file Particle.f90.

63  integer(I4B), public :: ip !< index of particle in the particle list

◆ iprp

integer(i4b), public particlemodule::particletype::iprp

Definition at line 61 of file Particle.f90.

61  integer(I4B), public :: iprp !< index of release package the particle is from

◆ irpt

integer(i4b), public particlemodule::particletype::irpt

Definition at line 62 of file Particle.f90.

62  integer(I4B), public :: irpt !< index of release point the particle is from

◆ istatus

integer(i4b), public particlemodule::particletype::istatus

Definition at line 76 of file Particle.f90.

76  integer(I4B), public :: istatus !< tracking status

◆ istopweaksink

integer(i4b), public particlemodule::particletype::istopweaksink

Definition at line 65 of file Particle.f90.

65  integer(I4B), public :: istopweaksink !< weak sink option (0: do not stop, 1: stop)

◆ istopzone

integer(i4b), public particlemodule::particletype::istopzone

Definition at line 66 of file Particle.f90.

66  integer(I4B), public :: istopzone !< stop zone number

◆ itrdomain

integer(i4b), dimension(max_level), public particlemodule::particletype::itrdomain

Definition at line 69 of file Particle.f90.

69  integer(I4B), public :: itrdomain(MAX_LEVEL) !< tracking domain indices

◆ izone

integer(i4b), public particlemodule::particletype::izone

Definition at line 74 of file Particle.f90.

74  integer(I4B), public :: izone !< current zone number

◆ izp

integer(i4b), public particlemodule::particletype::izp

Definition at line 75 of file Particle.f90.

75  integer(I4B), public :: izp !< previous zone number

◆ name

character(len=lenboundname), public particlemodule::particletype::name = ''

Definition at line 59 of file Particle.f90.

59  character(len=LENBOUNDNAME), public :: name = '' !< optional particle name

◆ sinrot

real(dp), public particlemodule::particletype::sinrot

Definition at line 86 of file Particle.f90.

86  real(DP), public :: sinrot !< sine of rotation angle for coordinate transformation from model to local

◆ transformed

logical(lgp), public particlemodule::particletype::transformed

Definition at line 89 of file Particle.f90.

89  logical(LGP), public :: transformed !< whether coordinates have been transformed from model to local

◆ trelease

real(dp), public particlemodule::particletype::trelease

Definition at line 80 of file Particle.f90.

80  real(DP), public :: trelease !< release time

◆ tstop

real(dp), public particlemodule::particletype::tstop

Definition at line 81 of file Particle.f90.

81  real(DP), public :: tstop !< stop time

◆ ttrack

real(dp), public particlemodule::particletype::ttrack

Definition at line 82 of file Particle.f90.

82  real(DP), public :: ttrack !< time tracked so far

◆ x

real(dp), public particlemodule::particletype::x

Definition at line 77 of file Particle.f90.

77  real(DP), public :: x !< x coordinate

◆ xorigin

real(dp), public particlemodule::particletype::xorigin

Definition at line 83 of file Particle.f90.

83  real(DP), public :: xorigin !< x origin for coordinate transformation from model to local

◆ y

real(dp), public particlemodule::particletype::y

Definition at line 78 of file Particle.f90.

78  real(DP), public :: y !< y coordinate

◆ yorigin

real(dp), public particlemodule::particletype::yorigin

Definition at line 84 of file Particle.f90.

84  real(DP), public :: yorigin !< y origin for coordinate transformation from model to local

◆ z

real(dp), public particlemodule::particletype::z

Definition at line 79 of file Particle.f90.

79  real(DP), public :: z !< z coordinate

◆ zorigin

real(dp), public particlemodule::particletype::zorigin

Definition at line 85 of file Particle.f90.

85  real(DP), public :: zorigin !< z origin for coordinate transformation from model to local

The documentation for this type was generated from the following file: