The dynatop
package
represents an implementation of the concepts behind a dynamic TOPMODEL.
One of the underlying principles of dynamic TOPMODEL is that the
landscape can be broken up into hydrologically similar regions, or
Hydrological Response Units (HRUs), where all the area within a HRU
behaves in a hydrologically similar fashion.
While a Hydrological Response Unit (HRU) has typically been thought of as an area of hill slope with, for example, similar topographic, soil and upslope area characteristics the idea may be generalised. In doing this a catchments is conceptualised as a collection of HRUs which may represent of different types of landscape (e.g. hill slope, channel, lake) which exchange fluxes at specified levels (e.g. saturated zone, surface). Currently a single type of HRU is present in the model, which may be parameterised to represent a number of different physical features.
The aim of this document is to outline
Each HRU has a unique reference number in the id
variable. In principle the HRUs are solved in reverse order of
id
; that is from the largest id
value to the
smallest. Currently this is strictly enforced. Future releases may relax
this to enable parallel solutions.
Fluxes between the HRUs are represented as occurring at two levels, the surface and the saturated zones. For the ith HRU the outflow in m3/s at time t + Δt is qsf[i]|t + Δt at the surface and qsz[i]|t + Δt in the saturated zone.
The fraction of outflow going from the i th to the j th HRU is fi, j. The redistribution is conservative as does not vary in time so $$ \sum\limits_{j} f_{i,j} = 1 $$ Since there is no exchange between the surface and saturated zones during redistribution the inflows at time t + Δt to the kth HRU can be computed as $$ \sum\limits_{i>k} f_{i,k}\left.q_{sf}^{\left[i\right]}\right\rvert_{t+\Delta t} $$ and $$ \sum\limits_{i>k} f_{i,k}\left.q_{sz}^{\left[i\right]}\right\rvert_{t+\Delta t} $$
The values of fi, j
are specified in the flow_direction
data.frame of the
model.
It is expected that the precipitation and potential evapotranspiration inputs series are given in m accrued over the proceeding time step. So if the data has a time step Δt the value given at t + Δt is accrued in the interval between time t and time t + Δt.
To aid the readability of the code the variables are labelled consistently with regards to the vignettes. For example:
l_sz
, suz
becomes s_uz
etc.q_rz_uz
, etc.lambda
However the notation used in the vignettes for intermediate values of fluxes or states (e.g. ) is dropped from the code where it can be inferred from the computational sequence (or comments)
Currently the code uses a purely implicit scheme for the solution of the HRUs. This requires a solving two zero finding problems for each HRU at each (sub)time step. Currently a bisection algorithm is used with a user specified tolerance and maximum number of iterations. The tolerance is defined as the difference between the upper and lower limits of the interval containing the zero point. Notionally faster algorithms (such as the TOMS-748 algorithm) could be used.