![]() |
![]()
| ![]() |
![]()
NAMEr3.gwflow - Numerical calculation program for transient, confined groundwater flow in three dimensions. KEYWORDSraster3d, groundwater flow, voxel, hydrology SYNOPSISr3.gwflow
Flags:
Parameters:
DESCRIPTIONThis numerical module calculates implicit transient and steady state, confined groundwater flow in three dimensions based on volume maps and the current 3D region settings. All initial- and boundary-conditions must be provided as volume maps. The unit of the current coordinate refernce system must be meters. This module is sensitive to mask settings. All cells which are outside the mask are ignored and handled as no flow boundaries. The module calculates the piezometric head and optionally the water balance for each cell and the groundwater velocity field in 3 dimensions. The vector components can be visualized with ParaView if they are exported with r3.out.vtk. The groundwater flow will always be calculated transient. For steady state computation the user should set the timestep to a large number (billions of seconds) or set the specific yield raster map to zero. NOTESThe groundwater flow calculation is based on Darcy’s law and a numerical implicit finite volume discretization. The discretization results in a symmetric and positive definite linear equation system in form of Ax = b, which must be solved. The groundwater flow partial differential equation is of the following form: (dh/dt)*S = div (K grad h) + q In detail for 3 dimensions: (dh/dt)*S = Kxx * (d^2h/dx^2) + Kyy * (d^2h/dy^2) + Kzz * (d^2h/dz^2) + q
Two different boundary conditions are implemented, the Dirichlet and Neumann conditions. By default the calculation area is surrounded by homogeneous Neumann boundary conditions. The calculation and boundary status of single cells can be set with the status map, the following cell states are supported:
Note that all required raster maps are read into main memory. Additionally the linear equation system will be allocated, so the memory consumption of this module rapidely grow with the size of the input maps. The resulting linear equation system Ax = b can be solved with several solvers. An iterative solvers with sparse and quadratic matrices support is implemented. The conjugate gradients method with (pcg) and without (cg) precondition. Additionally a direct Cholesky solver is available. This direct solver only work with normal quadratic matrices, so be careful using them with large maps (maps of size 10.000 cells will need more than one Gigabyte of RAM). The user should always prefer to use a sparse matrix solver. EXAMPLE 1This small script creates a working groundwater flow area and
data. It cannot be run in a lat/lon project.
# set the region accordingly g.region res=25 res3=25 t=100 b=0 n=1000 s=0 w=0 e=1000 -p3 #now create the input raster maps for a confined aquifer r3.mapcalc expression="phead = if(row() == 1 && depth() == 4, 50, 40)" r3.mapcalc expression="status = if(row() == 1 && depth() == 4, 2, 1)" r3.mapcalc expression="well = if(row() == 20 && col() == 20 && depth() == 2, -0.25, 0)" r3.mapcalc expression="hydcond = 0.00025" r3.mapcalc expression="syield = 0.0001" r.mapcalc expression="recharge = 0.0" r3.gwflow solver=cg phead=phead statuyield=status hc_x=hydcond hc_y=hydcond \ EXAMPLE 2This will create a nice 3D model with geological layer with
different hydraulic conductivities. Make sure you are not in a lat/lon
projection.
# set the region accordingly g.region res=15 res3=15 t=500 b=0 n=1000 s=0 w=0 e=1000 #now create the input raster maps for a confined aquifer r3.mapcalc expression="phead = if(col() == 1 && depth() == 33, 50, 40)" r3.mapcalc expression="status = if(col() == 1 && depth() == 33, 2, 1)" r3.mapcalc expression="well = if(row() == 20 && col() == 20 && depth() == 3, -0.25, 0)" r3.mapcalc expression="well = if(row() == 50 && col() == 50 && depth() == 3, -0.25, well)" r3.mapcalc expression="hydcond = 0.0025" r3.mapcalc expression="hydcond = if(depth() < 30 && depth() > 23 && col() < 60, 0.000025, hydcond)" r3.mapcalc expression="hydcond = if(depth() < 20 && depth() > 13 && col() > 7, 0.000025, hydcond)" r3.mapcalc expression="hydcond = if(depth() < 10 && depth() > 7 && col() < 60, 0.000025, hydcond)" r3.mapcalc expression="syield = 0.0001" r3.gwflow solver=cg phead=phead statuyield=status hc_x=hydcond hc_y=hydcond \ SEE ALSOr.gwflow, r.solute.transport, r3.out.vtk AUTHORSören Gebbert This work is based on the Diploma Thesis of Sören Gebbert available here at Technical University Berlin, Germany. SOURCE CODEAvailable at: r3.gwflow source code (history) Latest change: Wednesday Nov 27 22:53:26 2024 in commit: b90ce69e88409469369ec1edb86fde8ec822af8b Main index | 3D raster index | Topics index | Keywords index | Graphical index | Full index © 2003-2025 GRASS Development Team, GRASS GIS 8.4.1 Reference Manual
|