Computational Hydraulics PDF
Computational Hydraulics PDF
Computational Hydraulics PDF
This is an Open Access book distributed under the terms of the Creative Commons
Attribution-NonCommercial-NoDerivatives Licence (CC BY-NC-ND 4.0), which
permits copying and redistribution in the original format for non-commercial
purposes, provided the original work is properly cited.
(http://creativecommons.org/licenses/by-nc-nd/4.0/). This does not affect the rights
licensed or assigned from any third party in this book.
Ioana Popescu
Apart from any fair dealing for the purposes of research or private study, or criticism or review, as permitted under the
UK Copyright, Designs and Patents Act (1998), no part of this publication may be reproduced, stored or transmitted
in any form or by any means, without the prior permission in writing of the publisher, or, in the case of photographic
reproduction, in accordance with the terms of licenses issued by the Copyright Licensing Agency in the UK, or in
accordance with the terms of licenses issued by the appropriate reproduction rights organization outside the UK.
Enquiries concerning reproduction outside the terms stated here should be sent to IWA Publishing at the address
printed above.
The publisher makes no representation, express or implied, with regard to the accuracy of the information contained in
this book and cannot accept any legal responsibility or liability for errors or omissions that may be made.
Disclaimer
The information provided and the opinions given in this publication are not necessarily those of IWA and should not be
acted upon without independent consideration and professional advice. IWA and the Author will not accept responsibility
for any loss or damage suffered by any person acting or refraining from acting upon any material contained in this
publication.
Chapter 1
Modelling theory . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1
1.1 Context and Nature of Modelling . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1
1.1.1 Classification of models . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 2
1.1.2 Computational Hydraulics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5
1.2 Conceptualiation: Building a Model . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6
1.3 Mathematical Modelling in Practice . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
1.3.1 Selecting a proper model . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 7
1.3.2 Testing a model . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8
1.4 Development and Application of Models . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
Chapter 2
Modelling water related problems . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
2.1 Basic Conservation Equations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
2.1.1 Conservation of mass . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
2.1.2 Conservation of momentum . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
2.1.3 Conservation of energy . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
2.2 Mathematical Classification of Flow Equations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
2.2.1 Solutions of ODE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
2.2.2 Solutions of PDE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
2.3 Navier-Stokes and Saint-Venant Equations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24
2.3.1 Navier-Stokes equations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24
Chapter 3
Discretization of the fluid flow domain . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33
3.1 Discrete Solutions of Equations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 33
3.2 Space Discretization . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
3.2.1 Structured grids . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
3.2.2 Unstructured grids . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
3.2.3 Grid generation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
3.2.4 Physical aspects of space discretization . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40
3.3 Time Discretization . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
Chapter 4
Finite difference method . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
4.1 General Concepts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
4.2 Approximation of the First Order Derrivative . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44
4.3 Approximation of Higher Order Derrivatives . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48
4.4 Finite Differences for Ordinary Differential Equations . . . . . . . . . . . . . . . . . . . . . . . . . 50
4.4.1 Problem position . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50
4.4.2 Explicit schemes (Euler method) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 52
4.4.3 Implicit schemes (Improved Euler method) . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
4.4.4 Mixed schemes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
4.4.5 Weighted averaged schemes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
4.4.6 Runge–Kutta methods . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55
4.5 Numerical Schemes for Partial Differential Equations . . . . . . . . . . . . . . . . . . . . . . . . . 56
4.5.1 Principle of FDM for PDEs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56
4.5.2 Hyperbolic PDEs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 59
4.5.3 Parabolic PDEs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
4.5.4 Elliptic PDEs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67
4.6 Examples . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 68
4.6.1 ODE: Solution of the linear reservoir problem . . . . . . . . . . . . . . . . . . . . . . . . . 68
4.6.2 PDE: Simple wave propagation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72
4.6.3 PDE: Diffusion equation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 74
Chapter 5
Finite volume method . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77
5.1 General Concept . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 77
5.2 FVM Application Details . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80
5.2.1 Step by step application of the FVM . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80
5.2.2 Surface and volume integrals . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81
5.2.3 Discretization of convective fluxes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83
Chapter 6
Properties of numerical methods . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 95
6.1 Properties of Numerical Methods . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 95
6.1.1 Convergence . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 95
6.1.2 Consistency . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 96
6.1.3 Stability . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 96
6.1.4 Lax’s theorem of equivalence . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97
6.2 Convergence of FDM Schemes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97
6.2.1 Convergence for ODEs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97
6.2.2 Convergence for PDEs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101
6.2.3 Amplitude and phase errors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 109
6.3 Convergence of FVM Schemes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111
6.3.1 Convective fluxes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 111
6.3.2 Diffusive fluxes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 112
6.4 Examples . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113
6.4.1 Stability region of a simple ODE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113
6.4.2 Convergence of an ODE: Emptying of a groundwater reservoir . . . . . . . . . . 113
6.4.3 PDE: Convergence analysis for Preissmann scheme applied
to advection equation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 117
6.4.4 PDE: Convergence analysis for diffusion equation . . . . . . . . . . . . . . . . . . . . 123
Chapter 7
River system modelling and flood propagation . . . . . . . . . . . . . . . . . . . . . . . . 125
7.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 125
7.2 River Systems Modelling . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 126
7.2.1 Preissmann solution . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 127
7.2.2 Abbott-Ionescu solution . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 133
7.2.3 Initial and boundary conditions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 137
7.2.4 River networks . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 137
7.3 Modelling Floods . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 140
7.4 River Routing Example . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 142
Chapter 8
Water quality modelling . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 147
8.1 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 147
8.2 Processes Described in Water Quality Models . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 149
8.3 River Water Quality Models . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 151
8.4 Lakes Water Quality Modelling . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 152
8.5 Examples of Lake Hydrodynamics and Water Quality Models . . . . . . . . . . . . . . . . . . 154
8.5.1 Sontea-Fortuna wetland system . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 154
8.5.2 Lake Taihu water quality . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 156
References . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 161
Index . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 167
Ioana Popescu is Associate Professor of Hydroinformatics at UNESCO-IHE Institute for Water Education
in Delft, The Netherlands. Her teaching and research focuses on computational methods, aspects of
flood modeling and vulnerability related to floods, lake and reservoir modeling, river systems and water
supply systems modelling and optimisation. Dr. Ioana Popescu has been involved in several EU FP7
research projects (IceWater, lenvis, EnviroGRIDS, Floodsite) as well as other research projects related to
development and application of modelling systems for water related areas. She is also the author of more
than 30 peer-reviewed journal articles and 40 other publications, including invited book chapters and
conference proceedings.
‘No modern applied mathematician, physical scientist, or engineer can be properly trained without some
understanding of numerical methods’
—E. Issacson and H. B. Keller
Computational hydraulics is one of the many fields of science for which computers opened a new way
of working. The user of computer based models should be able to critically evaluate results given by
different computational methods used in solving practical hydraulic problems. As such the book is
intended to serve as a course for both undergraduate and graduate students in the fields of hydraulics and
water resources.
The text of this book is based on the course of “Numerical methods for free surface flow”, which
evolved over the years at UNESCO-IHE Institute for Water Education. My students have been a source of
motivation in trying to explain and clarify complex aspects of numerical methods, as well as free surface
flows and hydrodynamics of large water bodies such as lakes and reservoirs.
There is a great deal of literature devoted to computational hydraulics in terms of numerical methods
and fluid flow phenomena. However, it would be impossible to cover everything in one single book.
Hence I have tried to cover only those methods that are most used in hydrodynamics. In Chapter 1, the
book introduces the concept of modeling and the contribution of both numerical methods and numerical
analysis to modeling. A description of the basic hydraulic principles, and the problems addressed by
these principles in the aquatic environment is presented in Chapter 2, followed by the discretization
principles of the fluid flow domain in Chapter 3. The finite difference method and finite volume method
are presented in Chapters 4 and 5, respectively, with all the necessary steps for building and applying
these numerical method approaches in hydraulics. Chapter 6 presents the properties of numerical
methods that gives insight into how to avoid wrong results. The final two chapters show different
example applications of computational hydraulics: river system modeling alongside hydrodynamic and
water quality modeling of lakes and reservoirs. Worked-out examples that help in understanding the
main concepts of computational hydraulics are developed for demonstration purposes at the end of
Chapters 4, 5, 6 and 7.
Many concepts and results of the book have been discussed over the past years with Andreja Jonoski
and Roland Price, whom I would like to thank for their inspiring talks. Their encouragement and research
collaboration has been invaluable to me. I would like to thank my students Mario Castro Gama and Quan
Pan, who provided me with some of the figures in Chapters 7 and 8. Lastly I am grateful and I would like
to acknowledge my family for kindly helping and supporting me during the book writing process as well
as drawing most of the figures.
Ioana Popescu
Delft, 2014
Modelling is as much an art as it is a science. The purpose to construct a model is to gain insight into
the underlying causes or to provide accurate prediction of the system behaviour. Reliability on the model
results depends on the expertise of the modeller about the system to be modelled. In general models are,
as mentioned, mathematical representations, in forms of equations, of physical phenomena, embedding
parameters and quantitative relationships between different variables and parameters. They should be seen
as condensed versions of the knowledge of the modeller about the modelled system.
Approaches to construct a model are different from one problem to another as well as from one
modeller to another. An engineer approach to problem solution is different from that of a mathematician.
Mathematicians are interested in finding whether a solution to a differential equation exists, while an
engineer assumes that the existence of a physical system is proof enough for the existence of a solution and
focuses in finding the solution itself. The understanding of an engineering system is essentially gained by
observation and experiment. After years of observation and measurements, engineers notice that certain
aspects of their studies occur repeatedly. Such general behaviour can then be expressed as fundamental
laws or models. These kinds of models embody the cumulative wisdom of past experience. As the purpose
of modelling is to increase the understanding of a system behaviour, the validity of it does not reduce to
its fit to observations and measurements, but also to model’s ability to simulate and replicate situations or
data beyond those originally described in the model (James & Burges 1982; Dooge, 1986). For example
a descriptive model of the system is used to understand how the system could work; or to predict how an
unexpected event could affect the system; or in some cases to try different control approaches in case a
system is controlled by structures.
The developer of a model considers that advances in modelling can only be attained by forming close
links between measurement, theory and modelling (Woods et al., 1995). Models are constantly being
improved and advanced, which implies that users of the models should always obtain the up-to-date
version of a model to be applied for finding solutions to an engineering problem (Schulze, 1995).
Models in civil engineering refer to the modelling of the continuum, however the present book is
concerned with the modelling and numerical methods applied to fluid flow problems. Computational
fluid dynamics (CFD) is defined as the field of science that uses computers and numerical techniques
to solve problems involving fluid flow. The term Computational Hydraulics was defined by Abbot
and Minns (1998) to be ‘the reformulation of traditional hydraulics to suit the possibilities and
requirements of discrete, sequential and recursive processes of digital computation’, and it is a sub-
field of CFD.
In order to build a model apart from the mathematical formulation of the phenomena a lot of
observed data is required to perform simulations. For the majority of hydraulic problems there is an
imbalance between the lack of available data (little knowledge about the problem) and the availability of
sophisticated methods that can be applied to simulate the system under study. Numerical methods and
simulations fill the ‘gap’ between theory and experiment, providing qualitative and quantitative insight
into many phenomena that are too complex to be dealt with by analytical methods and too expensive,
time consuming and/or impossible to be performed experimentally. Hence it can be stated that simple
models provide insight, complicated models provide many results for which insight need to be carefully
analysed.
as well as the amount of information required to build the model. Model classification helps users to select
the appropriate model for a particular problem solving need.
Before any classification of models is done several formal mathematical notions and definitions are
introduced:
• independent variables used in modelling are space and time. Time is usually defined over an interval,
t ∈ [to, T], and space x refers to the volume V that contains the system under study, x ∈ V;
• dependent variable is the state variable, which takes values depending on parameters and independent
variables. The state variable is a finite dimensional vector u = u(x, t), which is n dimensional u = (u1,
u2, . . . un ), and describes sufficiently the evolution of the phenomena (real system);
• a mathematical model is the set of equations that defines the evolution of the state variable in space
and time.
In order to properly represent the phenomena in nature, the real systems and the mathematical model
need to be consistent. This means that the number of unknown dependent variables must be equal to the
number of independent equations.
Purely from mathematical point of view models are dynamic or static, or they are finite and continuous.
A mathematical model is dynamic if the state variable u is time dependent. If u does not depend on time
then the mathematical model is static. A mathematical model is finite if the state variable does not depend
on the space variables. Otherwise the mathematical model is continuous. Finite dynamic models are
represented through ordinary differential equations; while continuous dynamic models are represented by
partial differential equations. Static models, finite or continuous, are particular cases of dynamic models
(the case when time derivative is zero).
From engineering point of view mathematical models for water related problems can be described as:
• Lumped conceptual models that are based on the concept of exchanges between global storage
entities, which compose the system under study (i.e., one compartment for surface water, another one
for aquifer storage, etc). These models satisfy principles such as the continuity principle, but do not
embed a complete description of the driving forces, which govern the system to be modelled (e.g.,
rainfall-runoff model, reservoir model, etc).
• Physically-based, distributed models, that use a description of the physical phenomenon which
govern the behaviour of water in the system under study. The principles that are applied are mass
conservation and additional laws describing the driving forces, such as momentum equation. In case
that these models refer to flow in saturated or unsaturated porous media, along with the continuity
principle, the hypothesis of laminar flow is applied (i.e., shear stress proportional to the velocity,
which determines the Darcy or Richards’ equations for flow).
• Data driven models that seek for a correlation between input and output data, without trying to
detail/analyse phenomena (e.g., linear regression, unit hydrograph). These models do need a lot of
prior knowledge and data observations of the system under study.
Lumped conceptual and physically-based models use differential relationships, describing the changes
in time of a set of variables. Most of the time, the formulations used are either Ordinary Differential
Equations (ODEs) or Partial Differential Equations (PDEs). As these ODEs and PDEs are very often
complex, it is not always possible to find analytical solutions to them.
Researchers (Singh, 1995; Tim, 1995), further classified models depending on the description of:
– Problem type and solution (Figure 1.1).
– Processes addressed (water quality, water allocation, reservoir operation, flood management, etc).
– Time and space problem dimension (lumped conceptual, one dimensional, two dimensional and
three dimensional) (Figure 1.2);
– Method of solution (finite differences, finite elements, etc. See Figure 1.3.)
Physical system
Problem type
(water allocation, Water quality, river
basin managment, flood control, etc.)
Grey box
Scale
Space Time
Large
Mathematical modelling problems are structurally classified into black box and white box models,
depending on how much information is available about the system under study before the formulation
of the mathematical model to be used for the problem solution. A black-box model is a system for which
no a priori information is available and no understanding of the processes involved in the transformation
is required. Only the input and the output have physical meaning. Stochastic models are black box
models. A white-box model is a system where all necessary information is available and all processes are
understandable and accounted for. Deterministic and physically based models fall into this category. The
term grey box can also be used if not enough data is available and just partial understanding of processes
is available. Lumped conceptual models are grey box models. In practice it is good to use as much a
priori information as possible because it makes models behave correctly (accurately) (see Figure 1.4).
Phenomena in nature
(described in terms of properties that
prevail at each point in time and
space separately)
Solution of PDEs
Numerical Deterministic
Neural numerical
models
networks models
Fully data and Fully process
oriented models Hybrid Data oriented models
models assimilation
Measured Data
with numerical methods implemented on digital computers, a process called simulation. Experimental
fluid mechanics puts physical laws, mathematical models and numerical simulations under the test of
observation. Computational Hydraulics is interdisciplinary and has four major contributing disciplines
(see Figure 1.5).
Computational Hydraulics
Hydraulics, Numerical
Hydrodynamics, methods
Hydrology
Applied mathematics
Computer &
& analysis
Information sciences
Engineering problems related to Hydraulics are of three kind; steady state, propagation problems and
eigen-value problems. Steady state problems have as main characteristic the fact that the system does not
change in time. Thus the equations representing the problem do not involve time as variable. Propagation
problems are also called dynamic problems and the main characteristics of it is that the system changes
with time. The variables and equilibrium relations depend in this case on time. The objective of the analysis
is to calculate the state variables in time. In the case of eigen-values problems there is no unique solution to
the system equilibrium equations. The analysis of the system has as the objective to determine the various
possible solutions. Eigen-value problems arise in both steady-state and dynamic analysis.
Discrete model
Visualization &
Numerical solution
The next step is the Mathematical Formulation of the problem. After determining all relevant aspects,
these are translated into mathematical relations that are in the form of a system of partial differential
equations for various field quantities, which have to be solved over a given suitable domain (e.g., the whole
volume of a lake, the whole river length). Boundary conditions are required over the domain of computation.
The third step is the one of translating the problem from the language of mathematics into a computable
form. This is done by generating a grid of the computational domain on which the mathematical equations
are formulated in a discrete form using different numerical approaches such as finite differences (FDM),
finite volume (FVM), finite elements (FEM), boundary elements (BEM), and so on. The grid generation
itself poses challenges for complex geometries applications. The discretization method is a matter of choice
of the modeler and in majority of the cases depends on experience, but it should correspond to the grid used.
At the end of the discretization step a system of nonlinear or linear algebraic equations is obtained and
appropriate solvers have to be used in order to find the solution. In case that nonlinear system of equations are
obtained iterative methods based on successive linearization are used. This approach may lead to large systems
of linear equations that are again solved using iterative methods. This step is known as Numerical Solution.
After obtaining a solution, visualization of results is needed. Post-processing is used to visualize the
simulation results. This step enables interpretation of results, which is very important not only for the
practitioner, but also for the developer of a model, because it helps to determine if there are errors in
the computations and to see what is the quality of the model.
If results of simulation differ from the real situation, the model and/ or the numerical methods have to
be refined and the cycle of mathematical modelling starts again.
Naturally the question arise which model to choose from the wide variety of available models. The choice
is difficult because there are models that are licence free as well as commercial ones.
Several authors (Woolhiser & Brakensiek, 1982; Sorooshian, 1991; Burnett & Watson, 1995) are defining
practical criteria to be considered in selecting a model; the ability of the model to address the nature of the
problem to be solved; availability of data for a particular problem; cost of the selected tool; possibility of
applying the model for other similar problems.
The first criteria to consider is the ability of the model to address the problem that needs solution, by
looking at the processes that are represented in the model, what are the equations representing these and
what are the assumptions and limitations of the mathematical model. The availability of data is a very
important issue, because even if the model is capable to describe processes that would be interesting
for the modeller, if there is no data available to instantiate the model then a simpler model has to be
considered.
Models range from very simple formula to complex ones that require implementation on a computer.
there are advantages and disadvantages in using a complex or a simple model, but the most important is the
objective for which the model is build. The choice to choose a complex model is an important decision in
the modelling process, in the light data requirements, model applicability and computer power (Bergström,
1991). Complex models should be used for complex simulations, such as water quantity and quality for an
entire catchment, however they should be used with care because they require a lot of input and there is a
danger to introduce errors (Hughes & Beater, 1987). Complex models need long computational times and
a thorough understanding of the model.
1.3.2 Testing a model
Any mathematical model is applied to solve engineering problems needs to be tested through validation,
calibration and verification.
Schultze (1995) mentions that verification and validation notions are two terms used interchangeably by
modellers, ‘what is one modeller’s verification may be another modeller’s validation’. The use of the two
terms might be misleading (Bredenhoeft & Koniko, 1993), hence the definition of the notions, according
to the Oxford English Dictionary is given below in order to clarify terminology:
– Validate is defined as ‘well founded and applicable, sound and to the point, against which no
objection can be fairly brought’ (i.e., authentic, true);
– Verify is defined as ‘to test the accuracy, or establish the truth or correctness, of something by
examination or by comparison with known data or some standard’ (i.e., evidence, approval).
Any mathematical model selected to seek the solution for a given problem is first validated by using it
to simulate small scale simple cases for which the results are known or can be easily obtained, analytically
or by measurements. The validation ensures the applicability of the mathematical model. After selection
of the model, the particular problem case is modeled by instantiating the model with data. The evaluation
of the performance of it will take place in two steps; calibration and verification. During the calibration
step all model parameters are estimated based on comparison of the simulation results with observed
data. In the calibration phase the ability of the model to reproduce the response of the system is tested,
as it is for example the simulation of a downstream hydrograph based on an inflow hydrograph upstream.
The next step is verification when a simulation is performed, using parameters values obtained during
calibration. The results of the verification step are compared with an observed data set, specifically
reserved for this purpose.
In case of hydraulic and hydrological models, where time is involved, model calibration is usually done
in three steps:
(1) Selection of a simulation time period from the available observation data set. Normally the
available data set is split in two, one set for calibration and one for verification. Selection of the
time length for calibration depends on the problem that needs to be addressed by the model. For
example if flood is of interest the observed period should contain a flood event.
(2) Preliminary calibration, when based on the experience of the modeler a set of parameters are
chosen and changed in such a way that the simulation results are as close as possible to the
observed data.
(3) Refined calibration, when a thorough analysis of the output results is done and refinement of
parameters values is carried out (either manually or by automatic procedures).
In order to determine the quality of the calibration a set of criteria are chosen, based on which the fit
between simulated and observed data is evaluated. The selection of criteria depends on the objective of
the modelling. In flood event modelling, for example several criteria such as time to peak, peak of the
hydrograph, are used to assess the correspondence between observed and simulated flows.
Parameter calibration is not an easy task because some parameters may be influencing each other
(especially in complex models) and this can generate sub-optimum determination of parameters. It is
advisable that some of the parameters are obtained by direct field measurement, where possible, and
for models for which they have physical meaning. Bathurst (1986) advises that a sensitivity of the fitting
criterion to any changes in parameter values should be carried out before selecting any value for a
parameter.
Immediately after calibration verification is carried out, by using the remaining data sets from the
available observations. While verifying the outputs of a simulation the assumption is made that the
governing equations and computer coding are valid, because the model passed the validation test.
Verification therefore needs to be objective, subject to rigorous testing criteria, while taking into account
the conditions for testing (e.g., years, inflow flood hydrograph, land use, etc).
With the development and application of models a special issue arises, the uncertainty of the model
results. Uncertainty in modelling is of three types; structural, parametric or stochastic (Smith & Kuhn,
2002). Structural uncertainty comes from lack of knowledge about the phenomena that is modeled (i.e.,
lack of measurements, poor measured data, human errors, etc), while parametric uncertainty comes from
using parameters with unsure values. Stochastic uncertainty shows the randomness of the phenomena and
can not be reduced.
Though uncertainties are important in modelling, models can be evaluated based on clear defined
criteria.
Problem definition
Model objectives
Mathematical formulation
of the problem
implementation
Numerical solution
Computer
phase
Validation
Evaluation phase
Sensitivity analysis
Verification
Application
Post processing
(2) Determine if there is available a similar model that can be used. If there is no model available than
a new model is defined and implemented on a computer;
(3) Define the mathematical representation of the phenomena that requires solution;
(4) Select the numerical approach that solves the mathematical representation of the phenomena;
(5) Coding and implementing the code on a computer;
(6) Validation of the mathematical model, by checking the model against simple examples. There is
a need to check what are the limitations in applicability, and what are the required boundary and
initial conditions;
(7) Sensitivity Analysis for the parameters of the model;
(8) Testing and Evaluation, when calibration and verification is performed;
(9) Application of the model for different problems;
(10) Presentation of results in graphical format, tabulated format or animated form to decision makers
and stakeholders.
A good modelling practice does not mean just the development of a model and its implementation on a
computer, but also continuous maintenance and refinement (improvement) without affecting its integrity.
• First law: a body is at rest or continues in a uniform state of motion, unless acted on by an applied
force.
• Second law: the net force acting on a given mass is proportional to the time rate of change of the
product of mass and velocity (also known as linear momentum);
• Third law: action and reaction are equal and opposite.
It is the second Newton’s law that introduces the notion of change of state.
The laws of thermodynamics can be stated as:
• First law: in a system thermally isolated by impermeable walls the work done in taking one state A
of a system into another state B is entirely determined by the terminal states A and B. The internal
energy difference between state A and state B is defined as the mechanical work done in taking
either state A into state B or state B into state A;
• Second law: there is a tendency on the part of nature to proceed towards a state of greater disorder.
Based on the above laws the general principle of conservation laws is that the rate of change of a
quantity u within a volume V plus the flux of u through the boundary A (noted as f(u)) is the same as the
rate of production of u denoted by S(u, t) (see Figure 2.1):
∂ (2.1)
∂t ∫ u ⋅ dV + ∫
V A
f (u) ⋅ n ⋅ dA − ∫ S(u, t )dV = 0
V
y
x
n
V
A
f (u)
Equation (2.1) is referred to as the integral form of the conservation law, and can be further detailed for
mass, energy and momentum.
2.1.1 Conservation of mass
Conservation of mass states that for any control volume, during a small time interval Δt the mass
entering the volume minus the mass leaving the volume equals the change of mass inside the control
volume. In case of continuation of mass equation (2.1) for mass m of density ρ, and advection
velocity u over the control volume V gives:
∂
∂t ∫ ρ ⋅ dV + ∫ (ρ ⋅ u) ⋅ n ⋅ dA = 0
V A
(2.2)
where:
f (u) = ρ ⋅ u and u ⋅ n = u (2.3)
In case of conservation of mass the term S, is the source term, and since there is no mass production, S
is zero. Integration of equation (2.2) yields:
∂ρ
+ ∇(u ρ ) = 0 (2.4)
∂t
∂ρ
+ (u ⋅ ∇)ρ + ρ∇ ⋅ u = 0 (2.5)
∂t
Dρ
+ ρ∇ ⋅ u = 0 (2.6)
Dt
where D/Dt is the total derivative with respect to time:
D ∂ dx ∂ dy ∂ dz ∂
= + + + (2.7)
Dt ∂t dt ∂x dt ∂y dt ∂z
In general water is considered an incompressible fluid (i.e., ρ = const.), hence the continuity equation
simplifies to:
∇⋅u = 0 (2.8)
Equation (2.6) is the continuity of mass, while equation (2.8) can be regarded as the equation of
continuity of volume.
2.1.2 Conservation of momentum
Conservation of momentum is demonstrated in x direction only. Conservation in y and z dimensions is
similar.
In case of momentum in x direction, the conserved quantity is ρux. In equation (2.1) momentum flux in
x direction is ρux u and S are the body and boundary forces acting on the control volume. Body force is the
gravity and boundary forces are pressure, shear and surface forces.
∂( ρux )
+ ∇ ⋅ ( ρux u ) = SP , x + SF , x + SG , x
∂t (2.9)
Pressure force Friction Force Gravity Force
If gravity and pressure forces are detailed, yields:
Du ∂p
ρ =− + ρg x + SF, x (2.10)
Dt ∂x
u x u x ux uy u x uz
u × u = ∇ uy ux uy uy u y uz (2.13)
uz u x uz u y uz uz
Hence,
∂ ∂ ∂
∂x ( ρux ux ) + ∂y ( ρux uy ) + ∂z ( ρux uz )
∂ ∂ ∂ (2.14)
= ( ρuy ux ) + ( ρuuy uy ) + (uρy uz )
∂x ∂y ∂z
∂ ( ρu u ) + ∂ ( ρu u ) + ∂ ( ρu u )
∂x z x
∂y z y
∂z z z
= (∇ρ ⋅ u )u + ρu (∇ ⋅ u ) + ρ (u ⋅ ∇)u
∂u
ρ + ρ (u ⋅ ∇)u = −∇p + ρg + SF (2.16)
∂t
Equation (2.16) represents the conservation of momentum in a three dimensional (3D) space.
2.1.3 Conservation of energy
For phenomena in which temperature varies, in addition to momentum equation, conservation of energy
must be considered. The energy equation accounts for both kinetic and potential energy. Hence energy is
( )
expressed by the term ρ e + u 2 , and the equation for conservation of energy is:
2
∂ u2 u2
ρ
e + + ∇ ⋅ ρ
e + u = ∇ ⋅ (k∇T ) − ∇ ⋅ (up) + ∇ ⋅ (uτ ) + ρgu (2.17)
∂t 2 2
where e is the potential energy; p is pressure; τ is stress tensor; k coefficient; and T is temperature.
The three presented conservation laws form the so-called Navier-Stokes equations, which are space
and time-dependent, that is, there are four independent variables. In a three dimensional domain there are
six dependent variables and only a set of five equations available; a continuity equation for conservation of
mass, three equations for conservation of momentum and one equation for conservation of energy. The six
dependent variables are pressure, density, temperature, and three components of the velocity vector u. The
six equation that is used is the law of thermodynamics relating pressure and temperature:
− p ⋅ V = nRT (2.18)
where p-pressure; V-control volume; T temperature; and n, R coefficients.
A system of six equations with six unknowns is formed, which can be solved. Usually, the Navier-
Stokes equations are too complicated to be solved, and simpler forms are used. These are discussed further
in this chapter.
representation of the physical processes in terms of differential equations (DE). Differential equations
are models of the phenomena and require integration to be solved. This is not always possible, hence they
are solved numerically.
As opposed to an algebraic equation, where the unknown is a number, in a differential equation, the
unknown is a function that expresses the behaviour of the variable as a function of time and space. A
differential equation has order, which is given by the order of the derivative of the unknown function
involved in the equation. If the values of the unknown function and its derivatives at some point are known
the solution to DE is called an initial value problem (IVP). If no initial conditions are given, the description
of all solutions to the DE is called the general solution.
DE are classified taking into account several criteria, as follows:
• order:
the highest order of the derivative that appears into equation, that is, an equation is of n-order if
{{
In water related problems, most frequently the 2nd order, linear PDEs with two independent variables
(homogeneous or nonhomogeneous) are used. In such a case, if the two independent variables are assumed
to be x and t, the PDE is written as:
∂ 2u ∂ 2u ∂ 2u
A( x, t ) + B( x , t ) + C ( x , t )
∂x 2 ∂x ∂t ∂t 2
∂u ∂u
= D ( x, t ) + E ( x, t ) + F ( x, t )u( x, t ) + G( x, t ) (2.19)
∂x ∂t
where the coefficients A(x, t) … G(x, t) may be functions of x, t, or both, or they may be a constant. The
function u(x, t) is the solution of the equation. The second-order PDE (2.19) has a discriminant defined as:
∆ = [ B( x, t )]2 − 4 ⋅ A( x, t ) ⋅ C ( x, t ) (2.20)
Depending on the sign of the discriminant Δ (as defined by equation (2.20)), equation (2.19) is
classified as:
• elliptic PDEs, if Δ < 0, which are PDEs with smooth solutions, easy to solve;
• hyperbolic PDEs, if Δ > 0, which have solutions that may have discontinuities, usually difficult to
solve computationally; and
• parabolic PDEs, if Δ = 0, which may have features of hyperbolic and elliptic PDEs combined.
The terminology for this classification is coined from the geometry of conic sections that satisfies a
similar type of equation like (2.19), just that they are expressed in coordinates x and y.
Each type of equation describes a certain type of physical phenomena; elliptic PDEs describe processes
that are in steady state, time-independent (e.g., steady-state aquifer flow, backwater curves); hyperbolic
PDEs describe time-dependent, conservative physical processes, (e.g., advection/convection), that are
in unsteady state and not evolving towards steady state; and parabolic PDEs describe time-dependent,
dissipative physical processes (e.g., such as diffusion, transient aquifer flow) that are evolving towards a
steady state. These three types of equations are very important for flow problems and the solution for each
one of them is further presented.
2.2.1 Solutions of ODE
An Ordinary Differential Equation (ODE) is a differential equation where the solution depends on one
independent variable only. The general form of an ODE is:
du(t ) (2.21)
= f (u, t )
dt
where u(t) is an unknown function of the variable t (time) and f is an arbitrary function in u(t) and t.
Ordinary differential equations may have analytical solutions that are easy to obtain if the function
f(u, t) is not too complicated. However even if the analytical solution exist the implementation of the
solution into a computer programme may be difficult.
If along with equation (2.21) an initial value of the function u(x, t) is given then the problem is called
initial value problem (IVP) and can be solved easily using numerical approximations, as it is detailed
further in Chapters 4 and 5 of the book.
2.2.2 Solutions of PDE
In order to have a solution for a PDE, the problem must be well posed mathematically (Garabedian,
1966; Cunge & Verwey, 1986; Ligget & Cunge, 1975). This implies that solution fulfils three conditions;
it exists; it is unique; and depends on auxiliary conditions such as boundary conditions. Fletcher (1998)
states that uniqueness of solution is not a problem in general, and if it does not exist is mainly due to
failure to fulfil auxiliary conditions. Moreover from mathematical point of view for some particular
equations there are isolated points in the definition domain for which the solution may not be unique.
There are physical phenomena for which multiple solutions exists, due to the physical phenomena, not
due to the mathematical position of the problem. Such an example is the case of transition from laminar
to turbulent flow.
Any PDE can be solved if boundary conditions and initial conditions on the computational domain are
known. Typical representations of the computational domains and required boundary conditions for the
three defined types of second order PDEs are represented in Figure 2.2.
The definition of boundary conditions constitutes the start for determining the solution of any problem
inside the computational domain. There are three ways of defining boundary conditions; Dirichlet type
of conditions, when the values of the unknown function u are known at the border of the computational
volume (on A, see Figure 2.1); Neumann type of conditions, when derivatives of the unknown function
is known at the border of the computational domain; and Robin or mixed type of conditions, when a
combination of Dirichlet and Neumann conditions are applied at the domain boundary.
(a) t t t
B.C.
B.C.
B.C.
B.C.
(b) t (c) y
B.C.
Computational Computational
Domain Domain
B.C.
B.C.
B.C.
B.C.
x x
a I.C. b a B.C. b
Parabolic equations Elliptic equations
Figure 2.2 Computational domains, boundary and initial conditions for PDEs. (B.C. Boundary conditions;
I.C. Initial conditions; (a) Hyperbolic type of equations; (b) Parabolic type of equations; (c) Elliptic type of
equations).
An important issue in finding the solution of a PDE are the errors. Hyperbolic types of problems are the
most exposed to errors because in their case conditions at the boundary of the computational domain are
the ones introducing the errors that will propagate inside the computational domain.
∂u ∂u ∂v ∂v
a1 + b1 + c1 + d1 = f1 (2.22a)
∂ξ ∂η ∂ξ ∂η
∂u ∂u ∂v ∂v
a2 + b2 + c2 + d2 = f2 (2.22b)
∂ξ ∂η ∂ξ ∂η
where, ξ and η are the independent variables. For water related problems ξ corresponds to the x-coordinate
and η to time t. The unknown functions are variables that correspond to flow quantities, such as flow
velocity or water depth h.
Because both u and v are functions of (ξ, η), their total derivatives in the (ξ, η) plane are:
∂u ∂u
du = dξ + dη (2.23a)
∂ξ ∂η
∂v ∂v
dv = dξ + dη (2.23b)
∂ξ ∂η
These derivatives can have different values in different regions of the (ξ, η) plane, or may not exist in
some regions. The curves that are splitting the lines into different regions are called characteristic curves
and are determined from the condition that the determinant of the system formed from the four equations
(2.22a, b) and (2.2.3a, b) is not zero, that is, the system of equations has a unique solution. The formed
system of equations is written in matrix format as:
a1 b1 c1 d1 ∂u/∂ξ f1
a b2 c2 d2 ∂u/∂η f2 (2.24)
2 =
dξ dη 0 0 ∂v/∂ξ du
0 0 dξ dη ∂v/∂∂η dv
The unknowns of the system (2.24) are the derivatives of the unknown functions u and v. These are not
determined if the determinant of the system (2.24) is zero, The value zero of the determinant defined by
(2.24) determines the regions in space beyond which there is no solution for the given equation, because
the derivatives do not exists. The condition is written as:
a1 b1 c1 d1
a b2 c2 d2
2 =0 (2.25)
dξ dη 0 0
0 0 dξ dη
2
dη dη
(a1c2 − a2 c1 ) ⋅ − (a1d2 − a2 d1 + b1c2 − b2 c1 ) ⋅ + (b1d2 − b2 d1 ) = 0 (2.26)
dξ dξ
Rearranging yields:
2
dη dη
a + b +c=0 (2.27)
dξ dξ
with coefficients:
a = (a1c2 − a2 c1 ); b = (− a1d2 + a2 d1 − b1c2 + b2 c1 ); c = (b1d2 − b2 d1 ) (2.28)
Equation (2.27) has two solutions, real or imaginary, depending on the value of the discriminant. The
two solutions of the equation (2.27) are the known solutions of the quadratic equation:
dη −b ± b2 − 4 ac
= (2.29)
dξ 2a
Equation (2.29) represents curves in the (ξ, η) plane, called characteristic curves (C1 and C2), and
determines the number of required boundary conditions in order to have a unique solution. The discriminant
is similar to the one defining the types of PDEs, hence depending on the value of the discriminant the
problem can be of 3 types: hyperbolic – with two real characteristics; parabolic – with one characteristic;
or elliptic – with two imaginary characteristics (see Figure 2.3).
Domain of dependance
x x x
Hyperbolic P.D.E. Parabolic P.D.E. Elliptic P.D.E.
Figure 2.3 Domain of solution for a system of two first order differential equations.
If the analysis is done from the point of view of the solution of flow phenomena it can be stated, as
already mentioned, that hyperbolic behaviour means that a system develop from the state at point P of the
computational domain towards a state in between the characteristics C1 and C2 (shock waves). In case of
parabolic type of problems it can be seen that from a state P in the computational domain the solution can
evolve only in one part of the computational domain. Elliptic type of problems can develop from any state
P to any state in the computational domain.
∂2u ∂2u
− a2 2 = 0 (2.30)
∂t 2
∂x
where u is the unknown function and a is the wave speed, considered a constant in this example.
Given the initial and boundary conditions, over the domain (0, L) (see Figure 2.4a):
u( x, 0) = sin π x
∂u
∂t =0 (2.31)
( x ,0)
u(0, t ) = u( L, t ) = 0
Representation in the (x, t) plane, of the solution given by (2.32), is shown in Figure 2.4b.
1 1
1
0.9 0.9 0.9
0.8 0.8 0.8
0.7
0.7 0.7
0.6
Solution
Sin(π*x)
Figure 2.4 (a) Initial condition and (b) solution of the wave equation.
In general, for different types of initial conditions the solution of the equation (2.30) is not easy to
be determined. The method used to solve the wave equation is usually the method of characteristics
(Abbott & Basco, 1982). According to equation (2.27) there are two real characteristics available for
equation (2.30):
dx
dt = a
(2.33)
dx = − a
dt
The set of equations (2.33) are two straight lines (because a is a constant), which show that a disturbance
in solution of u, taking place at point P influences the solution domain after P (CPD in Figure 2.5(b)).
Solution in point P is influenced by disturbances in the domain before point P (APB). Depending on the
position of P in the computational domain initial conditions may be sufficient to determine the solution
at point P, uniquely. However there are points in the computational domain for which solution can be
determined uniquely only if boundary conditions are given (see Figure 2.5).
Another example of hyperbolic equation, which is very common for many phenomena in aquatic
environment, is the advection equation:
∂u ∂u
+a =0 (2.34)
∂t ∂x
In case of equation (2.34), just one characteristic line passes through every point of the space (see
Figure 2.6). Equations (2.30) and (2.34), presented herein, are equation showing propagation phenomena.
No dissipation effect is present, just convection.
dx
=a
dt
The exponential part of the solution given by equation (2.36) represents the time decay.
Initial Condition
(a) (b)
1 1
0.9 0.9
1
0.8 0.8 0.9
0.8
0.7 0.7
0.7
Sin(π*x)
Solution
0.5 0.5 0.5
0.4
0.4 0.4
0.3
0.3 0.3 0.2
0.1
0.2 0.2
0
0 0.8
0.1 0.1 0.2 0.6
0.4 0.4
0 0 0.6
0.8 0.2
0 0.2 0.4 0.6 0.8 1 Distance 1 0 Time
Figure 2.7 (a) Initial conditions and (b) solution for the diffusion equation.
When other types of boundary and initial conditions are given the solution has to be computed either
through integration or through numerical approximation. In case of parabolic equations characteristics are
not so important because they are equal, and they show that solution at point P of the computational space
can influence any point in the computational domain. In case of parabolic equations any combination of
Dirichlet, Neumann or Robin boundary conditions are appropriate to be used.
y
B.C.
Computational
P Domain
B.C.
B.C.
B.C. x
Figure 2.8 Computational domain and boundary conditions for elliptic PDEs.
∂u 1
= − (u ⋅ ∇)u + ϑ∇ 2u − ∇p + S (2.38)
∂t d
∇u = 0
where u is the velocity vector, ϑ viscosity (controls the velocity of diffusion), p is pressure and S the
external forces. First equation of the system (2.38) shows the change in velocity, which is composed of
a summation of four terms. The first term in the right-hand side of the first equation of system (2.38) is
called advection (convective) term, and it shows how the fluid moves around, it shows the force exerted on
a particle of the fluid by the other particles of fluid surrounding it. The second term in the same equation
is the diffusion term and it shows how the fluid motion is damped. The third term is the pressure term, and
the fourth term are the external forcing functions such as gravity or wind.
Navier-Stokes equations are not easy to solve, because of the non-linearity of the advective term of the
equation. Analytical solutions however, are available for particular cases, very simple ones that have a
simple geometrical computational domain and simple boundary conditions.
For flow of water the Navier-Stokes equations are solved, by making further assumptions, which simplify
the equations and allows for numerical approximation of the solution. Each of the simplified approach is
used for different problems, because the assumptions made are depending on the considered phenomena.
There are three main approaches, in water related flows, in order to represent Navier-Stokes equations in a
simpler form:
• Averaging the equations: Reynolds averaged equations plus a turbulence model (RANS);
• Large Eddy Simulation (LES);
• Approximations of the averaged equations, that is, equations averaged over the cross-section (Depth
averaged).
In the first approach, the average of the flow is used, and the turbulence fluctuations are considered less
important. Each physical quantity is represented as an average over the computational time interval. The
quantity itself is represented as a summation between a mean value and a fluctuating part. The averaging
transforms the non-linear terms in linear ones, but they do introduce a new term, the derivative of the
averaged quantity. The equations obtained are called Reynolds averaged equations. The additional term
in the equation requires the use of a turbulence model. The LES forms of the Navier-Stokes equations
are used for turbulence modelling (Aldama, 1990; Lesieur, 1997; Sagaut, 2001). In the third approach
depth averaged approximations of velocity in space are used for the simplification of the Navier-Stokes
equations.
2.3.2 Saint-Venant equations
The flow of water can be in a closed or open space. These two types of flow differ in the fact that in the
open space water flows with a free surface, while in the closed space is a pressurised flow. The flow in a
closed space is flow in conduits (pipes) and can be in some instances with free surface, however they can
be considered the same as the flow in an open space. The free surface flow is the flow occurring in oceans,
estuaries, coastal regions, lakes and impoundments. This kind of flow is subject to atmospheric pressure
and water surface changes in space and time, hence it is more difficult to solve. Variables that are part of
the equation; depth of flow, velocity or discharge, bottom slope, position of the free surface flow; are all
interrelated. Moreover in case that flow is in a river the shape of the cross-section of the channel flow is
arbitrary, while in pipe flow cross-sections are simple (circular or regular shape). Roughness of a channel
may vary much more than the roughness of a pipe, which makes the free surface flow more complex.
These equations are not easy to solve, hence research on methods of solution of the free surface flow
equations has received considerable attention.
Due the complexity and importance of free surface flow, the equations are presented and analysed
in detail here. Methods of solution for these equations through numerical approximations are shown in
Chapters 4 and 5. For the special case of flow in rivers and lakes these equations and their solution is
addressed in Chapters 7 and 8 of the book.
Free surface flow is unsteady in nature and the equations expressing it are unsteady flow equations.
There are however cases in which the problems are steady in nature and the solution is easier to be
determined. Though the equations of steady flow are determined separately, through assumptions on the
steady character of the flow, they can also be determined from the unsteady flow equations, as particular
case, when all changes with time are set to zero.
Flow is classified in respect with its variation with space, not only with time, as uniform and non-
uniform flow. Flow is considered uniform if depth and velocity of flow is the same at every point in space.
It occurs when gravity forces are in equilibrium with friction forces.
In case that the wave length of the free surface flow is much more bigger than the depth of flow then
the equations describing the phenomena are referred as shallow water flow equations or Saint-Venant
equations. These equations are Reynolds depth averaged forms of the Navier-Stokes equations. They can
be determined also independently of Navier-Stokes equations, using physical arguments and by making
assumptions on the fluid flow.
For simplicity of formulation Saint-Venant equations are further discussed for the case of one dimensional
flow. The basic assumptions for the derivation of Saint-Venant equations are (Saint-Venant, 1871):
(1) The wave length of the disturbance of the flow is very long as compared with the depth of the flow.
This assumption implies that flow is one dimensional and parallel to the walls and bottom forming
a channel in which flows takes place;
(2) The channel geometry is not changing in time, that is, deposition or scour of sediment is very small
and considered to have no effect;
(3) Streamline curvature of the channel is small; lateral and vertical accelerations are negligible
compared to the longitudinal accelerations; therefore, the pressure distribution is hydrostatic;
(4) Slope of the channel bed is small, that is, the tangent and sine of the angle between bottom and
horizontal have the same value as the angle itself;
(5) The effect of boundary friction force is estimated using a relation derived from steady uniform
flow;
(6) Water surface in any cross section of the channel is assumed to be horizontal and parallel with the
bottom of the channel.
There are two ways of expressing the Saint-Venant equations; in conservative form, when the dependent
variables are discharge and depth of flow; and in non-conservative form, when velocities and water depth
are the dependent variables. Equations expressed in velocities are non-conservative because velocities are
not subject to conservation, and the equations do not hold across discontinuities, such as hydraulic jumps
or in case of shocks. Equations in conservative form have the advantage that they do hold even if some of
the assumptions of Saint-Venant equations break, as it is the case for example of the hydraulic jump. They
are used when there are significant variations of flow in space.
The Saint-Venant equations are obtained by writing the conservation of mass and momentum over a
small control volume. For a 1D channel, which has the longitudinal profile, and cross-section as the one
represented in Figure 2.9, Saint-Venant equations for an arbitrary cross-section of a channel, in conser
vative form, are (Cunge et al., 1986; Popescu, 2013):
∂A ∂Q
+ =q (2.39a)
∂t ∂x
∂Q 2Q ∂Q Q 2 gA ∂A
+ + − + − gAS0 + gAS f = quq (2.39b)
∂t A ∂x A2 B ∂x
A ∆t
t Β
Q
A q
q Q ∆x
Q+
x q h
S0
∆x y
y
∂h ∂(uh)
+ =q (2.39c)
∂t ∂x
∂u ∂u ∂h
+u +g − gS0 + gAS f = quq (2.39d)
∂t ∂x ∂x
In equations (2.39a–d) the notations are, as per Figure 2.9; A, area of the cross-section; Q discharge in
the control volume; q lateral flow; h water depth; S 0 the slope of the channel, Sf the friction slope; u velocity
of flow; and uq velocity of the lateral flow.
Equation (2.39a) and (2.39c) represent the continuity equation, while (2.39b) and (2.39d) represent the
momentum equation.
In both representations, momentum equation has five terms; the local acceleration, which describes
the change of momentum due to the change of velocity over time; the convective acceleration that shows
the change in momentum due to change of velocity along the channel; the pressure term that describes
the pressure force which is proportional to the change in water depth along the channel; the gravity term
that shows the force due to gravity; and the friction term that shows the friction force proportional to the
friction slope.
The system formed by the above two equation, in conservative or non-conservative form, does not have
an analytical solution. There are cases when momentum equation can be used with less than five terms,
depending on the problem to be solved. Some of the terms, of the momentum equation might be very
small, as compared to the other terms, hence they can be neglected (Price, 1985). Depending on how many
terms are used in the representation of the equation of momentum, the following terminology is used:
• Kinematic wave representation, when momentum equation reduces to two terms: S 0 = Sf ;
• Diffusive wave approximation, when the first two terms of the momentum equation, called inertia
terms, are neglected; and
• Fully dynamic wave, when the full momentum equation is considered.
Solution approaches for these three cases are detailed below.
∂Q ∂Q ∂h
= ⋅ (2.40)
∂x ∂h ∂x
∂A ∂Q ∂Q ∂A ∂Q ∂Q ∂h
+ = + ⋅ =q (2.41)
∂Q ∂t ∂x ∂Q ∂t ∂h ∂x
∂Q
Equation (2.41) is a form of advection equation, with the wave celerity c = .Re-arranging (2.41), for
∂A
the case of zero lateral flow, yields:
∂A dQ ∂h dQ ∂h
⋅ ⋅ + ⋅ =0 (2.42)
∂Q dh ∂t dh ∂x
Hence:
∂h ∂h
+c⋅ =0 (2.43)
∂t ∂x
An expression for the kinematic wave celerity c may be obtained from one of the steady flow equations
such as Chezy or Manning (Chow et al., 1988). For example by using Manning equation, and a wide cross-
section approximation, for which hydraulic radius is approximately the same as the water depth, the value
of the wave celerity is:
2
c= u (2.44)
3
Equation (2.43) is the kinematic wave equation and is a linear advection equation if c is a constant. The
advection equation with a positive velocity c will propagate just in the positive direction of the x axis, that
is, towards downstream. In general, the wave velocity is a function of water depth c = c(h). The bigger the
flow depth, the bigger the value for c. For one-dimensional problems this results in a steepening of the
wave front. Kinematic wave equation applies to situations where flows are on steep bed channels, but do
not apply to backwater effects, nor to tidal flows. An extensive study on the kinematic wave can be found
in Ponce and Simon (1977).
∂h
= S0 − S0 (2.45)
∂x
∂h
( )
which is equivalent with stating that Q = Q h( x ), ∂x . Replacing this relation into equation (2.38a), and
considering lateral flow to be zero, lead to:
∂Q ∂Q ∂2Q
=c +D 2 (2.46)
∂t ∂x ∂x
where c is the kinematic wave celerity (as previously defined) and D is the diffusion coefficient. Equation
(2.46) has the form of an advection-diffusion equation, hence its name. The diffusion coefficient has the
expression:
1 ∂Q
D= ⋅ (2.47)
B ∂h
∂
∂x
The diffusion coefficient is always positive because the energy slope is always positive. Different from
kinematic wave, in case of diffusive wave, as the name is stating, there is diffusion. While the water wave
travels towards the downstream direction diffusion in form of attenuation happens.
Applying the diffusive wave description of phenomena it is possible to solve problems with relatively
small backwater effects, slowly propagating flood waves and runoff on mild slopes. Several methods of
solution are available in the literature for the diffusive wave approximation such as Muskingum-Cunge
method (Cunge, 1969), the Zero-Inertial solution (Strelkoff & Katopodes, 1977) or Parabolic and Backwater
(Todini & Bossi, 1986).
∂h 2 c ∂c
= ⋅ (2.48a)
∂t g ∂t
∂h 2 c ∂c
= ⋅ (2.48b)
∂x g ∂x
Equations (2.48) are substituted in (2.39a) and (2.39b), then the obtained equations are divided by c
and multiplied by g. As a result, the following two equations are obtained:
∂c ∂c ∂u
2 + 2u ⋅ +c⋅ =0 (2.49a)
∂t ∂x ∂x
∂u ∂u ∂c
+u⋅ + 2c ⋅ =0 (2.49b)
∂t ∂x ∂x
Adding (2.49a) and (2.49b) and then subtracting them, results in:
df ∂f dx ∂f
= + ⋅ (2.51)
dt ∂t dt ∂x
df
If dx
dt = u + c, then dt
= 0. This is similar with saying that:
d (u + 2c) dx
= 0 along = (u + c) (2.52a)
dt dt
or equivalent
dx
J + = (u + 2c) = const along = (u + c) (2.52b)
dt
Similarly:
d (u − 2c) dx
= 0 along line = (u − c) (2.53a)
dt dt
or equivalent
dx
J − = (u − 2c) = const along = (u − c) (2.53b)
dt
Equations (2.52a,b) and (2.53a,b) are the characteristic equations; J−, J+ are called Riemann invariants.
These equations are of hyperbolic type. The fact that along the characteristic a special condition is valid
shows that characteristics can pass information on the state of the fluid. The auxiliary variable, which has
been introduced, is called celerity, and has a special meaning, it is the celerity with which a disturbance is
propagated in water. Cunge et al. (1986) shows the relation between characteristic lines and the boundary
and initial data requirements for the solution of Saint-Venant equations. In Figure 2.10 it is shown that
in the case of subcritical flow at the upstream boundary of the computational domain one characteristic
arrives from inside the domain, carrying information from another point of the computational domain.
The other characteristic comes from the outside of the computational domain, hence it has to be replaced
by a boundary condition. Such a boundary condition is given usually in the form of water depth, water
velocity or discharge-stage relationship. The same analysis applies at the downstream boundary of
the computational domain. In Figure 2.10b the case of supercritical flow is shown. It can be seen that
the problem can be solved if two boundary conditions are given at the upstream boundary. The main
conclusion is that for every characteristic entering a computational domain, one boundary condition has
to be given.
c1+
c+ c–
L c2+ R R
L R L
I I I
c– c+
1 B.C. 1 B.C. 2 B.C. 1 B.C.
x x x
I.C. I.C. I.C.
Subcritical flow Supercritical flow Critical flow
c+ – pozitive characteristics
c– – negative characteristics
Figure 2.10 Characteristic solution of Saint-Venant equations over a given computational domain;
(a) Subcriticalflow conditions; (b) Supercriticalflow conditions; and (c) Critical flow conditions.
Though this approach is very important, it cannot be applied to problems that include dissipative terms
or for channels with irregular topographies. It is easier to use numerical approaches for finding the solution
of Saint-Venant equations.
equation; the discretization of the unknown function in values at discrete points (i.e., the approximate
representation of the solution); and the discretization of the equation itself. Each of these stages is described
separately in this book. Discretization of the computational domain is covered in the current chapter,
while the discretization of the solution and of the equation are explained in the chapters about finite
differences and finite volume methods. Regardless of the numerical method used, different types of grids
are used in engineering problem practice. Figure 3.1 shows an example of a simple grid, representing the
discretization of Yongdam reservoir, in South Korea. The gridlines cross each other orthogonally, hence
the grid is called Cartesian.
Figure 3.1 Vertical Cartesian computational grid, the example of Yongdam reservoir, South Korea.
The transformation of the continuous equations into discrete forms is done through methods such as
finite difference, finite volume, finite element, boundary element, spectral methods, collocation methods,
and so on. The first two are the methods used in this book and the presentation of grid generation is done
in relation with these two methods. Discretization is done for both time and space, however the space
discretization using in grids is more complex than that of time discretization, especially because it involves
three independent variables (see Figure 3.2).
Initially space grids were regular and structured, however as more complex numerical methods were
developed, due to the computational power of computers, irregular physical geometries could be accounted
for. Space grids, also known as mesh are of three types; structured, unstructured and meshless. Meshless
discretization is not used by the finite differences and finite volume methods therefore not addressed here.
y
x
...
tinitial tfinal
873 873
871 871
North [km]
North [km]
869 869
867 867
865 865
837 839 841 843 845 847 837 839 841 843 845 847
East [km] East [km]
The finite difference method requires a structured grid, while for the finite volume method both structured
and unstructured meshes can be used (see Figure 3.3).
For each cell of a computational grid a space is allocated in the computer’s memory, because the
unknown function is defined at the nodes of the grid or at the cell points of the grid. In case the grid
extends over domains that are not of interest, the required computational memory is very high.
Several author presents comprehensive reviews on how meshes are generated and for which type of
problems they should be used (Buell & Bush, 1973; Thacker, 1980; Ho-Le, 1988).
3.2 Space Discretization
Space discretization is discussed for two and three dimensions of space, because the one-dimensional space
does not poses any challenge in discretization. One-dimensional computational domains are discretized in
a computational grid by selecting nodes unequally or equally spaced (see Figure 3.4).
(a)
... x
(b)
... x
∆x ∆x ∆x ∆x ∆x
equally spaced grid
3.2.1 Structured grids
Structured grids are simple, used for the discretization of a rectangular domain. Each of the axes of
coordinates is divided by nodes in subdomains, independently of the number of subdivision on the other
axes. For example in case of a 2D grid there are a number of nx and ny cells in the x and y direction,
respectively. Each node or cell in the computational grid is identified by two indices.
Structured grids are classified as:
• Uniform regular grid, where the division of space in each direction is a constant (equally spaced)
(see Figure 3.5a);
• Non-Uniform regular grid, where the division of space in each direction is not constant (see Figure 3.5b);
• Orthogonal grids, where the grid lines are orthogonal to each other (see Figure 3.5a and 3.5b);
• Curvilinear grids, where the grid lines are curves in space (see Figure 3.5c).
Regular structured grids are especially used with the finite difference method, because the derivatives
of the unknown function are easily computed with respect to all spatial directions. Moreover these types
of grids do not require a transformation of the coordinates, as is the case with the finite volume method,
or other numerical methods. The use of such grids is easily implemented in a computer programme,
because the nodes and cells are determined using their indices, hence the structure of the solution matrix
is known in advance. The main disadvantage of structured grids is that they cannot represent irregular
complex domains.
(a) (b)
∆y
∆x
∆x = ∆y
∆y
(c)
∆x
∆x = ∆y
curvilinear
The only way for structured grids to partially cover irregular domains is by using the so-called
multiblock grids, which are a combination of several structured grid blocks (see Figure 3.6). The solution
computation is done on each block separately, however the computation advance from one block to another
requires special treatment.
Block 2
Block 1
Block 3
Apart from the multi-block type grids, which try to overcome irregular domains, there is another
particular type of discretization grid called a staggered grid. These type of grids are specific to the problem
that is solved by the differential equation and the way derivatives of the unknown function are expressed.
They are used in case of a phenomenon that requires solutions for a system of differential equations and
the different unknown variables have different approximation representations for the derivatives. For such
grids different unknown variables are determined in different nodes of the grids.
An example of a staggered grid in one dimension is shown in Figure 3.7 in which Saint Venant equations
are solved for a one-dimensional flow in open channels.
t - unknown value
- known value
...
q
h h q h q h
n+1
q
h
n
q
...
h
x
L L
3.2.2 Unstructured grids
Unstructured grids are complex and are not generated easily, however they are highly flexible in
representing the computational domain. The number of nodes and cells of an unstructured grid are not
related by an equation, hence it is not easy to identify a cell using indices only, as in the case of structured
grids. Each cell of an unstructured grid has to be defined by the nodes that are forming it, therefore all
coordinates of the nodes have to be defined along with the information regarding the cell to which they
belong. Unstructured grids are used for the finite volume method and they are the grid of preference for the
finite element method. They have the advantage that they can represent some areas of the computational
domain in a very detailed manner, however they have the disadvantage of longer computational time. An
example of an unstructured grid is shown in Figure 3.8, as general representation. Figure 3.9 shows the
structured and unstructured grid representation for a portion of Yellow River, in China.
Figure 3.9 Structured (a) and unstructured (b) grid representation for the middle section of the Yellow
River, China.
The output of a grid generation is a set of elements along with a set of points that define it. The set of
elements represents the grid topology. Depending on the approach taken to create the elements of a grid,
the grid generators are (see Figure 3.10):
• Creating first nodes then elements;
• Creating first grid topology then nodes;
• Creating nodes and elements simultaneously; and
• Adapting grid from pre-defined grid templates.
Topology Description
Nodes creation
Node description
Mesh generation
methods Grid based
Use of predefined
templates Geometry decomposition
From the four methods listed above the templates are generated separately, independently of the
computational domain and they are later adapted for the given computational domain. The approaches
known to create templates are: grid-based, mapped elements, conformal mapping and nodes and elements
created simultaneously.
There are several quality checks that need to be performed over a grid after it has been generated using
a grid generator. The most important aspects are: grid smoothing, grid density and grid conformity. In case
these three qualities of a grid are not fulfilled then the grid has to be refined manually.
Grid smoothing refers to the shape of the elements. Smoothing is performed by repositioning the nodes.
Repositioning is a difficult task that requires iterations, as repositioning might be wrong.
Density of a grid refers to the ability of a grid to change from one part of the computational domain to
another depending on the computational needs. Conformity is related to the density of a grid, because when
a grid is refined smaller elements are introduced and they might be distorted. In general orthogonality is
the measure to check for grid conformity.
values of the unknown function are placed back to the initial computational domain, which represents
the real domain. Such an example is a distorted L-shape region that can be transformed into a simple
I-shape (see Figure 3.11).
y η
x ζ
Figure 3.11 Computational domain transformations from one system of coordinates to another.
Transformation should be done with care because it may introduce accuracy problems in the solution.
In case of a bump a transformation grid may eliminate the bump (see Figure 3.12).
y η
x ζ
Fletcher (1991) emphasizes the importance of carefully making such transformations because the
computational domain is distorted and so is the corresponding approximate solution.
3.3 Time Discretization
Discretization of time is separated from the one in space. Time discretization is used for problems, where
the boundary of the computational domain varies in time, as is the case with free surface flows. In each
time step values of the unknown function are computed at all nodes of the grid in space. When all values
of the unknown function have been determined at time step n computation advances to the next time step
(n + 1). Numerical methods algorithms are written with respect to time level n and (n + 1), considering that
all values of the unknown function are known at time step n, for all nodes of the space grid, and a new
computation starts to determine all the values at time level (n + 1) where values of the unknown function
are considered unknown (see Figure 3.13).
t
...
n+1
∆t ... ...
n
0 1 2 3 i-1 i i+1
...
Depending on the numerical method to determine the approximate solution of a differential equation,
there are two main types of discretization with respect to time; explicit and implicit methods.
In explicit discretization the values at the grid nodes of each unknown variable at the new time step
of computation depend only on known values at the previous time step. The advantage of this kind of
discretization is that in many cases no system of equation is formed, hence no solver is required, because
the solution is straightforward computed step by step. Such a discretization is easy to implement in a
computer programme. The disadvantage of such an approach is that solution becomes unstable if the time
intervals for computation are selected bigger than a threshold value. Such a threshold value is usually
determined from stability conditions of the solution combined with physical characteristics of the variable
that needs to be determined.
The implicit method of time discretization determines the values of the unknown function at the grid
nodes from values of the function at neighbouring points at the same time level. An algebraic system of
equations is formed, that requires a solver to be solved. The advantage of such method is that they are
stable and no threshold value on the time interval of computation is required. From an accuracy point of
view one should always try to solve the problems with small time intervals.
In order to take advantage of both implicit and explicit methods of discretization for time, combined
methods are also used. They are called semi-implicit methods, where the variable at the new time step
depends both on the old and new time step.
• Schemes in which the determination of the derivative involves the value of the unknown variable
at time level n + 1. In such schemes there is an implicit relationship between the derivative and the
unknown variable, hence they are called implicit schemes.
• Schemes in which the explicit and implicit approaches are combined.
Ordinary differential equations, depending on the computational approach of the numerical scheme,
are classified as one-step methods and multi-step methods. If the unknown function at a node of the
grid can be computed using information only from the previous node of the discretization grid then the
method is called one-step. One-step methods are also known as self starting methods, because the given
initial condition is sufficient to perform the computation for the value of the unknown function in all the
nodes of the discretization grid. If the value of the unknown function in the current computational step
is computed based on information from more than one preceding step of computation then the method
is called multi-step.
Each type of scheme has very different properties, as shown in Chapter 6 of the book. There are many
finite difference methods available for solving differential equations, however due to the properties of the
equations used in the aquatic environment, only few of them are applicable, therefore only a selection of
these methods are presented in this chapter.
f ( x + ∆x ) − f ( x )
f ′( x ) = lim (4.1)
∆x → 0 ∆x
f (x )
x
x x + ∆x
∆x
Nowadays calculations are carried out on computers and these cannot deal with a limit for which
Δx → 0, therefore a discrete form of the continuous case is introduced.
The function f(x) is defined by a set of values available at a number of discrete points of the domain of
definition of the function. Figure 4.2 shows a set of discrete points xi where the function is known. The
nodes xi are positioned at distance intervals Δxi = xi+1 − xi. The notation fi is used to denote the value of the
function f(xi) at the i-th node, that is, fi = f(xi). The set of nodes is called the computational grid (as already
defined in Chapter 3).
f (x )
...
f (x 2)
fi fi+1
f (x 1)
f1 f2
x1 x2 ... xi xi+1 x
The approximation of the function’s derivative is done using the discrete values of function f in a number
of points of the domain of the function. This approximation is obtained using Taylor series expansions.
Consider, for simplicity, an equally spaced grid of the independent variable x. A Taylor series is an
expansion of f(x + Δx) or f(x − Δx) for a finite Δx at a fixed node x and can be expressed as:
(∆x )2 (∆x )3
f ( x + ∆x ) = f ( x ) + ∆x f ′( x ) + f ″( x ) + f ′″( x ) … (4.2)
2! 3!
(∆x )2 (∆x )3
f ( x − ∆x ) = f ( x ) − ∆x f ′( x ) + f ″( x ) − f ′′′( x ) … (4.3)
2! 3!
where f ′ is the first derivative of f with respect to x, f ″, the second derivative and so on.
Rearranging (4.2) gives:
f ( x + ∆x ) − f ( x ) 1 (∆x )2 (∆x )3
= ∆xf ′( x ) + f ′′( x ) + f ′″( x ) + = f ′( x ) + O(∆x ) (4.4)
∆x ∆x 2! 3!
If equations (4.2) and (4.3) are subtracted from each other it yields:
f ( x + ∆x ) − f ( x − ∆x ) 1 ∆x 3
= 2 ∆xf ′ ( x ) + 2 f ′″( x ) + = f ′( x ) + O(∆x 2 ) (4.5)
2 ∆x 2 ∆x 3!
If Δx is small then it can be considered that:
f ( x + ∆x ) − f ( x )
f ′( x ) ≈ = (4.6)
∆x
or
f ( x ) − f ( x − ∆x )
f ′( x ) ≈ = (4.7)
∆x
or
f ( x + ∆x ) − f ( x − ∆x )
f ′( x ) ≈ = (4.8)
2 ∆x
Equations (4.6)–(4.8) are examples of three simple finite difference approximations, as represented in
Figure 4.3; the forward, backward and centered difference, respectively.
f (x)
P
F
Backward derivative
B Forward derivative
Central derivative
xi-1 xi xi+1 x
∆xi ∆xi+2
In Figure 4.3 function f(x) is represented for a small interval near the discretization point xi. It can be
seen that forward differencing uses the forward values of function f(x), that is, the values of the function
in point (xi+1, f(xi + Δxi)), backward values in point (xi−1, f(xi − Δxi−1) for backward differencing and values
on both sides of the function, in points (xi+1, f(xi + Δxi)) and (xi−1, f(xi − Δxi−1)) for central differencing.
The term O(Δx) in equation (4.4) or O(Δx2) in equation (4.5) is a truncation of the Taylor series after
the second term (right hand side of the equation). These terms are referred to as the truncation error (T.E.)
because they represent the error when equations (4.6)–(4.8) are used. Hence the T.E. can be defined as the
difference between the partial derivative and its finite difference representation.
For smooth functions (the ones that have continuous higher order derivatives), and for a sufficiently
small Δx, the first term of the truncation error, can give the order of magnitude of the error. Depending on
the order of the term O(Δx), the following terminology is used:
Several higher order approximations of the first derivative of a function can be obtained by linearly
combining the two Taylor series representations given by equations (4.2) and (4.3).
In case that the discretization grid is not equally spaced (see Figure 4.2), equations (4.2) and (4.3) are:
(∆xi )2 (∆xi )3
f ( xi + ∆xi ) = f ( xi ) + ∆xi f ′( xi ) + f ″( xi ) + f ′″( xi ) + (4.9)
2! 3!
(∆xi −1 )2 (∆xi −1 )3
f ( xi − ∆xi −1 ) = f ( xi ) − ∆xi −1 f ′( xi ) + f ″( xi ) − f ′″( xi ) + (4.10)
2! 3!
If equation (4.9) multiplied by Δxi−1, is added to equation (6.10) multiplied by Δxi, the following equation
is obtained:
It can be noticed that in case of an equally spaced grid equation (4.11) is simplified to equation (4.6),
that is, the cantered difference approximation is obtained.
From equation (4.11), it can be noticed, that three values of the unknown function in three discretization
nodes are used to compute the discrete value of the centered derivative at the node xi, that is, the nodes xi−1,
xi and xi+1. The truncation error O(ΔxiΔxi−1) is of second order.
Equation (4.11) can be used to determine higher order approximations for the first derivative of a
function. For an equally spaced grid, the following expression holds:
8( f ( xi + ∆x ) − f ( xi − ∆x )) 4(∆x )4 ( 5) 20(∆x )6 ( 7) (4.12)
= f ′( xi ) − f ( xi ) − f ( xi ) …
12 ∆x 5! 7!
If equation (4.11) multiplied by 4 is subtracted from equation (4.11), written for a 2Δx grid spacing,
equation (4.12) is obtained, which is a fourth order approximation of f ′(x).
It is important to be noted that the validity of the Taylor series regarding the existence of higher order
approximations of the derivatives depends on the existence of the derivatives themselves. If derivatives do
not exist, then the higher order approximations do not hold.
In a similar way the first derivative of a function of one variable is approximated by a finite difference,
a first order partial derivative of a function depending on two or more variables can be approximated
by finite differences.
g(x,t)
g in
g in+1
g i+1n
gi+1n+1
tn
xi t n+1
xi+1 t
Let g = g(x, t), than the first order partial derivatives of the function with respect to x or t are (see Figure 4.4):
∂g g n − gIn
≈ = i +1 (4.13)
∂ x (i,n ) ∆x
and
∂g g n +1 − gIn
≈= i (4.14)
∂ t (i,n ) ∆t
ℓ points r points
ℓ+ r + 1 points
In equation (4.15), time level n has been fixed, hence the indices for the independent variables t are
not shown, for simplicity of expression.
If each of the r + l + 1 equations of type (4.15) is multiplied by a constant coefficient am and then all
are summed up:
r r r ∆x ∂ u r (∆x )2 ∂ 2 u
∑
m =− l , m ≠ 0
am ⋅ ui − m − ∑ am ui =
m =− l , m ≠ 0 ∑
m =− l , m ≠ 0
m ⋅ am + ∑
1! ∂ x i m =− l , m ≠ 0
m 2 ⋅ am
2 ! ∂ x 2 i
r (∆x )3 ∂ 3u r (∆x )4 ∂ 4 u
+ ∑
m =− l , m ≠ 0
m 3 ⋅ am + ∑
3! ∂ x 3 i m =− l , m ≠ 0
m 2
⋅ a m
4 ! ∂ x 4 i
+
(4.16)
Equation (4.16) is used to determine the r + l coefficients am of the derivative depending on the desired
order. For example if the numerical solution requires a first order derivative, fourth order accurate the
values of the coefficients bi are set as follows:
b1 =1
b =0
2 (4.17)
b3 =0
b4 =0
where
r
bk = ∑ma k
m
(4.18)
m =− l , m
The system (4.17) gives four equations that would require the use of four discretization points, in order
to have a unique solution of the system.
In general if the k-th derivative is needed then the highest derivative to be neglected is of order k + p − 1,
that is, k + p − 1 grid points are needed to determine the solution, and equation (4.18) can be re-written as:
r
bq = δ qk = ∑ma q
m ; q = 1, 2, …, k + p − 1 (4.19)
m =− l , m
with
1, if q = k
δ qk = (4.20)
0, if q ≠ k
with δqk known as the Kronecker delta. The solution exist and it is unique if:
l + r = k + p (4.21)
Based on (4.19)–(4.21) the order of the T.E. is determined by multiplying the next higher derivative in
the truncation error series with the coefficient:
r
bk +1 = ∑m k+ p
am (4.22)
m =− l , m
Based on (4.18), selecting the centred difference approximation, and considering an equally spaced
grid, it can be noticed that the second order derivative of a function u(x, t), for which the domain is
represented in Figure 4.6, can be computed as:
∂ 2u uin+1 − 2uin + 2uin−1
≈= (4.23)
∂ x2 (i,n )
(∆x )2
∆xi ∆xi+1
(n+1)
n
∆t
(n)
(i-1) (i) (i+1)
n+1
t
n
t
g(x,t)
...
gi n
gin+1
gi+1n
n+1
gi+1
2
t
tn
t
n+1
xi t
1
xi+1 t
x 0 x
0 x1 x2 ... xi-1 xi xi+1
Figure 4.6 Domain of definition and grid discretization for function u(x, t).
Another way of developing finite difference approximations are, as previously mentioned, polynomial
fitting, such as splines or Lagrange interpolations. These approaches consist in fitting a polynomial of
a certain degree to a set of selected nodes of the grid. For example, in case of a function u(x), of one
independent variable, the slope of the function u, at node xi is approximated by considering the derivative
of the considered polynomial at the point (xi, ui). The development of these approaches are presented in
detail in Boyd (1989), Butcher (1987) and Duran (1999).
du (4.24)
u′ = = f (u, t )
dt
where u = u(t) is the unknown function, t is the independent variable and f(u, t) is an arbitrary function of
u(t) and t.
Integrating equation (4.24) yields:
where C is a constant of integration. There are an infinite number of values for C, hence the obtained
solution of equation (4.24) is not unique. However in the daily practice of engineering solving problem,
there is interest just for a unique solution for a specified range of t, over a given interval. In order to choose
a solution an extra condition, called initial condition, must be specified.
The problem is formulated as follows: Determine the unknown function u(t), over the interval (tinitial,
t ) (see Figure 4.7), which satisfies the following set of equations (the given ODE and the initial condition):
final
du
= f (u, t ) (4.26)
dt
u(t initial ) = uinitial
u(t )
u(t )
n+1
u(t )
n
u
un+1
u( t )
0 un
u0
t
t initial ... tn t n+1 ... t
∆t
N intervals
Figure 4.7 Discretization domain and solution approximation for function u(t).
The problem formulated by (4.26) is called an initial value problem (IVP), for the ODE, and has a
unique solution (Asher & Petzold, 1998).
Examples of engineering problems in water related field that are represented by equations like the ones
of (4.26) are the steady flow in open channels; unit hydrograph or reservoir storage equation.
There are many more numerical schemes available for ODEs, such as explicit, implicit, Adams–
Bashford, or Adams–Moulton (Ascher & Petzold, 1998). A selection of the most used numerical solutions
for ODE, as they are used in water related problems, is presented in this section of the book.
where Δt = (t final − tinitial )/N; n = 0, 1, . . ., N; and u(tn) = un is the value of u(t) at the n-th time-step (see
Figure 4.7).
In order to approximate the derivative du/dt, the forward difference expression for the derivative
du u n +1 − u n
= + O(∆t ) (4.28)
dt ∆t
is substituted into equation (4.26). It yields:
u n +1 − u n
+ O(∆t ) = f (u n , t n ) (4.29)
∆t
Re-arranging expression (4.29) gives:
(4.30)
u n +1 ≈ u n + ∆t ⋅ f (u n , t n )
It is important to note that O(Δt) term has been neglected and by that the equation is now an
approximation. Equation (4.30) provides an expression to calculate u(t) at a particular time-step tn+1 from
its value at a previous time-step, tn. This is known as explicit differencing numerical scheme.
If u 0 = uinitial is known than u1 can be estimated; from u1, estimation of u2 can be done, and so on. After
N steps, uN = ufinal is determined.
In each approximation of the derivative term O(Δt) is neglected therefore there is a small error, that is
accumulating in time, hence, the error in the calculation of u1 is carried over in the calculation of u2, and
so on (Figure 4.8).
f(t)
f (un-1,t n-1)
f (u0,t0) f (u1,t1)
t
t0 t1 t2 ... tn
The step by step procedure of computing the values of un in time can be expressed as:
n
u n +1 ≈ u0 + ∆t ⋅ ∑ f (u , t )
j =0
j i
(4.31)
The explicit method approach for solving the ODE (4.26) is a one-step method approach.
This formula allows to calculate the unknown value of un at a certain time-step from its value at next
time-step, un+1. Unfortunately to do this, value of un+1 needs to be known and replaced into the function f in
the first step of computation. This is what is known as an implicit differencing scheme and usually cannot
be solved within a single step when the expression of the function f is complicated. Seldom it is necessary
to use a technique called iteration, such as Newton’s method.
4.4.4 Mixed schemes
If the explicit and explicit schemes are averaged together, the first-order ODE, defined by (4.26) is
differenced as:
u n +1 − u n 1 (4.34)
+ O(∆t ) = f (u n, t n ) + f (u n +1, t n +1 )
∆t 2
By rearranging expression (4.34), it yields:
u n +1 − u n 1 (4.35)
≈ = f (u n, t n ) + f (u n +1, t n +1 )
∆t 2
Expression (4.35) is more complicated than the explicit or implicit schemes and may require iteration
to be solved. It is known as trapezoidal differencing scheme or a Crank-Nicholson scheme.
tP − tn
θ = (4.36)
∆t
u n +1 − u n
≈ f (u P , t P ) (4.37)
∆t
u(t ) P F
B
t
tn-1 tn tP tn+1
θ∆ t (1-θ)∆ t
∆t
Figure 4.9 Weighted average position of a Point P in the interval (tn, tn+1).
The value of f(u, t) in point P is calculated by linear interpolation between the end points of the interval as:
f (u P , t P ) = (1 − θ ) f (u n, t n ) + θ ⋅ f (u n +1, t n +1 ) (4.38)
u(t )
u(t n+1)
un+1
∆t f (un,t n)
un
tn tn+1
∆t
f(u,t) f(
f(u,t) f(u,t)
n+1 n+1 n+1 n+1
f (u ,t ) f (u ,t )
f (un,t n) f (un,t n)
4.4.6 Runge–Kutta methods
A similar approach to the weighted averaged schemes are the so called Runge–Kutta methods in which a
set of multiple internal points of computation are selected inside the interval (tn, tn+1).
The general numerical scheme for Runge–Kutta methods, for a number of m points inside the
computational domain, can be formulated as:
m
∑
u n +1 = u n + ∆t ⋅ w j k j
j =1
1 k = f ( )
u ,
n n
t (4.40)
j −1
j
k = f
u n
+ ∆t ⋅ ∑
l =1
a jl kl , t n + c j ⋅ ∆t
where m ≥ 1, and wj, cj, and ajl are numerical coefficients. Depending of the number of internal points m,
the corresponding Runge–Kutta method is called m-stage.
Legras (1971) presents formulas for Runge–Kutta coefficients, up to 8-stage. One of the most popular
Runge–Kutta formula is the one in 4-stages for which the formulas defined by equations (4.40) are:
k1 = f (u n, t n )
k ∆t ∆t
= f u n + k1 , t n +
2 2 2
(4.41)
k ∆t ∆t
= f u n + k2 , t n +
3 2 2
k4 = f (u n + k2 ∆t , t n + ∆t )
with the solution at time step n + 1:
∆t
u n +1 = u n + (k + 2 k2 + 2 k3 + k4 ) (4.42)
6 1
There are many more numerical schemes available for ODEs, such as Adams–Bashford or Adams–
Moulton (Ascher & Petzold, 1998).
u( x, t ) = F ( x − at ) (4.44)
where F(s) is an arbitrary single-valued differentiable function; with s = x − at. Substitution of expression
(4.44) into the left-hand-side of equation (4.43) yields:
∂ F (s) ∂ F (s) dF ∂ s dF ∂ s dF ∂ s ∂ s dF
+a = +a = +a = (− a + a + 1) = 0 (4.45)
∂t ∂x ds ∂ t ds ∂ x ds ∂ t ∂ x ds
Deduction (4.45) shows that u(x, t) is carried along x at a constant velocity a, and the shape of u(x, t)
remains unchanged (see Figure 4.11).
u(t) t=0 t = t1
x
L
In order to solve equation (4.43) using the discrete approach, the time-derivative between points (i, n)
and (i, n + 1) are used (see Figure 4.12):
∂ u uin +1 − uin
≅ (4.46)
∂t ∆t n
∂ u uin − uin−1
≅ (4.47)
∂x ∆xi
u(t)
Computational Domain
t
Right B.C.
n+1
Left B.C.
tn
x
I.C. xi-1 xi xi+1
∆xi ∆x i+1
Figure 4.12 Unequally spaced grid discretization for the advection equation computational domain.
where:
∆t n
Crin = a ⋅ (4.49)
∆xi
Expression (4.49) is called the Courant number, and depends on the grid size at time level (n + 1) and space
size at (i + 1). Assuming that the values for u are known at any point i of the space, at time level n, the value
for u at any point in space, at time level n + 1 can be computed using (4.48). Equation (4.48) cannot be applied
at the left-hand boundary of the domain where i = 1, because there is no point to the left of the left boundary.
This analysis shows the need to know the Boundary Condition, u1n +1 , at the left boundary (see Figure 4.13).
t
Known Left B.C.
Computational Domain
x
Given I.C.
B.C. - Boundary Conditions
I.C. - Initial Conditions
The notion of stencil is introduced here by definition. A stencil is the representation in the computational
domain coordinates, of the nodes that relate to the point of computation by using a numerical approximation
method. In case that two independent variables, space and time, are used to express a function in a
differential equation, than in the notation used for stencils, n − 1, n, n + 1 indicate the time steps, and i − 1,
i, i + 1 indicate space step. It is always assumed that all values of the function under consideration are
known at time steps n and n – 1, and the time step n + 1 is to be calculated.
The stencil of the numerical scheme (4.48) is shown in Figure 4.14.
(n+1)
or
(n)
(i-1) (i)
4.5.2 Hyperbolic PDEs
Demonstration of the application of the FDM for hyperbolic equations is shown on the linear advection
equation. As seen from the principle of the method the first step in applying the finite difference technique
is to discretise the problem domain. Next step is to find a suitable approximation to the hyperbolic equation
for the considered discretization.
The linear advection equation has two first order partial derivatives, ∂u/∂x and ∂u/∂t. There are
many different numerical schemes to determine the appropriate solution of the equation, depending
on the selected approximation of the two derivatives, with respect to time and space. If only the
three different approximations for such derivatives (forward, backward and central differences) are
considered a minimum of nine different approximations to equation (4.43) can be expressed. The
main question is which approximation should be used, because while seeking a solution one needs to
be sure that the differencing scheme should be as accurate as possible, numerically stable and easy to
implement.
∂ u uin +1 − uin−+11
≅ (4.50)
∂x ∆xi
Substituting expression (4.50) and (4.46) into (4.43) yields:
The unknown solution at point i for time level n + 1 depends on the known values at the previous time
level n, as well as on the unknown value at point i – 1 at time level n + 1. The values of u at time level
n + 1 are linked together through a linear relationship. If equation (4.51) is written for all the nodes at
time level n + 1, a system of equations is obtained and must be solved. The upstream boundary condition,
u1n +1 is known and, u2n , is known from the previous time step, hence it is possible to compute, u2n +1. Sweeping
along i in ascending order provides, u3n +1 , u4n +1 , and so on (see Figure 4.16).
Stencil of
the
explicit
scheme
x
A scheme where there is a relationship between several points at the unknown time level, leads to a
system of equations. The equations of this system must be solved simultaneously to compute the unknowns.
Such a scheme is called an implicit scheme. If the relationship between the unknown points is complex (for
instance, non-linear), the system must be solved in an iterative way.
The differential approximations of the derivatives that are forward, backward and centred space are
abbreviated as FS, BS and CS respectively. Similarly the ones for time are abbreviated as FT, BT and CT.
Any numerical scheme that uses a combination of any of these two approximations is also referred to as
a combination of the two abbreviations. The numerical scheme (4.49) is referred as FTBS, and (4.51) as
BTBS.
or, re-arranging
1 a∆t n
uin +1 = uin − ⋅ (u − uin−1 ) (4.53)
2 ∆x i +1
Durran (1999) shows through Fourier analysis that this scheme is unconditionally unstable. Numerical
models still use a FTCS scheme to calculate the few first time-step, because the errors introduced by using
the FTCS scheme at the beginning of the computational steps, are negligible when compared with all the
other errors that are present in a model.
a∆t n
uin +1 = uin −1 − (u − uin−1 ) (4.55)
∆x i +1
Scheme defined by relation (4.55) can produce two solutions to the same problem under special
circumstances of boundary conditions. The stencil of the CTCS scheme is given in Figure 4.17. It can
be seen that for a particular grid-point i and time-step n, the CTCS approximation equation (4.55) links
together the values of U at (i, n + 1), (i – 1, n), (i + 1, n) and (i, n – 1). The value of u at grid point (i, n) is
not part of the relationship. The same equation for the same grid-point i at the next time-step, n + 1, links
(i, k + 2), (i ± 1, n + 1) and (i, n). Figure 4.17 shows the nodes for which the values of u effect the value of u
at node (i, n) and those that effects the value of u at (i, n + 1).
t
(n+2)
(n+1)
(n)
Figure 4.17 Relation between nodes for the CTCS numerical scheme.
∂u u n +1 − uin−1 u n +1 − uin
= ψ ⋅ i −1 + (1 − ψ ) ⋅ i
∂t P ∆t ∆t
(4.56a)
tn+1
P (1-θ)∆t
∆t θ∆t
t n
(1-ψ)∆t ψ∆t
xi xi+1 x
∆x
If all values of u(x, t) at time level n are known then equation (4.57) relates the values of the unknown
function u(x,t) at grid points (i, n + 1) and (i − 1, n + 1) as follows:
ψ + (1 − θ ) ⋅ Cr
ai = 1 − ψ + θ ⋅ Cr
b = 1 − ψ − (1 − θ ) ⋅ Cr
i 1 − ψ + θ ⋅ Cr
(4.59)
b = −ψ + θ ⋅ Cr
i 1 − ψ + θ ⋅ Cr
Cr = a ∆t
∆x
In case that a canal of length L is considered, over a time period T, and an equally spaced grid
discretization of the computational domain in (M − 1) space intervals Δx, and (N – 1) time intervals Δt.
Such a discretization results in M points along the x axis and N time levels of computation, as represented
in Figure 4.19. Equation (4.57) is valid on every point i = 2,…, M, at a specific time level n. At point i = 1,
the value of function u(x, t) is the upstream boundary condition and it is known, as are known all the values
of u(x, 0) as initial condition to the problem.
t
...
Given B.C.
Given B.C.
h
...
... ...
Q,h Q,h
Q,h Q,h x
x
1 M
Given I.C. L L
Writing equation (4.58) on every point i = 2,…, M, a system of (M - 1) equations, at time tn+1 is obtained.
Adding the known boundary condition u1n +1 , a linear system of M equations with M unknowns is required
to be solved in order to have the solution.
∂u ∂h ∂h
h −u + ( gh − u2 ) =0
∂t ∂t ∂x (4.60a)
∂h ∂u ∂u
g −u + ( gh − u2 ) =0
∂t ∂t ∂x (4.60b)
where g is gravitational acceleration; h channel water depth; and u flow velocity.
The discretization grid used for solving these equations is a staggered one that is, the space- and time-
derivatives of the variables h and u are not computed at the same grid point (see Figure 4.20).
t
...
Given B.C.
Given B.C.
h
...
... ...
Q h
Q h x
x
1 M
Given I.C. L L
∂ h hin +1 − hin
= (4.61a)
∂t ∆t
∂ u uin++11 − uin+1
= (4.61d)
∂t ∆t
(n+1)
(n)
4.5.3 Parabolic PDEs
The solution of parabolic equations using FDM approach is demonstrated on the one-dimensional diffusion
equation, which has the general form:
∂u ∂ 2u
= D 2 (4.62)
∂t ∂x
Computational Domain
Required B.C.
Required B.C.
x
Required I.C.
B.C. - Boundary Conditions
I.C. - Initial Conditions
Figure 4.22 Computational domain, boundary and initial conditions for the diffusion equation.
with
∆t
r = D⋅ (4.65)
(∆x )2
(a) (b)
t
∆t
Figure 4.23 Stencil of the explicit FTCS scheme for a parabolic equation.
The stencil of the numerical scheme given by equation (4.64) is shown in Figure 4.24.
Other explicit schemes for the diffusion equation are the DuFort-Frankel or Three level scheme for
which the corresponding equations are (4.66) and (4.67), respectively:
2r n
uin +1 = (u + uin+1 ) + 11 +− 22rr uin−1
1 + 2r i −1
(4.66)
1 + 2γ n γ n −1 r
uin +1 = ui − 1 + γ ui + 1 + r L xx ((1 − β )ui + β ui )
n n −1
(4.67)
1+γ
1
β = −0.5 − γ − (4.68)
12r
The value of the coefficient γ is arbitrary and has to be chosen with care so that in combination with the
value of r fives a stable numerical scheme.
Equations (4.66) and (4.67) involves values of the unknown function at three time levels (n – 1), n, and
(n + 1), except for the case r = 0.5 when equation (4.66) reduces to the FTCS scheme.
Similar to the case of explicit schemes, a more general formulation of the implicit scheme is the three
level scheme:
A particular Three level scheme, the one for which γ = 0.5 and β = 1, is often used for solution of
problems.
4.5.4 Elliptic PDEs
As for previous types of PDEs, the application of the FDM method for elliptic type of PDEs is shown on
the example of Laplace equation. Poisson equation is an example of an elliptic equation, and it is written
in the form:
∂ 2u ∂ 2u
+ = f (u, x, y) (4.73)
∂ y2 ∂ x 2
In case that the function f(u, x, y) = 0 the equation is called Laplace.
Notice that time is not involved in the elliptic type of equations, because they are for steady state
problems, hence time independent. For the numerical solution the domain represented in Figure 4.25 is
used and the partial derivatives are substituted by the finite difference approximation (4.23). Because
time is not involved in this kind of problem, only subscript notations are used, the ones for space
(i and j).
(a) (b)
y
Required B.C.
Required B.C.
Required B.C.
x
Required B.C.
Figure 4.25 Domain of computation and stencil for elliptic type of equations.
For an equally spaced grid, (i.e., Δx = Δy) ,the numerical scheme obtained after substitution is:
4.6 Examples
4.6.1 ODE: Solution of the linear reservoir problem
One of the most used ODE in hydraulic engineering is the linear reservoir. The linear reservoir is the continuity
equation written for an inflow and outflow that changes the volume of water contained in a reservoir. The
equation applies in reservoir operation, hydrological routing of flow, groundwater flow, and so on.
Given a reservoir, as shown in Figure 4.26, the change in volume is given by:
dV (t )
= Qin (t ) − Qout (t ) (4.75)
dt
in which V(t) is the water volume stored in the reservoir, Qin(t) is the inflow into the reservoir and Qout(t) is
the outflow from the reservoir.
dV
Qin dt
V(t) Qout
Equations (4.75) has two unknowns, the volume of the reservoir, V(t), and the outflow from the
reservoir Qout(t). Taking into account that the outflow from the reservoir is a function of the storage of
the reservoir:
Qout (t ) = f (V (t )) (4.76)
If the assumption is made that f(V(t)) is a power function then it can be written:
where k is a storage constant, which shows how fast the storage is emptied and is measured in units of
1/time; and a is a constant parameter. For a particular reservoir both a and b need to be determined from
specific particularities of the reservoir.
In general it is considered that a = 1 is a good value (Henderson, 1966; Sturm, 2001), in which case
equation (4.77) can be rearranged as:
1
V (t ) = Q (t ) (4.78)
k out
If the simplified notation Qout(t) = Q and Qin(t) = I is used; and replacing equation (4.78) into the initial
mass conservation equation (4.75) gives:
Q
d
k (4.79)
= I −Q
dt
Re-arranging gives:
1 dQ
=I − Q (4.80)
k dt
or
dQ
+ kQ = kI (4.81)
dt
Equation (4.81) can be integrating applying the integrating factor method, for solving ODE. The
equation (4.81) is multiplied with the term etk, hence:
dQ
etk ⋅ + ketk Q = ketk I (4.82)
dt
The right-hand-side of the equation (4.82) represents the derivative of the function Qetk, hence integrating
the equation, yields:
∫
etk Q = ketk I dt
(4.83)
Q=
∫
k etk I dt (4.84)
etk
Expression (4.84) is not easy to be used in practice, because I(t) is a function that has discrete values.
When I(t) is known the solution for Q(t) is determined by using numerical integration of the term etkI.
In the particular case that I(t) = 0, equation (4.81) reduces to a simple ODE, that can be numerically
solved using finite difference methods. Assuming that Q(t = 0) = Qo, the equation that is solved numerically
is (see Figure 4.27):
dQ
= − kQ (4.85)
dt
50
Analytical solution
Implicit solution
45 Explicit solution
40
35
Discharge [m3/s]
30
25
20
15
10
0
0 50 100 150 200 250 300 350 400 450 500 550 600
Time (Days)
Figure 4.27 The analytical and numerical solution of the linear reservoir equation.
The explicit and implicit method are applied to solve the ODE defined by (4.85) and these are compared
with the analytical solution in order to determine how well are the numerical approximations performing.
Application of an explicit numerical scheme to equation (4.85) gives:
Q n +1 − Q n
= − kQ n ⇒ Q n +1 = Q n (1 − k ∆t ) (4.86)
∆t
Application of an implicit numerical scheme to equation (4.85) gives:
Q n +1 − Q n Qn
= − kQ n +1 ⇒ Q n +1 = (4.87)
∆t (1 + k ∆t )
Table 4.1 show the values of Q(t) in case equations (4.83)–(4.85) are used to determine the solution. The
values considered for Qo, k, and Δt are:
m3 1
Qo = 50 ; k = 0.01 ; ∆t = 40 days (4.89)
s day
Table 4.1 Solution results for equation (4.85) for data as defined in (4.89) using
analytical solution and explicit and implicit solution approaches.
1 dQ ∂ h ∂ h
b dh ∂ x + ∂ t = 0 (4.93)
that simplifies to the linear advection equation:
∂h ∂h 1 dQ
+c = 0 where c= (4.94)
∂t ∂x b dh
Using a discretization that is made up of a forward difference in time and backward difference in space,
the solution of h(x, t) for each grid point on the x − t computational domain shown in Figure 4.28, which
is 60 km long and has an input stage hydrograph raising from 2 m to 6 m over 6000 second. The total
computational time is 60,000 seconds. Figure 4.29 and Table 4.2 shows the results obtained with the FTBS
scheme for a grid size Δx = 3000 m and Δt = 3000 s; and a c = 1 m/s. Table 4.2 gives and extract for the
first 50 minutes and for 24 km out of the 60 km long channel.
t
Boundary condition upstream
Computational Domain
Given B.C.
x
h
Given I.C.
h
Initial conditions
Figure 4.28 Computational domain, initial and boundary conditions for the simple wave propagation problem.
5
Water Depth [m]
0
1200
1100
1000
900 60
800 55
700 50
600 45
40
500 35
400 30
300 25
20
200 15
100 10
0 5
0 Distance (km)
Table 4.2 Solution results (extract) for equation (4.94) for Δx = 3000 m and Δt = 3000 s, over 60 km
long channel and during 60,000 seconds.
Results are showing that in case the product c Δt/Δx is equal to one the advection equation
transports the input unchanged. This product is called the CFL condition and it is described in detail
in Chapter 6.
In case that this product is less than 1 diffusion appears in the solution, which is due to the numerical
approximation and should not be confused with the attenuation of a flood wave. The result that is obtained
for a selection of Δx = 3000 m and Δt = 1500, for the same canal, time length and c = 1 m/s is presented in
Figure 4.30. The numerical effect of diffusion can be noticed.
4
Water Depth [m]
0
600
500
55 60
400 50
300 40 45
30 35
200 25
15 20
100 10
5 Distance (km)
0 0
Figure 4.30 Solution of the simple wave propagation with numerical diffusion.
∂C ∂ 2C
= Dm (4.95)
∂t ∂ x2
where C is chemical concentration, and Dm is the molecular diffusion coefficient. Equation (4.95) has
several analytical solutions depending on initial and boundary conditions. For the case of a pollutant in the
form of an impulse input at x = 0 into a semi-infinite media (C = 0 at x = ∞ at all times), where C(t = 0) = 0
at all other values of x, equation (4.95) has the following analytical solution:
− x2
M
C ( x, t ) = e 4⋅ Dm t (4.96)
2 π ⋅ Dm ⋅ t
where M is the mass of chemical added at x = L, with units of mass per cross-sectional area (e.g., mg/cm2).
This solution is valid when diffusion occurs in both directions, with the concentration profile extending
further as time passes.
Using a discretization that is made up of a forward difference in time and backward difference in space,
the solution of c(x,t) for each grid point on the x − t computational domain, is given Figure 4.31, for the
grid size Δx = 50 cm, Δt = 27 hours; Dm = 0.01 cm2/sec, M = 0.7 mg/cm2. The length over which diffusion
takes place is 600 cm.
12
Initial Condition
time=140 hrs
10 time=300 hrs
time=415 hrs
time=550 hrs
Concentration [mg/I]
0
0 100 200 300 400 500 600
Distance (cm)
• Problem domain is discretized into discrete elements called control volumes (CV);
• The differential equation to be solved is integrated into a balance equations for each control volume
of the computational domain;
• Obtained integrals are approximated using numerical integration;
• The values of the unknown function and their derivatives are approximated using the values at the
nodes of the control volume;
• The solution of the problem over the computational domain is obtained by assembling the obtained
discrete equations over a control volume, into an algebraic system of equations.
An important feature of the FVM approach is the fact that the numerical flux is conserved from one
discretization cell to another (the neighbouring cell), that is, there is local conservation of the numerical
fluxes. This is very important especially because flux is an important element in fluid dynamics.
The FVM principle is detailed bellow. The method is applicable for the solution of conservation laws,
and for simplicity of the demonstration of the method the one-dimensional general form of the conservation
law (see chapter 2) is used:
∂
∂t ∫
u( x, t )dV +
V
∫ f (u) ⋅ n ⋅ dA − ∫ S(u, t ) dV = 0
A V
(5.1)
Equation (5.1) shows the transport of a variable (substance, water depth, etc.) under the influence of
advection, that is, the rate of change of variable u(x, t) inside a defined volume V together with the flux of
u(x, t) through boundary A is the same as the rate of S(u, t). Equation (5.1) is valid at each point x and each
time t, of the computational domain, where the conservation of u(x, t) is written. S(u, x, t) is also known as
source term of the equation and expresses a possible volumetric exchange between conserved quantities
u(x, t), that is, the diffusion phenomena. The term n represents the unit vector perpendicular on surface A,
pointing outwards.
Before showing the principle of the FVM method it is important to note that in the integral expression
(5.1) the derivatives are zero order for the advection term ( f(u)) and first order for the diffusion term
(S(x, t)), if it exists. The fact that the order of the derivatives is so low is important when solutions are
sought for problems where phenomena change rapidly in space so that the spatial derivative does not
exist, such as in the case of a hydraulic jump. Functions that are discontinuous do not have derivatives
at the discontinuity position, hence the conservation equation expressed as a PDE, is not valid at the
discontinuity point. Finite volume method presents the advantage that they overcome this issues, by
considering the integral representation of the PDE and by having reduced order of derivatives, that can
be easily treated.
The principle of the method is illustrated on a simple example of the one-dimensional linear advection
equation, which is obtained from (5.1) if f(u) = au and S(u, t) = 0:
∂u ∂f (u)
∫ ∂t +
V
∂x
dV = 0 (5.2)
Consider the above equation to be solved over the one dimensional computational domain V that
is discretized in control volumes Vi, defined between points xi−1/2 and xi+1/2 (see Figure 5.1b). Volume
integration of equation (5.2) over the control volume (CV) yields:
xi +1/ 2 xi +1/ 2
∂u ∂f
∫
xi −1/ 2
∂t
dx + ∫
xi −1/ 2
∂x
dx = 0
(5.3)
In Figure 5.1 points xi are equally spaced along the space domain x with a constant distance
Δx = xi+1/2 − xi−1/2; i = 1, . . . , N − 1. Same convention of notation holds, as in Chapter 4, that u(xi+1) =
u(xi + Δx) = ui+1. In Figure 5.1 control volumes are noted with Vi.
(a)
ui (b)
ui
ui-1 ui+1 ui-1 ui+1
Vi xi-1/2 Vi xi+1/2
1D Cell centered FVM 1D Vertex centered FVM
(c) (d)
Vi
Nodes Nodes
Vi
cv
cv
Figure 5.1 Finite volume examples of control volume in one- and two-dimensional space.
Equation (5.3) represents the integral formulation of the differential equation over control volume Vi
which is written in all CVs of the computational domain to yield a system of equations, and gives the
solution to the problem by determining the values of the unknown variable in all CVs.
Solution of the system formed by types of equation (5.3) requires:
• numerical approximation of the space integrals, which can be volume and/or surface integrals,
depending on the problem dimension;
• interpolation, to determine the values of coefficients that describe the numerical approximations of
the surface and volume integrals; and
• time integration by evaluating the time derivatives.
If ui is averaged and considered constant over CV, then the first term of the equation (5.3) can be
integrated numerically as:
xi +1/ 2
∂u
∫ ∂t
dx = ui ⋅ ( xi +1/ 2 + xi −1/ 2 ) (5.4)
xi −1/ 2
The second term of equation (5.3) integrated analytically yields:
xi +1/ 2
∂f
∫ ∂x
dx = f (ui +1/ 2 ) − f (ui −1/ 2 ) (5.5)
xi −1/ 2
Substitution of equation (5.4) and (5.5) into equation (5.3) gives its discrete form as:
Equation (5.6) is a conservative scheme if the flux on the boundary of one cell is equal with the flux on
the boundary of the neighboring cell.
The discretization of the space domain, as selected, is known as cell-centered method, where the
unknown variables, u(x, t) are computed as average values over the CV and they are attached to the middle
of the cell. A similar discretization is the cell-vertex method, in which the variables are averaged over a
CV, but they are attached to the nodes of the discretization grid, that is, at the edge of the CV (see Figure
5.1a). Figure 5.1c, d, shows two types of discretization for a two dimensional space.
nz
N
nx ny
W
P ∆z
E nx
ny
z
S
nz
y x CV
∆y
∆x
The domain is divided into i (i = 1, . . . , N) computational cells (Vi) – control volumes. A number of
nodes are created at the center of the control volumes, where the unknown variable is computed. The
balance equation for each of the defined CV is obtained by formulating the problem in an integral form,
which is equivalent to the integration of equation (5.7). The integration over an arbitrary CV yields:
3
∂ ∂u
∂t∫udV + ∑∫ u − α ∂x n dA = ∫S(u)dV
i =1 A
i
i (5.8)
V V
where, A is the surface of the CV and ni the unit normal vector to the surface, corresponding to the xi
component of the space.
In the FVM approach a numerical approximation of the solution is introduced by the space integration
of the equation, hence fluxes in space and time are to be calculated. At each CV the average value of the
function u is known. The advection and diffusion fluxes of the equation (5.8) are calculated in three steps,
as follows:
(1) Determination of the values of function u for each CV: Both the value of the function u and
its derivatives are numerically approximated for each CV. Based on these approximations both
advective and diffusive fluxes are determined. Function ui for the CV i (Vi) is approximated using
a polynomial representation:
P
ui = ∑a φ ( x)n n (5.9)
n =1
where an are multiplication coefficients of ϕn chosen interpolation functions (simple polynomials).
Each ϕn is valid in one of the P surrounding cells of the considered Vi control volume. Coefficients an
are determined from the condition that the cell averages are valid over a number of (i + m) cells, hence:
∫ udV = V u
i+m i+m , m = 0, 1, 2, … , P − 1
(5.10)
Vi + m
where Vi + m are the number of P cells surrounding the cell Vi.
The unknown coefficients, an, are determined from a system of algebraic equation, of the form:
P
∑A
n =1
a = Vi + m ui + m , with Am,n =
m ,n n ∫ φ dV n (5.11)
Vi + m
(2) Evaluation of the integrals: The integrals are approximated numerically. The most often used
approach to evaluate the integrals is the Gauss quadrature approach. In this case the selected
functions ϕn determines the number of quadrature points to match polynomials of degree P.
(3) Temporal integration: The computed fluxes are used to advance the solution in time using an
explicit time approximation method such as Euler, or Runge–Kutta, or the Adams-Bashforth
class of methods. Time integration is dependent on the spatial approximation and is checked for
stability.
The details of the three calculation steps are further explained, along with considerations regarding
boundary conditions and the solution of the obtained system of equations. The chapter ends with an
example on how to apply the method for a one dimensional advection diffusion equation.
nW P nW P nE
W
nE W E
E
SW S SE yS
nS S
nS
xW xE
x(x1) x(x1)
arbitrary perpendicular to the axis
Figure 5.3 Quadrilateral control volume: (a) oblique; and (b) perpendicular on the coordinate axes.
According to the notation in Figure 5.3, the surface integral of equation (5.8) on the left-hand-side, is
the summation of four surface integrals, over the four sides of the CV:
4
∂u
∑ ∫ u − α ∂x n dA
l =1 Al
i
li l (5.12)
In equation (5.12) l is the number of sides of the CV (i.e., 4 sides), and all indices with l, represents the
elements corresponding to side l of the CV. There are two types of fluxes; convective FlC , and diffusive
Fl D through the CV faces l:
FlC = ∫ un dA li l (5.13)
Al
and
∂u
Fl D = − α ∫
n dA
∂xi li l (5.14)
Al
The area/length of side Al, is the length of the CV side. For the neighboring CVs with a common side
the total value of the flux is:
Fl = FlC + Fl D (5.15)
The sign of the flux, however is opposite for the two neighboring cells.
The approximation of the surface integrals (5.13) and (5.14), for side l of the CV with a cell-centered
variable, is done by steps 1 and 2, as detailed in Section 5.2.1. It yields:
FlC = ml ⋅ ∆ Al ⋅ u,
D ∂u (5.16)
Fl = α ⋅ ∆ Al ⋅ ∂xi
l
where mi is the mass through face l of the CV. Relation (5.16) is approximated at side AE of the CV for a
selected polynomial. ΔAl is the area of element l.
The volume integral of equation (5.9) is approximated through numerical integration. The following
relation holds over a CV:
∫ SdV ≈ S ∆V
V
P (5.17)
where SP represents the value of S at the center of the CV (the average value of S over CV). ΔV represents
the volume of the considered CV. Taking into account notations from Figure 5.3 the volume of the CV can
be expressed as:
1
∆V = ( x − x NW )( yNE − y Aw ) − ( x NE − x AW )( y AE − yNW ) (5.18)
2 AE
All the integrals in equation (5.9) evaluated using (5.17) and (5.18) are added up over the whole computational
domain. The following overall equation holds:
∂u
∑m cv ∑
∆ Acv ucv − α ⋅ ncvi ∆ Acv
∂xi cv
= SP ∆V
(5.19)
cv
cv source terms
convective fluxes diffuzive fluxes
The values of the unknown function and its derivatives at each side of the CVs are determined using
equation (5.19).
uE = uP , if mE > 0 (5.20a)
uE = uR , if mE < 0 (5.20b)
A special upwind approximation is the quadratic upwind interpolation, also known as the QUICK
method (see Figure 5.5). In the QUICK approach a polynomial is determined using an interpolation
through 3 points; two neighboring points P and R, and a third point, RE or PW, depending on the flow
direction. The resulting polynomial for the approximation of uE is:
ui
ui-1
mE>0
ui+1
mE<0
P R
w e x
PW xi-1 xi xi+1 RE
mE>0 ui ui+1
ui-1
ui-2
P R
w e x
xi-2 PW xi-1 xi xi+1 RE
Figure 5.5 Approximation of function u using linear interpolation over two control volumes.
(2 − γ w )γ e2 (1 − γ e )(1 − γ w )2
a1 = , a2 =
1+ γe −γw 1 + γ e − γ w (5.22a)
(1 + γ w )(1 − γ e )2 γ re2 γ e
b1 = , b2 =
1 + γ re − γ e 1 + γ re − γ e (5.22b)
and,
xe − x P
γe = (5.23)
x R − xP
Relation (5.24) represents the interpolation factor for function u at side e, based on the values of u in points
P and R (see Figure 5.6), that is:
u e ≈ γ e ue + (1 − γ e )uP (5.24)
3 1 3 1
In case of a equally spaced grid: a1 = ,a = ,b = ,b = .
8 2 8 1 8 2 8
ui=uP
ui+1=uR
uE
P R
xi-1 w e x
xi xi+1
∆x
∂u uR − uP
∂x ≈ x − x (5.25)
e R P
∂ uin +1 − uin
∂t∫udV ≅ Vi ⋅
∆t (5.26)
V Vi
∂u uP − uw uP − uwBC
∂x ≈ x − x = x − x (5.28)
P w P w
w
The algebraic system of equations obtained when the FVM approach is used has a unique solution only
if the boundary conditions at all boundaries of the computational domain are defined.
where c represents the number of all cells around the CV, which has as a center point P. If equation (5.59)
is written for each of the control volumes Vi (i = 1, . . . , N), there are N equations formed because there are
a total of N discretization nodes.
Schafer et al. (1993) shows how such a system of type (5.29) is obtained and solved for a one- and two-
dimensional advection diffusion equation, in steady state (no time term).
Consider the steady one-dimensional advection-diffusion equation defined on domain [0, L], discretized
into N control volumes (see Figure 5.7). Using a second-order central differencing scheme, the discrete
equations of the phenomena, after computing all fluxes are:
x
0 ... w e ...
PW P R L
1 2 i M
x
1 3 ... i- 1 i+ 1
...
2 2 2 2
cell i
Values of the function over each CV, as defined in Figure 5.7, are:
uwi = uPi−1 for all i − 2, … , N (5.31a)
which leads to a linear system of equations, that can be represented in matrix form as:
bP1
uP 2
1
a1P − a1R .
−a2 a2 −a2 0 ⋅ bP
w P R
i −1 ⋅
. . . uP .
− awi aPi − aRi uPi = i
i +1 bP (5.32)
. . . uP ⋅
N −1
0 − a R
.
.
− awN aPN u N
P
bPN
A u
u
aPi, j uPi, j − aEi, j uEi, j − awi, j uwi, j − a iA, j uiA, j − aNi, j uNi, j = bPi, j (5.33)
M+1
M
ui,j+1
...
ui-1,j ui,j ui+1,j
j ui,j j
ui,j-1
... ...
where i = 1, . . . , N are the discretization intervals on the x axis; and j = 1, . . . , M, are the discretization
intervals on the y axis. Using the notations from Figure 5.8, the matrix A of the system is:
∂u ∂u ∂ 2u
+a =α 2 (5.35)
∂t ∂x ∂x
Equation (5.35) has two types of fluxes; the advective flux, which is noted as F = au, and the diffusive
fluxes noted as D = αu. These fluxes are written at any point xj + ½.
(a) (b)
1 1
0.8 0.8
0.6 0.6
0.4 0.4
0.2 0.2
0 0
−0.2 −0.2
−0.4 −0.4
−0.6 −0.6
−0.8 −0.8
−1 −1
−1 −0.75 −0.5 −0.25 0 0.25 0.5 0.75 1 −1 −0.75 −0.5 −0.25 0 0.25 0.5 0.75 1
(c)
1
0.8
0.6
0.4
0.2
0
−0.2
−0.4
−0.6
−0.8
−1
−1 −0.75 −0.5 −0.25 0 0.25 0.5 0.75 1
Figure 5.9 Values of the unknown function over an equally spaced grid using a constant function
approximation and a discretization of: (a) 4 cells, (b) 8 cells, (c) 16 cells.
F 1 −F 1 D 1 −D 1
dui i+ i− i+ i− (5.36)
=− 2 2
+ 2 2
dt ∆x ∆x
The evaluation of the terms F and D in equation (5.36) is done at the cell edges of the control volumes.
Before time integration takes place the fluxes are evaluated using the step by step procedure. Values of
function u are written as a polynomial representation, as detailed by equation (5.9):
p
x − xi
u= ∑a ξ , n
n
where ξ =
∆ xi (5.37)
n=0
In equation (5.37) an are P + 1 coefficients that are determined from P + 1 conditions on the averages of
the polynomials over multiple cells, as shown by equation (5.10). In equation (5.37) the coordinate system
is centered to the cell and scaled so that the cell length is from −1/2 to 1/2.
x −x 1
n
x 1 −x 1
n
∆ xi m + 12 i−
2
m− i−
= − 2 2
(5.39)
n ∆ xi ∆ xi
ξn 1 − ξn 1
m+ m− xm ± i (5.40)
= ∆ xi 2 2
, with ξ =
n m±
1
∆ xi
2
Values of Am,n are determined and the system of equation (5.38) is solved. Different polynomial
representations for the function u are considered and shown bellow, for an initial condition of a cosine
function.
∫ a dx = u ∆ x
x 1
0 i i
(5.42)
i−
2
Equation (5.40) states that the volume integral over the control volume is equal with the function value
times the control volume length, hence:
a 0 = ui (5.43)
Two approximations are available for (5.41), either the left value of u, in cell i, or the right value of u in
cell i + 1. The flux is advective, hence the information usually is traveling from upstream to downstream,
therefore, the solution is:
ui if a 1 ≥ 0
i+
2
u 1 = (5.44)
ui +1 if ai + 1 < 0
i+
2
2
The diffusive term cannot be computed when constant functions are used because the derivative of a
constant is zero.
In equation (5.45) there are two unknown coefficients, a 0 and a1, hence two conditions are set in order to
determine them. Consider two consecutive control volumes i and (i + 1) so that xi − 1 ≤ x ≤ xi + 3 ; hence
2 2
− 12 ≤ ξ ≤ 23 . The two necessary conditions to find a 0 and a1 s are:
1
2
∫ (a
− 21
0 + a1ξ )dξ = ui (5.46)
3
2
∆ xi +1
∫ (a
1
0 + a1ξ )dξ = u
∆ xi i +1 (5.47)
2
After performing the integration, the following system of equations is obtained:
ui
1 0 a0
1 1 a = ∆ xi +1 u (5.48)
i +1
1
∆ xi
For an equally spaced discretization, it yields:
a0 = ui , a1 = ui +1 − ui −1 (5.49)
hence
1 3
u = (1 − ξ )ui + ξui +1 , for − ≤ξ ≤ (5.51)
2 2
The unknown function u at the edge of the control volume is obtained for values of ξ = ± 12 .
−u + 26ui − ui −1 ui +1 − ui −1 ui +1 − 2ui + ui −1 2
u = i +1 + ξ + ξ (5.52)
24 2 2
The interpolation is centered on the control volume cells (i − 1), i and (i + 1), and as in previous cases:
3 3 x − xi (5.53)
− ≤ξ ≤ , ξ =
2 2 ∆x
At the edge of the control volume, where xi+1/2 and ξ = 1/2 the value of the unknown function u is:
−ui −1 + 5ui + 2ui +1 (5.54)
u 1 =
i+
2
6
In order to assess the how good are the different forms of representation of the unknown function an
example is considered, for which the analytical solution is known. The difference between the two results,
the analytical and numerical solution, is the error, which depends on the discretization. The more refined
discretization, the smaller the error.
(c)
1
0.8
0.6
0.4
0.2
0
−0.2
−0.4
−0.6
−0.8
−1
−1 −0.75 −0.5 −0.25 0 0.25 0.5 0.75 1
Figure 5.10 Values of the unknown function over an equally spaced grid using a linear function
approximation and a discretization of: (a) 4 cells, (b) 8 cells, (c) 16 cells.
(a) (b)
1 1
0.8 0.8
0.6 0.6
0.4 0.4
0.2 0.2
0 0
−0.2 −0.2
−0.4 −0.4
−0.6 −0.6
−0.8 −0.8
−1 −1
−1 −0.75 −0.5 −0.25 0 0.25 0.5 0.75 1 −1 −0.75 −0.5 −0.25 0 0.25 0.5 0.75 1
(c)
1
0.8
0.6
0.4
0.2
0
−0.2
−0.4
−0.6
−0.8
−1
−1 −0.75 −0.5 −0.25 0 0.25 0.5 0.75 1
Figure 5.11 Values of the unknown function over an equally spaced grid using a parabolic approximation
and a discretization of: (a) 4 cells, (b) 8 cells, (c) 16 cells.
In Figure 5.9 the representation of the solution using constant approximation and a number of 4, 8, and
16 discretization cells is given. The solid curved line is the exact solution, while the dotted lines represent
the approximate solution. Similarly, Figures 5.10 and 5.11 shows the representation of the solution for the
case of linear and parabolic approximation, respectively. The representation of the linear approximation is
done over two cells, while the parabolic one is represented over three cells.
Analysing the results it can be noted that cosine wave is not well represented in case that a coarse
discretization grid is used along with a constant approximation for the unknown function. In case that a
linear and/or parabolic approximation is used with a finer discretization grid, then the solution is better,
however there are still several values that are out of bound.
6.1.1 Convergence
A solution obtained by a numerical scheme is by definition convergent if it is closer and closer to the
analytical (exact) solution of the differential equation (ODE or PDE) when the grid size of the discretization
tends to zero. The difference between the exact solution and the value of the solution obtained with
numerical approximation is called solution error.
There are two different meanings of convergence in numerical analysis; if the discretized interval is
getting finer and finer after discretizing the continuous problems, the solution is convergent to the true
solution; and for an iterative scheme, convergence means the iteration gets closer and closer to the true
solution as computation progresses.
PDE describing a
phenomenon
Consistency
Discretization
System of algebraic
equations
Stability
Convergence
Analytical solution Numerical approximate
∆ ∆ solution
In order for an approximate solution to converge to the exact solution of a discretised equation (ODE or
PDE) as the time and/or space step sizes goes to zero, two conditions must be met: consistency and stability.
6.1.2 Consistency
A solution obtained with a numerical scheme is consistent if it gives a correct approximation of the
differential equation as the computational, of time and/or space, step is decreased, which means that local
truncation error goes to zero as step size go to zero. Consistency is usually verified using Taylor Series
expansion. The analysis of the consistency of a scheme is done for each particular studied scheme, and it is
further presented in this chapter for the schemes that were introduced in Chapters 4 and 5.
6.1.3 Stability
Stability refers to the magnitude of the change of the error. A scheme is stable if any initially finite
perturbation remains bounded as time grows. A scheme is stable if initial errors or small errors at any time
remain small while computation progresses. It is unstable if initial errors or small errors at any time get
larger and larger, or eventually get unbounded, as computation advances in time.
Though it may seem a very simple issue, it is interesting to mention that stability is an important
property of the numerical methods which is not easy to notice and has not even been discovered by the
one who defined the finite difference method for the first time, L.F. Richardsond in his book on weather
predictions using numerical methods, which was issued in 1922. The issue of stability was noticed by
Courant, Friedrichs and Levy in late twenties (hence the name CFL condition); was well defined by von
Neumann in 1940’s and rigorously defined by Lax and Rychtmyer in 1950’s.
Numerical methods can be classified in absolutely stable, conditionally stable and unstable.
Stability verification is more complex than consistency. Several methods are available to carry out
stability analysis:
• Matrix method, which is based on finding the eigen values of the matrix representation of the solution
given by the numerical scheme. It is used mainly for FDM method.
• Fourier method, or also known as von Neumann analysis, in which the solution given by the
numerical method is expressed as a complex Fourier exponential. The substitution of the Fourier
representation of the solution into the original equation allows for the analysis of growth or decay of
the error. The method however is limited to linear equations.
• Domain of dependence, in which the domains of dependence of the analysed differential equation
and the numerical representation of the solution are compared.
u n +1
A= (6.2)
un
In expression (6.2) un is the numerical approximate solution obtained for the unknown function, at time
level n of computation, and un+1 at time level (n + 1).
in which un+1 is the approximate solution computed at time level (n + 1) and u(tn + Δt) is the exact value of
the function u(t) at the node of the grid where the evaluation of the error is carried out. If u(t) is placed in
equation (6.3), the error is a function of only one variable, Δt. Using Taylor series expansion to express the
value of TE(Δt) around zero, yields:
d (TE ) (∆t )2 d 2 (TE ) (∆t )3 d 3 (TE )
TE (∆t ) = TE (0) + ∆t + ⋅ + ⋅ +… (6.4)
d (∆t ) 0 2 ! d (∆t ) 0
2 3! d (∆t )3 0
According to equation (6.4) any numerical method is a good approximation if the value of the error is
as small as possible or equal to zero, hence the smaller the Δt the smaller the error. Equation (6.4) shows
the magnitude of the error of the approximation.
A numerical approximation method is defined to be of order p, if the first p terms of the equation (6.4)
are zero. Hence a method of order p generates an error for which the first term is:
(∆t ) p +1 d p +1 (TE )
TE (∆t ) = ⋅ +… (6.5)
( p + 1)! d (∆t ) p +1 0
Consider the weighted method for approximating the solution of an ordinary differential equation.
According to the weighted method the approximate solution, as shown in Chapter 4, is:
u n +1 = u n + ∆t ⋅ (1 − θ ) ⋅ f (u n , t n ) + ∆t ⋅ θ ⋅ f (u n +1 , t n +1 ) (6.6)
Equation (6.6) is also known as the multi-step method solution. Ascher and Petzold (1998) defined a
general form for this solution as:
k k
∑ α m ⋅ u n − m = ∆t ⋅ ∑β m ⋅ f n−m (6.7)
m=0 m=0
where:
– α mβ m – coefficients of the method;
– un – values of the function u(t) at grid point n (see Figure 4.7);
– f n – value of the derivative of u at grid point n;
– k – the number of past steps applied to solve the ODE.
For the particular case of equation (6.6) the values of the coefficients in equation (6.7) are:
α 0 = 1; α 1 = −1; β 0 = θ ; β1 = 1 − θ ; k = 1; (6.8)
k
Co =
∑α
m=0
m
(6.11)
∞
1 k
1
k
C p = ∑ (−1) p ⋅ ⋅
p!
∑ mp ⋅ αm +
( p − 1)!
⋅ ∑m p −1
⋅ βm
p=0 m =1 m=0
Calculation of the above coefficients determines the order of the method, that is, if C1, C2, . . . ,Cp = 0
and Cp+1 ≠ 0 then the method of approximation is of order p. In case of equation (6.6) these coefficients
are:
Co = 1−1 = 0
C = 1 − θ − (1 − θ ) = 0
1
1
C2 = − + (1 − θ ) = 0.5 − θ (6.12)
2
1 1 1 θ
C3 = − (−1) − (1 − θ ) = − +
6 2 3 2
Based on (6.12) both explicit and implicit methods are first order.
6.2.1.2 Stability
Stability means that if an initial small error is introduced in the initial conditions of the ODE, this should
remain bounded, hence the computed solution at the next time level should only slightly change with
respect to the original solution. Unstable methods produce oscillatory solutions. If the growth of numerical
error is not bounded then the solution is unstable.
Stability condition for an ODE is usually checked using Fourier analysis and the condition expressed by
equation (6.2), or what is known as Von Neumann method of analysis.
Ascher and Petzold (1998) show that multi-step methods can be defined using two characteristic
polynomials:
k
ρ (Z ) = ∑α m ⋅ Z k−m (6.13a)
m=0
k
σ (Z ) = ∑β m ⋅ Z k−m (6.13b)
m=0
Characteristic polynomials (6.13) are expressed in Z, which is a complex number. For equation (6.6)
these two characteristic polynomials have the form:
ρ(Z ) = Z − 1 (6.14a)
σ (Z ) = θ ⋅ Z + (1 − θ ) (6.14b)
The numerical solution is stable if the ratio of these two polynomials is less than 1 (Szymkiewicz, 2010),
which is equivalent with condition (6.2), hence:
ρ(Z ) ρ (ei⋅ϕ )
A= = (6.15)
σ ( Z ) σ (ei⋅ϕ )
where i is the imaginary unit, and φ is the argument (angle) of the complex number, which takes values in
the interval (0, 2π). Knowing the trigonometric expression, Euler, for a complex number:
A complex number has a real and an imaginary part and A as a ratio of two complex numbers is:
with
Based on relations (6.19) the region of absolute stability can be represented graphically in the imaginary
plane (see Figure 6.2) for different values of θ. Weighting factor θ gives the extent of the region of absolute
stability, which is the region for which equation (6.1) holds.
In case of the explicit method θ = 0 and region of stability is very small, while the maximum extent for
stability is obtained for θ = 1, which is the case of the implicit method. There is one family of numerical
methods for ODEs that are called A-stable methods. By definition (Szymkiewicz, 1993, 1995, 2010) a
difference method is considered A-stable if its region of absolute stability covers the entire left pane of the
complex plane.
Another important term related to stability analysis of an ODE is the phase error. The phase error is
the difference in phase between the analytical and numerical solution and is determined by analysing the
argument of the amplification factor. The amplification factor defined by equation (6.2) is expressed in
complex form as:
u n +1
A= = |A| ⋅ ei µ (6.20)
un
4 4 4
3 3 3
2 2 2
1 1 1
Im(A)
Im(A)
Im(A)
0 0 0
−1 −1 −1
−2 −2 −2
−3 −3 −3
−4 −4 −4
−4 −3 −2 −1 0 1 2 3 4 −4 −3 −2 −1 0 1 2 3 4 −4 −3 −2 −1 0 1 2 3 4
Re(A) Re(A) Re(A)
Θ=0 Θ = 1/4 Θ = 1/2
4 4
3 3
2 2
1 1
Im(A)
Im(A)
0 0
−1 −1
−2 −2
−3 −3
−4 −4
−4 −3 −2 −1 0 1 2 3 4 −4 −3 −2 −1 0 1 2 3 4
Re(A) Re(A)
Θ = 2/3 Θ =1
Figure 6.2 Region of stability for multistep methods of solution for ODEs.
In equation (6.18) the term μ is the argument of the amplification factor. If the analytical change of
phase for an ODE is noted as μa, the ratio of the numerical and analytical phase is called the relative phase
error and is expressed as:
µ
R= (6.21)
µa
Value R > 1 means that numerical phase exceeds the analytical phase, hence scheme is called
accelerating; while R < 1 is called decelerating scheme. Further detailed analysis for accuracy and stability
of ODEs can be found in Dahlquist & Bjorck (2007) or LeVeque (2007).
Convergence for PDEs is studied, similarly as for ODEs, by looking at the difference between the exact
and the numerical solution of the partial differential equation, at the same discretization grid point. In case
of a one dimensional problem the error is expressed as:
in which u(xi, tn) is exact value of the function u(x, t) at the grid point (xi, tn), and uin is the approximate
value of the function u(x, t) at the same grid point.
In general it is very difficult to proof that the numerical solution converges to the exact solution of
a PDE, even for simple cases (Fletcher, 1991). The Lax theorem of equivalence is also used for PDEs,
though it is applicable just for a restricted class of problems, the ones that are linear. All fluid problems
are in general of non-linear nature, hence Lax theorem is used as a necessary condition for convergence
and as a useful indication for excluding inconsistent approaches. Each problem has to be treated on a case
by case basis.
For example in case of diffusion equation an analytical solution is available, hence a numerical
approximation of the solution can be obtained on a successively refined grid. The error of approximation is
computed for each approximation. If the error reduces to zero, as the grid discretization is reduced implies
that approximate solution is convergent to the analytical solution.
The exemplification of the procedure to demonstrate convergence of a numerical solution to
the analytical one is shown for the case of the linear advection equation, as represented by equation
(4.43) in Chapter 4. A one dimensional linear advection equation with positive constant advection
velocity a is:
∂u ∂u
+a =0 (6.23)
∂t ∂x
In case of an equally spaced grid, on both x and t directions, the forward time backward space (FTBS)
up-wind numerical solution to the equation is given by equation (4.48), as:
∆t
Cr = a ⋅ (6.25)
∆x
Consider that u(x, t) represents the water depth in a 10 km long canal, which has an initial water level
of u 0 = 5 m. Based on the canal geometry the advection velocity is a = 0.5 m/s.
For the given initial condition of the form:
t
u0 ⋅ , 0 ≤ t < tm
tm
(6.26)
u( x = 0, t ) = t
u ⋅ 2 − m , t m ≤ t < 2t m
0 t
0, t ≥ 2t m
equation (6.23) has an exact solution as shown in Figure 6.3. The exact solution at a later moment in
time and space is the same as the initial condition, that is, initial condition is, advected unchanged
towards downstream. For different values of grid discretization, such that Courrant number is kept
constant, Cr = 0.5, the result is presented in Figure 6.3. Comparing numerical solutions with the
analytical solution, it is noticed that the numerical solution tends to the analytical solution as the grid
dimensions are reduced, which shows that the up-wind FTBS scheme converges to the analytical
solution.
4.5
4
Water Level (m)
3.5
2.5
Cr=0.5, ∆t=50 sec
2
Cr=0.5, ∆t=100 sec
1.5
0.5
0
0 500 1000 1500 2000 2500 3000 3500 4000 4500 5000
Time (sec)
Figure 6.3 Linear advection equation’s initial condition, exact solution and numerical approximations by
the FTBS up-wind scheme.
The above demonstration shows that for the particular case of advection equation a particular numerical
scheme converges to the analytical solution, however this is not easy to do for other types of equations.
In case of the numerical scheme (6.24) for the linear advection equation Taylor series expansion of the
point values uin−1 , and uin around point (i, n) are:
n n n
∂u ∆x 2 ∂ 2 u ∆x 3 ∂ 3u
uin−1 = uin − ∆x + − + (6.27)
∂x i 2 ∂x i 2 6 ∂x 3 i
n +1 n +1 n +1
∂u ∆t 2 ∂ 2 u ∆t 3 ∂ 3u (6.28)
u = u + ∆t
n n
+ − +
i i
∂t i 2 ∂t 2 i 6 ∂t 3 i
Substitution in equation (6.24) gives:
∂u ∂u (6.29)
+a = TE (∆x, ∆t )
∂t ∂x
where TE(Δx, Δt) is the reminder term (or the truncation error term):
6 x=2500m
5.5 x=0
Boundary Condition Cr=1, ∆t=100 sec
5
4.5
3.5
2.5
1.5
0.5
0
0 500 1000 1500 2000 2500 3000 3500 4000 4500 5000
Time (sec)
Figure 6.4
Linear advection equation’s numerical approximations by the FTBS up-wind scheme for
Courant numbers greater than 1.
Conditions of stability of the advection equation are investigated bellow. According to equation (6.22)
each approximated value of the unknown function at a discretization node is a difference between the
exact value and the error. For the three terms in equation (6.24) it yields:
uin +1 = u( xi , t n +1 ) − TEin +1
n (6.31)
ui = u( xi , t ) − TEi
n n
u n = u( x , t n ) − TE n
i −1 i −1 i −1
The exact solution of the linear advection equation satisfies relation (6.24) of the numerical scheme:
u( xi , t n +1 ) = Cr ⋅ u( xi −1 , t n ) + (1 − Cr ) ⋅ u( xi , t n ) (6.33)
hence:
Equation (6.34) is written for all the points of the discretization grid. The analysis using von Neumann
method implies to expand all errors from time level n as finite complex Fourier series and to analyze how
a single component of the series behaves from time level n to time level (n + 1). If each component of the
Fourier series is stable then the numerical solution is stable. If one single component of the Fourier series
is not stable then the solution is not stable.
Based on the above statements looking at the error term of time level n, TE nj expressed in terms of
Fourier series (Abbott & Basco, 1989) gives:
KF
TE nj = ∑( Ao ⋅ A ) ⋅ e
n
k
i ⋅k ⋅m⋅ j ⋅∆x
(6.35)
k =1
(Note: Throughout the book indices notation i is used for space discretization. In order to avoid confusion
with the unit imaginary number, j is used as an indices notation along x axis, in the Fourier series (6.35).)
In relation (6.35) notations are:
2π
m= (6.36)
λ
If parameter N is introduced as being the number of discretization grid intervals available in one wave
length:
λ
N = (6.37)
∆x
and equation (6.36) is multiplied by Δx on both sides then the term φ (the phase of the error) called the
wave number, is defined as:
2π
ϕ = m ⋅ ∆x = (6.38)
N
The shortest waves represented at the considered grid point is 2Δx, while the longest one is ∞, hence
2 ≤ N ≤ ∞, which gives the range of the wave number in the interval [0, π].
The error term (6.35), for only one Fourier component, k = 1, is:
TE nj = An ⋅ ei⋅ϕ ⋅ j (6.39)
Substitution of equation (6.39) into (6.34) yields:
The ratio:
A n +1
A= = 1 − Cr + Cr ⋅ e − i⋅ϕ (6.41)
An
is the amplification factor of the k-th component of the Fourier series representation of the error function
TE while passing from time level n to time level (n + 1). The error does not increase if the modulus of the
amplification factor is less than one, that is, |A| ≤ 1.
Knowing from (6.16) that e−i⋅ϕ = cos φ − i ∙ sin φ, yields:
Equation (6.42) shows that A is a complex number, hence condition on the modulus is:
ϕ ϕ ϕ ϕ (6.44)
cosϕ = cos2 − sin 2 and sinϕ = 2sin cos
2 2 2 2
ϕ
|A|2 = 1 − 4Cr (1 − Cr )sin 2 (6.45)
2
The wave number φ ranges in the interval [0, π]. For φ = 0 the inequality (6.43) is verified (1 = 1). In
case φ = π the maximum value of sin 2
ϕ
2 ( )
in expression (6.44) is 1. The term Cr(1 − Cr) is a parabola
which has a maximum value of 0.25 for Cr = 0.5. Hence the amplification factor remains less or equal to
1 as long as:
∆x
0 ≤ Cr ≤ 1 or ∆t ≤ (6.46)
a
Equation (6.46) is known as the Courant-Friederichs-Levy condition (CFL condition) and is valid for
hyperbolic equations solved by explicit schemes. The CFL condition is a very important one, however
is not a sufficient condition for convergence. It states that a necessary condition for convergence of a
numerical scheme to the analytical solution is that the numerical domain of dependence contains the
analytical domain of dependence. Courant number is also known to measure the ‘numerical speed’ of the
numerical solution.
The FTBS scheme for the solution of the linear advection equation proofs to be a consistent and a stable
scheme, if Cr < 1, hence it is a convergent scheme.
1.2
0.9
t=40sec
Water Level (m)
t=80sec
0.6 t=120sec
0.3
0
0 10 20 30 40 50 60 70 80 90 100
X (m)
Because numerical diffusion is not a desirable phenomenon, a better scheme to discretise the advection
equation is usually used. For example the Preissmann scheme with θ = ψ = 1/2 is second-order accurate,
which implies that the first term in the truncation error is zero. The equation is consistent with the
following one:
∂u ∂u ∂ 3u
+a =k 3 (6.47)
∂t ∂x ∂x
Equation (6.47) is in fact a dispersion equation. Instead of smoothing profiles artificially, a dispersive
scheme tend to make them sharper and create oscillations. This is the numerical dispersion effect. Figure
6.6 shows a typical example of computed profile using a dispersive scheme.
1.2
t=80 sec
t=0 Cr=0.5
Cr=1
0.9
Water Level (m)
0.6
0.3
0
0 10 20 30 40 50 60 70 80 90 100
X (m)
Figure 6.6 Linear advection equation’s numerical approximations by the a dispersive scheme.
A typical example of the effects of numerical dispersion is that the computed concentrations of a
pollutant in a river may become negative. Dispersion is due to errors introduced when estimating the
derivatives. Numerical dispersion causes phase errors.
not necessarily travel at the same speed. The graph that shows how the Fourier components are amplified
is called amplitude portrait and the one showing at what speed the Fourier components travel is called a
phase portrait.
For the FTBS numerical scheme for the advection equation the argument of the amplitude factor given
by (6.42) is:
Following the same approach as for the FTBS scheme the argument of the exact solution results in:
2Cr ⋅ π (6.48b)
µa = arctan(−Cr ⋅ ϕ ) = −Cr ⋅ m ⋅ ∆x =
N
Based on (6.48) the ratio of the numerical to analytical phase speed R (see equation (6.21)) is calculated.
Amplitude portrait is shown in Figure 6.7 for the advection equation for the FTBS scheme for different
values of the Courant number.
1.2
Cr=1.25
0.9
Cr=1.05
Amplitude factor
Cr=1.00
0.6
Cr=0.75
0.3
Cr=0.50
0
0 1 2 3 4 5 6 7 8 9 10
N
Figure 6.7 Amplitude portrait for advection equation using FTBS numerical approximation.
Figure 6.8 shows the decrease in amplitude of Fourier components for the FTBS scheme after one time
step and after 100 time steps, using a value of Courant number of 0.5. Analysing the amplitude decrease,
it can be concluded that FTBS scheme has strong numerical diffusion. This is due to the fact the scheme
is of first order and truncation errors are large. FTBS scheme is not recommended for the solution of the
advection equation, except for cases when boundary conditions are outflows.
1.0
0.8
After 1∆ t
0.6
Amplitude
0.4
0.2
After 100∆ t
0
0 0.39 0.79 1.18 1.57 1.96 2.36 2.75 3.14
φ
Figure 6.8 Amplification factor of the wave components for advection equation.
∂u ( x − x P )2 ∂ 2 u
uE = uP + ( xE + xP ) + E ∂x 2 + TE (6.49)
∂x P 2 P
In equation (6.49) TE is referred as previously as truncation error. From equation (6.49) it can be seen
that the method does not dependent on the computational grid. The interpolation error of the scheme is of
1st order. The first term in the TE of the convective flux FcC is:
∂u
TE1 = me ( xe − xP ) (6.50)
∂x P
The error as it is expressed by equation (6.50) is called numerical diffusion (sometimes artificial
diffusion), because the term is like a diffusive flux. The advantage of using an upwind scheme is that such
a method generates an unconditionally bounded error. The magnitude of the numerical diffusion is given
by the coefficient me(xe – xp). In case that the transport takes place perpendicular to the control volume
face, then the approximation of the convective fluxes is good, because the term (∂u/∂x)P is small in such a
case. In case that the condition of transport being perpendicular on the face of the control volume is not
met then the approximation may be inaccurate and for large values of fluxes (such as large velocities) it is
required to use very fine grids in order to obtain good accuracy of the solution. Very fine grids would make
the difference xe − xP very small.
In case that a central scheme is used for the discretization of convective fluxes then the approximation
has an interpolation error of a second order, as it is illustrated by the interpolation in equation (5.12). The
second order of the interpolation error is valid for both an equally spaced grid and an unequally spaced
grid. Taylor series expansion of u, around the middle point P gives:
∂u ( x − x P )2 ∂ 2 u
u( x ) = uP + ( x − xP ) + ∂x 2 + TE (6.51)
∂x P 2 P
Evaluating expression (6.51) at xe and xE and comparing them leads to:
( xe − xP )( xE − xe ) ∂ 2 u
ue = γ e uE + (1 − γ e )uP − ∂x 2 + TH (6.52)
2 P
which shows that the first term in the error depends quadratically on the grid discretization.
6.3.2 Diffusive fluxes
The analysis of the error magnitude of the diffusive fluxes is done by analysing the difference of the Taylor
series expansion at points xP and xE , around point xe. Hence:
∂u uE − uP ( xe − x P ) 2 − ( x E − xe ) 2 ∂ 2u ( xe − xP )3 + ( xE − xe )3 ∂ 3u
∂x = x − x + 2( xE − xP ) ∂x 2 − 6( x E − x P ) ∂x 3 + TE (6.53)
e E P e e
Analysing expression (6.53) it can be noticed that for an equally spaced grid the second term of the
expression becomes zero, hence a second order error results. In case that the grid is not equally spaced,
shows that the term is proportional with the expansion rate of the neighboring grid cell, ξe:
(1 − ξe )( xe − xP ) ∂ 2u x E − xe
2 ∂x 2 , with ξe = x − x (6.54)
e P
e
which is equivalent with stating that the larger the expansion, the larger the error. This gives modellers the
indication on how should unequally spaced grids be build, and that expansion from one grid cell size to
another should be done smoothly and with care.
There are other possibilities available for approximating derivatives when using finite volumes, such
as forward or backward differencing formulas, however they are hardly used in practice, because of the
advantage that central differencing has of being very accurate. Error bounding is not an issue for the
diffusive fluxes.
6.4 Examples
6.4.1 Stability region of a simple ODE
For illustrating the above principles consider the simple ODE and its initial conditions as defined by
equation (6.23) below:
du(t )
= λu(t ), for t ∈ [t 0 , t final ]
dt (6.55)
u(t 0 ) = u0
In the ODE defined by (6.54), λ may be a complex number (i.e., λ = λr + iλi ). Introducing an equally
spaced grid with (N + 1) nodes of discretization, such that:
t final − t 0
t i = t 0 + ∆t , ∆t = (6.56)
N
and using an explicit discretization approach (Euler’s forward finite difference method), the solution of the
ODE is given by:
u n +1 = u n + ∆t ⋅ λ ⋅ u n = u n (1 + λ ⋅ ∆t ), n = 0,1, 2, … , N (6.57)
u n = u0 (1 + λ ⋅ ∆t )n = u0 ⋅ An (6.58)
A = 1 + λr ⋅ ∆t + i ⋅ λi ⋅ ∆t (6.59)
As previously shown, in order to obtain the region of stability the condition to be met is:
This condition represents the unit circle centred at Z = −1 in the complex plane Z. As long as λ ⋅ Δt is
positioned inside the circle the numerical method is stable. This shows that if λ is a negative real number,
stability condition requires that
2
∆t ≤ (6.61)
|λ |
Assuming a constant reservoir surface area A, a constant porosity n and an outflow discharge Q defined
as linear function of the water level h, gives the following ODE representation for the reservoir:
dh
nA = −Q (6.62)
dt
Eliminating Q, which is a linear function of h, yields:
dh
= −αh (6.63)
dt
where α is the linear reservoir coefficient. Equation (6.62) has the exact solution
h = h0 e −αt (6.64)
h n +1 = h n − α ⋅ ∆t ⋅ h n = (1 − α∆t ) ⋅ h n (6.65)
If the numerical solution (6.65) of the equation (6.63) is represented graphically for different (Δt), for
a given initial condition of h = 15 m (see Figure 6.10), a comparison with the analytical solution (6.64)
indicates that the solution decreases too slowly when Δt is large. Moreover this simple example shows
that numerical methods are not always accurate, for example for a value of Δt of 22 days, failures in
determining the accurate solution may be observed. This can be avoided by choosing the time step in a
proper way. Analysis of the accuracy of the method is further done.
Equation (6.65) is an accurate approximation of the equation (6.63) if it behaves in the same way as
the function to which it is an approximation, and if it becomes a better approximation as the time-step is
reduced. Starting from the first time-step of discretization, when t = to, equation (6.65) yields:
h1 = (1 − α∆t )h0
2
h = (1 − α ∆t )h1 = (1 − α ∆t )(1 − α ∆t )h0 = (1 − α ∆t )2 h0
(6.66)
…
h = (1 − α∆t ) h
n n 0
40 exact solution
stable oscilatory
30
unstable
20
10
h (mm)
0
0 50 100 150 200 250
-10
-20
-30
-40
Time (days)
Figure 6.10 Exact and explicit solutions for the reservoir equation.
Relation of type (6.66) is analysed in behaviour as Δt → 0. Because Δt = tn /n, equation (6.66) can be
written as:
n
αt
h n = 1 + − h0 (6.67)
n
n
2
n
n −1 αt n − 2 αt
h = h 1 + 1 − + 1 − + …
0 n 0
(6.68)
n 1 n 2
where ( nr ) is the number of ways of choosing r items from a set of n items. Order of choosing is not
important. The number of possible combinations is:
n n!
r = (n − r )! r ! (6.69)
As n → ∞, which is equivalent with Δt → 0, n becomes so big that n – 1 ≈ n, n – 2 ≈ n, and so on. As a
result:
n! n nr
= n(n − 1)(n − 2)… → nr and → (6.70)
(n − r )! r ! r n!
Hence:
n αt n2 αt
2
αt 1 αt
2
h n → h0 1n + − + 1n − 2 − + = h 0
1n
+ − + − +
1! n 2! n 1 2! 1 (6.71)
Taylor series for e − αt
Hence:
h n → h0 e −αt (6.72)
which is the exact solution of the ODE, that is, equation (6.64).
The exact solution to the equation (6.63) decays with time. The value of hn at a given time step always
smaller than the value at the previous time step. The decay is monotonic, i.e. the sign of hn does not
change. Looking at equation (6.65), and taking into account the previous statement, if hn+1 is less then
hn yields:
1
0 ≤ 1 − α ∆t ≤ 1 ↔ 0 ≤ ∆t ≤ (6.73)
α
Equation (6.73) shows that the numerical solution decays monotonically only for a limited range of
values of Δt, as it could be noticed from Figure 6.10.
Stability of numerical scheme (6.65) is analysed by applying the von Neumann principle:
h n +1
≤1 ↔ 1 − α ∆t ≤ 1 (6.74)
hn
For this to be true, the two following conditions must be verified simultaneously:
(6.75)
α ∆t ≤ 2
−α ∆ t ≤ 0
The first of the condition (6.74) is always verified because both the constant α and the time step Δt are
positive. The second condition means that the time step cannot be larger than a maximum value defined by
2
∆t Max = (6.76)
α
The term O(Δt3) accounts for all the higher-order terms in the Taylor series expansion. Substituting the
expression (6.77) into the numerical scheme (6.65), yields:
dh ∆t 2 d 2 h (6.78)
h n + ∆t + + O(∆t 3 ) = (1 − k ∆t )h n
dt 2 dt 2
dh ∆t d 2 h (6.79)
+ αh = − + O(∆t 3 )
dt 2 dt 2
Comparing equation (6.79) with the original equation (6.63) shows that the discretised equation (6.79)
is different from the original equation. The difference is the truncation error term, which becomes smaller
when Δt decreases to zero. When Δt tends to zero, the term O(Δt2) decreases faster than the term Δtd 2 h/dt2
hence the term in Δt is the larger of the two. The truncation error is of first-order with respect to time
step. The truncation error contains a second-order derivative d2 h/dt2, which is not present in the real
equation, consequently, the discretised equation approximates the real equation up to the first order only.
The discretization is first-order accurate with respect to h.
hn (6.80)
h n +1 =
1 + α ∆t
h n +1 1 (6.81)
= ≤ 1 ↔ 1 + α ∆t ≥ 1
h n 1 + α ∆t
Condition expressed by (6.81) is always verified. Since α > 0, condition (6.81) is valid for all Δt > 0 and
Δt > 0 by definition. The scheme always decays and never oscillates around 0. It is unconditionally stable,
hence there is no stability constraint for the implicit method. (Note: because a scheme is stable, does not
make it accurate.)
From physical point of view the reservoir becomes empty over time, hence h should decrease
monotonically to 0, which is shown by the analytical solution. For the case of the explicit scheme Δh is
invariably overestimated, to the extent that in some cases h is negative. In contrast, the implicit scheme,
invariably underestimates the solution.
convergence is an important aspect to be looked at. Recall from chapter 4, section 4.5.2.4, using notations
from Figure 4.18 and equations 4.56 for the scheme that problem to be solved is:
∂u + a ∂u = 0
∂t ∂x
∂u uin−+11 − uin−1 u n +1 − uin
∂t = ψ ∆t
+ (1 − ψ ) i
∆t
(6.82a,b,c)
P
∂u u − ui −1
n n
u − uin−+11
n +1
= (11 − θ ) i +θ i
∂x P ∆x ∆x
The domain of computation of equation (6.82a) and the 4 point scheme is represented in Figures (4.19)
and (4.18) of Chapter 4. The box scheme approximates the derivatives at a point P inside the discretization
grid, using the values of the unknown function at grid points. There are in total M points of discretization.
Advection velocity a is assumed constant and positive (i.e., a > 0), which implies that boundary condition
is specified at x = 0, hence all values u1n are known at all time levels n of computation. The two weighting
parameters θ and ψ ranges in the interval [0, 1].
Substitution of the derivatives discretization in advection equation yields:
In each of the (M–1) equations of system (6.83) there is one unknown, hence each equation of the system
can be written in a general form as:
uin +1 = α ⋅ uin−1 + β ⋅ uin + γ ⋅ uin−+11 (6.84)
solution is carried out over 10 hours. Results of solution for this problem, using numerical scheme (6.84)
and different values for the weighting coefficients (θ and ψ), are shown in Figures 6.11, 6.12 and 6.13, at
the discretization grid point x = 5 km.
6
5.5 x=0 x=2500m
Boundary Condition
5 Cr=1
Cr=0.8
4.5
Cr=0.5
4
Cr=1.5
3.5
3
Water Level (m)
2.5
2
1.5
1
0.5
0
−0.5
−1
−1.5
−2
0 500 1000 1500 2000 2500 3000 3500 4000 4500 5000
Time (sec)
Figure 6.11 Solution of advection equation using the 4-point numerical scheme for θ = 0.5 and ψ = 0.5.
6
5.5 x=0 x=2500m
Boundary Condition
5 Cr=1
4.5 ψ =0.5
4
3.5
3
Water Level (m)
2.5
ψ =0.25
2
1.5
1
0.5
0
−0.5
−1
−1.5
−2
0 500 1000 1500 2000 2500 3000 3500 4000 4500 5000
Time (sec)
Figure 6.12 Solution of advection equation using the 4-point numerical scheme for θ = 0 and Cr = 0.5.
6
x=0 x=2500m
5.5
Boundary Condition
5 Cr=1
Θ =0.48
4.5 Θ=0.5
4
3.5
3
Water Level (m)
2.5
Θ =1.00
2
1.5
1
0.5
0
−0.5
−1
−1.5
−2
0 500 1000 1500 2000 2500 3000 3500 4000 4500 5000
Time (sec)
Figure 6.13 Solution of advection equation using the 4-point numerical scheme for ψ = 0 and Cr = 0.5.
Figures 6.11, 6.12, 6.13 shows that there are values of θ, ψ, Cr for which solutions are either oscillating
or dampening. The physical phenomenon represented in the equation is just advection, hence the errors
in solution are of numerical nature. Analysis of the error of the solution must give the constraints of
application of the numerical scheme.
As shown by relation (6.33) the error of the numerical scheme solution satisfy the equation of the
applied numerical scheme, hence in the case of box scheme the error is:
TE nj +1 = α ⋅ TE nj −1 + β ⋅ ET jn + γ ⋅ TE nj −+11 (6.86)
(Note: Because Fourier series are used further for the analysis of the error, indices j are used for space
discretization points, in order to avoid confusion with the imaginary unit i.)
Using Fourier series to represent the solution error yields:
A n +1 β + α ⋅ e − i⋅ϕ
= A= (6.88)
A n
1 − γ ⋅ e − i⋅ϕ
The amplitude of the error should not increase, it is required that |A| < 1, hence:
β + α ⋅ cos ϕ − i ⋅ α ⋅ sin ϕ
A= (6.89)
1 − γ ⋅ cos ϕ + i ⋅ γ ⋅ sin ϕ
β + (α − β ⋅ γ ) cos ϕ − α ⋅ γ (α + β ⋅ γ )sin ϕ
A= − i (6.90)
1 − 2γ ⋅ cos ϕ + γ 2
1 − 2γ ⋅ cos ϕ + γ 2
Stability condition yields:
2 2
β + (α − β ⋅ γ ) cos ϕ − α ⋅ γ (α + β ⋅ γ )sin ϕ
|A| = + 2
≤1 (6.91)
1 − 2γ ⋅ cos ϕ + γ 2
1 − 2γ ⋅ cosϕ + γ
In inequality (6.91) φ ∈ [0, π], hence the inequality is checked for the minimum and maximum values
of φ.
If = π, inequality (6.91) is:
2
β −α
1 + γ ≤ 1 (6.92)
equivalent with
β −α (6.93)
−1 ≤ ≤1
1+γ
2Cr
−1 ≤
1 − 2ψ − 2(1 − θ )Cr 1 − 2ψ + 2θ ⋅ Cr
−1 ≤ ≤1 ⇔ (6.94)
1 − 2ψ + 2θ ⋅ Cr 1 − 2Cr
≤1
1 − 2ψ + 2θ ⋅ Cr
If = 0, inequality (6.91) is:
β +α
≤1 (6.95)
1−γ
equivalent with
β +α
−1 ≤ ≤1 (6.96)
1−γ
Replacing the expression of coefficients α, β, and γ, yields:
2 + θ ⋅ Cr
0≤
1 + 2ψ 1 − 2ψ + θ ⋅ Cr
−1 ≤ ≤1 ⇔ (6.97)
1 − 2ψ + θ ⋅ Cr 4ψ + θ ⋅ Cr
≤0
1 − 2ψ + 2θ ⋅ Cr
1 1
θ ≥ and ψ ≤ (6.98)
2 2
(a)
2.20 ψ=1.00
1.60 ψ=0.75
Amplitude factor
1.00 ψ=0.50
0.65 ψ=0.25
0.40 ψ=0.00
0
0 1 2 3 4 5 6 7 8 9 10
N
(b)
3.00 Θ=0.00
Amplitude factor
2.00 Θ=0.25
1.00 Θ=0.50
0.50 Θ=0.75
0.40
Θ=1.00
0
0 1 2 3 4 5 6 7 8 9 10
N
Figure 6.14 Amplification factor versus N for advection equation for Cr = 2: (a) different θ values and
ψ = 0.5; (b) different ψ values and θ = 0.5.
Condition (6.98) ensures the denominator in relations (6.94) and (6.98) is not zero. Moreover the
inequalities are satisfied for any value of Courant number, Cr, hence the scheme is unconditionally stable
if (6.98) is valid.
In the case that values of parameters θ and ψ are zero the explicit FTBS scheme is obtained, which has
different numerical properties than the box scheme, as shown earlier in the chapter.
Further it is important to analyse the conditions for which box scheme does not introduce artificial
dissipation or dispersion, because the analytical solution of the advection equation is a wave that has a
specific amplitude and celerity which should not be changed by the numerical solution. The analysis is
carried out, by examining the amplitude and phase errors. The amplitude errors are given by the modulus
of the amplification factor, which for box scheme is:
1
2π
2
2π
2 2
β + (α − β ⋅ γ ) cos − α ⋅ γ (α + β ⋅ γ )sin N
N
|A| = + (6.99)
2π 2π 2
1 − 2γ ⋅ cos + γ 2
N 1 − 2γ ⋅ cos N + γ
Recall that N is the ratio between the wave length and the size of the space discretization (Δx).
Representing graphically the function A given by (6.99) for different values of Courant number (see
Figure 6.14), it can be seen that for Cr = 1, and θ = ψ = 0.5 the box scheme is free from dissipation, while
for, θ ≥ 0.5 and ψ ≥ 0.5, the scheme increases the wave amplitude over time, which leads to instabilities.
Small values of N and large Courant numbers creates damping, hence the number of discretization points
over the wave length should be carefully selected.
∂u ∂ 2u
∂ t − D ∂x 2 = 0
∂u uin +1 − uin
∂t = ∆t
(6.100a, b, c)
∂u ui +1 − 2uin + uin−1
n
∂x = D ∆x
where D is the diffusion coefficient. Substitution of the derivatives discretization in advection equation
yields:
D∆t
uin +1 = uin + r ⋅ (uin+1 − 2uin + uin−1 ), with r = (6.101)
(∆x )2
The error of the numerical scheme solution satisfy the equation of the applied numerical scheme, hence
using Fourier series to represent the solution error yields:
(Note: Because Fourier series are used further for the analysis of the error, indices j are used for space
discretization points, in order to avoid confusion with the imaginary unit i.)
From equation (6.102) the amplification factor is computed as:
A n +1
= A = 1 − 2r ⋅ (1 − cos ϕ ) (6.103)
An
The amplitude of the error should not increase, it is required that |A| < 1, hence:
r ≤ 1/ 2 (6.104)
7.1 Introduction
Rivers are very important for mankind because they provide a source for drinking water and food
production. Moreover they are important as a habitat for wildlife and for maintaining the equilibrium
of the ecosystems formed along them. Apart from these natural benefits, rivers can also be used as
means of transportation of goods and as recreation areas. Though sometimes rivers are causing floods,
human settlements were always located in the river floodplains because of the social and economic
benefits that the rivers are bringing (Knight, 2006; Novak, 1990). As societies developed their need for
managing the river systems along which they live grew and changes started to be implemented in order
to take advantage of the river’s water availability or to protect the settlements against flood hazards.
Communities have been developing and managing water resources in river basins in order to satisfy their
demands for water quantity and quality or to cope with extreme events such as floods and droughts, by
building dams to have access to water, irrigation channels to take water from rivers, dykes to protect the
floodplains from flood risks, and so on. These developments were challenges to hydraulic engineers who
needed to understand and evaluate the mechanism of flow in a river as well as the mechanism of flood
formation. Stream flow predictions at particular locations in a river channel were done by engineers since
a long time, and lately due to the advent of computers their tasks is facilitated by the availability of river
system modelling tools, that are able to help in long and short term planning. The concept of River Basin
Management (RBM) emerged and is accepted as a central element in all policy directives regarding
rivers worldwide. The concept emerged as a holistic approach to river systems management and tries
to eliminate the negative effect of the competitive interventions in a system due to the different water
resources needs, such as unbalanced water resources exploitation between upstream and downstream of
a river system.
In the last four decades model codes have been developed for water resources and environmental
analyses. These codes have been developed by academia, governmental and consultancy agencies and
they vary in complexity from simple conceptual codes to complex ones based on physical processes.
Majority of these codes are nowadays embedded in a tool, with complex graphical user interfaces.
Further more, many of these tools are embedded in Decision Support Systems (DSSs), that are not only a
framework for providing data and information to decision makers, but they are also platforms for sharing
and disseminating information to the public (Popescu et al., 2012).
The DSS systems applied in RBM are using river system modelling, because it allows for understanding
the behaviour of the river system as a response to some input variables such as discharges in an upstream part
and/or conditions at the downstream boundary of a river. Moreover water quality analysis can be carried out
if the hydrodynamic of flow in a river is known. A model of a river can help the decision making process by
equipping the decision makers with a tool to objectively evaluate the effect of certain decisions. Mathematical
(hydraulic) models for rivers, channel and pipe systems, emerged in 1980 and are the most widely used codes.
They are used for predicting flows, travel times, and water level variations in rivers, channels and canal systems.
Floodplains along the rivers are also important because they are the preferred location for living,
however the effect of floods are loss of life, loss of property and adverse impacts on economic activities.
Hence there is the need for accurate and reliable flood analysis and management of flood from both
forecasting and mitigating points of view. Hydraulic models of river flow simulations became important
instruments to address these issues.
Development of river models started during 1970s. River models are in general part of river basin models,
which were developed especially for planning purposes (Zagona et al., 2001; Jonoski & Popescu, 2004),
both long and short-term. River basin models are used for water management purposes using different
approaches and technologies. There are a number of models able to represent different hydrological
processes, as well as river hydrodynamics. Examples of such systems that include sophisticated graphical
user interfaces are MIKE SHE (DHI, 2012), HEC suite of models (USACE models) and SOBEK (Deltares,
2010). There are many other examples of such systems. A comprehensive overview of existing river
modelling systems is given by Horrit and Bates (2002) .
fronts and rapid changes in velocity occur. In this section of the book the conservative equations of flow are
considered and solutions are shown. All demonstrations are made on rectangular grids because historically
they have remained a popular choice and are the basis for a number of widely used algorithms (Sturm, 2001).
For channels of irregular topographies, the flow can be described by the Saint-Venant equations, as
shown in Chapter 2. The Saint-Venant equations for one-dimensional flow are:
– continuity equation (CE):
∂Q ∂h 1 ∂Q ∂h q
+b = q or ⋅ + = (7.1)
∂x ∂t b ∂x ∂t b
∂Q ∂ Q2 ∂h QQ
+ β + gA − gASO + gA 2 = 0 (7.2)
∂t ∂x A ∂x K
where Q is the discharge (m3/s); b the storage width at the water surface level (m); h water depth (m); A
the cross-sectional area (m2); q the lateral discharge (m3/s); K the conveyance (m3/s); β the Boussinesq
coefficient (–); g gravity (m/s2) and So the bed slope of the channel (–).
The system of equation formed by (7.1) and (7.2) has an analytical solution just for very few particular
cases. These are usually solved using numerical approximation. There are many approaches to solve the
system of equations however two of them, based on FDM, are the most used ones in practice, and are
detailed further, the four point Preissmann scheme and the six-point Abbott Ionescu scheme.
Prior to building any mathematical model and performing computations for a specific river, the geometry
of the river needs to be known (Figure 7.1), by determining the course of it (the river bottom in a number
of cross-sections. River systems are schematised into a simplified river network using a node-link structure
(see Figure 7.1). The river network begins and ends with a node, and all nodes are interconnected. From the
map representation of the river network, the extent of the model is selected by positioning the upstream and
downstream boundaries. A computational space step Δx (usually constant) is selected as well. The obtained
nodes represent the computational points on the grid and all relationship between the water depth h in these
nodes and a number of water depth related parameters, such as width of water table (B), or cross-sectional
area (A) are computed in all discretization points. Computational nodes do not usually correspond to the
measured cross-sections and interpolation is used to determine values of parameters in computational nodes.
in momentum equations in order to ensure that flow remains in sub-critical regime. Hence the convective
acceleration term is multiplied by a factor (Djordevic et al., 2004) which ensures that flow is always
subcritical.
Cross section
z B
Datum
50 x x
Discretization of the equations (7.1) and (7.2) is done on a computational domain (x, t), as it is represented
in Figure 7.2. using the stencil from Figure 4.18 of Chapter 4 of the book.
t - unknown values at
,
time level (n+1)
- known value at
n+1 Q,h Q,h Q,h Q,h Q,h Q,h time level n
Q,h Q,h Q,h Q,h Q,h Q,h - known value at
n time level (n+1)
...
Figure 7.2 Computational domain for the Saint-Venant equations for Preissmann scheme solution.
The discretization grid considered is a structured one that computes values of Q and h in all points of
the computational domain. Solution of the system of equations defined by (7.1) is solved for x ∈ [0, L] and
t ≥ 0. Applying the Preissmann scheme to the terms in equation (7.1) yields:
∂Q ∂Q ∂Q Q n +1 − Qin +1 Q n − Qin
=θ + (1 − θ ) = θ i +1 + (1 − θ ) i +1 (7.3)
∂x ∂x n +1 ∂x n ∆x ∆x
∂h ∂h ∂h h n +1 − hin+1 h n +1 − hin
=ψ + (1 − ψ ) = ψ i +1 + (1 − ψ ) i (7.4)
∂t ∂t i +1 ∂t i ∆t ∆t
Substituting (7.3) and (7.4) in equation (7.1) and grouping the unknown variables, Qin +1 , hin +1, on the left
hand side results in:
A1i Qin +1 + B1i hin +1 + C1i Qin++11 + D1i hin++11 = E1i (7.5)
−θ
A1i +1 = (7.6a)
∆x
b
B1i +1 = (1 − ψ ) (7.6b)
∆t
θ
C1i +1 = (7.6c)
∆x
bψ
D1i +1 = (7.6d)
∆t
1−θ n
E1i +1 =
∆x
(
Q j − Q nj +1 +
b
∆t
)
[(1 − ψ )h nj + ψh nj +1 ]
(7.6e)
Applying the same approach (substituting (7.3) and (7.4) in equation (7.2)) to momentum equation,
yields:
– Discretization of first term of momentum equation:
∂Q Q n +1 − Qhin+1 Q n +1 − Qin
= ψ i +1 + (1 − ψ ) i (7.7a)
∂t ∆t ∆t
∂ Q2 β Q 2 Q2
β = −
∂x A ∆x A A i
i +1
Considering the following linearization for the non linear term Q2 (Abbot & Basco, 1989):
Q2 = Qn × Qn+1
and
Ain+1 + Ain++11
Ai +1 = Ain++11/ 2 =
2
∂ Q2 Q n × Q n +1 Q n × Q n +1
β = β i +1 n +1i/+21 − i n +1i / 2 (7.7b)
∂x A ∆x ( Ai +1 ) ∆x ( Ai )
– Discretization of third term of momentum equation:
∂h ∂h ∂h
gA = gAin++11/ /22 θ + (1 − θ )
∂x ∂x n +1 ∂x n
h n +1 − hin +1 h n − hin
= gAin++11/ /22 θ i +1 + (1 − θ ) i +1 (7.7c)
∆x ∆x
– Discretization of fourth term of momentum equation:
– Discretization of fifth term of momentum equation is done using the coefficient ψ because Q and K
are varying over time:
QQ QQ QQ
gA 2
= gψΑ 2 + g(1 − ψ ) A
K K K2
i +1 i
hence:
QQ n+ 1 Qin+1 Qin++11 n+
1
Qin Qin +1
gA 2 = g ψAi +12 + (1 − ψ ) Ai 2
2
(7.7e)
K n + 12 n + 12
K i +1 Ki
Grouping the unknown variables, Qin +1 , hin +1, on the left hand side results in:
βQ nj Qin
1−ψ
A2i +1 = − + (1 − ψ ) A n +1 / 2 (7.9a)
∆t ∆x ( Ain +1/ 2 ) ( )
i
K n +1 / 2
2
i
θ
B2i +1 = − gAin++11/ /22 (7.9b)
∆x
Qin+1
ψ Qin+1
C 2 i +1 = + β + gψAin++11/ 2 (7.9c)
∆t ∆x( Ai +1 ) ( )
+
n 1 / 2
K n +1 / 2
2
i +1
n+
1
θ
D2i +1 = gψAi +12 (7.9d)
∆x
1−ψ n ψ n 1 − θ n
E 2 i +1 = Qi + Qi +1 + gAin++11/ /22 ( hi +1 − hi ) + gAi +1/ 2 So
n +1 / 2
n
(7.9e)
∆t ∆t ∆x
The pair of equations (7.5) and (7.8) are written for each point of the discretization grid, that is for
i = 1, 2 … , M – 1, to obtain a system of 2(M – 1) equations that has 2M unknowns. The system is completed
with two more relations at the boundary of the domain:
– for node i = 1:
In equations (7.10) bc(x) is a coefficient which takes the value 0 or 1 depending on the type of the
specified boundary condition, that is coefficient value 1 means water depth is specified as boundary
condition and value zero means a discharge boundary condition.
A number of 2M equations are obtained for a number of 2M unknowns. Such a system can be solved
using matrix calculations or in an iterative method by using the so-called Double Sweep Algorithm.
Solution of the linear system of equation is given by the solution of the bandwidth matrix:
An alternative solution to matric calculations is the one given by the Double Sweep Algorithm, which
takes into account that at each point of discretization grid a relationship can be written between the
unknowns, Qin+1 and hin+1 , as well as between , Qin++11 , hin +1, in the form:
− D1i
Ii = (7.12b)
A1i Fi + B1i
E1i − A1i Gi
Ji = (7.12c)
A1i Fj + B1i
D2i ( A1i Fi + B1i ) − D1i ( A2i Fi + B2i ) − I ( A2i Fi + B2i ) − D2i
Fi +1 = = i (7.12d)
C1 j ( A2 j Fj + B2 j ) − C1 j ( A1 j Fj + B1 j ) Hi ( A2i Fi + B2i ) + C 2i
E 2i − A2i Fi J i − A2i Gi − B2i J i
Gi +1 = (7.12e)
Hi ( A2i Fi + B2i ) + C 2i
The step by step procedure to solve the system of equations for time level (n + 1) using the double
sweep algorithm is illustrated in Figure 7.3 and follows the steps:
(1) Initial data in terms of water level and discharge are specified for all grid points from point 1 to
point M of discretization grid, at time level n.
(2) In order to start the computation of Q and h at time level (n + 1) the assumption that all values
of water level and discharge at time level (n + 1) are the same as the values of water level and
discharge at time level n is made.
(3) Computation of all A1i,B1i,C1i,D1i,E1i, A2i,B2i,C2i,D2i,E2i coefficients at level (n + 1) is done
using formulas (7.8a–e). Coefficients are computed based on available data at time level n and
(n + 1).
(4) Boundary data at the upstream end is provided in terms of discharge or water level in grid
discretization point 1. Coefficient bc(0) (see equation (7.11a)) is set to the appropriate choice.
(5) Values of Q and h at time level (n + 1), at the left boundary (upstream) are used to compute
coefficients F and G in point 1 of the discretization grid (i.e., F1 and G1).
(6) Forward sweep: Using recurrence relations (7.12d–e), values of coefficients Fi and Gi are
computed by sweeping across the grid (from point 1 to point M). Coefficients Hi, Ii, and Ji are
calculated using relations (7.12a–c). All values are computed at discretization points of the grid,
as opposed to coefficients A,B,C,D,E, which are computed in grid cells (see Figure 7.3).
(7) Based on downstream boundary condition, which may be either discharge or water level the other
unknown (water level or discharge, respectively) is computed using relations (7.11a).
(8) Backward sweep: Using previously computed coefficients Fi, Gi, Hi, Ii and Ji, discharge and water
depth at time level (n + 1) are calculated by sweeping back across the grid (from point M to point
1) calculating discharge and water depth at time level (n + 1) using relations (7.12a–b). Discharge
and water depth are determined at time level (n + 1) for all points.
(9) Computed values for water level and discharge, obtained in step 8, are compared with the values
from previous iteration. If they are not in accordance with a comparison criterion step 10 is applied.
(10) Iterate: Computation is repeated starting at step 3, using the values obtained in step 8 to re-compute
all the coefficients in a forward sweep.
(11) Iterations are repeated until a certain condition is fulfilled (difference between two computed
values, maximum number of iterations, etc.).
Compute h,Q
t
n+1 n+1
Compute A,B, C, D, E, F, G, H, I, J
Grid
... ... cell i
i
n n
i i+1
1 i-1 i i+1 M
x
t
, - unknown values at
time level (n+1)
- known value at
n+1 Q h Q h Q h
time level n
Q h Q h Q h - known value at
n time level (n+1)
...
Figure 7.4 Computational domain for the Saint-Venant equations for Abbott-Ionescu scheme solution.
Figure 7.4. shows the one dimensional (x, t) computational domain for which the method is applied
to solve the Saint-Venant system of equations. The Abbot-Ionescu scheme has been developed to solve
subcritical river flow, hence one boundary condition has to be defined upstream and one downstream. For
showing the principle of the method the boundary condition upstream has been selected to be inflow (the
most common condition) and the downstream one has been selected to be water depth, which means that
the time series of inflow Q(x = 0, t) and h(M ⋅ Δx, t) are known before the computation of the solution,
in the entire domain, starts to be determined. The number of discretization nodes along the x axis is M
starting with 1 as the first point. An odd number of points are required for the discretization.
The staggered grid definition and the boundary conditions imposes that at all time levels, in all
even points of the discretization grid (1 = 0, 2, 4. . . , M – l) a Q value is computed; and in all odd ones
(i = 1, 3, 5, . . . , M), a h value is computed.
In order to demonstrate the method it is considered that all values of discharge and water depth, at time
level n, Qn and hn, respectively, are known; and they are the basis for computing the values at time level
(n + 1) where Qn+1 and hn+1 are not yet known.
The Abbot-Ionescu formulas, as described in Chapter 4, equations (4.61a–c), applied to continuity
equation (7.1), by considering a weighting factor θ = 0.5, yields:
h n +1 − hin ( bi + bi )
1 n n +1
∂h n+ h n +1 − hin
b⋅ ≈ bi 2 ⋅ i = ⋅ i (7.13b)
∂t ∆t 2 ∆t
1 q n + qin +1 q n + qin++11
q= ⋅ i ⋅ ∆x + i +1 ⋅ ∆x (7.13c)
2 ⋅ ∆x 2 2
Inserting equations (7.14a–c), in (7.1) and grouping all unknown terms, Qn+1 and hn+1, at time level
(n + 1) on the left hand side of the equation, it yields:
∆t
A1i = − (7.15a)
4 ⋅ ∆x
1
B1i = ⋅ ( Bin + Bin +1 ) (7.15b)
2
C1i = − A1i (7.15c)
1
D1i = B1i ⋅ hin + A1i ⋅ (Qin+1 − Qin−1 ) + ⋅ ( qin + qin +1 + qin+1 + qin++11 ) (7.15d)
4
Equation (7.14) is linear in of Qn+1 and hn+1 and is valid for i = 1, 3, 5,…, M – 2. The equation is space-
centred around a computational point where h is the unknown value. Because the weighting factor is 0.5
the equation is also centered in time, between the time levels n and (n + 1).
Applying the Abbot-Ionescu formula of discretization for the derivatives of momentum equation,
yields:
n +1
∂h 1 Qi +1 ⋅ Qin+1 Qin−+11 ⋅ Qin−1
≈ ⋅ − (7.16b)
∂x 2 ⋅ ∆x n+
1
n+
1
Ai +1 2
Ai −12
1
∂h n+ 1 h n +1 − hin−+11 hin+1 − nin−1
g⋅ A⋅ ≈ g ⋅ A1 2 ⋅ ⋅ i +1 + (7.16c)
∂x 2 2 ⋅ ∆x 2 ⋅ ∆x
1
n+
g ⋅ A ⋅ S0 ≈ g ⋅ A1 2
⋅ S0 (7.16d)
Q⋅ Q Q⋅ Q n+
1
Q n +1 ⋅ Qin
g⋅ A⋅ 4
= g⋅ A⋅ 2
≈ g ⋅ A1
2
⋅ 1 1 (7.16e)
K
( K 2 )i 2
n+
M 2 ⋅ R 3 ⋅ A2
where K = SM ⋅ R2/3 is the conveyance of the cross-section and SM is the Strickler coefficient.
Equations (7.16a–e) are linear, because the term in Q, which was at power two is expressed as a product
between a known value at time level n and an unknown value at time level (n + 1).
Similarly, using relations (7.16), for momentum equation, yields:
1
n+ ∆t (7.18a)
A2i = − g ⋅ Ai 2
⋅
4 ⋅ ∆x
n+
1
Qin
B2i = 1.0 + Ai 2
⋅ 1
⋅ ∆t (7.18b)
( K )i
n+
2 2
C 2i = − A2i (7.18c)
n +1
∆t Qi +1 ⋅ Qin+1 Qin−+11 ⋅ Qin−1
D 2i = Q − n
⋅ − (7.18d)
2 ⋅ ∆x
i
n+
1
n+
1
Ai +1 2
Ai −12
Equations (7.14) and (7.17) form together a linear system of equations of the form:
The above system of equations can be solved using the classical approach of matrix algebra from
calculus or the most used method, the Double Sweep Algorithm, as it was demonstrated previously
for Preissmann scheme which uses the physical properties between Q and h to simplify the way the
computation is done. As presented in the previous section yhe method of solution is based on continuous
replacement from one equation to the next. In equation 1 from the linear system (7.14) the term Q 2
can be transferred in the right hand side in order to obtain an expression for h1 as a function of Q 2 and
other known terms. Further the expression of h1 is replaced in the second equation and then into the
following and so on. Eventually the last equation of the linear system contains one unknown value, the
QN x − i . The value of the unknown is calculated and a backward insertion trough the equations can be
started in order to determine all the unknowns. Computation is carried on several times, until a stop
criterion is fulfilled. Moreover it needs to be noted that the coefficients are expressed using values of
Q and h in discretization points where these are not computed, because of the staggered nature of the
grid. This issue is overcome by using interpolated values for flow in grid-points where a water depth
is computed and vice versa by using interpolated water depth in Q grid-points. The interpolation can
be linear or parabolic, and can be calculated as an intermediate value or as a final step in the iteration
procedure.
As shown in Chapter 6 the solution accuracy is influenced by the choice of Δx and Δt. Given nowadays
computer power the choice of Δx (implicitly of number of discretization points M) is not a problem
anymore. Based on several application results as well as theoretical analysis conducted by Wright and
Crossato (2013) concluded that the Abbott-Ionescu-Scheme gives numerical stable results without
numerical diffusion. Chintu (1986) mention that the Abbott-Ionescu scheme works properly with Courant
number values close to 10 due to the implicit nature of the scheme. Compared with an explicit numerical
scheme, where the values of Q and A in a point P of the computational domain depends on the values of
3 points from the previous time level, within an implicit scheme as is the Abbott-Ionescu scheme these
values depend on 20 points, located to the left and the right of the P point, in the previous time level (see
Figure 7.5). The Courant number can be considered as a measure of the extent of the flow regime from
time level n to time level (n + 1). The requirement of Cr < 10 for the Abbott-Ionescu scheme is equivalent
∆h
⋅u± g ⋅ h < 10 (7.20)
∆x
P
n+1
2∆x
20∆x
Figure 7.5 Domain of dependence for a point P in the computational domain, when Abbott-Ionescu
scheme is used for solution of Saint-Venant equations.
The values of Δx and Δt as defined by equations (7.19–7.20) have to be correlated with the variations
in initial and/or boundary conditions and of the tributaries of a modelled river. The choice of Δx and Δt
should make a good description of all variations in times series as well as longitudinal profiles.
7.2.4 River networks
It is important to mention that in case lateral inflow is considered in Saint-Venant equations, then relation
(7.14c) takes into account the possible variations in space and time by considering the values of q from
space point i to space point (i + 1) and values at time levels n and (n + 1). Notice that lateral inflow variation
in time and space has to be known when applying Preissmann or Abbott-Ionescu schemes. If the model has
a network of river branches that are joining together, than a tributary is a lateral flow to the main branch.
Figure 7.6 gives the possible variation of q in space at each time step. The flow values coming from a
tributary at time level n (tn = n ⋅ Δt) are added to the lateral inflow term. In case that Abbot-Ionescu scheme
is used for the solution of the Saint-Venant equations due to the staggered nature of the discretization, grid
tributaries have to be associated with odd i-points and they should be dispersed over a distance 2 ⋅ Δx. This
approach requires careful selection of Δx.
(a)
Q (t)
n
Q L2
... n n+1 t
...
∆t ∆t ∆t ∆t ∆t ∆t ∆t
Q L2
J1
J2
Q L1
V/S D/S
Q(t)
n
Q L1
...
n n+1 t
∆t ∆t ... ∆t ∆t ∆t ∆t ∆t
(b)
n n
Q L1 Q L2
2∆x 2∆x
qlat
J1 J2
∆x ∆x ∆x ∆x ∆x ∆x ∆x ∆x
Figure 7.6 (a) Lateral inflow variation for network river systems and (b) tributaries handling in the Abbot-
Ionescu solution approach.
In case a river is formed from a network of channels the same procedure of solution is applied as for
a single river reach, provided that boundary conditions are specified at all ends of the pendant branches
that is in points 1, 71 and 101, as per Figure 7.1. A system of algebraic equations that need to be solved is
obtained after adding additional equations for the channel junctions (see Figure 7.6):
Qi = Q j + Qk
hi = h j (7.21)
h = h
i k
First equation in conditions (7.22) represents continuity equation, whereas the later two are simplified
forms of energy equation written at the junction, under the assumption that local losses are neglected.
Forsius and Huttula (1982) show that if flow velocities are too high, such that velocity head becomes
significant, the equal water level condition in (7.22) should be replaced with an equal energy level
compatibility equation.
The corresponding matrix of the solution system for the Saint-Venant equations is represented in Figure
7.8, for the river network of Figure 7.7.
1
3∆x1
Ch
ann 4∆x3
el A j
3
i
k
2∆x2 Channel C
B
nel
an
Ch
2
The double sweep method can also be applied to network river systems as long as certain computational
order is respected (Wu, 2008). For the channel network of Figure 7.7, the computational order is as
follows; the forward sweep computes the recurrence coefficients for channel A starting from 1, where
boundary condition is known, and is carried on down to junction point j. A similar sweep is carried on
channel B from first to last point. At the junction the three cross sections should be located very close
to each other and according to relation (7.21) it is assumed that the water levels at the cross sections
are equal and discharge at the downstream cross section is equal to the sum of discharges in upstream
cross sections of channel A and channel B, hence initial values for coefficients F and G for channel 3
are computed. The forward sweep is further carried out from point i to point 3 of channel C and the
recurrence coefficients are computed. Backward sweep start from the most downstream point of channel
C (point 3), where boundary condition are known. Values for discharge and water level are computed
first along channel C back to the junction. From the junction the backward sweep algorithm is carried on
further along channel A and B.
Figure 7.8 Structure of a matrix for the river network system represented in Figure 7.7.
7.3 Modelling Floods
Flood are phenomena characterised by high discharges and/or water levels, which may cause inundation
of floodplains (the land adjacent to rivers) or to terrain close to water bodies. In general flooding happen
when rivers are unable to route the amount of water coming to the river due to runoff. Because a river has
no conveyance capacity leads to overtopping of river banks. Floods causes disruption of activities and loss
of lives, hence they are given a lot of attention in water engineering practice. Flood disasters account for
about a third of all natural disasters (by number and economic losses).
Flood events may be caused by intense or long-lasting rainfall, snowmelt, dam or dyke break, ice jams,
high tides, storm surges or by operation of reservoirs.
One dimensional models for Saint-Venant applications have been widely applied in simulating flood
routing and unsteady flow in river networks (Hicks et al., 2005; Gichamo et al., 2012; Moya Gomez et al.,
2013). Though there are advances in the two (2D) and three dimensional (3D) hydrodynamic modeling of
flow in rivers, models based on one dimensional Saint-Venant equations still are the most popular choice
for solving large-scale river engineering problems. The choice is due to their reduced data requirements
compared to those for 2D and 3D models, as well as reduced computational cost.
Special insights in flood propagation in river channels are gained by using Price’s (1985) analysis of
the Saint-Venant equations (7.1), which can be rearranged in the form:
∂Q Q 1 dK 1 db ∂Q K 2 ∂2Q
+ − − q − =0 (7.23)
∂t b K dh 2b dh ∂x 2bQ ∂x 2
Equation (7.23) is obtained by neglecting the inertial terms (the local acceleration and convection
of momentum), and has the form of an advection-diffusion equation with advection and diffusion
terms:
Q 1 dK 1 db
c(Q, h) = − (7.24a)
b k dK 2b dh
and
K2
D(Q, h) = (7.24b)
2bQ
Coefficients given by relations (7.24) show that when a flow disturbance occurs on a river channel,
a process of translation/advection takes place along with a corresponding diffusion. The phenomenon
is known as attenuation of peak flow. The speed of the wave traveling downstream is given by the
advection speed (7.24a). Note that equation (7.23) has Q as the primary dependent variable within the
differentials, however because Q is dependent on h (or A), a continuity equation is required in order to
solve it.
An more general representation of equation (7.23) given by Price (1985) is:
∂Q ∂Q ∂ a ∂Q ∂ Qq
+ c0 + εc0 20 = c0 q − εγ c0 + O(ε 2 ) (7.25)
∂t ∂x ∂t c0 ∂x ∂t 2qAs0
where
h
ε = x (7.26a)
s0
Q2
γ = (7.26b)
gA2 y
Q Q
2
γB
a0 = 1 − c − (7.26c)
2 s0 B gA 0 A
Equation (7.25) is the basic flood routing equation, valid for any Froude number. It is also known
as the Muskingum-Cunge equation. Muskingum is the name of a river in North America and Cunge is
the scientist who first established the relationship between the Muskingum method and the Saint-Venant
equations (Cunge, 1969). Based on equation (7.25) attenuation parameter can be determined for any river
for specific discharge values. An example of a typical such curve is given in Figure 7.9.
Flood attenuation studies (Anderson et al., 2006; Acreman et al., 2003; Castro Gama et al., 2014)
concluded that the peak discharge attenuation is affected by floodplain (width and roughness) as well as
by bed slope. Hence floodplain storage is an important process to take into consideration while predicting
the peak flood attenuation. One-dimensional models should be capable to account for floodplain storage
during flood events, hence, considering a coupled 1D/2D model in flood simulations is important. An
extensive overview of flood inundation models is given by Horrit and Bates (2003).
a(Q )
Bank full Q
t
Boundary S0
condition
upstream
L= 200 km b
Results of routing are shown in Figures 7.11, 7.12, 7.13. Figure 7.11 shows the effect of roughness in
flood routing. Figure 7.12 shows the effect of the slope on river floods. Steep slope route quicker the flood
peak, however the attenuation is smaller. Figure 7.13 shows the effect of cross-section width on river
routing. The wider the river cross-section the higher the attenuation of the flood peak, however longer the
time for the flood to be routed out of the river system.
400
Flow [m3/s]
300 4
3.5
100
0 20 40 60 80 100 120
Time [hr]
3
Loop IN
Water Depth [m]
4.5
Loop OUT
MAX. QIN
4
MAX. QOUT
2.5
3.5 min. QIN
min. Q
OUT
3
MAX. hIN
2.5 2 MAX. hOUT
min. hIN
2 min. hOUT
0 20 40 60 80 100 120 100 150 200 250 300 350 400 450 500
400
300 4.5
Water Depth [m]
200
4
100
0 20 40 60 80 100 120
5 Loop IN
Loop OUT
3 MAX. QIN
4.5
MAX. QOUT
4
min. QIN
3.5 2.5 min. Q
OUT
MAX. hIN
3
MAX. hOUT
2.5 min. hIN
2
min. hOUT
2
0 20 40 60 80 100 120 100 150 200 250 300 350 400 450 500
Figure 7.11 Effect of roughness on routing a flood wave in a river; (a) n = 0.025; (b) n = 0.030.
4
400
Flow [m3/s]
300
3.5
200
Loop IN
4 2.5
Loop OUT
MAX. QIN
Water Depth [m]
3.5 MAX. Q
OUT
min. QIN
3
2 min. Q
OUT
2.5 MAX. hIN
MAX. hOUT
2 min. hIN
1.5 min. hOUT
1.5
0 20 40 60 80 100 120 100 150 200 250 300 350 400 450 500
400
Flow [m3/s]
7
300
200
6.5
Water Depth [m]
100
0 20 40 60 80 100 120
6
Time [hr]
7.5 Loop IN
5.5 Loop OUT
Water Depth [m]
7 MAX. QIN
MAX. QOUT
6.5
min. QIN
6 5
min. Q
OUT
5.5 MAX. hIN
MAX. hOUT
5
4.5 min. h
IN
4.5 min. h
OUT
0 20 40 60 80 100 120 100 150 200 250 300 350 400 450 500
Figure 7.12 Effect of slope on routing a flood wave in a river; (a) S = 0.0003; (b) S = 0.00001.
8.5
400
Flow [m3/s]
8
300
7.5
100
0 20 40 60 80 100 120 6.5
Time [hr]
6
Loop IN
5.5
Loop OUT
8 MAX. QIN
Water Depth [m]
5 MAX. QOUT
7 min. QIN
4.5 min. Q
6 OUT
MAX. hIN
5 4 MAX. hOUT
min. hIN
4 3.5 min. h
OUT
0 20 40 60 80 100 120 100 150 200 250 300 350 400 450 500
400
Flow [m3/s]
5
300
200
Water Depth [m]
4.5
100
0 20 40 60 80 100 120 4
Time [hr]
3.5 Loop IN
5.5
Water Depth [m]
Loop OUT
MAX. QIN
5
MAX. QOUT
4.5 3 min. QIN
4 min. Q
OUT
MAX. hIN
3.5
2.5 MAX. hOUT
3 min. hIN
2.5 min. h
OUT
2 2
0 20 40 60 80 100 120 100 150 200 250 300 350 400 450 500
Figure 7.13 Effect of cross-section width on routing a flood wave in a river; (a) 50 m width; (b) 100 m width.
8.1 Introduction
Fresh water is very important for development because it is a source of energy, a mean for transportation
and a habitat for aquatic life. Availability of good quality water (fresh water) is very important for economic
activities and growth, however as population and economies grow, so does the amount of pollutants that
are discarded in water bodies (Orlob, 1983). When levels for water quality are not met, treatment must be
carried out, which brings extra costs to water users.
The issue of water quality is not something new, as Heathcote (2009) notes Romans issued the following
Roman decree:
‘Ne quis aquam oletato dolo malo ubi publice saliet si quis oletarit sestertiorum X mila multa esto.’
which reads
‘It is forbidden to pollute the public water supply: any deliberate offender shall be punished by a fine of 10,000
sesterces’. Year 1989 was the 2000th anniversary of the issuing of this decree.
Countries around the world defined standards for water quality and make plans for reaching good
ecological status of their water resources. A good example of such efforts is the European Water Framework
Directive, which is a major policy in the area of water resources management in European Union (EU). All
countries of EU follows the policy, which sets clear requirements regarding attitudes and approaches to
water resources at both national and regional levels. The directive’s main goal is sustainable use of water
resources with a dominant ‘environmental objective’ of preventing the deterioration of the status of all
EU waters.
In this context of continuous need to maintain and improve water quality scientists and managers
are continuously trying to come with solutions for providing understanding of freshwater ecological
systems and predictions of the water quality responses to human interventions, as well as evolution of
these responses in time. Hence water quality models are important tools assisting in the analysis regarding
pollution of water and ultimately in the identification of the state of the environment. Such tools need to be
able to show the impact of humans activities on the status of a water body (i.e., lake, river, etc.).
Water quality modelling aims to simulate behaviour of variables related to quality of a water body.
Variables include characteristics of the water body, such as temperature, solar radiation, wind speed, as
well as pollutants existent in the modelled water body. Models of water quality describe physical processes
in terms of hydrodynamics; and are complemented by a description of chemical and biological processes
that control the transport and transformation of the variables. Pollution elements are defined as point-
source and nonpoint source loads. Developed water quality models range from very general, applicable to
all kind of water bodies; to very specific ones, that are applicable to a particular problem type. Hence each
model may have its own characteristics and requirement for data input. Water quality models are known
not to be able to accurately predict what happens, however they are still valuable to understand processes
and estimate relative changes due to management practices and policies. Hence even the simpler water
quality model is a useful tool to be used.
First water quality model, the so-called S-P model, was defined by Streeter and Phelps (1925) for Ohio
river, in United States. The S-P model is steady state one-dimensional determining the oxygen balance and
the decay of bio-chemical oxygen demand (BOD). Since 1925 models have evolved from steady state models
to dynamic ones and from point source pollution to non-point pollution sources (Jung et al., 2011), as it is the
example of EFDC model developed by Virginia Institute of Marine Science, which is suitable to be used for
water quality simulation in rivers, lakes, reservoirs, estuaries, and wetlands, for one-, two-, or three-dimensions
(EPA, 1999). Table 8.1 presents the main available models and their characteristics, as they evolved in time.
An important aspect of water quality modelling is the availability of monitoring data, which decide
the appropriate model to be used for the complexity of the situation (Louks & Beek, 2005). Depending on
the availability of monitored water quality data it is advisable to begin with simple models and gradually
extend to additional complexity as data becomes available due to data collection campaigns. Prediction
of hydrodynamics of the water body has long been the recognised as an important component of any
water quality study (Martin & McCutcheon, 1999). It is well known that river have good collection data
for hydrodynamic parameters, however most water quality monitoring programmes for water bodies with
stagnant waters, detailed hydrodynamic measurement is hardly included neither is prediction of water
motion, the emphasis is mainly on general physical-chemical parameters due to their ease of measurement.
In case of lakes water quality parameters collected during spring and fall overturn represent the best
and most uniform water quality conditions and are most valuable for calibrating and validating models.
However making model predictions based on one or two samples is not enough. More extensive sampling
is suggested because it provides additional information.
Present chapter presents the main equations that are used to define water quality models. First the main
processes described by a water quality model are presented, followed by specific particularities of processes
for rivers and lakes. Models used for lakes and reservoirs are substantially different from the ones used for
rivers. Usually water movements are very slow in lakes and reservoirs, hence the hydrodynamics is driven
by wind; heat exchange due to solar radiation; and inflows and outflows. Phenomena that are normally
absent or negligible in river flow are very important in non-flowing waters (‘standing’ waters) such as
lakes and wetlands. For example in lakes the phenomena of temperature stratification appears, which can
influence the vertical turbulent mixing; or different density stratification of water causes advection. These
phenomena are known to create a particular thermo-hydrodynamics state in a lake. In rivers the main
driving force is gravity and bed friction (as resisting force), which generates perceptible velocities and
turbulent mixing. Moreover sediment transport and deposition is different in rivers and lakes, therefore
their effect on water quality is different. Usually in lakes and reservoirs a phenomenon of slow deposition
of fine sediments takes place and the bottom of the lake can release substances, as effect of bacterial
decompositions and chemical processes that are taking place. In rivers such processes are negligible as
compared with the advective transport of substances in the water.
• changes due to physical or (bio)chemical processes (P) occurring within the computational cell; and
• changes attributed to sources/discharges to or from the computational cell (S).
Mass balance over a time step interval Δt, for computational cell i at time level t + Δt can be expressed
as:
t + ∆t t + ∆t t + ∆t
M (t + ∆t ) = M (t ) + ∫ MTR dt + ∫ M P dt + ∫ M dt S (8.1)
t t t
In equation (8.1) M is the mass in computational cell i, MF is the mass change in computational cell i,
due to component F, which is transport (TR); (bio)chemical or biological processes (P); and sources (S).
Equation (8.1) of the mass balance for computational cell i at time level (n + 1) can be further expressed
as (Louks & van Beek, 1983):
due to component F. ∆t F ( )
computational cell i at time level (n + 1). The term ∆Mi represent the changes in computational cell i,
Transport due to dispersion is important in lakes where water column is stratified, and it is less visible in
rivers. Dispersion is not the same as diffusion. Figure 8.1 shows schematically possible transport elements
in lakes and rivers.
(a)
water air exchan
ges
transport/
m ixing(ho
ow rizontal
& vertical
)
sedimentation
sediment resusp
sediment ension ow
(b)
water air interface
surface water
ow horizontal transport/mixing
ow
diffusion
turnover
advection
ground water t
ow en
m
di
se
seepage
sediment water interface
sedimentation
Physical processes include settling of sediments and substances, as well as phenomena such as aeration.
Biochemical processes transform one substance into another through adsorption, decay, or biological
processes. Sources add or subtract mass from the computational cell. Additional pollutant mass can come
due to sewer wasteloads and subtraction is due to intakes.
The three change processes described above (TR, P and S) are governed by the extended transport
equations (Somlyódy & van Straten, 1986), which is written in three dimensions as:
∂C ∂ ∂C ∂
∂t
= D ⋅ − (u C ) + ∂∂x Dy ⋅ ∂∂Cx − ∂∂x (uy C ) + ∂∂x Dz ⋅ ∂∂Cx − ∂∂x (uz C )
∂ x x ∂ x ∂ x x
+ rc(C, param) (8.3)
where C(c1, c2,…, cn) is the n dimensional mass concentration vector for n constituents of analysed water
quality; u(ux, uy, uz) is the velocity vector; D(Dx, Dy, Dz) is a vector containing diffusion coefficients for
the x, y and z, directions respectively; and rc(C, param) is the n dimensional vector of rates of change of
constituents due to P and S processes as a function of concentrations of the n constituents and a number of
parameters, param that depend on the model choice. Model calibration is usually performed to determine
the values of param.
In case sediment is a component of the water quality model a mass conservation equation for the
sediment is added to the model along with corresponding interface terms sediment-water and water-air.
Equation (8.3) is a system of PDEs that are solved numerically (together with the sediment equation in
case sediment is considered). Another approach to solve the formed system of PDEs is to use a number of
m interconnected conceptual elements (so-called tanks) that lead to a system of n x m ODEs.
Models that are defined in steady state are the ones for which there are no changes in the concentrations
with time, that is, the term ∂C/∂ t in equation (8.3) equals zero.
Temperature affects water quality processes, hence it is important to incorporate temperature and its
modelling when it varies over the simulation period, or when the inflow to the water body has a heat that
is different from the one of the water body that is modeled. Temperature models are based on heat balance
of the modeled water body, by taking into account solar and atmospheric radiation and evaporation. Such
models are not easy to set-up, because they require a lot of measured data that is not always available.
Oxygen concentration of river waters is the most important factors affecting aquatic life. Hence water
quality standards are related to the concentration of dissolved oxygen (DO) and parameters affecting
it. Discharging pollutants in receiving river waters has as effect a reduction in the oxygen content. A
related element is the Biochemical Oxygen Demand (BOD), which shows the oxygen consumption due to
degradation of organic material. BOD5 is the amount of BOD consumed over 5 days.
Oxygen consumption is described in form of a first order ordinary differential equation:
dCBOD
= −( K1 + K1,S ) ⋅ CBOD + K (Cos − Co ) − Db (8.4)
dt
where CBOD is the concentration of BOD (M/L3); K1 the decay constant (sec−1); K1S the sedimentation/
adsorption constant (sec−1); Cos the oxygen saturation constant (M/L3); Co the oxygen concentration in the
river (M/L3); K the re-aeration kinetic constant (sec−1) and Db the rate of oxygen removal caused by benthic
processes. Consequently oxygen concentration in a river is determined using the equation:
dCO
= − K1 ⋅ CBOD (8.5)
dt
An important phenomena in modelling water quality in rivers is re-aeration that occurs at the air-water
interface:
dR0
= K (Cos − Co ) (8.6)
dt
Removal of organic material due to sedimentation process (Dobbins, 1964) is represented in equation
(8.4) by the sedimentation/adsorption constant. The actual amount of BOD sedimented/adsorbed at the
bottom of a river was described by Harremoes in 1982, which is an important component of river water
quality analysis when storm sewer overflows are involved because of their high content in suspended
organic content ready to be settled.
Oxygen concentrations are important for the aquatic life, however other factors are also important,
such as is the case of ammonia in non-ionized form (NH3), which is toxic to fish. The pH value in a
river determines the dissociation of ammonia into ionized and non-ionized, the higher the PH the higher
fraction of ammonia is non-ionized. At pH values above 9 almost all ammonia is in a non-ionized form.
Values of pH should not be too high, neither too low, because high pH shows increasing acidification,
while low pH is toxic to the aquatic life, because alluminium’s solubility increases.
Water quality in lakes and reservoirs is assessed based on several characteristics of the water body.
These were defined by Louks and van Beek (1983) as:
• clarity or transparency of the water, that is, greater water clarity indicates better water quality;
• concentration of nutrients, that is, lower concentrations show better water quality;
• quantity of algae, that is, lower levels of algae indicate better water quality;
• oxygen concentration, that is, the higher the concentration of oxygen the better for fish;
• concentration of dissolved minerals, that is, low values give better water quality;
• pH value (a neutral pH of 7 is advised).
Supply of water to a lake is important for determining its water quality. There are two main sources of
water supply for lakes and reservoirs; precipitation and river inflow. If precipitation is the major source
of water, the lake is acidic and low in nutrients. If river inflows are the major source for water supply, lake
water quality is more variable, and has high nutrients level. For the later case water quality depends on the
volume of inflow and runoff from the surrounding slopes. Human activities around a lake have important
effect on its water quality.
Lakes and reservoirs have three fundamental characteristics that make them quite different in physical
behaviour as compared with rivers. These characteristics include: mixing, long retention time, and response
dynamics.
Reservoirs or lakes receive inputs from diverse sources; precipitation, river inflow, heat and
wind-induced energies that cause waves, thermal energies, contaminants, nutrients and organic substances;
which are mixed within a lake so that both the resources and problems are dissipated throughout its
volume.
Lakes and reservoirs are generally slow to respond to changes due to their long retention times. They
store floods, pollutants, and heat without experiencing immediate changes. The implications of the
long retention times is that lakes are relatively stable; allow for suspended materials to settle to the
bottom, acting as high efficiency sinks for many materials; and allow for complex, and sometimes unique
ecosystems to evolve. The drawback of long retention time is that, once a lake or reservoir is degraded, it
takes a long time for it to recover or be restored.
The response dynamics of lakes to a nutrient concentration is different from one of a river. Lakes and
reservoirs respond to changes in a highly non-linear way, as depicted in Figure 8.2. Degradation in response
to increased nutrient concentrations (from A to B), may not be visible until nutrient concentrations are
high and the water body abruptly switches its status. In Figure 8.2 the plankton concentrations are high,
and the lake goes from status B to C. The lake cannot simply go back from C to B. There are likely to be
irreversible changes to the ecosystem, so recovery follows a path from C down to A through D.
Plankton concentration
Time
C
D
B
A Time
Nutrient concentration
Water quality of a lake is affected by the extent to which the water mixes. The depth, size and shape
of a lake are the most important factors influencing mixing, along with other factors such as climate,
lakeshore topography and inflow from rivers. Density of water has highest value at 4°C. Variations
in density caused by difference in temperatures prevent warm and cold water from mixing. Uniform
water density facilitates complete mix of lake waters, recharging the bottom water with oxygen and
bringing nutrients to the surface. Wind and waves circulates warm water only 6–8 m deep. If a lake
is shallow the water may stay completely mixed for the entire summer season. During summer season
deep lakes experience stratification into three zones: epilimnion (warm surface layer), thermocline or
metalimnion (transition zone between warm and cold water), and hypolimnion (cold bottom water).
Stratification traps nutrients from bottom sediments in the hypolimnion. In the fall season, the lake
surface cools and eventually water temperature becomes uniform from top to bottom, hence mixing
appears (fall overturn). During fall season often algae bloom appears to the surface of a lake because
of the mixing.
DANUBE DELTA
Chilia Branch
UCRAINE
Danube
ROMANIA
Sulina Branch
Black sea
SONTEA-FORTUNA AREA
Sontea Canal
Fortuna Lake
Mila 36 Canal
Tulcea Branch
Figure 8.4 Water levels in Sontea Fortuna wetland for dry hydrological conditions.
Model is setup for three hydrological conditions; wet, normal and dry year, which correspond to high,
medium, and low water level respectively, based on measured data kindly provided through the EU FP7
research project EnviroGRIDS (Popescu et al., 2014). The Sontea–Fortuna area is modelled using Delft3D,
which is a tool developed by Deltares (Deltares, 2010) to simulate hydraulic phenomena in river, estuarine
and coastal areas. The software simulates variations in time and space (2D or 3D) of hydrodynamics,
morphology water quality and sediment transport phenomena. The Sontea–Fortuna grid is a combination
of grid size cells that varies from 90 m × 60 m to 160 m × 90 m. Total number of computational cells is
37039.
Figure 8.4 shows water levels in the area, as results of the model, for dry hydrological conditions.
6 Wet conditions
Dry conditions
5 Adaptation measure
4
Water level (m)
2
Minimum required water
1 level
0
0 5 10 15 20 25 30
Time (days)
Figure 8.5 Water levels at upstream boundary of Sontea-Fortuna wetland for dry hydrological conditions.
Results help in identifying dry areas, where habitat is at risk and water quality conditions deteriorate, for
too low water levels. Treshold for water levels are set by policies of the Romanian Ministry of Environment.
Figures 8.5, 8.6 and 8.7 shows results of water levels predictions in three points of the Sontea-Fortuna
wetland for the three modelling cases; wet condition (October–December, 2010), dry condition (June–
August, 2010) and one adaptation measure for the case of dry condition. The three points are located in the
upstream, middle and downstream of the wetland, respectively.
For the three considered cases it can be seen that water level can be maintained between and above the
levels of 1.5 m (m.b.s.l) to 3.5 m (m.b.s.l), and flooding does not exceed 30 days.
Based on the outcomes of the model adaptation measures can be proposed for improving the ecological
status of the wetland.
6 Wet conditions
Dry conditions
5 Adaptation measure
4
Water level (m)
2
Minimum required water
1 level
0
0 5 10 15 20 25 30
Time (days)
Figure 8.6 Water levels in the middle of Sontea-Fortuna wetland for dry hydrological conditions.
6 Wet conditions
Dry conditions
5 Adaptation measure
4
Water level (m)
2
Minimum required water
1 level
0
0 5 10 15 20 25 30
Time (days)
Figure 8.7 Water levels at downstream boundary of Sontea-Fortuna wetland for dry hydrological conditions.
Jiangsu Province Ya
ng
tze
Wuxi city riv
er
Taihu
lake Shanghai city
Huzhou city ea
n as
Chi
Zhejiang Province st
Ea
Many studies have been carried out regarding the water quality condition in the Taihu Basin. Zhu and
Geng (2004) show that according with Chinese surface water quality standards there are 5.99 billion m3
of water (42% in the total runoff) that are severely polluted and unusable for any user in Lake Taihu.
Wang et al. (2011) estimated the pollutant fluxes of rivers in Zhejiang Province as part of the Taihu Lake
Basin and indicated that the increasing levels of inflow of pollutants in the lake is the main reason for the
deterioration of water quality in the lake. When comparing the mean values to those obtained between 1991
and 2001, the water quality parameters such as TN and TP have had higher values in the recent five years.
Mao et al. (2008) published a three-dimensional eutrophication model of Lake Taihu, which fully couples
the biological processes and hydrodynamics, and takes into account the effects of sediment release and the
external loads from the tributaries. The main outcome of such a model is that two of the Lake Taihu’s bays;
Zhushan Bay and Xu Bay; are susceptible to algal blooms with high chlorophyll-a concentration.
gN/m3 gP/m3
70 2.5 70 0.12
60 60 0.10
2
50 50
0.08
1.5
40 40
y (km)
y (km)
0.06
30 1 30
0.04
20 20
0.5 0.02
10 10
0 0 0 0
0 20 40 60 0 20 40 60
x (km) x (km)
Nitrogen Phosphorus
gC/m3
70 2.5
60
2
50
1.5
40
y (km)
30 1
20
0.5
10
0 0
0 20 40 60
x (km)
Green Algae
Figure 8.9 Spatial distribution of Nitrogen and Phosphorus in Taihu lake, during year 2008.
Here are presented water quality model results using a two-dimensional hydrodynamic model coupled
with a two-dimensional water quality model. Model is set-up to investigate possible effects of wind on
the eutrophication of the lake. A Delft3D model is built to simulate the hydrodynamic state of the lake.
Hydrological, topographical and water quality data to set-up an example model are collected from published
papers of Yue et al. (2013); Hu et al. (1998); Zhu and Geng (2004) and Yiping and Zhougho (2011). Three
different sets of wind conditions (no wind, constant wind and measured wind) are considered as wind
effects on the water level and velocity, in wet and dry seasons. Based on the calibrated hydrodynamic
model a two dimensional water quality model is built and calibrated based on estimated data inputs for
nutrient loads. A one-year hydrodynamic simulation is performed, for the year 2008, in order to show
possibilities for determining the state of water quality in Lake Taihu. The estimated nutrient loads included
total nitrogen (TN) and total phosphorus (TP) concentrations. The estimates are based on the population
of cities around Lake Taihu, and the wastewater treatment plant capacity of the provinces of Jiangsu and
Zhejiang, where the main sources of pollutants come from. Two time periods (spring and autumn) of algae
blooms development for the year 2008 are noticed to form in the lake.
Figures 8.9 and 8.10 shows different modelling results for nitrogen, phosphorus and algae bloom for
Taihu Lake, for the year 2008, for conditions of constant wind conditions.
Figure 8.10 Temporal distribution of Algae bloom in Taihu lake, during year 2008.
The results of the study indicate that the hydrodynamic model with constant wind conditions (southeast,
5 m/s) shows better results than the one where measured wind conditions are used, simply because the
measured wind data is insufficient; and an increase in population in the area would lead to an increase in
the maximum value of algae concentration from 35% to 76%. An improvement of technologies used for the
treatment of the wastewater may bring the maximum value of algae concentration between 17% and 42%.
Abbot M. B., Minns A. W. (1998). Computational Hydraulics, 2nd ed, Alder, Ashgate Publishing, Aldershot,
Hampshire, UK.
Abbott M. B. (1979). Computational Hydraulics. Pitman, London.
Abbott M. B. and Basco D. R. (1989). Computational fluid dynamics. Longman Scientific and Technical, New York.
Acreman M. C., Riddington R. and Booker, D. J. (2003). Hydrological impacts of floodplain restoration: a case study
of the River Cherwell, UK. Hydrological and Earth System Sciences, 7(1), 75–85.
Aldama A. A. (1990). Filtering Techniques for Turbulent Flow Simulation, Springer Lecture Notes in English 56.
Springer, Berlin.
Anderson B. G., Rutherfurd I. D. and Western A. W. (2006). An analysis of the influence of riparian vegetation on the
propagation of flood waves. Environmental Modelling and Software, 21, 1290–1296.
Ascher U. M. and Petzold L. R. (1998). Computer Methods for Ordinary Differential Equations and Differential
Algebraic Equations. SIAM, Philadelphia, PA.
Barendregt A. and Bio A. M. F. (2003). Relevant variables to predict macrophyte communities in running waters.
Ecological Modelling, 160, 205–217.
Bathurst S. C. (1986). Sensivity analysis of the Systeme Hydrologique Europeen for an upland catchment. Journal of
Hydrology, 87, 103–123.
Bellinger G. (2004). An Introduction to Modeling & Simulation. http://www.systems-thinking.org/modsim/modsim.
htm (accessed 31 December 2013).
Bergstrom S. (1991). Principles and confidence in hydrological modelling. Nordic Hydrology, 22, 123–136.
Boqiang Q. P. X., Qinglong W., Liancong L. and Yunlin Z. (2007). Environmental issues of Lake Taihu, China.
Hydrobiologia, 581, 3–14.
Boubez T. I., Funnell W. R. J., Lowther D. A., Pinchuk A. R. and Silvester P. P. (1986). Mesh generation for
computational analysis. Computer-Aided Engineering Journal, 3(5), 196–201.
Boyd J. P. (1989). Chebyshev and Fourier Spectral Methods. Lecture Notes in Engineering. Springer-Verlag,
New York.
Branson F. A., Gifford G. F., Renard K. G. and Hadley R. F. (1981). Rangeland Hydrology. Kendall/Hunt, Dubuque,
USA, p. 339.
Bredenhoeft J. D. and Konikow L. F. (1983). Ground-water models: Validate or invalidate. Ground Water, 31(2), 178–179.
Brostow W. and Dussault J. P. (1978). Construction of Voronoi polyhedral. Journal of Computational Physics,
29, 81–92.
Brunner G. W. (2010). HEC-RAS, River Analysis System Hydraulic Reference Manual. U.S. Army Corps of Engineers
Hydrologic Engineering Center.
Buell W. R. and Bush B. A. (1973). Mesh generation – a survey. Trans. ASME, Journal of Engineering Industry Series
B, 95(1), 332–338.
Burnett A. and Watson I. (1995). Hydrology, an Environmental Approach. Lewis Publishers, Florida, USA,
pp. 585–602.
Butcher J. C. (1987). The Numerical Analysis of Ordinary Differential Equations. John Wiley and Sons Inc., NY.
Castro-Gama M. E., Popescu I., Li S., Mynett A. and van Dam A. (2014). Flood inference simulation using surrogate
modelling for the Yellow River multiple reservoir system. Environmental Modelling and Software, 55, 250–265.
Casulli V. (1990). Semi-implicit finite-difference methods for the two-dimensional shallow water equations. Journal
of Computer and Physics, 86, 56–74.
Chapra S. C. and Canale R. P. (2006). Numerical Methods for Engineers, McGraw-Hill, New York.
Chau K. W. (1990). Application of the Preissmann scheme on flood propagation in river systems in difficult terrain.
In: Hydrology in Mountainous Regions. I – Hydrological Measurements; the Water Cycle, H. Lang and A. Musy
(eds), IAHS Press, Wallingford, pp. 535–543. IAHS Publication No. 193. ISBN: 0-947571-57-4.
Chaudhry M. H. (1987). Applied Hydraulic Transients. Van Nostrand Reinhold Company, New York.
Chow W. T., Maidment D. R. and Mays L. W. (1988). Applied Hydrology. McGraw-Hill, New York, p. 572.
Chintu L. (1986). Numerical modeling of unsteady open-channel flow. Advances in Hydroscience, 14, 161–333.
Clemmens A. J., Holly F. M. and Schuurmans W. (1993). Description and evaluation of program Duflow. Journal of
Irrigation and Drainage Engineering, ASCE, 119(4), 724–734.
Cunge J. A. (1969). On the subject of a flood propagation method. Journal of Hydraulic Research, 7, 205–230.
Cunge J. A., Holly F. M. and Verwey A. (1986). Practical Aspects of Computational River Hydraulics. Pitman
Publishing, London, p. 250.
Cox B. A. (2003). A review of currently available in-stream water-quality models and their applicability for simulating
dissolved oxygen in lowland rivers. Science of the Total Environment, 314–316(1), 335–377.
Dahlquist G. and Bjorck A. (2007). Numerical Methods in Scientific Computing. SIAM, Philadelphia, USA.
de Saint-Venant B. A. (1871). Theorie du mouvement non-permanent des eaux avec application aux crues des rivieres
et a l’introduction des marees dans leur lit (Theory of unsteady water flow with application to river floods and
to propagation of tides in river channels). Comptes rendus, Paris Academy of Science, 73, 148–154, 237–240.
Deltares (2010). DELFT-WAQ User Manual, Delatres, p. 250.
DHI (2012). MIKE 11: A modelling system for rivers and channels, reference manual. DHI Water & Environment, p. 524.
Djordjevic S., Prodanovic D. and Walters G. A. (2004). Simulation of transcritical flow in pipe/channel networks.
Journal of Hydraulic Engineering, 130(12), 1167–1178.
Dooge J. C. I. (1986). Looking for hydrologic laws. Water Resources Research, 22, 46–58.
Durran D. (1998). Numerical Methods for Wave Equations in Geophysical Fluid Dynamics. Springer, New York, USA.
Durran D. R. (1999). Numerical Methods for Wave Equations in Geophysical Fluid Dynamics. Springer, New York.
EU WFD, Water Framework Directive (2000). Directive 2000/60/EC of the European Parliament and of the Council,
Establishing a Framework for Community Action in the Field of Water Policy. The European Parliament,
Brussels, Belgium.
Eykhoff P. (1974). System Identification: Parameter and State Estimation. John Wiley & Sons, London.
Fletcher C. A. J. (1991). Computational Techniques for fluid Dynamics, 1: Fundamental and General Techniques.
Springer, Berlin.
Forsius J. and Huttula T. (1982). Application of a mathematical model to a branched watercourse. Geophysica, 19(1), 55–64.
Garabedian P. R. (1966). Partial Differential Equations. John Willey and Sons, NY, p. 672.
Gichamo T. Z., Popescu I., Jonoski A. and Solomatine D. (2012). River cross-section extraction from the ASTER
global DEM for flood modeling. Environmental Modelling and Software, 31, 37–46.
Godlewski E. and Raviart P.-A. (1996). Numerical approximation of hyperbolic systems of conservation laws. Applied
Mathematical Sciences, 118, Springer-Verlag, New York, USA.
Guinot V. (2003). Godunov-type Schemes: An Introduction for Engineers. Elsevier, Amsterdam, NL.
Heathcote I. W. (2009). Integrated Watershed Management: Principles and Practice, 2nd ed., John Wiley & Sons,
Inc., NY
Henderson F. M. (1966). Open Channel Flow. Macmillan Series in Civil Engineering, Macmillan Company, New York.
Hicks N. S., Smith J. A., Miller A. J. and Nelson P. A. (2005). Catastrophic flooding from an orographic thunderstorm
in the central Appalachians. Water Resources Research, 41, 1–17.
Hirch C. (1988). Numerical Computation of Internal and External Flows, Volume 1: Fundamental of Numerical
Discretization. Wiley and Son, Chichester.
Ho-Le K. (1988). Finite element mesh generation methods: A review and classification. Computer-Aided Design,
20(1), 27–38.
Horrit M. S., Bates P. D. (2002). Evaluation of 1d and 2d numerical models for predicting river flood inundation.
Journal of Hydrology, 268 , 87–99.
Horritt M. S. (2000). Calibration of a two-dimensional finite element flood flow model using satellite radar imagery.
Water Resources Research, 36(11), 3279–3291.
Holly F. M. Jr. and Preissmann A. (1977). Accurate calculation of transport in two dimensions. Journal of Hydraulic
Engineering, 3(11), 1259–1277.
Hu W. P., Pu P. M. and Qin B. Q. (1998). A three-dimensional numerical simulation on the dynamics in Lake Taihu,
China (II): The typical wind-driven current and its divergence. Journal of Lake Science, 10(4), 26–34.
Huges D. A. and Beater A. B. (1987). A comparison between lumped and semi-distributed approaches to modelling
isolated flood events. In: Proceedings of the Hydrological Sciences Symposium, D. A. Hughes and A. W. Stone,
(eds), Departement of Geography, Rhodes University, Grahamstown, RSA, pp. 547–561.
Hunsaker C. T. and Levine D. A. (1995). Hierarchical approaches to the study of water quality in rivers. BioScience,
45,193–203.
ILEC (2005). Managing Lakes and their Basins for Sustainable Use: A Report for Lake Basin Managers and
Stakeholders. International Lake Environmental Committee Foundation, Kusatsu, Japan.
Imberger J. (1987). Mixing processes relevant to phytoplanktondynamics in lakes. New Zealand J. Marine Freshwater
Res. 21, 361–377.
Jain S. C. (2001). Open-Channel Flow. John Wiley and Sons, New York.
James L. D. and Burges J. J. (1982). Selection, calibration and testing of hydrologic medels. In: Hydrologic Modeling
of Small Watersheds, C. T. Haan, H. P. Johnson and D. L. Brakensiek (eds), ASAE Monograph No. 5, St. Joseph,
Michgan, pp. 437–472.
Jung N.-C., Popescu I., Kelderman P., Solomatine D. P. and Price R. K. (2010). Application of model trees and other
machine learning techniques for algal growth prediction in Yongdam reservoir, Republic of Korea. Journal of
Hydroinformatics, 12(3), 262–274.
Jung N.-C., Popescu I., Price R. K., Solomatine D., Kelderman P. and Shin J.-K. (2011). The use of the A.G.P.
test for determining the phytoplankton production and distribution in the thermally stratified reservoirs:
The case of Yongdam reservoir in Korea. Environmental Engineering and Management Journal, 10(11),
pp. 1647–1657.
Knight D. W. (2006). Introduction to flooding and river basin modelling, Chapter 1. In: River Basin Modelling for
Flood Risk Mitigation D. W. Knight and A. Y. Shamseldin (eds), Taylor & Francis, 1–19.
Lazarov R. D., Makarov V. L. and Samarskii A. A. (1982). Application of exact difference schemes to the construction
and study of difference schemes for generalized solutions. Matematisk Sb. (N.S.), 117(4), 469–480.
Lane L. J., Nichols M. H., Hernandez M., Manetsch C. and Osterkamp W. R. (1994). Variability in discharge, stream
power, and particle-size distribution in ephemeral-stream channe systems, in Variability in Stream Erosion and
Sediment Transport (Proc. of the Canberra Symposium December 1994). Edited by Olive, L. J. Loughram, R. J.
and Kesby, J. A. IAHS Publ. no. 224, 335–342.
Legras J. (1971). Méthodes et Techniques de L’analyse Numérique (Methods and Techniques for Numerical Analysis).
Dunod, Paris.
Lesieur M. (1997). Turbulence in Fluids, Fluid Mechanics and its Applications, 40, 3rd edn, Kluwer Academic
Publishers, Dordrecht, The Netherlands.
LeVeque R. J. (2002). Finite Volume Methods for Hyperbolic Problems (Cambridge Texts in Applied Mathematics).
Cambridge University Press, Cambridge, UK.
LeVeque R. J. (2007). Finite difference methods for ordinary and partial differential equations: Steady-state and time
dependent problems, SIAM, Philadelphia, PA.
Liggett J. A. and Cunge J. A. (1975). Numerical methods of solution of the unsteady flow equations. In: Unsteady Flow
in Open Channels, K. Mahmood and V. Yevjevich (eds), Water Resources, Fort Collins, Colorado, pp. 89–182.
Louks, D. P. and van Beek E. (2005). Water resources systems planning and management. Studies and Reports in
Hydrology, pp. 649–672.
Mandel J., McCormick S. C. and Multilevel A. (1989). Variational Method for Au = λBu on Composite Grids. Journal
of Computational Physics, 80, 442–452.
Manteuffel T. A. and White A. B. Jr. (1987). The numerical solution of second-order boundary value problems on
nonuniform meshes. Mathematics of Computation, 47, 511–535.
Mao J., Chen Q. and Chen Y. (2008). Three dimensional eutrophication model and application to Taihu Lake, China.
Journal of Environmental Sciences, 20, 278–284.
Martin J. L. and McCutcheon S. C. (1999). Hydrodynamics and Transport for Water Quality Modeling. CRC Press,
Inc, 335–384.
Meselhe E. A. Holly F. M. Jr. (1997). Invalidity of Preissmann scheme for transcritical flow. Journal of Hydraulic
Engineering, 123(7), 652–655.
Moya Quiroga V., Popescu I., Solomatine D. P. and Bociort L. (2013). Cloud and cluster computing in uncertainty
analysis of integrated flood models. Journal of Hydroinformatics, 15(1), 55–70.
Novak P., Moffat A. I. B., Nalluri C. and Narayanan R. (1990). Propagation of translatory waves in channels and rivers
4th edn, Editeed by the Academic Division of Unwin Hyman Ltd.
Ogden F. L. and Julien, P. Y. (2002). Mathematical Models of Small Watershed Hydrology and Applications. 1st ed.
Colorado, US, Water Resources Publication, LLC, 90–91. (eBook).
Orlob G. T. (1983). Mathematical Modeling of Water Quality Streams, Lakes, and Reservoirs. Wiley and Sons, New York.
Ponce V. M. and Simon D. B. (1997). Shallow water propagation in open channel flow. Journal of Hydraulic Division,
ASCE, 103, 1461–1476.
Popescu I. (2013). Unsteady Flow in Floods in a changing climate: Inundation Modelling G. di Baldassarre, Cambridge
University Press, Cambridge, UK.
Popescu I., Jonoski A. and Bociort L. (2012). Decision support systems for flood management in the Timis Bega
catchment. Environmental Engineering and Management Journal, 11(12), 2305–2311.
Preissmann A. (1961). Propagation of translatory waves in channels and rivers., Proc., 1st Congress of French
Association for Computation, Grenoble, France, A. F. C. A. L., 433–442 (in French).
Price R. K. (1985). Flood routing. Chap 4 in Developments in Hydraulic Engineering-3. Elsevier Applied Sciences
Publishers, London, pp. 129–174.
Rauch W., Henze M., Koncsos L., Reichert P., Shanahan P., Somlyody L. and Vanrolleghem P. (1998). River water
quality modelling: I. State of the art. Water Science and Technology 38(11), 237–244.
Richtmyer R. D. and Morton K. W. (1967). Difference methods for initial-value problems. Interscience Publishers,
New York.
Rouse H. (1950). Fundamental Principles of Flow. In: Engineering Hydraulics. H. Rouse (ed.), Wiley, New York,
USA, p. 135.
Sagaut B. (2001). Large Eddy Simulation for Incompressible Flows. Springer-Verlag, Berlin Heidelberg, New York.
Schaffer H. A., Madsen P. A. and Deigaard R. (1993). A Boussinesq model for waves breaking in shallow water.
Coastal Engineering, 20, 185–202.
Schultze R. E. (1995). Hydrology and Agrohydrology. Water Research Commision, Pretoria, RSA, WRC Report
TT69/95, p. 552 (ISBN: 1-86845-136-4).
Shepherd R. G. and Geter W. F. (1995). Verification, calibration, simulation: Protocolls in ground-water and AG/
NP5 modeling. In: Water Quality Modeling, C. Heatwole (ed.), American Society of Agricultural Engineers,
St. Joseph, MI, USA, pp. 87–90.
Singh V. P. (ed.) (1995). Computer Models of Watershed Hydrology. Water Resources Publication, Highlands Ranch
CO, USA, p. 1130.
Singh V. P. (1996). Kinematic wave modeling in water resources, Surface Water Hydrology, John Wiley & Sons Inc.,
New York
Smith M. and Kohn R. (2002). Parsimonious covariance matrix estimation for longitudinal data. J. Amer. Statist.
Assoc., 97, 1141—1153.
Sorooshian S. (1991). Parameter estimation, model identification, and model validation: Conceptual-type models.
In: Recent Advances in the Modeling of Hydrologic Systems, D. S. Bowles and P. E. O’Connell (eds), Kluwer
Academic Publishers, Dordrecht, Netherlands, pp. 443–467.
Strelkoff T. and Katodes N. D. (1977). Dimensionless solutions of border-irrigation advance. Journal of Irrigation
and Drainage Division, ASCE, 103(4), 401–417.
Streeter H. W. and Phelps E. B. (1925). A Study of the pollution and natural purification of the Ohio river. III. Factors
concerned in the phenomena of oxidation and reaeration, Public Health Bulletin no. 146, Reprinted by U.S.
Department of Health, Education and Welfare, Public Health Service, 1958.
Sturm T. W. (2001). Open Channel Hydraulics. McGraw-Hill Series in Water Resources and Environmental
Engineering, New York.
Szymkiewicz R. (1993). Solution of the advection-diffusion equation using the spline function and finite elements.
Communication Numeral Methods Engineering, 9(4), 197–206.
Szymkiewicz R. (1995). Method to solve 1D unsteady transport and flow equations. Journal of Hydralic Engineering,
121(5), 396–403.
Szymkiewicz R. (2010). Numerical Modeling in Open Channel Hydraulics. Springer, Dordrecht, p. 370.
Thacker W. C. (1980). A brief review of techniques for generating irregular computational grids. International
Journal of Numerial Method Engineering, 15, 1335–1341.
Tim U. S. (1995). Emerging issues in hydrologic and water quality modeling research. In: Water Quality Modeling,
C. Heatwolw, (ed.), American Society of Agricultural Emgineers, St. Joseph, MI, USA, pp. 358–373.
Todini E. and Bossi A. (1986). Parabolic and Backwater, an unconditionally stable flood routing scheme particularly
suited for real time forecasting and control. Journal of Hydraulic Research, 24(5), 405–424.
van Leer B. (1979). Towards the Ultimate Conservative Difference Scheme V. A second order sequel to Godunov’s
method. Journal Computational Physics, 32(1), 101–136.
Wang F. E., Tian P., Yu J., Lao G. M. and Shi T. C. (2011). Variations in pollutant fluxes of rivers surrounding Taihu
Lake in Zhejiang Province in 2008, Physics and Chemistry of the Earth, 36, 366–371.
Wetzel R. G. (2001). Limnology: Lake and Reservoir Ecosystems. Academic Press, New York.
Wright N. G. and Crosato A. (2011). The hydrodynamics and morphodynamics of rivers, in Treatise on Water Science,
Four-Volume Set P. Wilderer, Editor. Elsevier Science Ltd. pp. 135–156.
Woods R. A., Sivapalan M. and Duncan M. (1995). Investigating the representative elementary area concept: An
approach based on field data. In: Advances in Hydrological Processes, Scale Issues in Hydrological Modelling,
J. D. Kalma and M. Sivapalan (eds), John Wiley and Sons, UK, pp. 49–70.
Woolhiser D. A. and Brakensiek D. L. (1982). Hydrologic modeling of small watersheds. In: Hydrologic Modeling
of Small Watersheds, C. T. Haan, H. P. Johson and D. L. Brakensiek (eds), ASAE Monograph 5, St. Josephs,
MI, USA, pp. 3–16.
Wu W. (2008). Computational River Dynamics. Taylor & Francis, London, p. 494, ISBN: 978-0-414-44960-1.
Yiping L. K. A. and Zhongbo Y. (2011). Modeling impacts of Yangtze River water transfer on water ages in Lake
Taihu, China. Ecological Engineering, 37, 325–334.
Yue C., Popescu I., Mynett A., Pan Q. and Postma L. (2013). Challenges for 2D water quality modelling of lake Taihu
in China. Environmental Engineering and Management Journal, 12(5), 1031–1044.
Zagona E. A., Fulp T. J., Shane R., Magee T. M. and Goranflo H. M. (2001). RiverWare: A generalized tool for
complex reservoir system modeling. Journal of the American Water Resources Association, 37(4), 913–929.
Zalewski M. and Wagner-Lotkowska I. (eds). (2004). Integrated Watershed Management – Ecohydrology and
Phytotechnology-Manual. UNESCO IHP, UNEP IETC. pp. 246.
Zhu W. and Geng Y. Q. (2004). Water quality issues in the catchment water balance of Taihu Lake, China. In:
Hydrology: Science and Practice for the 21st century, Volume II, Proceedings of the British Hydrological Society
International Conference, Imperial College, London, July 2004, 534–541.
K scheme, 61–63
kinematic wave approximation, 27 solution algorithm, 127–133
L R
lateral inflow, 137–138 domain of influence, 22
Riemann invariants, 30
M
momentum
S
conservation law, 13–14, 26
Saint-Venant equations, 24–31, 126–128, 137–140
equation, 15, 27–29, 127–130
six-point scheme, 127
stability, 96–97
N
analysis, 96, 100, 117
Navier-Stokes equations, 15, 24–25, 126
definition, 96, 99
O von Neumann condition, 96–97, 99, 106, 116
ordinary differential equation (ODE), 3, 15–17
finite differences, 50–55 T
Oxygen consumption, 152 Taylor series expansion, 45, 48, 96, 103–104, 116–117
truncation error (T.E.), 46–47, 95–97, 117
P two-dimensional, 79, 159
parabolic equations, 23, 56, 65, 68
phase error, 100–101, 109–110 W
phase portrait, 110 wave, 106
Preissmann approximation, 27
amplitude and phase portraits, 109–110 equation, 20
iwapublishing.com
@iWapublishing
isBn: 9781780400440 (paperback)
isBn: 9781780400457 (eBook)