source: anuga_core/documentation/user_manual/anuga_user_manual.tex @ 4785

Last change on this file since 4785 was 4785, checked in by ole, 16 years ago

Added build placeholder to Release info in user guide

  • Property svn:keywords set to LastChangedDate LastChangedRevision LastChangedBy HeadURL Id
File size: 150.8 KB
Line 
1% Complete documentation on the extended LaTeX markup used for Python
2% documentation is available in ``Documenting Python'', which is part
3% of the standard documentation for Python.  It may be found online
4% at:
5%
6%     http://www.python.org/doc/current/doc/doc.html
7
8
9%labels
10%Sections and subsections \label{sec: }
11%Chapters \label{ch: }
12%Equations \label{eq: }
13%Figures \label{fig: }
14
15% Is latex failing with;
16% `modanuga_user_manual.ind' not found?
17% try this command-line
18%   makeindex modanuga_user_manual.idx
19% To produce the modanuga_user_manual.ind file.
20
21
22\documentclass{manual}
23
24\usepackage{graphicx}
25\usepackage{datetime}
26
27\input{definitions}
28
29\title{\anuga User Manual}
30\author{Geoscience Australia and the Australian National University}
31
32% Please at least include a long-lived email address;
33% the rest is at your discretion.
34\authoraddress{Geoscience Australia \\
35  Email: \email{ole.nielsen@ga.gov.au}
36}
37
38%Draft date
39
40% update before release!
41% Use an explicit date so that reformatting
42% doesn't cause a new date to be used.  Setting
43% the date to \today can be used during draft
44% stages to make it easier to handle versions.
45
46
47\longdate       % Make date format long using datetime.sty
48%\settimeformat{xxivtime} % 24 hour Format
49\settimeformat{oclock} % Verbose
50\date{\today, \ \currenttime}
51%\hyphenation{set\_datadir}
52
53\ifhtml
54\date{\today} % latex2html does not know about datetime
55\fi
56
57
58
59
60\input{version} % Get version info - this file may be modified by
61                % update_anuga_user_manual.py - if not a dummy
62                % will be used.
63               
64%\release{1.0}   % release version; this is used to define the
65%                % \version macro
66
67\makeindex          % tell \index to actually write the .idx file
68\makemodindex       % If this contains a lot of module sections.
69
70\setcounter{tocdepth}{3}
71\setcounter{secnumdepth}{3}
72
73
74\begin{document}
75\maketitle
76
77
78% This makes the contents more accessible from the front page of the HTML.
79\ifhtml
80\chapter*{Front Matter\label{front}}
81\fi
82
83%Subversion keywords:
84%
85%$LastChangedDate: 2007-11-05 03:58:54 +0000 (Mon, 05 Nov 2007) $
86%$LastChangedRevision: 4785 $
87%$LastChangedBy: ole $
88
89\input{copyright}
90
91
92\begin{abstract}
93\label{def:anuga}
94
95\noindent \anuga\index{\anuga} is a hydrodynamic modelling tool that
96allows users to model realistic flow problems in complex geometries.
97Examples include dam breaks or the effects of natural hazards such
98as riverine flooding, storm surges and tsunami.
99
100The user must specify a study area represented by a mesh of triangular
101cells, the topography and bathymetry, frictional resistance, initial
102values for water level (called \emph{stage}\index{stage} within \anuga),
103boundary
104conditions and forces such as windstress or pressure gradients if
105applicable.
106
107\anuga tracks the evolution of water depth and horizontal momentum
108within each cell over time by solving the shallow water wave equation
109governing equation using a finite-volume method.
110
111\anuga also incorporates a mesh generator %, called \code{graphical
112                                %mesh generator},
113that
114allows the user to set up the geometry of the problem interactively as
115well as tools for interpolation and surface fitting, and a number of
116auxiliary tools for visualising and interrogating the model output.
117
118Most \anuga components are written in the object-oriented programming
119language Python and most users will interact with \anuga by writing
120small Python programs based on the \anuga library
121functions. Computationally intensive components are written for
122efficiency in C routines working directly with the Numerical Python
123structures.
124
125
126\end{abstract}
127
128\tableofcontents
129
130
131\chapter{Introduction}
132
133
134\section{Purpose}
135
136The purpose of this user manual is to introduce the new user to the
137inundation software, describe what it can do and give step-by-step
138instructions for setting up and running hydrodynamic simulations.
139
140\section{Scope}
141
142This manual covers only what is needed to operate the software after
143installation and configuration. It does not includes instructions
144for installing the software or detailed API documentation, both of
145which will be covered in separate publications and by documentation
146in the source code.
147
148\section{Audience}
149
150Readers are assumed to be familiar with the operating environment
151and have a general understanding of the subject matter, as well as
152enough programming experience to adapt the code to different
153requirements and to understand the basic terminology of
154object-oriented programming.
155
156\pagebreak
157\chapter{Background}
158
159
160Modelling the effects on the built environment of natural hazards such
161as riverine flooding, storm surges and tsunami is critical for
162understanding their economic and social impact on our urban
163communities.  Geoscience Australia and the Australian National
164University are developing a hydrodynamic inundation modelling tool
165called \anuga to help simulate the impact of these hazards.
166
167The core of \anuga is the fluid dynamics module, called \code{shallow\_water},
168which is based on a finite-volume method for solving the Shallow Water
169Wave Equation.  The study area is represented by a mesh of triangular
170cells.  By solving the governing equation within each cell, water
171depth and horizontal momentum are tracked over time.
172
173A major capability of \anuga is that it can model the process of
174wetting and drying as water enters and leaves an area.  This means
175that it is suitable for simulating water flow onto a beach or dry land
176and around structures such as buildings.  \anuga is also capable
177of modelling hydraulic jumps due to the ability of the finite-volume
178method to accommodate discontinuities in the solution.
179
180To set up a particular scenario the user specifies the geometry
181(bathymetry and topography), the initial water level (stage),
182boundary conditions such as tide, and any forcing terms that may
183drive the system such as wind stress or atmospheric pressure
184gradients. Gravity and frictional resistance from the different
185terrains in the model are represented by predefined forcing terms.
186
187The built-in mesh generator, called \code{graphical\_mesh\_generator},
188allows the user to set up the geometry
189of the problem interactively and to identify boundary segments and
190regions using symbolic tags.  These tags may then be used to set the
191actual boundary conditions and attributes for different regions
192(e.g.\ the Manning friction coefficient) for each simulation.
193
194Most \anuga components are written in the object-oriented programming
195language Python.  Software written in Python can be produced quickly
196and can be readily adapted to changing requirements throughout its
197lifetime.  Computationally intensive components are written for
198efficiency in C routines working directly with the Numerical Python
199structures.  The animation tool developed for \anuga is based on
200OpenSceneGraph, an Open Source Software (OSS) component allowing high
201level interaction with sophisticated graphics primitives.
202See \cite{nielsen2005} for more background on \anuga.
203
204\chapter{Restrictions and limitations on \anuga}
205\label{ch:limitations}
206
207Although a powerful and flexible tool for hydrodynamic modelling, \anuga has a
208number of limitations that any potential user need to be aware of. They are
209
210\begin{itemize}
211  \item The mathematical model is the 2D shallow water wave equation.
212  As such it cannot resolve vertical convection and consequently not breaking
213  waves or 3D turbulence (e.g.\ vorticity).
214  \item The surface is assumed to be open, e.g. \anuga cannot model
215  flow under ceilings or in pipes
216  \item All spatial coordinates are assumed to be UTM (meters). As such,
217  ANUGA is unsuitable for modelling flows in areas larger than one UTM zone
218  (6 degrees wide).
219  \item Fluid is assumed to be inviscid
220  \item The finite volume is a very robust and flexible numerical technique,
221  but it is not the fastest method around. If the geometry is sufficiently
222  simple and if there is no need for wetting or drying, a finite-difference
223  method may be able to solve the problem faster than \anuga.
224  %\item Mesh resolutions near coastlines with steep gradients need to be...
225  \item Frictional resistance is implemented using Manning's formula, but
226  \anuga has not yet been fully validated in regard to bottom roughness
227  \item ANUGA contains no tsunami-genic functionality relating to
228  earthquakes.
229\end{itemize}
230
231
232
233\chapter{Getting Started}
234\label{ch:getstarted}
235
236This section is designed to assist the reader to get started with
237\anuga by working through some examples. Two examples are discussed;
238the first is a simple example to illustrate many of the ideas, and
239the second is a more realistic example.
240
241\section{A Simple Example}
242\label{sec:simpleexample}
243
244\subsection{Overview}
245
246What follows is a discussion of the structure and operation of a
247script called \file{runup.py}.
248
249This example carries out the solution of the shallow-water wave
250equation in the simple case of a configuration comprising a flat
251bed, sloping at a fixed angle in one direction and having a
252constant depth across each line in the perpendicular direction.
253
254The example demonstrates the basic ideas involved in setting up a
255complex scenario. In general the user specifies the geometry
256(bathymetry and topography), the initial water level, boundary
257conditions such as tide, and any forcing terms that may drive the
258system such as wind stress or atmospheric pressure gradients.
259Frictional resistance from the different terrains in the model is
260represented by predefined forcing terms. In this example, the
261boundary is reflective on three sides and a time dependent wave on
262one side.
263
264The present example represents a simple scenario and does not
265include any forcing terms, nor is the data taken from a file as it
266would typically be.
267
268The conserved quantities involved in the
269problem are stage (absolute height of water surface),
270$x$-momentum and $y$-momentum. Other quantities
271involved in the computation are the friction and elevation.
272
273Water depth can be obtained through the equation
274
275\begin{tabular}{rcrcl}
276  \code{depth} &=& \code{stage} &$-$& \code{elevation}
277\end{tabular}
278
279
280\subsection{Outline of the Program}
281
282In outline, \file{runup.py} performs the following steps:
283
284\begin{enumerate}
285
286   \item Sets up a triangular mesh.
287
288   \item Sets certain parameters governing the mode of
289operation of the model-specifying, for instance, where to store the model output.
290
291   \item Inputs various quantities describing physical measurements, such
292as the elevation, to be specified at each mesh point (vertex).
293
294   \item Sets up the boundary conditions.
295
296   \item Carries out the evolution of the model through a series of time
297steps and outputs the results, providing a results file that can
298be visualised.
299
300\end{enumerate}
301
302\subsection{The Code}
303
304%FIXME: we are using the \code function here.
305%This should be used wherever possible
306For reference we include below the complete code listing for
307\file{runup.py}. Subsequent paragraphs provide a
308`commentary' that describes each step of the program and explains it
309significance.
310
311\verbatiminput{demos/runup.py}
312
313\subsection{Establishing the Mesh}\index{mesh, establishing}
314
315The first task is to set up the triangular mesh to be used for the
316scenario. This is carried out through the statement:
317
318{\small \begin{verbatim}
319    points, vertices, boundary = rectangular(10, 10)
320\end{verbatim}}
321
322The function \function{rectangular} is imported from a module
323\module{mesh\_factory} defined elsewhere. (\anuga also contains
324several other schemes that can be used for setting up meshes, but we
325shall not discuss these.) The above assignment sets up a $10 \times
32610$ rectangular mesh, triangulated in a regular way. The assignment
327
328{\small \begin{verbatim}
329    points, vertices, boundary = rectangular(m, n)
330\end{verbatim}}
331
332returns:
333
334\begin{itemize}
335
336   \item a list \code{points} giving the coordinates of each mesh point,
337
338   \item a list \code{vertices} specifying the three vertices of each triangle, and
339
340   \item a dictionary \code{boundary} that stores the edges on
341   the boundary and associates each with one of the symbolic tags \code{`left'}, \code{`right'},
342   \code{`top'} or \code{`bottom'}.
343
344\end{itemize}
345
346(For more details on symbolic tags, see page
347\pageref{ref:tagdescription}.)
348
349An example of a general unstructured mesh and the associated data
350structures \code{points}, \code{vertices} and \code{boundary} is
351given in Section \ref{sec:meshexample}.
352
353
354
355
356\subsection{Initialising the Domain}
357
358These variables are then used to set up a data structure
359\code{domain}, through the assignment:
360
361{\small \begin{verbatim}
362    domain = Domain(points, vertices, boundary)
363\end{verbatim}}
364
365This creates an instance of the \class{Domain} class, which
366represents the domain of the simulation. Specific options are set at
367this point, including the basename for the output file and the
368directory to be used for data:
369
370{\small \begin{verbatim}
371    domain.set_name('runup')
372\end{verbatim}}
373
374{\small \begin{verbatim}
375    domain.set_datadir('.')
376\end{verbatim}}
377
378In addition, the following statement now specifies that the
379quantities \code{stage}, \code{xmomentum} and \code{ymomentum} are
380to be stored:
381
382{\small \begin{verbatim}
383    domain.set_quantities_to_be_stored(['stage', 'xmomentum',
384    'ymomentum'])
385\end{verbatim}}
386
387
388\subsection{Initial Conditions}
389
390The next task is to specify a number of quantities that we wish to
391set for each mesh point. The class \class{Domain} has a method
392\method{set\_quantity}, used to specify these quantities. It is a
393flexible method that allows the user to set quantities in a variety
394of ways---using constants, functions, numeric arrays, expressions
395involving other quantities, or arbitrary data points with associated
396values, all of which can be passed as arguments. All quantities can
397be initialised using \method{set\_quantity}. For a conserved
398quantity (such as \code{stage, xmomentum, ymomentum}) this is called
399an \emph{initial condition}. However, other quantities that aren't
400updated by the equation are also assigned values using the same
401interface. The code in the present example demonstrates a number of
402forms in which we can invoke \method{set\_quantity}.
403
404
405\subsubsection{Elevation}
406
407The elevation, or height of the bed, is set using a function,
408defined through the statements below, which is specific to this
409example and specifies a particularly simple initial configuration
410for demonstration purposes:
411
412{\small \begin{verbatim}
413    def f(x,y):
414        return -x/2
415\end{verbatim}}
416
417This simply associates an elevation with each point \code{(x, y)} of
418the plane.  It specifies that the bed slopes linearly in the
419\code{x} direction, with slope $-\frac{1}{2}$,  and is constant in
420the \code{y} direction.
421
422Once the function \function{f} is specified, the quantity
423\code{elevation} is assigned through the simple statement:
424
425{\small \begin{verbatim}
426    domain.set_quantity('elevation', f)
427\end{verbatim}}
428
429NOTE: If using function to set \code{elevation} it must be vector
430compatible. For example square root will not work.
431
432\subsubsection{Friction}
433
434The assignment of the friction quantity (a forcing term)
435demonstrates another way we can use \method{set\_quantity} to set
436quantities---namely, assign them to a constant numerical value:
437
438{\small \begin{verbatim}
439    domain.set_quantity('friction', 0.1)
440\end{verbatim}}
441
442This specifies that the Manning friction coefficient is set to 0.1
443at every mesh point.
444
445\subsubsection{Stage}
446
447The stage (the height of the water surface) is related to the
448elevation and the depth at any time by the equation
449
450{\small \begin{verbatim}
451    stage = elevation + depth
452\end{verbatim}}
453
454
455For this example, we simply assign a constant value to \code{stage},
456using the statement
457
458{\small \begin{verbatim}
459    domain.set_quantity('stage', -.4)
460\end{verbatim}}
461
462which specifies that the surface level is set to a height of $-0.4$,
463i.e. 0.4 units (m) below the zero level.
464
465Although it is not necessary for this example, it may be useful to
466digress here and mention a variant to this requirement, which allows
467us to illustrate another way to use \method{set\_quantity}---namely,
468incorporating an expression involving other quantities. Suppose,
469instead of setting a constant value for the stage, we wished to
470specify a constant value for the \emph{depth}. For such a case we
471need to specify that \code{stage} is everywhere obtained by adding
472that value to the value already specified for \code{elevation}. We
473would do this by means of the statements:
474
475{\small \begin{verbatim}
476    h = 0.05 # Constant depth
477    domain.set_quantity('stage', expression = 'elevation + %f' %h)
478\end{verbatim}}
479
480That is, the value of \code{stage} is set to $\code{h} = 0.05$ plus
481the value of \code{elevation} already defined.
482
483The reader will probably appreciate that this capability to
484incorporate expressions into statements using \method{set\_quantity}
485greatly expands its power.) See Section \ref{sec:Initial Conditions} for more
486details.
487
488\subsection{Boundary Conditions}\index{boundary conditions}
489
490The boundary conditions are specified as follows:
491
492{\small \begin{verbatim}
493    Br = Reflective_boundary(domain)
494
495    Bt = Transmissive_boundary(domain)
496
497    Bd = Dirichlet_boundary([0.2,0.,0.])
498
499    Bw = Time_boundary(domain=domain,
500                f=lambda t: [(0.1*sin(t*2*pi)-0.3), 0.0, 0.0])
501\end{verbatim}}
502
503The effect of these statements is to set up a selection of different
504alternative boundary conditions and store them in variables that can be
505assigned as needed. Each boundary condition specifies the
506behaviour at a boundary in terms of the behaviour in neighbouring
507elements. The boundary conditions introduced here may be briefly described as
508follows:
509
510\begin{itemize}
511    \item \textbf{Reflective boundary}\label{def:reflective boundary} Returns same \code{stage} as
512      as present in its neighbour volume but momentum vector
513      reversed 180 degrees (reflected).
514      Specific to the shallow water equation as it works with the
515      momentum quantities assumed to be the second and third conserved
516      quantities. A reflective boundary condition models a solid wall.
517    \item \textbf{Transmissive boundary}\label{def:transmissive boundary} Returns same conserved quantities as
518      those present in its neighbour volume. This is one way of modelling
519      outflow from a domain, but it should be used with caution if flow is
520      not steady state as replication of momentum at the boundary
521      may cause occasional spurious effects. If this occurs,
522      consider using e.g. a Dirichlet boundary condition.
523    \item \textbf{Dirichlet boundary}\label{def:dirichlet boundary} Specifies
524      constant values for stage, $x$-momentum and $y$-momentum at the boundary.
525    \item \textbf{Time boundary}\label{def:time boundary} Like a Dirichlet
526      boundary but with behaviour varying with time.
527\end{itemize}
528
529\label{ref:tagdescription}Before describing how these boundary
530conditions are assigned, we recall that a mesh is specified using
531three variables \code{points}, \code{vertices} and \code{boundary}.
532In the code we are discussing, these three variables are returned by
533the function \code{rectangular}; however, the example given in
534Section \ref{sec:realdataexample} illustrates another way of
535assigning the values, by means of the function
536\code{create\_mesh\_from\_regions}.
537
538These variables store the data determining the mesh as follows. (You
539may find that the example given in Section \ref{sec:meshexample}
540helps to clarify the following discussion, even though that example
541is a \emph{non-rectangular} mesh.)
542
543\begin{itemize}
544\item The variable \code{points} stores a list of 2-tuples giving the
545coordinates of the mesh points.
546
547\item The variable \code{vertices} stores a list of 3-tuples of
548numbers, representing vertices of triangles in the mesh. In this
549list, the triangle whose vertices are \code{points[i]},
550\code{points[j]}, \code{points[k]} is represented by the 3-tuple
551\code{(i, j, k)}.
552
553\item The variable \code{boundary} is a Python dictionary that
554not only stores the edges that make up the boundary but also assigns
555symbolic tags to these edges to distinguish different parts of the
556boundary. An edge with endpoints \code{points[i]} and
557\code{points[j]} is represented by the 2-tuple \code{(i, j)}. The
558keys for the dictionary are the 2-tuples \code{(i, j)} corresponding
559to boundary edges in the mesh, and the values are the tags are used
560to label them. In the present example, the value \code{boundary[(i,
561j)]} assigned to \code{(i, j)]} is one of the four tags
562\code{`left'}, \code{`right'}, \code{`top'} or \code{`bottom'},
563depending on whether the boundary edge represented by \code{(i, j)}
564occurs at the left, right, top or bottom of the rectangle bounding
565the mesh. The function \code{rectangular} automatically assigns
566these tags to the boundary edges when it generates the mesh.
567\end{itemize}
568
569The tags provide the means to assign different boundary conditions
570to an edge depending on which part of the boundary it belongs to.
571(In Section \ref{sec:realdataexample} we describe an example that
572uses different boundary tags --- in general, the possible tags are entirely selectable by the user when generating the mesh and not
573limited to `left', `right', `top' and `bottom' as in this example.)
574All segments in bounding polygon must be tagged. If a tag is not supplied, the default tag name 'exterior' will be assigned by ANUGA.
575
576
577Using the boundary objects described above, we assign a boundary
578condition to each part of the boundary by means of a statement like
579
580{\small \begin{verbatim}
581    domain.set_boundary({'left': Br, 'right': Bw, 'top': Br, 'bottom': Br})
582\end{verbatim}}
583
584It is critical that all tags are assoctiated with a boundary conditing in this statement. If not the program will halt with a statement like
585
586\begin{verbatim}
587
588Traceback (most recent call last):
589  File "mesh_test.py", line 114, in ?
590    domain.set_boundary({'west': Bi, 'east': Bo, 'north': Br, 'south': Br})
591  File "X:\inundation\sandpits\onielsen\anuga_core\source\anuga\abstract_2d_finite_volumes\domain.py", line 505, in set_boundary
592    raise msg
593ERROR (domain.py): Tag "exterior" has not been bound to a boundary object.
594All boundary tags defined in domain must appear in the supplied dictionary.
595The tags are: ['ocean', 'east', 'north', 'exterior', 'south']
596\end{verbatim} 
597
598
599The command \code{set\_boundary} stipulates that, in the current example, the right
600boundary varies with time, as defined by the lambda function, while the other
601boundaries are all reflective.
602
603The reader may wish to experiment by varying the choice of boundary
604types for one or more of the boundaries. (In the case of \code{Bd}
605and \code{Bw}, the three arguments in each case represent the
606\code{stage}, $x$-momentum and $y$-momentum, respectively.)
607
608{\small \begin{verbatim}
609    Bw = Time_boundary(domain=domain,
610                       f=lambda t: [(0.1*sin(t*2*pi)-0.3), 0.0, 0.0])
611\end{verbatim}}
612
613
614
615\subsection{Evolution}\index{evolution}
616
617The final statement \nopagebreak[3]
618{\small \begin{verbatim}
619    for t in domain.evolve(yieldstep = 0.1, duration = 4.0):
620        print domain.timestepping_statistics()
621\end{verbatim}}
622
623causes the configuration of the domain to `evolve', over a series of
624steps indicated by the values of \code{yieldstep} and
625\code{duration}, which can be altered as required.  The value of
626\code{yieldstep} controls the time interval between successive model
627outputs.  Behind the scenes more time steps are generally taken.
628
629
630\subsection{Output}
631
632The output is a NetCDF file with the extension \code{.sww}. It
633contains stage and momentum information and can be used with the
634ANUGA viewer \code{animate} (see Section \ref{sec:animate})
635visualisation package
636to generate a visual display. See Section \ref{sec:file formats}
637(page \pageref{sec:file formats}) for more on NetCDF and other file
638formats.
639
640The following is a listing of the screen output seen by the user
641when this example is run:
642
643\verbatiminput{examples/runupoutput.txt}
644
645
646\section{How to Run the Code}
647
648The code can be run in various ways:
649
650\begin{itemize}
651  \item{from a Windows or Unix command line} as in\ \code{python runup.py}
652  \item{within the Python IDLE environment}
653  \item{within emacs}
654  \item{within Windows, by double-clicking the \code{runup.py}
655  file.}
656\end{itemize}
657
658
659\section{Exploring the Model Output}
660
661The following figures are screenshots from the \anuga visualisation
662tool \code{animate}. Figure \ref{fig:runupstart} shows the domain
663with water surface as specified by the initial condition, $t=0$.
664Figure \ref{fig:runup2} shows later snapshots for $t=2.3$ and
665$t=4$ where the system has been evolved and the wave is encroaching
666on the previously dry bed.  All figures are screenshots from an
667interactive animation tool called animate which is part of \anuga and
668distributed as in the package anuga\_viewer.
669Animate is described in more detail is Section \ref{sec:animate}.
670
671\begin{figure}[hbt]
672
673  \centerline{\includegraphics[width=75mm, height=75mm]
674    {graphics/bedslopestart.jpg}}
675
676  \caption{Runup example viewed with the ANUGA viewer}
677  \label{fig:runupstart}
678\end{figure}
679
680
681\begin{figure}[hbt]
682
683  \centerline{
684   \includegraphics[width=75mm, height=75mm]{graphics/bedslopeduring.jpg}
685    \includegraphics[width=75mm, height=75mm]{graphics/bedslopeend.jpg}
686   }
687
688  \caption{Runup example viewed with ANGUA viewer}
689  \label{fig:runup2}
690\end{figure}
691
692
693
694\clearpage
695
696%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
697
698\section{A slightly more complex example}
699\label{sec:channelexample}
700
701\subsection{Overview}
702
703The next example is about waterflow in a channel with varying boundary conditions and
704more complex topograhies. These examples build on the
705concepts introduced through the \file{runup.py} in Section \ref{sec:simpleexample}.
706The example will be built up through three progressively more complex scripts.
707
708\subsection{Overview}
709As in the case of \file{runup.py}, the actions carried
710out by the program can be organised according to this outline:
711
712\begin{enumerate}
713
714   \item Set up a triangular mesh.
715
716   \item Set certain parameters governing the mode of
717operation of the model---specifying, for instance, where to store the
718model output.
719
720   \item Set up initial conditions for various quantities such as the elevation, to be specified at each mesh point (vertex).
721
722   \item Set up the boundary conditions.
723
724   \item Carry out the evolution of the model through a series of time
725steps and output the results, providing a results file that can be
726visualised.
727
728\end{enumerate}
729
730
731\subsection{The Code}
732
733Here is the code for the first version of the channel flow \file{channel1.py}:
734
735\verbatiminput{demos/channel1.py}
736
737In discussing the details of this example, we follow the outline
738given above, discussing each major step of the code in turn.
739
740\subsection{Establishing the Mesh}\index{mesh, establishing}
741
742In this example we use a similar simple structured triangular mesh as in \code{runup.py}
743for simplicity, but this time we will use a symmetric one and also
744change the physical extent of the domain. The assignment
745
746{\small \begin{verbatim}
747    points, vertices, boundary = rectangular_cross(m, n,
748                                                   len1=length, len2=width)
749\end{verbatim}}
750returns a m x n mesh similar to the one used in the previous example, except that now the
751extent in the x and y directions are given by the value of \code{length} and \code{width}
752respectively.
753
754Defining m and n in terms of the extent as in this example provides a convenient way of
755controlling the resolution: By defining dx and dy to be the desired size of each hypothenuse in the mesh we can write the mesh generation as follows:
756
757{\small \begin{verbatim}
758length = 10.
759width = 5.
760dx = dy = 1           # Resolution: Length of subdivisions on both axes
761
762points, vertices, boundary = rectangular_cross(int(length/dx), int(width/dy),
763                                               len1=length, len2=width)
764\end{verbatim}}
765which yields a mesh of length=10m, width=5m with 1m spacings. To increase the resolution, as we will later in this example, one merely decrease the values of dx and dy.
766
767The rest of this script is as in the previous example.
768% except for an application of the 'expression' form of \code{set\_quantity} where we use the value of \code{elevation} to define the (dry) initial condition for \code{stage}:
769%{\small \begin{verbatim}
770%  domain.set_quantity('stage', expression='elevation')
771%\end{verbatim}}
772
773\section{Model Output}
774
775The following figure is a screenshot from the \anuga visualisation
776tool \code{animate} of output from this example.
777\begin{figure}[hbt]
778  \centerline{\includegraphics[height=75mm]
779    {graphics/channel1.png}}%
780
781  \caption{Simple channel example viewed with the ANUGA viewer.}
782  \label{fig:channel1}
783\end{figure}
784
785
786\subsection{Changing boundary conditions on the fly}
787\label{sec:change boundary}
788
789Here is the code for the second version of the channel flow \file{channel2.py}:
790\verbatiminput{demos/channel2.py}
791This example differs from the first version in that a constant outflow boundary condition has
792been defined
793{\small \begin{verbatim}
794    Bo = Dirichlet_boundary([-5, 0, 0]) # Outflow
795\end{verbatim}}
796and that it is applied to the right hand side boundary when the water level there exceeds 0m.
797{\small \begin{verbatim}
798for t in domain.evolve(yieldstep = 0.2, finaltime = 40.0):
799    domain.write_time()
800
801    if domain.get_quantity('stage').get_values(interpolation_points=[[10, 2.5]]) > 0:
802        print 'Stage > 0: Changing to outflow boundary'
803        domain.set_boundary({'right': Bo})
804\end{verbatim}}
805\label{sec:change boundary code}
806
807The if statement in the timestepping loop (evolve) gets the quantity
808\code{stage} and obtain the interpolated value at the point (10m,
8092.5m) which is on the right boundary. If the stage exceeds 0m a
810message is printed and the old boundary condition at tag 'right' is
811replaced by the outflow boundary using the method
812{\small \begin{verbatim}
813    domain.set_boundary({'right': Bo})
814\end{verbatim}}
815This type of dynamically varying boundary could for example be
816used to model the
817breakdown of a sluice door when water exceeds a certain level.
818
819\subsection{Output}
820
821The text output from this example looks like this
822{\small \begin{verbatim}
823...
824Time = 15.4000, delta t in [0.03789902, 0.03789916], steps=6 (6)
825Time = 15.6000, delta t in [0.03789896, 0.03789908], steps=6 (6)
826Time = 15.8000, delta t in [0.03789891, 0.03789903], steps=6 (6)
827Stage > 0: Changing to outflow boundary
828Time = 16.0000, delta t in [0.02709050, 0.03789898], steps=6 (6)
829Time = 16.2000, delta t in [0.03789892, 0.03789904], steps=6 (6)
830...
831\end{verbatim}}
832
833
834\subsection{Flow through more complex topograhies}
835
836Here is the code for the third version of the channel flow \file{channel3.py}:
837\verbatiminput{demos/channel3.py}
838
839This example differs from the first two versions in that the topography
840contains obstacles.
841
842This is accomplished here by defining the function \code{topography} as follows
843{\small \begin{verbatim}
844def topography(x,y):
845    """Complex topography defined by a function of vectors x and y
846    """
847
848    z = -x/10
849
850    N = len(x)
851    for i in range(N):
852
853        # Step
854        if 10 < x[i] < 12:
855            z[i] += 0.4 - 0.05*y[i]
856
857        # Constriction
858        if 27 < x[i] < 29 and y[i] > 3:
859            z[i] += 2
860
861        # Pole
862        if (x[i] - 34)**2 + (y[i] - 2)**2 < 0.4**2:
863            z[i] += 2
864
865    return z
866\end{verbatim}}
867
868In addition, changing the resolution to dx=dy=0.1 creates a finer mesh resolving the new featurse better.
869
870A screenshot of this model at time == 15s is
871\begin{figure}[hbt]
872
873  \centerline{\includegraphics[height=75mm]
874    {graphics/channel3.png}}
875
876  \caption{More complex flow in a channel}
877  \label{fig:channel3}
878\end{figure}
879
880
881
882
883\clearpage
884
885%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
886
887\section{An Example with Real Data}
888\label{sec:realdataexample} The following discussion builds on the
889concepts introduced through the \file{runup.py} example and
890introduces a second example, \file{runcairns.py}.  This refers to
891a real-life scenario, in which the domain of interest surrounds the
892Cairns region. Two scenarios are given; firstly, a
893hypothetical tsunami wave is generated by a submarine mass failure
894situated on the edge of the continental shelf, and secondly, a fixed wave
895of given amplitude and period is introduced through the boundary.
896
897\subsection{Overview}
898As in the case of \file{runup.py}, the actions carried
899out by the program can be organised according to this outline:
900
901\begin{enumerate}
902
903   \item Set up a triangular mesh.
904
905   \item Set certain parameters governing the mode of
906operation of the model---specifying, for instance, where to store the
907model output.
908
909   \item Input various quantities describing physical measurements, such
910as the elevation, to be specified at each mesh point (vertex).
911
912   \item Set up the boundary conditions.
913
914   \item Carry out the evolution of the model through a series of time
915steps and output the results, providing a results file that can be
916visualised.
917
918\end{enumerate}
919
920
921
922\subsection{The Code}
923
924Here is the code for \file{runcairns.py}:
925
926\verbatiminput{demos/cairns/runcairns.py}
927
928In discussing the details of this example, we follow the outline
929given above, discussing each major step of the code in turn.
930
931\subsection{Establishing the Mesh}\index{mesh, establishing}
932
933One obvious way that the present example differs from
934\file{runup.py} is in the use of a more complex method to
935create the mesh. Instead of imposing a mesh structure on a
936rectangular grid, the technique used for this example involves
937building mesh structures inside polygons specified by the user,
938using a mesh-generator.
939
940In its simplest form, the mesh-generator creates the mesh within a single
941polygon whose vertices are at geographical locations specified by
942the user. The user specifies the \emph{resolution}---that is, the
943maximal area of a triangle used for triangulation---and a triangular
944mesh is created inside the polygon using a mesh generation engine.
945On any given platform, the same mesh will be returned.
946%Figure
947%\ref{fig:pentagon} shows a simple example of this, in which the
948%triangulation is carried out within a pentagon.
949
950
951%\begin{figure}[hbt]
952
953%  \caption{Mesh points are created inside the polygon}
954  %\label{fig:pentagon}
955%\end{figure}
956
957Boundary tags are not restricted to \code{`left'}, \code{`bottom'},
958\code{`right'} and \code{`top'}, as in the case of
959\file{runup.py}. Instead the user specifies a list of
960tags appropriate to the configuration being modelled.
961
962In addition, the mesh-generator provides a way to adapt to geographic or
963other features in the landscape, whose presence may require an
964increase in resolution. This is done by allowing the user to specify
965a number of \emph{interior polygons}, each with a specified
966resolution. It is also
967possible to specify one or more `holes'---that is, areas bounded by
968polygons in which no triangulation is required.
969
970%\begin{figure}[hbt]
971%  \caption{Interior meshes with individual resolution}
972%  \label{fig:interior meshes}
973%\end{figure}
974
975In its general form, the mesh-generator takes for its input a bounding
976polygon and (optionally) a list of interior polygons. The user
977specifies resolutions, both for the bounding polygon and for each of
978the interior polygons. Given this data, the mesh-generator first creates a
979triangular mesh with varying resolution.
980
981The function used to implement this process is
982\function{create\_mesh\_from\_regions}. Its arguments include the
983bounding polygon and its resolution, a list of boundary tags, and a
984list of pairs \code{[polygon, resolution]}, specifying the interior
985polygons and their resolutions.
986
987The resulting mesh is output to a \emph{mesh file}\index{mesh
988file}\label{def:mesh file}. This term is used to describe a file of
989a specific format used to store the data specifying a mesh. (There
990are in fact two possible formats for such a file: it can either be a
991binary file, with extension \code{.msh}, or an ASCII file, with
992extension \code{.tsh}. In the present case, the binary file format
993\code{.msh} is used. See Section \ref{sec:file formats} (page
994\pageref{sec:file formats}) for more on file formats.)
995
996In practice, the details of the polygons used are read from a
997separate file \file{project.py}. Here is a complete listing of
998\file{project.py}:
999
1000\verbatiminput{demos/cairns/project.py}
1001
1002Figure \ref{fig:cairns3d} illustrates the landscape of the region
1003for the Cairns example. Understanding the landscape is important in
1004determining the location and resolution of interior polygons. The
1005supporting data is found in the ASCII grid, \code{cairns.asc}, which
1006has been sourced from the publically available Australian Bathymetry
1007and Topography Grid 2005, \cite{grid250}. The required resolution
1008for inundation modelling will depend on the underlying topography and
1009bathymetry; as the terrain becomes more complex, the desired resolution
1010would decrease to the order of tens of metres.
1011
1012\begin{figure}[hbt]
1013\centerline{\includegraphics[scale=0.5]{graphics/cairns3.jpg}}
1014\caption{Landscape of the Cairns scenario.}
1015\label{fig:cairns3d}
1016
1017\end{figure}
1018The following statements are used to read in the specific polygons
1019from \code{project.cairns} and assign a defined resolution to
1020each polygon.
1021
1022{\small \begin{verbatim}
1023    islands_res = 100000
1024    cairns_res = 100000
1025    shallow_res = 500000
1026    interior_regions = [[project.poly_cairns, cairns_res],
1027                        [project.poly_island0, islands_res],
1028                        [project.poly_island1, islands_res],
1029                        [project.poly_island2, islands_res],
1030                        [project.poly_island3, islands_res],
1031                        [project.poly_shallow, shallow_res]]
1032\end{verbatim}}
1033
1034Figure \ref{fig:cairnspolys}
1035illustrates the polygons used for the Cairns scenario.
1036
1037\begin{figure}[hbt]
1038
1039  \centerline{\includegraphics[scale=0.5]
1040      {graphics/cairnsmodel.jpg}}
1041  \caption{Interior and bounding polygons for the Cairns example.}
1042  \label{fig:cairnspolys}
1043\end{figure}
1044
1045The statement
1046
1047
1048{\small \begin{verbatim}
1049remainder_res = 10000000
1050create_mesh_from_regions(project.bounding_polygon,
1051                         boundary_tags={'top': [0],
1052                                        'ocean_east': [1],
1053                                        'bottom': [2],
1054                                        'onshore': [3]},
1055                         maximum_triangle_area=remainder_res,
1056                         filename=meshname,
1057                         interior_regions=interior_regions,
1058                         use_cache=True,
1059                         verbose=True)
1060\end{verbatim}}
1061is then used to create the mesh, taking the bounding polygon to be
1062the polygon \code{bounding\_polygon} specified in \file{project.py}.
1063The argument \code{boundary\_tags} assigns a dictionary, whose keys
1064are the names of the boundary tags used for the bounding
1065polygon---\code{`top'}, \code{`ocean\_east'}, \code{`bottom'}, and
1066\code{`onshore'}--- and whose values identify the indices of the
1067segments associated with each of these tags. (The value associated
1068with each boundary tag is a one-element list.)
1069If polygons intersect, or edges coincide the resolution may be undefined in some regions.
1070Use the underlying mesh interface for such cases. See Section
1071\ref{sec:mesh interface}.
1072
1073Note that every point on each polygon defining the mesh will be used as vertices in triangles.
1074Consequently, polygons with points very close together will cause triangles with very small
1075areas to be generated irrespective of the requested resolution.
1076Make sure points on polygons are spaced to be no closer than the smallest resolution requested.
1077
1078
1079\subsection{Initialising the Domain}
1080
1081As with \file{runup.py}, once we have created the mesh, the next
1082step is to create the data structure \code{domain}. We did this for
1083\file{runup.py} by inputting lists of points and triangles and
1084specifying the boundary tags directly. However, in the present case,
1085we use a method that works directly with the mesh file
1086\code{meshname}, as follows:
1087
1088
1089{\small \begin{verbatim}
1090    domain = Domain(meshname, use_cache=True, verbose=True)
1091\end{verbatim}}
1092
1093Providing a filename instead of the lists used in \file{runup.py}
1094above causes \code{Domain} to convert a mesh file \code{meshname}
1095into an instance of \code{Domain}, allowing us to use methods like
1096\method{set\_quantity} to set quantities and to apply other
1097operations.
1098
1099%(In principle, the
1100%second argument of \function{pmesh\_to\_domain\_instance} can be any
1101%subclass of \class{Domain}, but for applications involving the
1102%shallow-water wave equation, the second argument of
1103%\function{pmesh\_to\_domain\_instance} can always be set simply to
1104%\class{Domain}.)
1105
1106The following statements specify a basename and data directory, and
1107identify quantities to be stored. For the first two, values are
1108taken from \file{project.py}.
1109
1110{\small \begin{verbatim}
1111    domain.set_name(project.basename)
1112    domain.set_datadir(project.outputdir)
1113    domain.set_quantities_to_be_stored(['stage', 'xmomentum',
1114        'ymomentum'])
1115\end{verbatim}}
1116
1117
1118\subsection{Initial Conditions}
1119Quantities for \file{runcairns.py} are set
1120using similar methods to those in \file{runup.py}. However,
1121in this case, many of the values are read from the auxiliary file
1122\file{project.py} or, in the case of \code{elevation}, from an
1123ancillary points file.
1124
1125
1126
1127\subsubsection{Stage}
1128
1129For the scenario we are modelling in this case, we use a callable
1130object \code{tsunami\_source}, assigned by means of a function
1131\function{slide\_tsunami}. This is similar to how we set elevation in
1132\file{runup.py} using a function---however, in this case the
1133function is both more complex and more interesting.
1134
1135The function returns the water displacement for all \code{x} and
1136\code{y} in the domain. The water displacement is a double Gaussian
1137function that depends on the characteristics of the slide (length,
1138width, thickness, slope, etc), its location (origin) and the depth at that
1139location. For this example, we choose to apply the slide function
1140at a specified time into the simulation.
1141
1142\subsubsection{Friction}
1143
1144We assign the friction exactly as we did for \file{runup.py}:
1145
1146{\small \begin{verbatim}
1147    domain.set_quantity('friction', 0.0)
1148\end{verbatim}}
1149
1150
1151\subsubsection{Elevation}
1152
1153The elevation is specified by reading data from a file:
1154
1155{\small \begin{verbatim}
1156    domain.set_quantity('elevation',
1157                        filename = project.dem_name + '.pts',
1158                        use_cache = True,
1159                        verbose = True)
1160\end{verbatim}}
1161
1162%However, before this step can be executed, some preliminary steps
1163%are needed to prepare the file from which the data is taken. Two
1164%source files are used for this data---their names are specified in
1165%the file \file{project.py}, in the variables \code{coarsedemname}
1166%and \code{finedemname}. They contain `coarse' and `fine' data,
1167%respectively---that is, data sampled at widely spaced points over a
1168%large region and data sampled at closely spaced points over a
1169%smaller subregion. The data in these files is combined through the
1170%statement
1171
1172%{\small \begin{verbatim}
1173%combine_rectangular_points_files(project.finedemname + '.pts',
1174%                                 project.coarsedemname + '.pts',
1175%                                 project.combineddemname + '.pts')
1176%\end{verbatim}}
1177%The effect of this is simply to combine the datasets by eliminating
1178%any coarse data associated with points inside the smaller region
1179%common to both datasets. The name to be assigned to the resulting
1180%dataset is also derived from the name stored in the variable
1181%\code{combinedname} in the file \file{project.py}.
1182
1183\subsection{Boundary Conditions}\index{boundary conditions}
1184
1185Setting boundaries follows a similar pattern to the one used for
1186\file{runup.py}, except that in this case we need to associate a
1187boundary type with each of the
1188boundary tag names introduced when we established the mesh. In place of the four
1189boundary types introduced for \file{runup.py}, we use the reflective
1190boundary for each of the
1191eight tagged segments defined by \code{create_mesh_from_regions}:
1192
1193{\small \begin{verbatim}
1194Bd = Dirichlet_boundary([0.0,0.0,0.0])
1195domain.set_boundary( {'ocean_east': Bd, 'bottom': Bd, 'onshore': Bd,
1196                          'top': Bd} )
1197\end{verbatim}}
1198
1199\subsection{Evolution}
1200
1201With the basics established, the running of the `evolve' step is
1202very similar to the corresponding step in \file{runup.py}. For the slide
1203scenario,
1204the simulation is run for 5000 seconds with the output stored every ten seconds.
1205For this example, we choose to apply the slide at 60 seconds into the simulation.
1206
1207{\small \begin{verbatim}
1208    import time t0 = time.time()
1209
1210
1211    for t in domain.evolve(yieldstep = 10, finaltime = 60):
1212            domain.write_time()
1213            domain.write_boundary_statistics(tags = 'ocean_east')
1214
1215        # add slide
1216        thisstagestep = domain.get_quantity('stage')
1217        if allclose(t, 60):
1218            slide = Quantity(domain)
1219            slide.set_values(tsunami_source)
1220            domain.set_quantity('stage', slide + thisstagestep)
1221
1222        for t in domain.evolve(yieldstep = 10, finaltime = 5000,
1223                               skip_initial_step = True):
1224            domain.write_time()
1225        domain.write_boundary_statistics(tags = 'ocean_east')
1226\end{verbatim}}
1227
1228For the fixed wave scenario, the simulation is run to 10000 seconds,
1229with the first half of the simulation stored at two minute intervals,
1230and the second half of the simulation stored at ten second intervals.
1231This functionality is especially convenient as it allows the detailed
1232parts of the simulation to be viewed at higher time resolution.
1233
1234
1235{\small \begin{verbatim}
1236
1237# save every two mins leading up to wave approaching land
1238    for t in domain.evolve(yieldstep = 120, finaltime = 5000):
1239        domain.write_time()
1240        domain.write_boundary_statistics(tags = 'ocean_east')
1241
1242    # save every 30 secs as wave starts inundating ashore
1243    for t in domain.evolve(yieldstep = 10, finaltime = 10000,
1244                           skip_initial_step = True):
1245        domain.write_time()
1246        domain.write_boundary_statistics(tags = 'ocean_east')
1247
1248\end{verbatim}}
1249
1250\section{Exploring the Model Output}
1251
1252Now that the scenario has been run, the user can view the output in a number of ways.
1253As described earlier, the user may run animate to view a three-dimensional representation
1254of the simulation.
1255
1256The user may also be interested in a maximum inundation map. This simply shows the
1257maximum water depth over the domain and is achieved with the function sww2dem (described in
1258Section \ref{sec:basicfileconversions}).
1259\file{ExportResults.py} demonstrates how this function can be used:
1260
1261\verbatiminput{demos/cairns/ExportResults.py}
1262
1263The script generates an maximum water depth ASCII grid at a defined
1264resolution (here 100 m$^2$) which can then be viewed in a GIS environment, for
1265example. The parameters used in the function are defined in \file{project.py}.
1266Figures \ref{fig:maxdepthcairnsslide} and \ref{fig:maxdepthcairnsfixedwave} show
1267the maximum water depth within the defined region for the slide and fixed wave scenario
1268respectively.
1269The user could develop a maximum absolute momentum or other expressions which can be
1270derived from the quantities.
1271
1272\begin{figure}[hbt]
1273\centerline{\includegraphics[scale=0.5]{graphics/slidedepth.jpg}}
1274\caption{Maximum inundation map for the Cairns side scenario.}
1275\label{fig:maxdepthcairnsslide}
1276\end{figure}
1277
1278\begin{figure}[hbt]
1279\centerline{\includegraphics[scale=0.5]{graphics/fixedwavedepth.jpg}}
1280\caption{Maximum inundation map for the Cairns fixed wave scenario.}
1281\label{fig:maxdepthcairnsfixedwave}
1282\end{figure}
1283
1284The user may also be interested in interrogating the solution at a particular spatial
1285location to understand the behaviour of the system through time. To do this, the user
1286must first define the locations of interest. A number of locations have been
1287identified for the Cairns scenario, as shown in Figure \ref{fig:cairnsgauges}.
1288
1289\begin{figure}[hbt]
1290\centerline{\includegraphics[scale=0.5]{graphics/cairnsgauges.jpg}}
1291\caption{Point locations to show time series information for the Cairns scenario.}
1292\label{fig:cairnsgauges}
1293\end{figure}
1294
1295These locations
1296must be stored in either a .csv or .txt file. The corresponding .csv file for
1297the gauges shown in Figure \ref{fig:cairnsgauges} is \file{gauges.csv}
1298
1299\verbatiminput{demos/cairns/gauges.csv}.
1300
1301Header information has been included to identify the location in terms of eastings and
1302northings, and each gauge is given a name. The elevation column can be zero here.
1303This information is then passed to the function sww2timeseries (shown in
1304\file{GetTimeseries.py} which generates figures for
1305each desired quantity for each point location.
1306
1307\verbatiminput{demos/cairns/GetTimeseries.py}
1308
1309Here, the time series for the quantities stage and speed will be generated for
1310each gauge defined in the gauge file. Typically, stage is used over depth, particularly
1311for offshore gauges. In being able to interpret the output for onshore gauges however,
1312we use depth rather than stage. As an example output,
1313Figure \ref{fig:reef} shows the time series for the quantity stage (or depth for
1314onshore gauges) for the Elford Reef location for the slide scenario.
1315
1316\begin{figure}[hbt]
1317\centerline{\includegraphics[scale=0.5]{graphics/gaugeElfordReefslide.png}}
1318\caption{Time series information of the quantity depth for the Elford Reef location for the slide scenario.}
1319\label{fig:reef}
1320\end{figure}
1321
1322Note, the user may choose to compare the output for each scenario by updating
1323the \code{production\_dirs} as required. For example,
1324
1325{\small \begin{verbatim}
1326
1327    production_dirs = {'slide': 'Slide',
1328                       'fixed_wave': 'Fixed Wave'}
1329
1330\end{verbatim}}
1331
1332In this case, the time series output for Elford Reef would be:
1333
1334\begin{figure}[hbt]
1335\centerline{\includegraphics[scale=0.5]{graphics/gaugeElfordReefboth.png}}
1336\caption{Time series information of the quantity depth for the Elford Reef location for the slide and fixed wave scenario.}
1337\label{fig:reefboth}
1338\end{figure}
1339
1340
1341%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
1342%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
1343
1344\chapter{\anuga Public Interface}
1345\label{ch:interface}
1346
1347This chapter gives an overview of the features of \anuga available
1348to the user at the public interface. These are grouped under the
1349following headings, which correspond to the outline of the examples
1350described in Chapter \ref{ch:getstarted}:
1351
1352\begin{itemize}
1353    \item Establishing the Mesh
1354    \item Initialising the Domain
1355    \item Specifying the Quantities
1356    \item Initial Conditions
1357    \item Boundary Conditions
1358    \item Forcing Functions
1359    \item Evolution
1360\end{itemize}
1361
1362The listings are intended merely to give the reader an idea of what
1363each feature is, where to find it and how it can be used---they do
1364not give full specifications; for these the reader
1365may consult the code. The code for every function or class contains
1366a documentation string, or `docstring', that specifies the precise
1367syntax for its use. This appears immediately after the line
1368introducing the code, between two sets of triple quotes.
1369
1370Each listing also describes the location of the module in which
1371the code for the feature being described can be found. All modules
1372are in the folder \file{inundation} or one of its subfolders, and the
1373location of each module is described relative to \file{inundation}. Rather
1374than using pathnames, whose syntax depends on the operating system,
1375we use the format adopted for importing the function or class for
1376use in Python code. For example, suppose we wish to specify that the
1377function \function{create\_mesh\_from\_regions} is in a module called
1378\module{mesh\_interface} in a subfolder of \module{inundation} called
1379\code{pmesh}. In Linux or Unix syntax, the pathname of the file
1380containing the function, relative to \file{inundation}, would be
1381
1382\begin{center}
1383%    \code{pmesh/mesh\_interface.py}
1384    \code{pmesh}$\slash$\code{mesh\_interface.py}
1385\end{center}
1386\label{sec:mesh interface}
1387
1388while in Windows syntax it would be
1389
1390\begin{center}
1391    \code{pmesh}$\backslash$\code{mesh\_interface.py}
1392\end{center}
1393
1394Rather than using either of these forms, in this chapter we specify
1395the location simply as \code{pmesh.mesh\_interface}, in keeping with
1396the usage in the Python statement for importing the function,
1397namely:
1398\begin{center}
1399    \code{from pmesh.mesh\_interface import create\_mesh\_from\_regions}
1400\end{center}
1401
1402Each listing details the full set of parameters for the class or
1403function; however, the description is generally limited to the most
1404important parameters and the reader is again referred to the code
1405for more details.
1406
1407The following parameters are common to many functions and classes
1408and are omitted from the descriptions given below:
1409
1410%\begin{center}
1411\begin{tabular}{ll}  %\hline
1412%\textbf{Name } & \textbf{Description}\\
1413%\hline
1414\emph{use\_cache} & Specifies whether caching is to be used for improved performance. See Section \ref{sec:caching} for details on the underlying caching functionality\\
1415\emph{verbose} & If \code{True}, provides detailed terminal output
1416to the user\\  % \hline
1417\end{tabular}
1418%\end{center}
1419
1420\section{Mesh Generation}
1421
1422Before discussing the part of the interface relating to mesh
1423generation, we begin with a description of a simple example of a
1424mesh and use it to describe how mesh data is stored.
1425
1426\label{sec:meshexample} Figure \ref{fig:simplemesh} represents a
1427very simple mesh comprising just 11 points and 10 triangles.
1428
1429
1430\begin{figure}[h]
1431  \begin{center}
1432    \includegraphics[width=90mm, height=90mm]{triangularmesh.jpg}
1433  \end{center}
1434
1435  \caption{A simple mesh}
1436  \label{fig:simplemesh}
1437\end{figure}
1438
1439
1440The variables \code{points}, \code{vertices} and \code{boundary}
1441represent the data displayed in Figure \ref{fig:simplemesh} as
1442follows. The list \code{points} stores the coordinates of the
1443points, and may be displayed schematically as in Table
1444\ref{tab:points}.
1445
1446
1447\begin{table}
1448  \begin{center}
1449    \begin{tabular}[t]{|c|cc|} \hline
1450      index & \code{x} & \code{y}\\  \hline
1451      0 & 1 & 1\\
1452      1 & 4 & 2\\
1453      2 & 8 & 1\\
1454      3 & 1 & 3\\
1455      4 & 5 & 5\\
1456      5 & 8 & 6\\
1457      6 & 11 & 5\\
1458      7 & 3 & 6\\
1459      8 & 1 & 8\\
1460      9 & 4 & 9\\
1461      10 & 10 & 7\\  \hline
1462    \end{tabular}
1463  \end{center}
1464
1465  \caption{Point coordinates for mesh in
1466    Figure \protect \ref{fig:simplemesh}}
1467  \label{tab:points}
1468\end{table}
1469
1470The list \code{vertices} specifies the triangles that make up the
1471mesh. It does this by specifying, for each triangle, the indices
1472(the numbers shown in the first column above) that correspond to the
1473three points at its vertices, taken in an anti-clockwise order
1474around the triangle. Thus, in the example shown in Figure
1475\ref{fig:simplemesh}, the variable \code{vertices} contains the
1476entries shown in Table \ref{tab:vertices}. The starting point is
1477arbitrary so triangle $(0,1,3)$ is considered the same as $(1,3,0)$
1478and $(3,0,1)$.
1479
1480
1481\begin{table}
1482  \begin{center}
1483    \begin{tabular}{|c|ccc|} \hline
1484      index & \multicolumn{3}{c|}{\code{vertices}}\\ \hline
1485      0 & 0 & 1 & 3\\
1486      1 & 1 & 2 & 4\\
1487      2 & 2 & 5 & 4\\
1488      3 & 2 & 6 & 5\\
1489      4 & 4 & 5 & 9\\
1490      5 & 4 & 9 & 7\\
1491      6 & 3 & 4 & 7\\
1492      7 & 7 & 9 & 8\\
1493      8 & 1 & 4 & 3\\
1494      9 & 5 & 10 & 9\\  \hline
1495    \end{tabular}
1496  \end{center}
1497
1498  \caption{Vertices for mesh in Figure \protect \ref{fig:simplemesh}}
1499  \label{tab:vertices}
1500\end{table}
1501
1502Finally, the variable \code{boundary} identifies the boundary
1503triangles and associates a tag with each.
1504
1505\refmodindex[pmesh.meshinterface]{pmesh.mesh\_interface}\label{sec:meshgeneration}
1506
1507\begin{funcdesc}  {create\_mesh\_from\_regions}{bounding_polygon,
1508                             boundary_tags,
1509                             maximum_triangle_area,
1510                             filename=None,
1511                             interior_regions=None,
1512                             poly_geo_reference=None,
1513                             mesh_geo_reference=None,
1514                             minimum_triangle_angle=28.0}
1515Module: \module{pmesh.mesh\_interface}
1516
1517This function allows a user to initiate the automatic creation of a
1518mesh inside a specified polygon (input \code{bounding_polygon}).
1519Among the parameters that can be set are the \emph{resolution}
1520(maximal area for any triangle in the mesh) and the minimal angle
1521allowable in any triangle. The user can specify a number of internal
1522polygons within each of which the resolution of the mesh can be
1523specified. \code{interior_regions} is a paired list containing the
1524interior polygon and its resolution.  Additionally, the user specifies
1525a list of boundary tags, one for each edge of the bounding polygon.
1526
1527\textbf{WARNING}. Note that the dictionary structure used for the
1528parameter \code{boundary\_tags} is different from that used for the
1529variable \code{boundary} that occurs in the specification of a mesh.
1530In the case of \code{boundary}, the tags are the \emph{values} of
1531the dictionary, whereas in the case of \code{boundary_tags}, the
1532tags are the \emph{keys} and the \emph{value} corresponding to a
1533particular tag is a list of numbers identifying boundary edges
1534labelled with that tag. Because of this, it is theoretically
1535possible to assign the same edge to more than one tag. However, an
1536attempt to do this will cause an error.
1537
1538\textbf{WARNING}. Do not have polygon lines cross or be on-top of each
1539    other. This can result in regions of unspecified resolutions. Do
1540    not have polygon close to each other. This can result in the area
1541    between the polygons having small triangles.  For more control
1542    over the mesh outline use the methods described below.
1543   
1544\end{funcdesc}
1545
1546
1547
1548\subsection{Advanced mesh generation}
1549
1550For more control over the creation of the mesh outline, use the
1551methods of the class \class{Mesh}.
1552
1553
1554\begin{classdesc}  {Mesh}{userSegments=None,
1555                 userVertices=None,
1556                 holes=None,
1557                 regions=None}
1558Module: \module{pmesh.mesh}
1559
1560A class used to build a mesh outline and generate a two-dimensional
1561triangular mesh. The mesh outline is used to describe features on the
1562mesh, such as the mesh boundary. Many of this classes methods are used
1563to build a mesh outline, such as \code{add\_vertices} and
1564\code{add\_region\_from\_polygon}.
1565
1566\end{classdesc}
1567
1568
1569\subsubsection{Key Methods of Class Mesh}
1570
1571
1572\begin{methoddesc} {add\_hole}{x,y}
1573Module: \module{pmesh.mesh},  Class: \class{Mesh}
1574
1575This method is used to build the mesh outline.  It defines a hole,
1576when the boundary of the hole has already been defined, by selecting a
1577point within the boundary.
1578
1579\end{methoddesc}
1580
1581
1582\begin{methoddesc}  {add\_hole\_from\_polygon}{self, polygon, tags=None}
1583Module: \module{pmesh.mesh},  Class: \class{Mesh}
1584
1585This method is used to add a `hole' within a region ---that is, to
1586define a interior region where the triangular mesh will not be
1587generated---to a \class{Mesh} instance. The region boundary is described by
1588the polygon passed in.  Additionally, the user specifies a list of
1589boundary tags, one for each edge of the bounding polygon.
1590\end{methoddesc}
1591
1592
1593\begin{methoddesc}  {add\_points_and_segments}{self, points, segments,
1594    segment\_tags=None}
1595Module: \module{pmesh.mesh},  Class: \class{Mesh}
1596
1597This method is used to build the mesh outline. It adds points and
1598segments connecting the points.  A tag for each segment can optionally
1599be added.
1600
1601\end{methoddesc}
1602
1603\begin{methoddesc} {add\_region}{x,y}
1604Module: \module{pmesh.mesh},  Class: \class{Mesh}
1605
1606This method is used to build the mesh outline.  It defines a region,
1607when the boundary of the region has already been defined, by selecting
1608a point within the boundary.  A region instance is returned.  This can
1609be used to set the resolution.
1610
1611\end{methoddesc}
1612
1613\begin{methoddesc}  {add\_region\_from\_polygon}{self, polygon, tags=None,
1614                                max_triangle_area=None}
1615Module: \module{pmesh.mesh},  Class: \class{Mesh}
1616
1617This method is used to build the mesh outline.  It adds a region to a
1618\class{Mesh} instance.  Regions are commonly used to describe an area
1619with an increased density of triangles, by setting
1620\code{max_triangle_area}.  The
1621region boundary is described by the input \code{polygon}.  Additionally, the
1622user specifies a list of segment tags, one for each edge of the
1623bounding polygon.
1624
1625\end{methoddesc}
1626
1627
1628
1629
1630
1631\begin{methoddesc} {add\_vertices}{point_data}
1632Module: \module{pmesh.mesh},  Class: \class{Mesh}
1633
1634Add user vertices. The point_data can be a list of (x,y) values, a numeric
1635array or a geospatial_data instance.
1636\end{methoddesc}
1637
1638\begin{methoddesc} {auto\_segment}{raw_boundary=raw_boundary,
1639                    remove_holes=remove_holes,
1640                    smooth_indents=smooth_indents,
1641                    expand_pinch=expand_pinch}
1642Module: \module{pmesh.mesh},  Class: \class{Mesh}
1643
1644Add segments between some of the user vertices to give the vertices an
1645outline.  The outline is an alpha shape. This method is
1646useful since a set of user vertices need to be outlined by segments
1647before generate_mesh is called.
1648
1649\end{methoddesc}
1650
1651\begin{methoddesc}  {export\_mesh_file}{self,ofile}
1652Module: \module{pmesh.mesh},  Class: \class{Mesh}
1653
1654This method is used to save the mesh to a file. \code{ofile} is the
1655name of the mesh file to be written, including the extension.  Use
1656the extension \code{.msh} for the file to be in NetCDF format and
1657\code{.tsh} for the file to be ASCII format.
1658\end{methoddesc}
1659
1660\begin{methoddesc}  {generate\_mesh}{self,
1661                      maximum_triangle_area=None,
1662                      minimum_triangle_angle=28.0,
1663                      verbose=False}
1664Module: \module{pmesh.mesh},  Class: \class{Mesh}
1665
1666This method is used to generate the triangular mesh.  The  maximal
1667area of any triangle in the mesh can be specified, which is used to
1668control the triangle density, along with the
1669minimum angle in any triangle.
1670\end{methoddesc}
1671
1672
1673
1674\begin{methoddesc}  {import_ungenerate_file}{self,ofile, tag=None}
1675Module: \module{pmesh.mesh},  Class: \class{Mesh}
1676
1677This method is used to import a polygon file in the ungenerate
1678format, which is used by arcGIS. The polygons from the file are converted to
1679vertices and segments. \code{ofile} is the name of the polygon file.
1680\code{tag} is the tag given to all the polygon's segments.
1681
1682This function can be used to import building footprints.
1683\end{methoddesc}
1684
1685%%%%%%
1686\section{Initialising the Domain}
1687
1688%Include description of the class Domain and the module domain.
1689
1690%FIXME (Ole): This is also defined in a later chapter
1691%\declaremodule{standard}{...domain}
1692
1693\begin{classdesc} {Domain} {source=None,
1694                 triangles=None,
1695                 boundary=None,
1696                 conserved_quantities=None,
1697                 other_quantities=None,
1698                 tagged_elements=None,
1699                 use_inscribed_circle=False,
1700                 mesh_filename=None,
1701                 use_cache=False,
1702                 verbose=False,
1703                 full_send_dict=None,
1704                 ghost_recv_dict=None,
1705                 processor=0,
1706                 numproc=1}
1707Module: \refmodule{abstract_2d_finite_volumes.domain}
1708
1709This class is used to create an instance of a data structure used to
1710store and manipulate data associated with a mesh. The mesh is
1711specified either by assigning the name of a mesh file to
1712\code{source} or by specifying the points, triangle and boundary of the
1713mesh.
1714\end{classdesc}
1715
1716\subsection{Key Methods of Domain}
1717
1718\begin{methoddesc} {set\_name}{name}
1719    Module: \refmodule{abstract\_2d\_finite\_volumes.domain},
1720    page \pageref{mod:domain}
1721
1722    Assigns the name \code{name} to the domain.
1723\end{methoddesc}
1724
1725\begin{methoddesc} {get\_name}{}
1726    Module: \module{abstract\_2d\_finite\_volumes.domain}
1727
1728    Returns the name assigned to the domain by \code{set\_name}. If no name has been
1729    assigned, returns \code{`domain'}.
1730\end{methoddesc}
1731
1732\begin{methoddesc} {set\_datadir}{name}
1733    Module: \module{abstract\_2d\_finite\_volumes.domain}
1734
1735    Specifies the directory used for SWW files, assigning it to the
1736    pathname \code{name}. The default value, before
1737    \code{set\_datadir} has been run, is the value \code{default\_datadir}
1738    specified in \code{config.py}.
1739
1740    Since different operating systems use different formats for specifying pathnames,
1741    it is necessary to specify path separators using the Python code \code{os.sep}, rather than
1742    the operating-specific ones such as `$\slash$' or `$\backslash$'.
1743    For this to work you will need to include the statement \code{import os}
1744    in your code, before the first appearance of \code{set\_datadir}.
1745
1746    For example, to set the data directory to a subdirectory
1747    \code{data} of the directory \code{project}, you could use
1748    the statements:
1749
1750    {\small \begin{verbatim}
1751        import os
1752        domain.set_datadir{'project' + os.sep + 'data'}
1753    \end{verbatim}}
1754\end{methoddesc}
1755
1756\begin{methoddesc} {get\_datadir}{}
1757    Module: \module{abstract\_2d\_finite\_volumes.domain}
1758
1759    Returns the data directory set by \code{set\_datadir} or,
1760    if \code{set\_datadir} has not
1761    been run, returns the value \code{default\_datadir} specified in
1762    \code{config.py}.
1763\end{methoddesc}
1764
1765
1766\begin{methoddesc} {set\_minimum_allowed_height}{}
1767    Module: \module{shallow\_water.shallow\_water\_domain}
1768
1769    Set the minimum depth (in meters) that will be recognised in
1770    the numerical scheme (including limiters and flux computations)
1771
1772    Default value is $10^{-3}$ m, but by setting this to a greater value,
1773    e.g.\ for large scale simulations, the computation time can be
1774    significantly reduced.
1775\end{methoddesc}
1776
1777
1778\begin{methoddesc} {set\_minimum_storable_height}{}
1779    Module: \module{shallow\_water.shallow\_water\_domain}
1780
1781    Sets the minimum depth that will be recognised when writing
1782    to an sww file. This is useful for removing thin water layers
1783    that seems to be caused by friction creep.
1784\end{methoddesc}
1785
1786
1787\begin{methoddesc} {set\_maximum_allowed_speed}{}
1788    Module: \module{shallow\_water.shallow\_water\_domain}
1789
1790    Set the maximum particle speed that is allowed in water
1791    shallower than minimum_allowed_height. This is useful for
1792    controlling speeds in very thin layers of water and at the same time
1793    allow some movement avoiding pooling of water.
1794\end{methoddesc}
1795
1796
1797\begin{methoddesc} {set\_time}{time=0.0}
1798    Module: \module{abstract\_2d\_finite\_volumes.domain}
1799
1800    Sets the initial time, in seconds, for the simulation. The
1801    default is 0.0.
1802\end{methoddesc}
1803
1804\begin{methoddesc} {set\_default\_order}{n}
1805    Sets the default (spatial) order to the value specified by
1806    \code{n}, which must be either 1 or 2. (Assigning any other value
1807    to \code{n} will cause an error.)
1808\end{methoddesc}
1809
1810
1811\begin{methoddesc} {set\_store\_vertices\_uniquely}{flag}
1812Decide whether vertex values should be stored uniquely as
1813computed in the model or whether they should be reduced to one
1814value per vertex using averaging.
1815
1816Triangles stored in the sww file can be discontinuous reflecting
1817the internal representation of the finite-volume scheme
1818(this is a feature allowing for arbitrary steepness).
1819However, for visual purposes and also for use with \code{Field\_boundary} 
1820(and \code{File\_boundary}) it is often desirable to store triangles
1821with values at each vertex point as the average of the potentially
1822discontinuous numbers found at vertices of different triangles sharing the
1823same vertex location. 
1824 
1825Storing one way or the other is controlled in ANUGA through the method
1826\code{domain.store\_vertices\_uniquely}. Options are
1827\begin{itemize} 
1828  \item \code{domain.store\_vertices\_uniquely(True)}: Allow discontinuities in the sww file
1829  \item \code{domain.store\_vertices\_uniquely(False)}: (Default).
1830  Average values
1831  to ensure continuity in sww file. The latter also makes for smaller
1832  sww files.
1833\end{itemize}   
1834
1835\end{methoddesc}
1836
1837
1838% Structural methods
1839\begin{methoddesc}{get\_nodes}{absolute=False}
1840    Return x,y coordinates of all nodes in mesh.
1841
1842    The nodes are ordered in an Nx2 array where N is the number of nodes.
1843    This is the same format they were provided in the constructor
1844    i.e. without any duplication.
1845
1846    Boolean keyword argument absolute determines whether coordinates
1847    are to be made absolute by taking georeference into account
1848    Default is False as many parts of ANUGA expects relative coordinates.
1849\end{methoddesc}
1850
1851
1852\begin{methoddesc}{get\_vertex_coordinates}{absolute=False}
1853
1854    Return vertex coordinates for all triangles.
1855
1856    Return all vertex coordinates for all triangles as a 3*M x 2 array
1857    where the jth vertex of the ith triangle is located in row 3*i+j and
1858    M the number of triangles in the mesh.
1859
1860    Boolean keyword argument absolute determines whether coordinates
1861    are to be made absolute by taking georeference into account
1862    Default is False as many parts of ANUGA expects relative coordinates.
1863\end{methoddesc}
1864
1865
1866\begin{methoddesc}{get\_triangles}{indices=None}
1867
1868        Return Mx3 integer array where M is the number of triangles.
1869        Each row corresponds to one triangle and the three entries are
1870        indices into the mesh nodes which can be obtained using the method
1871        get\_nodes()
1872
1873        Optional argument, indices is the set of triangle ids of interest.
1874\end{methoddesc}
1875
1876\begin{methoddesc}{get\_disconnected\_triangles}{}
1877
1878Get mesh based on nodes obtained from get_vertex_coordinates.
1879
1880        Return array Mx3 array of integers where each row corresponds to
1881        a triangle. A triangle is a triplet of indices into
1882        point coordinates obtained from get_vertex_coordinates and each
1883        index appears only once.\\
1884
1885        This provides a mesh where no triangles share nodes
1886        (hence the name disconnected triangles) and different
1887        nodes may have the same coordinates.\\
1888
1889        This version of the mesh is useful for storing meshes with
1890        discontinuities at each node and is e.g. used for storing
1891        data in sww files.\\
1892
1893        The triangles created will have the format
1894
1895    {\small \begin{verbatim}
1896        [[0,1,2],
1897         [3,4,5],
1898         [6,7,8],
1899         ...
1900         [3*M-3 3*M-2 3*M-1]]
1901     \end{verbatim}}
1902\end{methoddesc}
1903
1904
1905
1906%%%%%%
1907\section{Initial Conditions}
1908\label{sec:Initial Conditions}
1909In standard usage of partial differential equations, initial conditions
1910refers to the values associated to the system variables (the conserved
1911quantities here) for \code{time = 0}. In setting up a scenario script
1912as described in Sections \ref{sec:simpleexample} and \ref{sec:realdataexample},
1913\code{set_quantity} is used to define the initial conditions of variables
1914other than the conserved quantities, such as friction. Here, we use the terminology
1915of initial conditions to refer to initial values for variables which need
1916prescription to solve the shallow water wave equation. Further, it must be noted
1917that \code{set_quantity} does not necessarily have to be used in the initial
1918condition setting; it can be used at any time throughout the simulation.
1919
1920\begin{methoddesc}{set\_quantity}{name,
1921    numeric = None,
1922    quantity = None,
1923    function = None,
1924    geospatial_data = None,
1925    filename = None,
1926    attribute_name = None,
1927    alpha = None,
1928    location = 'vertices',
1929    indices = None,
1930    verbose = False,
1931    use_cache = False}
1932  Module: \module{abstract\_2d\_finite\_volumes.domain}
1933  (see also \module{abstract\_2d\_finite\_volumes.quantity.set\_values})
1934
1935This function is used to assign values to individual quantities for a
1936domain. It is very flexible and can be used with many data types: a
1937statement of the form \code{domain.set\_quantity(name, x)} can be used
1938to define a quantity having the name \code{name}, where the other
1939argument \code{x} can be any of the following:
1940
1941\begin{itemize}
1942\item a number, in which case all vertices in the mesh gets that for
1943the quantity in question.
1944\item a list of numbers or a Numeric array ordered the same way as the mesh vertices.
1945\item a function (e.g.\ see the samples introduced in Chapter 2)
1946\item an expression composed of other quantities and numbers, arrays, lists (for
1947example, a linear combination of quantities, such as
1948\code{domain.set\_quantity('stage','elevation'+x))}
1949\item the name of a file from which the data can be read. In this case, the optional argument attribute\_name will select which attribute to use from the file. If left out, set\_quantity will pick one. This is useful in cases where there is only one attribute.
1950\item a geospatial dataset (See Section \ref{sec:geospatial}).
1951Optional argument attribute\_name applies here as with files.
1952\end{itemize}
1953
1954
1955Exactly one of the arguments
1956  numeric, quantity, function, points, filename
1957must be present.
1958
1959
1960Set quantity will look at the type of the second argument (\code{numeric}) and
1961determine what action to take.
1962
1963Values can also be set using the appropriate keyword arguments.
1964If x is a function, for example, \code{domain.set\_quantity(name, x)}, \code{domain.set\_quantity(name, numeric=x)}, and \code{domain.set\_quantity(name, function=x)}
1965are all equivalent.
1966
1967
1968Other optional arguments are
1969\begin{itemize}
1970\item \code{indices} which is a list of ids of triangles to which set\_quantity should apply its assignment of values.
1971\item \code{location} determines which part of the triangles to assign
1972  to. Options are 'vertices' (default), 'edges', 'unique vertices', and 'centroids'.
1973\end{itemize}
1974
1975%%%
1976\anuga provides a number of predefined initial conditions to be used
1977with \code{set\_quantity}. See for example callable object
1978\code{slump\_tsunami} below.
1979
1980\end{methoddesc}
1981
1982
1983
1984
1985\begin{funcdesc}{set_region}{tag, quantity, X, location='vertices'}
1986  Module: \module{abstract\_2d\_finite\_volumes.domain}
1987
1988  (see also \module{abstract\_2d\_finite\_volumes.quantity.set\_values})
1989
1990This function is used to assign values to individual quantities given
1991a regional tag.   It is similar to \code{set\_quantity}.
1992For example, if in the mesh-generator a regional tag of 'ditch' was
1993used, set\_region can be used to set elevation of this region to
1994-10m. X is the constant or function to be applied to the quantity,
1995over the tagged region.  Location describes how the values will be
1996applied.  Options are 'vertices' (default), 'edges', 'unique
1997vertices', and 'centroids'.
1998
1999This method can also be called with a list of region objects.  This is
2000useful for adding quantities in regions, and having one quantity
2001value based on another quantity. See  \module{abstract\_2d\_finite\_volumes.region} for
2002more details.
2003\end{funcdesc}
2004
2005
2006
2007
2008\begin{funcdesc}{slump_tsunami}{length, depth, slope, width=None, thickness=None,
2009                x0=0.0, y0=0.0, alpha=0.0,
2010                gravity=9.8, gamma=1.85,
2011                massco=1, dragco=1, frictionco=0, psi=0,
2012                dx=None, kappa=3.0, kappad=0.8, zsmall=0.01,
2013                domain=None,
2014                verbose=False}
2015Module: \module{shallow\_water.smf}
2016
2017This function returns a callable object representing an initial water
2018displacement generated by a submarine sediment failure. These failures can take the form of
2019a submarine slump or slide. In the case of a slide, use \code{slide_tsunami} instead.
2020
2021The arguments include as a minimum, the slump or slide length, the water depth to the centre of sediment
2022mass, and the bathymetric slope. Other slump or slide parameters can be included if they are known.
2023\end{funcdesc}
2024
2025
2026%%%
2027\begin{funcdesc}{file\_function}{filename,
2028    domain = None,
2029    quantities = None,
2030    interpolation_points = None,
2031    verbose = False,
2032    use_cache = False}
2033Module: \module{abstract\_2d\_finite\_volumes.util}
2034
2035Reads the time history of spatial data for
2036specified interpolation points from a NetCDF file (\code{filename})
2037and returns
2038a callable object. \code{filename} could be a \code{sww} file.
2039Returns interpolated values based on the input
2040file using the underlying \code{interpolation\_function}.
2041
2042\code{quantities} is either the name of a single quantity to be
2043interpolated or a list of such quantity names. In the second case, the resulting
2044function will return a tuple of values---one for each quantity.
2045
2046\code{interpolation\_points} is a list of absolute coordinates or a
2047geospatial object
2048for points at which values are sought.
2049
2050The model time stored within the file function can be accessed using
2051the method \code{f.get\_time()}
2052
2053
2054The underlying algorithm used is as follows:\\
2055Given a time series (i.e.\ a series of values associated with
2056different times), whose values are either just numbers or a set of
2057 numbers defined at the vertices of a triangular mesh (such as those
2058 stored in SWW files), \code{Interpolation\_function} is used to
2059 create a callable object that interpolates a value for an arbitrary
2060 time \code{t} within the model limits and possibly a point \code{(x,
2061 y)} within a mesh region.
2062
2063 The actual time series at which data is available is specified by
2064 means of an array \code{time} of monotonically increasing times. The
2065 quantities containing the values to be interpolated are specified in
2066 an array---or dictionary of arrays (used in conjunction with the
2067 optional argument \code{quantity\_names}) --- called
2068 \code{quantities}. The optional arguments \code{vertex\_coordinates}
2069 and \code{triangles} represent the spatial mesh associated with the
2070 quantity arrays. If omitted the function created by
2071 \code{Interpolation\_function} will be a function of \code{t} only.
2072
2073 Since, in practice, values need to be computed at specified points,
2074 the syntax allows the user to specify, once and for all, a list
2075 \code{interpolation\_points} of points at which values are required.
2076 In this case, the function may be called using the form \code{f(t,
2077 id)}, where \code{id} is an index for the list
2078 \code{interpolation\_points}.
2079
2080
2081\end{funcdesc}
2082
2083%%%
2084%% \begin{classdesc}{Interpolation\_function}{self,
2085%%     time,
2086%%     quantities,
2087%%     quantity_names = None,
2088%%     vertex_coordinates = None,
2089%%     triangles = None,
2090%%     interpolation_points = None,
2091%%     verbose = False}
2092%% Module: \module{abstract\_2d\_finite\_volumes.least\_squares}
2093
2094%% Given a time series (i.e.\ a series of values associated with
2095%% different times), whose values are either just numbers or a set of
2096%% numbers defined at the vertices of a triangular mesh (such as those
2097%% stored in SWW files), \code{Interpolation\_function} is used to
2098%% create a callable object that interpolates a value for an arbitrary
2099%% time \code{t} within the model limits and possibly a point \code{(x,
2100%% y)} within a mesh region.
2101
2102%% The actual time series at which data is available is specified by
2103%% means of an array \code{time} of monotonically increasing times. The
2104%% quantities containing the values to be interpolated are specified in
2105%% an array---or dictionary of arrays (used in conjunction with the
2106%% optional argument \code{quantity\_names}) --- called
2107%% \code{quantities}. The optional arguments \code{vertex\_coordinates}
2108%% and \code{triangles} represent the spatial mesh associated with the
2109%% quantity arrays. If omitted the function created by
2110%% \code{Interpolation\_function} will be a function of \code{t} only.
2111
2112%% Since, in practice, values need to be computed at specified points,
2113%% the syntax allows the user to specify, once and for all, a list
2114%% \code{interpolation\_points} of points at which values are required.
2115%% In this case, the function may be called using the form \code{f(t,
2116%% id)}, where \code{id} is an index for the list
2117%% \code{interpolation\_points}.
2118
2119%% \end{classdesc}
2120
2121%%%
2122%\begin{funcdesc}{set\_region}{functions}
2123%[Low priority. Will be merged into set\_quantity]
2124
2125%Module:\module{abstract\_2d\_finite\_volumes.domain}
2126%\end{funcdesc}
2127
2128
2129
2130%%%%%%
2131\section{Boundary Conditions}\index{boundary conditions}
2132
2133\anuga provides a large number of predefined boundary conditions,
2134represented by objects such as \code{Reflective\_boundary(domain)} and
2135\code{Dirichlet\_boundary([0.2, 0.0, 0.0])}, described in the examples
2136in Chapter 2. Alternatively, you may prefer to ``roll your own'',
2137following the method explained in Section \ref{sec:roll your own}.
2138
2139These boundary objects may be used with the function \code{set\_boundary} described below
2140to assign boundary conditions according to the tags used to label boundary segments.
2141
2142\begin{methoddesc}{set\_boundary}{boundary_map}
2143Module: \module{abstract\_2d\_finite\_volumes.domain}
2144
2145This function allows you to assign a boundary object (corresponding to a
2146pre-defined or user-specified boundary condition) to every boundary segment that
2147has been assigned a particular tag.
2148
2149This is done by specifying a dictionary \code{boundary\_map}, whose values are the boundary objects
2150and whose keys are the symbolic tags.
2151
2152\end{methoddesc}
2153
2154\begin{methoddesc} {get\_boundary\_tags}{}
2155Module: \module{abstract\_2d\_finite\_volumes.domain}
2156
2157Returns a list of the available boundary tags.
2158\end{methoddesc}
2159
2160%%%
2161\subsection{Predefined boundary conditions}
2162
2163\begin{classdesc}{Reflective\_boundary}{Boundary}
2164Module: \module{shallow\_water}
2165
2166Reflective boundary returns same conserved quantities as those present in
2167the neighbouring volume but reflected.
2168
2169This class is specific to the shallow water equation as it works with the
2170momentum quantities assumed to be the second and third conserved quantities.
2171\end{classdesc}
2172
2173%%%
2174\begin{classdesc}{Transmissive\_boundary}{domain = None}
2175Module: \module{abstract\_2d\_finite\_volumes.generic\_boundary\_conditions}
2176
2177A transmissive boundary returns the same conserved quantities as
2178those present in the neighbouring volume.
2179
2180The underlying domain must be specified when the boundary is instantiated.
2181\end{classdesc}
2182
2183%%%
2184\begin{classdesc}{Dirichlet\_boundary}{conserved_quantities=None}
2185Module: \module{abstract\_2d\_finite\_volumes.generic\_boundary\_conditions}
2186
2187A Dirichlet boundary returns constant values for each of conserved
2188quantities. In the example of \code{Dirichlet\_boundary([0.2, 0.0, 0.0])},
2189the \code{stage} value at the boundary is 0.2 and the \code{xmomentum} and
2190\code{ymomentum} at the boundary are set to 0.0. The list must contain
2191a value for each conserved quantity.
2192\end{classdesc}
2193
2194%%%
2195\begin{classdesc}{Time\_boundary}{domain = None, f = None}
2196Module: \module{abstract\_2d\_finite\_volumes.generic\_boundary\_conditions}
2197
2198A time-dependent boundary returns values for the conserved
2199quantities as a function \code{f(t)} of time. The user must specify
2200the domain to get access to the model time.
2201\end{classdesc}
2202
2203%%%
2204\begin{classdesc}{File\_boundary}{Boundary}
2205Module: \module{abstract\_2d\_finite\_volumes.generic\_boundary\_conditions}
2206
2207This method may be used if the user wishes to apply a SWW file or
2208a time series file to a boundary segment or segments.
2209The boundary values are obtained from a file and interpolated to the
2210appropriate segments for each conserved quantity.
2211\end{classdesc}
2212
2213
2214
2215%%%
2216\begin{classdesc}{Transmissive\_Momentum\_Set\_Stage\_boundary}{Boundary}
2217Module: \module{shallow\_water}
2218
2219This boundary returns same momentum conserved quantities as
2220those present in its neighbour volume but sets stage as in a Time\_boundary.
2221The underlying domain must be specified when boundary is instantiated
2222
2223This type of boundary is useful when stage is known at the boundary as a
2224function of time, but momenta (or speeds) aren't.
2225
2226This class is specific to the shallow water equation as it works with the
2227momentum quantities assumed to be the second and third conserved quantities.
2228\end{classdesc}
2229
2230
2231\begin{classdesc}{Dirichlet\_Discharge\_boundary}{Boundary}
2232Module: \module{shallow\_water}
2233
2234Sets stage (stage0)
2235Sets momentum (wh0) in the inward normal direction.
2236\end{classdesc}
2237
2238
2239
2240\subsection{User-defined boundary conditions}
2241\label{sec:roll your own}
2242
2243All boundary classes must inherit from the generic boundary class
2244\code{Boundary} and have a method called \code{evaluate} which must
2245take as inputs \code{self, vol\_id, edge\_id} where self refers to the
2246object itself and vol\_id and edge\_id are integers referring to
2247particular edges. The method must return a list of three floating point
2248numbers representing values for \code{stage},
2249\code{xmomentum} and \code{ymomentum}, respectively.
2250
2251The constructor of a particular boundary class may be used to specify
2252particular values or flags to be used by the \code{evaluate} method.
2253Please refer to the source code for the existing boundary conditions
2254for examples of how to implement boundary conditions.
2255
2256
2257
2258%\section{Forcing Functions}
2259%
2260%\anuga provides a number of predefined forcing functions to be used with .....
2261
2262
2263
2264
2265\section{Evolution}\index{evolution}
2266
2267  \begin{methoddesc}{evolve}{yieldstep = None, finaltime = None, duration = None, skip_initial_step = False}
2268
2269  Module: \module{abstract\_2d\_finite\_volumes.domain}
2270
2271  This function (a method of \class{domain}) is invoked once all the
2272  preliminaries have been completed, and causes the model to progress
2273  through successive steps in its evolution, storing results and
2274  outputting statistics whenever a user-specified period
2275  \code{yieldstep} is completed (generally during this period the
2276  model will evolve through several steps internally
2277  as the method forces the water speed to be calculated
2278  on successive new cells). The user
2279  specifies the total time period over which the evolution is to take
2280  place, by specifying values (in seconds) for either \code{duration}
2281  or \code{finaltime}, as well as the interval in seconds after which
2282  results are to be stored and statistics output.
2283
2284  You can include \method{evolve} in a statement of the type:
2285
2286  {\small \begin{verbatim}
2287      for t in domain.evolve(yieldstep, finaltime):
2288          <Do something with domain and t>
2289  \end{verbatim}}
2290
2291  \end{methoddesc}
2292
2293
2294
2295\subsection{Diagnostics}
2296\label{sec:diagnostics}
2297
2298
2299  \begin{funcdesc}{statistics}{}
2300  Module: \module{abstract\_2d\_finite\_volumes.domain}
2301
2302  \end{funcdesc}
2303
2304  \begin{funcdesc}{timestepping\_statistics}{}
2305  Module: \module{abstract\_2d\_finite\_volumes.domain}
2306
2307  Returns a string of the following type for each
2308  timestep:
2309
2310  \code{Time = 0.9000, delta t in [0.00598964, 0.01177388], steps=12
2311  (12)}
2312
2313  Here the numbers in \code{steps=12 (12)} indicate the number of steps taken and
2314  the number of first-order steps, respectively.\\
2315
2316  The optional keyword argument \code{track_speeds=True} will
2317  generate a histogram of speeds generated by each triangle. The
2318  speeds relate to the size of the timesteps used by ANUGA and
2319  this diagnostics may help pinpoint problem areas where excessive speeds
2320  are generated.
2321
2322  \end{funcdesc}
2323
2324
2325  \begin{funcdesc}{boundary\_statistics}{quantities = None, tags = None}
2326  Module: \module{abstract\_2d\_finite\_volumes.domain}
2327
2328  Returns a string of the following type when \code{quantities = 'stage'} and \code{tags = ['top', 'bottom']}:
2329
2330  {\small \begin{verbatim}
2331 Boundary values at time 0.5000:
2332    top:
2333        stage in [ -0.25821218,  -0.02499998]
2334    bottom:
2335        stage in [ -0.27098821,  -0.02499974]
2336  \end{verbatim}}
2337
2338  \end{funcdesc}
2339
2340
2341  \begin{funcdesc}{get\_quantity}{name, location='vertices', indices = None}
2342  Module: \module{abstract\_2d\_finite\_volumes.domain}
2343
2344  Allow access to individual quantities and their methods
2345
2346  \end{funcdesc}
2347
2348 
2349  \begin{funcdesc}{set\_quantities\_to\_be\_monitored}{}
2350  Module: \module{abstract\_2d\_finite\_volumes.domain}
2351
2352  Selects quantities and derived quantities for which extrema attained at internal timesteps
2353  will be collected.
2354 
2355  Information can be tracked in the evolve loop by printing \code{quantity\_statistics} and
2356  collected data will be stored in the sww file.
2357
2358  Optional parameters \code{polygon} and \code{time\_interval} may be specified to restrict the
2359  extremum computation.
2360  \end{funcdesc} 
2361   
2362  \begin{funcdesc}{quantity\_statistics}{}
2363  Module: \module{abstract\_2d\_finite\_volumes.domain}
2364
2365  Reports on extrema attained by selected quantities.
2366 
2367  Returns a string of the following type for each
2368  timestep:
2369
2370  \begin{verbatim} 
2371  Monitored quantities at time 1.0000:
2372    stage-elevation:
2373      values since time = 0.00 in [0.00000000, 0.30000000]
2374      minimum attained at time = 0.00000000, location = (0.16666667, 0.33333333)
2375      maximum attained at time = 0.00000000, location = (0.83333333, 0.16666667)
2376    ymomentum:
2377      values since time = 0.00 in [0.00000000, 0.06241221]
2378      minimum attained at time = 0.00000000, location = (0.33333333, 0.16666667)
2379      maximum attained at time = 0.22472667, location = (0.83333333, 0.66666667)
2380    xmomentum:
2381      values since time = 0.00 in [-0.06062178, 0.47886313]
2382      minimum attained at time = 0.00000000, location = (0.16666667, 0.33333333)
2383      maximum attained at time = 0.35103646, location = (0.83333333, 0.16666667)
2384  \end{verbatim}     
2385
2386  The quantities (and derived quantities) listed here must be selected at model
2387  initialisation using the method \code{domain.set_quantities_to_be_monitored}.\\
2388   
2389  The optional keyword argument \code{precision='\%.4f'} will
2390  determine the precision used for floating point values in the output.
2391  This diagnostics helps track extrema attained by the selected quantities
2392  at every internal timestep.
2393
2394  These values are also stored in the sww file for post processing.
2395
2396  \end{funcdesc}
2397 
2398
2399 
2400  \begin{funcdesc}{get\_values}{location='vertices', indices = None}
2401  Module: \module{abstract\_2d\_finite\_volumes.quantity}
2402
2403  Extract values for quantity as an array
2404
2405  \end{funcdesc}
2406
2407
2408  \begin{funcdesc}{get\_integral}{}
2409  Module: \module{abstract\_2d\_finite\_volumes.quantity}
2410
2411  Return computed integral over entire domain for this quantity
2412
2413  \end{funcdesc}
2414
2415
2416
2417
2418  \begin{funcdesc}{get\_maximum\_value}{indices = None}
2419  Module: \module{abstract\_2d\_finite\_volumes.quantity}
2420
2421  Return maximum value of quantity (on centroids)
2422
2423  Optional argument indices is the set of element ids that
2424  the operation applies to. If omitted all elements are considered.
2425
2426  We do not seek the maximum at vertices as each vertex can
2427  have multiple values - one for each triangle sharing it.
2428  \end{funcdesc}
2429
2430
2431
2432  \begin{funcdesc}{get\_maximum\_location}{indices = None}
2433  Module: \module{abstract\_2d\_finite\_volumes.quantity}
2434
2435  Return location of maximum value of quantity (on centroids)
2436
2437  Optional argument indices is the set of element ids that
2438  the operation applies to.
2439
2440  We do not seek the maximum at vertices as each vertex can
2441  have multiple values - one for each triangle sharing it.
2442
2443  If there are multiple cells with same maximum value, the
2444  first cell encountered in the triangle array is returned.
2445  \end{funcdesc}
2446
2447
2448
2449  \begin{funcdesc}{get\_wet\_elements}{indices=None}
2450  Module: \module{shallow\_water.shallow\_water\_domain}
2451
2452  Return indices for elements where h $>$ minimum_allowed_height
2453  Optional argument indices is the set of element ids that the operation applies to.
2454  \end{funcdesc}
2455
2456
2457  \begin{funcdesc}{get\_maximum\_inundation\_elevation}{indices=None}
2458  Module: \module{shallow\_water.shallow\_water\_domain}
2459
2460  Return highest elevation where h $>$ 0.\\
2461  Optional argument indices is the set of element ids that the operation applies to.\\
2462
2463  Example to find maximum runup elevation:\\
2464     z = domain.get_maximum_inundation_elevation()
2465  \end{funcdesc}
2466
2467
2468  \begin{funcdesc}{get\_maximum\_inundation\_location}{indices=None}
2469  Module: \module{shallow\_water.shallow\_water\_domain}
2470
2471  Return location (x,y) of highest elevation where h $>$ 0.\\
2472  Optional argument indices is the set of element ids that the operation applies to.\\
2473
2474  Example to find maximum runup location:\\
2475     x, y = domain.get_maximum_inundation_location()
2476  \end{funcdesc}
2477
2478
2479\section{Queries of SWW model output files} 
2480After a model has been run, it is often useful to extract various information from the sww
2481output file (see Section \ref{sec:sww format}). This is typically more convenient than using the
2482diagnostics described in Section \ref{sec:diagnostics} which rely on the model running - something
2483that can be very time consuming. The sww files are easy and quick to read and offer much information
2484about the model results such as runup heights, time histories of selected quantities,
2485flow through cross sections and much more.
2486
2487\begin{funcdesc}{get\_maximum\_inundation\_elevation}{filename, polygon=None,
2488    time_interval=None, verbose=False}
2489  Module: \module{shallow\_water.data\_manager}
2490
2491  Return highest elevation where depth is positive ($h > 0$)
2492
2493  Example to find maximum runup elevation:\\   
2494  max_runup = get_maximum_inundation_elevation(filename,
2495  polygon=None,
2496  time_interval=None,
2497  verbose=False)
2498
2499   
2500  filename is a NetCDF sww file containing ANUGA model output.                                                       
2501  Optional arguments polygon and time_interval restricts the maximum runup calculation
2502  to a points that lie within the specified polygon and time interval.
2503
2504  If no inundation is found within polygon and time_interval the return value
2505  is None signifying "No Runup" or "Everything is dry".
2506
2507  See doc string for general function get_maximum_inundation_data for details.
2508\end{funcdesc}
2509
2510
2511\begin{funcdesc}{get\_maximum\_inundation\_location}{filename, polygon=None,
2512    time_interval=None, verbose=False}
2513  Module: \module{shallow\_water.data\_manager}
2514
2515  Return location (x,y) of highest elevation where depth is positive ($h > 0$)
2516
2517  Example to find maximum runup location:\\   
2518  max_runup_location = get_maximum_inundation_location(filename,
2519  polygon=None,
2520  time_interval=None,
2521  verbose=False)
2522
2523   
2524  filename is a NetCDF sww file containing ANUGA model output.                                                       
2525  Optional arguments polygon and time_interval restricts the maximum runup calculation
2526  to a points that lie within the specified polygon and time interval.
2527
2528  If no inundation is found within polygon and time_interval the return value
2529  is None signifying "No Runup" or "Everything is dry".
2530
2531  See doc string for general function get_maximum_inundation_data for details.
2532\end{funcdesc}
2533
2534
2535\begin{funcdesc}{sww2timeseries}{swwfiles, gauge_filename, production_dirs, report = None, reportname = None,
2536plot_quantity = None, generate_fig = False, surface = None, time_min = None, time_max = None, time_thinning = 1,
2537time_unit = None, title_on = None, use_cache = False, verbose = False}
2538
2539  Module: \module{anuga.abstract\_2d\_finite\_volumes.util}
2540 
2541  Return csv files for the location in the \code{gauge_filename} and can also return plots of them
2542 
2543  See doc string for general function sww2timeseries for details.
2544
2545\end{funcdesc}
2546 
2547 
2548
2549\section{Other}
2550
2551  \begin{funcdesc}{domain.create\_quantity\_from\_expression}{string}
2552
2553  Handy for creating derived quantities on-the-fly as for example
2554  \begin{verbatim}
2555  Depth = domain.create_quantity_from_expression('stage-elevation')
2556
2557  exp = '(xmomentum*xmomentum + ymomentum*ymomentum)**0.5')
2558  Absolute_momentum = domain.create_quantity_from_expression(exp)
2559  \end{verbatim}
2560
2561  %See also \file{Analytical\_solution\_circular\_hydraulic\_jump.py} for an example of use.
2562  \end{funcdesc}
2563
2564
2565
2566
2567
2568%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
2569%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
2570
2571\chapter{\anuga System Architecture}
2572
2573
2574\section{File Formats}
2575\label{sec:file formats}
2576
2577\anuga makes use of a number of different file formats. The
2578following table lists all these formats, which are described in more
2579detail in the paragraphs below.
2580
2581\bigskip
2582
2583\begin{center}
2584
2585\begin{tabular}{|ll|}  \hline
2586
2587\textbf{Extension} & \textbf{Description} \\
2588\hline\hline
2589
2590\code{.sww} & NetCDF format for storing model output
2591\code{f(t,x,y)}\\
2592
2593\code{.tms} & NetCDF format for storing time series \code{f(t)}\\
2594
2595\code{.csv/.txt} & ASCII format called points csv for storing
2596arbitrary points and associated attributes\\
2597
2598\code{.pts} & NetCDF format for storing arbitrary points and
2599associated attributes\\
2600
2601\code{.asc} & ASCII format of regular DEMs as output from ArcView\\
2602
2603\code{.prj} & Associated ArcView file giving more metadata for
2604\code{.asc} format\\
2605
2606\code{.ers} & ERMapper header format of regular DEMs for ArcView\\
2607
2608\code{.dem} & NetCDF representation of regular DEM data\\
2609
2610\code{.tsh} & ASCII format for storing meshes and associated
2611boundary and region info\\
2612
2613\code{.msh} & NetCDF format for storing meshes and associated
2614boundary and region info\\
2615
2616\code{.nc} & Native ferret NetCDF format\\
2617
2618\code{.geo} & Houdinis ASCII geometry format (?) \\  \par \hline
2619%\caption{File formats used by \anuga}
2620\end{tabular}
2621
2622
2623\end{center}
2624
2625The above table shows the file extensions used to identify the
2626formats of files. However, typically, in referring to a format we
2627capitalise the extension and omit the initial full stop---thus, we
2628refer, for example, to `SWW files' or `PRJ files'.
2629
2630\bigskip
2631
2632A typical dataflow can be described as follows:
2633
2634\subsection{Manually Created Files}
2635
2636\begin{tabular}{ll}
2637ASC, PRJ & Digital elevation models (gridded)\\
2638NC & Model outputs for use as boundary conditions (e.g. from MOST)
2639\end{tabular}
2640
2641\subsection{Automatically Created Files}
2642
2643\begin{tabular}{ll}
2644ASC, PRJ  $\rightarrow$  DEM  $\rightarrow$  PTS & Convert
2645DEMs to native \code{.pts} file\\
2646
2647NC $\rightarrow$ SWW & Convert MOST boundary files to
2648boundary \code{.sww}\\
2649
2650PTS + TSH $\rightarrow$ TSH with elevation & Least squares fit\\
2651
2652TSH $\rightarrow$ SWW & Convert TSH to \code{.sww}-viewable using
2653\code{animate}\\
2654
2655TSH + Boundary SWW $\rightarrow$ SWW & Simulation using
2656\code{\anuga}\\
2657
2658Polygonal mesh outline $\rightarrow$ & TSH or MSH
2659\end{tabular}
2660
2661
2662
2663
2664\bigskip
2665
2666\subsection{SWW and TMS Formats}
2667\label{sec:sww format}
2668
2669The SWW and TMS formats are both NetCDF formats, and are of key
2670importance for \anuga.
2671
2672An SWW file is used for storing \anuga output and therefore pertains
2673to a set of points and a set of times at which a model is evaluated.
2674It contains, in addition to dimension information, the following
2675variables:
2676
2677\begin{itemize}
2678    \item \code{x} and \code{y}: coordinates of the points, represented as Numeric arrays
2679    \item \code{elevation}, a Numeric array storing bed-elevations
2680    \item \code{volumes}, a list specifying the points at the vertices of each of the
2681    triangles
2682    % Refer here to the example to be provided in describing the simple example
2683    \item \code{time}, a Numeric array containing times for model
2684    evaluation
2685\end{itemize}
2686
2687
2688The contents of an SWW file may be viewed using the anuga viewer
2689\code{animate}, which creates an on-screen geometric
2690representation. See section \ref{sec:animate} (page
2691\pageref{sec:animate}) in Appendix \ref{ch:supportingtools} for more
2692on \code{animate}.
2693
2694Alternatively, there are tools, such as \code{ncdump}, that allow
2695you to convert an NetCDF file into a readable format such as the
2696Class Definition Language (CDL). The following is an excerpt from a
2697CDL representation of the output file \file{runup.sww} generated
2698from running the simple example \file{runup.py} of
2699Chapter \ref{ch:getstarted}:
2700
2701\verbatiminput{examples/bedslopeexcerpt.cdl}
2702
2703The SWW format is used not only for output but also serves as input
2704for functions such as \function{file\_boundary} and
2705\function{file\_function}, described in Chapter \ref{ch:interface}.
2706
2707A TMS file is used to store time series data that is independent of
2708position.
2709
2710
2711\subsection{Mesh File Formats}
2712
2713A mesh file is a file that has a specific format suited to
2714triangular meshes and their outlines. A mesh file can have one of
2715two formats: it can be either a TSH file, which is an ASCII file, or
2716an MSH file, which is a NetCDF file. A mesh file can be generated
2717from the function \function{create\_mesh\_from\_regions} (see
2718Section \ref{sec:meshgeneration}) and used to initialise a domain.
2719
2720A mesh file can define the outline of the mesh---the vertices and
2721line segments that enclose the region in which the mesh is
2722created---and the triangular mesh itself, which is specified by
2723listing the triangles and their vertices, and the segments, which
2724are those sides of the triangles that are associated with boundary
2725conditions.
2726
2727In addition, a mesh file may contain `holes' and/or `regions'. A
2728hole represents an area where no mesh is to be created, while a
2729region is a labelled area used for defining properties of a mesh,
2730such as friction values.  A hole or region is specified by a point
2731and bounded by a number of segments that enclose that point.
2732
2733A mesh file can also contain a georeference, which describes an
2734offset to be applied to $x$ and $y$ values---eg to the vertices.
2735
2736
2737\subsection{Formats for Storing Arbitrary Points and Attributes}
2738
2739
2740A CSV/TXT file is used to store data representing
2741arbitrary numerical attributes associated with a set of points.
2742
2743The format for an CSV/TXT file is:\\
2744%\begin{verbatim}
2745
2746            first line:     \code{[column names]}\\
2747            other lines:  \code{[x value], [y value], [attributes]}\\
2748
2749            for example:\\
2750            \code{x, y, elevation, friction}\\
2751            \code{0.6, 0.7, 4.9, 0.3}\\
2752            \code{1.9, 2.8, 5, 0.3}\\
2753            \code{2.7, 2.4, 5.2, 0.3}
2754
2755        The delimiter is a comma. The first two columns are assumed to
2756        be x, y coordinates.
2757       
2758
2759A PTS file is a NetCDF representation of the data held in an points CSV
2760file. If the data is associated with a set of $N$ points, then the
2761data is stored using an $N \times 2$ Numeric array of float
2762variables for the points and an $N \times 1$ Numeric array for each
2763attribute.
2764
2765%\end{verbatim}
2766
2767\subsection{ArcView Formats}
2768
2769Files of the three formats ASC, PRJ and ERS are all associated with
2770data from ArcView.
2771
2772An ASC file is an ASCII representation of DEM output from ArcView.
2773It contains a header with the following format:
2774
2775\begin{tabular}{l l}
2776\code{ncols}      &   \code{753}\\
2777\code{nrows}      &   \code{766}\\
2778\code{xllcorner}  &   \code{314036.58727982}\\
2779\code{yllcorner}  & \code{6224951.2960092}\\
2780\code{cellsize}   & \code{100}\\
2781\code{NODATA_value} & \code{-9999}
2782\end{tabular}
2783
2784The remainder of the file contains the elevation data for each grid point
2785in the grid defined by the above information.
2786
2787A PRJ file is an ArcView file used in conjunction with an ASC file
2788to represent metadata for a DEM.
2789
2790
2791\subsection{DEM Format}
2792
2793A DEM file is a NetCDF representation of regular DEM data.
2794
2795
2796\subsection{Other Formats}
2797
2798
2799
2800
2801\subsection{Basic File Conversions}
2802\label{sec:basicfileconversions}
2803
2804  \begin{funcdesc}{sww2dem}{basename_in, basename_out = None,
2805            quantity = None,
2806            timestep = None,
2807            reduction = None,
2808            cellsize = 10,
2809            NODATA_value = -9999,
2810            easting_min = None,
2811            easting_max = None,
2812            northing_min = None,
2813            northing_max = None,
2814            expand_search = False,
2815            verbose = False,
2816            origin = None,
2817            datum = 'WGS84',
2818            format = 'ers'}
2819  Module: \module{shallow\_water.data\_manager}
2820
2821  Takes data from an SWW file \code{basename_in} and converts it to DEM format (ASC or
2822  ERS) of a desired grid size \code{cellsize} in metres.
2823  The easting and northing values are used if the user wished to clip the output
2824  file to a specified rectangular area. The \code{reduction} input refers to a function
2825  to reduce the quantities over all time step of the SWW file, example, maximum.
2826  \end{funcdesc}
2827
2828
2829  \begin{funcdesc}{dem2pts}{basename_in, basename_out=None,
2830            easting_min=None, easting_max=None,
2831            northing_min=None, northing_max=None,
2832            use_cache=False, verbose=False}
2833  Module: \module{shallow\_water.data\_manager}
2834
2835  Takes DEM data (a NetCDF file representation of data from a regular Digital
2836  Elevation Model) and converts it to PTS format.
2837  \end{funcdesc}
2838
2839
2840
2841%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
2842%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
2843
2844\chapter{\anuga mathematical background}
2845\label{cd:mathematical background}
2846
2847\section{Introduction}
2848
2849This chapter outlines the mathematics underpinning \anuga.
2850
2851
2852
2853\section{Model}
2854\label{sec:model}
2855
2856The shallow water wave equations are a system of differential
2857conservation equations which describe the flow of a thin layer of
2858fluid over terrain. The form of the equations are:
2859\[
2860\frac{\partial \UU}{\partial t}+\frac{\partial \EE}{\partial
2861x}+\frac{\partial \GG}{\partial y}=\SSS
2862\]
2863where $\UU=\left[ {{\begin{array}{*{20}c}
2864 h & {uh} & {vh} \\
2865\end{array} }} \right]^T$ is the vector of conserved quantities; water depth
2866$h$, $x$-momentum $uh$ and $y$-momentum $vh$. Other quantities
2867entering the system are bed elevation $z$ and stage (absolute water
2868level) $w$, where the relation $w = z + h$ holds true at all times.
2869The fluxes in the $x$ and $y$ directions, $\EE$ and $\GG$ are given
2870by
2871\[
2872\EE=\left[ {{\begin{array}{*{20}c}
2873 {uh} \hfill \\
2874 {u^2h+gh^2/2} \hfill \\
2875 {uvh} \hfill \\
2876\end{array} }} \right]\mbox{ and }\GG=\left[ {{\begin{array}{*{20}c}
2877 {vh} \hfill \\
2878 {vuh} \hfill \\
2879 {v^2h+gh^2/2} \hfill \\
2880\end{array} }} \right]
2881\]
2882and the source term (which includes gravity and friction) is given
2883by
2884\[
2885\SSS=\left[ {{\begin{array}{*{20}c}
2886 0 \hfill \\
2887 -{gh(z_{x} + S_{fx} )} \hfill \\
2888 -{gh(z_{y} + S_{fy} )} \hfill \\
2889\end{array} }} \right]
2890\]
2891where $S_f$ is the bed friction. The friction term is modelled using
2892Manning's resistance law
2893\[
2894S_{fx} =\frac{u\eta ^2\sqrt {u^2+v^2} }{h^{4/3}}\mbox{ and }S_{fy}
2895=\frac{v\eta ^2\sqrt {u^2+v^2} }{h^{4/3}}
2896\]
2897in which $\eta$ is the Manning resistance coefficient.
2898
2899As demonstrated in our papers, \cite{ZR1999,nielsen2005} these
2900equations provide an excellent model of flows associated with
2901inundation such as dam breaks and tsunamis.
2902
2903\section{Finite Volume Method}
2904\label{sec:fvm}
2905
2906We use a finite-volume method for solving the shallow water wave
2907equations \cite{ZR1999}. The study area is represented by a mesh of
2908triangular cells as in Figure~\ref{fig:mesh} in which the conserved
2909quantities of  water depth $h$, and horizontal momentum $(uh, vh)$,
2910in each volume are to be determined. The size of the triangles may
2911be varied within the mesh to allow greater resolution in regions of
2912particular interest.
2913
2914\begin{figure}
2915\begin{center}
2916\includegraphics[width=8.0cm,keepaspectratio=true]{graphics/step-five}
2917\caption{Triangular mesh used in our finite volume method. Conserved
2918quantities $h$, $uh$ and $vh$ are associated with the centroid of
2919each triangular cell.} \label{fig:mesh}
2920\end{center}
2921\end{figure}
2922
2923The equations constituting the finite-volume method are obtained by
2924integrating the differential conservation equations over each
2925triangular cell of the mesh. Introducing some notation we use $i$ to
2926refer to the $i$th triangular cell $T_i$, and ${\cal N}(i)$ to the
2927set of indices referring to the cells neighbouring the $i$th cell.
2928Then $A_i$ is the area of the $i$th triangular cell and $l_{ij}$ is
2929the length of the edge between the $i$th and $j$th cells.
2930
2931By applying the divergence theorem we obtain for each volume an
2932equation which describes the rate of change of the average of the
2933conserved quantities within each cell, in terms of the fluxes across
2934the edges of the cells and the effect of the source terms. In
2935particular, rate equations associated with each cell have the form
2936$$
2937 \frac{d\UU_i }{dt}+ \frac1{A_i}\sum\limits_{j\in{\cal N}(i)} \HH_{ij} l_{ij} = \SSS_i
2938$$
2939where
2940\begin{itemize}
2941\item $\UU_i$ the vector of conserved quantities averaged over the $i$th cell,
2942\item $\SSS_i$ is the source term associated with the $i$th cell,
2943and
2944\item $\HH_{ij}$ is the outward normal flux of
2945material across the \textit{ij}th edge.
2946\end{itemize}
2947
2948
2949%\item $l_{ij}$ is the length of the edge between the $i$th and $j$th
2950%cells
2951%\item $m_{ij}$ is the midpoint of
2952%the \textit{ij}th edge,
2953%\item
2954%$\mathbf{n}_{ij} = (n_{ij,1} , n_{ij,2})$is the outward pointing
2955%normal along the \textit{ij}th edge, and The
2956
2957The flux $\HH_{ij}$ is evaluated using a numerical flux function
2958$\HH(\cdot, \cdot ; \ \cdot)$ which is consistent with the shallow
2959water flux in the sense that for all conservation vectors $\UU$ and normal vectors $\nn$
2960$$
2961H(\UU,\UU;\ \nn) = \EE(\UU) n_1 + \GG(\UU) n_2 .
2962$$
2963
2964Then
2965$$
2966\HH_{ij}  = \HH(\UU_i(m_{ij}),
2967\UU_j(m_{ij}); \mathbf{n}_{ij})
2968$$
2969where $m_{ij}$ is the midpoint of the \textit{ij}th edge and
2970$\mathbf{n}_{ij}$ is the outward pointing normal, with respect to the $i$th cell, on the
2971\textit{ij}th edge. The function $\UU_i(x)$ for $x \in
2972T_i$ is obtained from the vector $\UU_k$ of conserved average values for the $i$th and
2973neighbouring  cells.
2974
2975We use a second order reconstruction to produce a piece-wise linear
2976function construction of the conserved quantities for  all $x \in
2977T_i$ for each cell (see Figure~\ref{fig:mesh:reconstruct}. This
2978function is allowed to be discontinuous across the edges of the
2979cells, but the slope of this function is limited to avoid
2980artificially introduced oscillations.
2981
2982Godunov's method (see \cite{Toro1992}) involves calculating the
2983numerical flux function $\HH(\cdot, \cdot ; \ \cdot)$ by exactly
2984solving the corresponding one dimensional Riemann problem normal to
2985the edge. We use the central-upwind scheme of \cite{KurNP2001} to
2986calculate an approximation of the flux across each edge.
2987
2988\begin{figure}
2989\begin{center}
2990\includegraphics[width=8.0cm,keepaspectratio=true]{graphics/step-reconstruct}
2991\caption{From the values of the conserved quantities at the centroid
2992of the cell and its neighbouring cells, a discontinuous piecewise
2993linear reconstruction of the conserved quantities is obtained.}
2994\label{fig:mesh:reconstruct}
2995\end{center}
2996\end{figure}
2997
2998In the computations presented in this paper we use an explicit Euler
2999time stepping method with variable timestepping adapted to the
3000observed CFL condition.
3001
3002
3003\section{Flux limiting}
3004
3005The shallow water equations are solved numerically using a
3006finite volume method on unstructured triangular grid.
3007The upwind central scheme due to Kurganov and Petrova is used as an
3008approximate Riemann solver for the computation of inviscid flux functions.
3009This makes it possible to handle discontinuous solutions.
3010
3011To alleviate the problems associated with numerical instabilities due to
3012small water depths near a wet/dry boundary we employ a new flux limiter that
3013ensures that unphysical fluxes are never encounted.
3014
3015
3016Let $u$ and $v$ be the velocity components in the $x$ and $y$ direction,
3017$w$ the absolute water level (stage) and
3018$z$ the bed elevation. The latter are assumed to be relative to the
3019same height datum.
3020The conserved quantities tracked by ANUGA are momentum in the
3021$x$-direction ($\mu = uh$), momentum in the $y$-direction ($\nu = vh$)
3022and depth ($h = w-z$).
3023
3024The flux calculation requires access to the velocity vector $(u, v)$
3025where each component is obtained as $u = \mu/h$ and $v = \nu/h$ respectively.
3026In the presence of very small water depths, these calculations become
3027numerically unreliable and will typically cause unphysical speeds.
3028
3029We have employed a flux limiter which replaces the calculations above with
3030the limited approximations.
3031\begin{equation}
3032  \hat{u} = \frac{\mu}{h + h_0/h}, \bigskip \hat{v} = \frac{\nu}{h + h_0/h},
3033\end{equation}
3034where $h_0$ is a regularisation parameter that controls the minimal
3035magnitude of the denominator. Taking the limits we have for $\hat{u}$
3036\[
3037  \lim_{h \rightarrow 0} \hat{u} =
3038  \lim_{h \rightarrow 0} \frac{\mu}{h + h_0/h} = 0
3039\]
3040and
3041\[
3042  \lim_{h \rightarrow \infty} \hat{u} =
3043  \lim_{h \rightarrow \infty} \frac{\mu}{h + h_0/h} = \frac{\mu}{h} = u
3044\]
3045with similar results for $\hat{v}$.
3046
3047The maximal value of $\hat{u}$ is attained when $h+h_0/h$ is minimal or (by differentiating the denominator)
3048\[
3049  1 - h_0/h^2 = 0
3050\]
3051or
3052\[
3053  h_0 = h^2
3054\]
3055
3056
3057ANUGA has a global parameter $H_0$ that controls the minimal depth which
3058is considered in the various equations. This parameter is typically set to
3059$10^{-3}$. Setting
3060\[
3061  h_0 = H_0^2
3062\]
3063provides a reasonable balance between accurracy and stability. In fact,
3064setting $h=H_0$ will scale the predicted speed by a factor of $0.5$:
3065\[
3066  \left[ \frac{\mu}{h + h_0/h} \right]_{h = H_0} = \frac{\mu}{2 H_0}
3067\]
3068In general, for multiples of the minimal depth $N H_0$ one obtains
3069\[
3070  \left[ \frac{\mu}{h + h_0/h} \right]_{h = N H_0} =
3071  \frac{\mu}{H_0 (1 + 1/N^2)}
3072\]
3073which converges quadratically to the true value with the multiple N.
3074
3075
3076%The developed numerical model has been applied to several test cases as well as to real flows. Numerical tests prove the robustness and accuracy of the model.
3077
3078
3079
3080
3081
3082\section{Slope limiting}
3083A multidimensional slope-limiting technique is employed to achieve second-order spatial accuracy and to prevent spurious oscillations. This is using the MinMod limiter and is documented elsewhere.
3084
3085However close to the bed, the limiter must ensure that no negative depths occur. On the other hand, in deep water, the bed topography should be ignored for the purpose of the limiter.
3086
3087
3088Let $w, z, h$  be the stage, bed elevation and depth at the centroid and
3089let $w_i, z_i, h_i$ be the stage, bed elevation and depth at vertex $i$.
3090Define the minimal depth across all vertices as $\hmin$ as
3091\[
3092  \hmin = \min_i h_i
3093\]
3094
3095Let $\tilde{w_i}$ be the stage obtained from a gradient limiter
3096limiting on stage only. The corresponding depth is then defined as
3097\[
3098  \tilde{h_i} = \tilde{w_i} - z_i
3099\]
3100We would use this limiter in deep water which we will define (somewhat boldly)
3101as
3102\[
3103  \hmin \ge \epsilon
3104\]
3105
3106
3107Similarly, let $\bar{w_i}$ be the stage obtained from a gradient
3108limiter limiting on depth respecting the bed slope.
3109The corresponding depth is defined as
3110\[
3111  \bar{h_i} = \bar{w_i} - z_i
3112\]
3113
3114
3115We introduce the concept of a balanced stage $w_i$ which is obtained as
3116the linear combination
3117
3118\[
3119  w_i = \alpha \tilde{w_i} + (1-\alpha) \bar{w_i}
3120\]
3121or
3122\[
3123  w_i = z_i + \alpha \tilde{h_i} + (1-\alpha) \bar{h_i}
3124\]
3125where $\alpha \in [0, 1]$.
3126
3127Since $\tilde{w_i}$ is obtained in 'deep' water where the bedslope
3128is ignored we have immediately that
3129\[
3130  \alpha = 1 \mbox{ for } \hmin \ge \epsilon %or dz=0
3131\]
3132%where the maximal bed elevation range $dz$ is defined as
3133%\[
3134%  dz = \max_i |z_i - z|
3135%\]
3136
3137If $\hmin < \epsilon$ we want to use the 'shallow' limiter just enough that
3138no negative depths occur. Formally, we will require that
3139\[
3140  \alpha \tilde{h_i} + (1-\alpha) \bar{h_i} > \epsilon, \forall i
3141\]
3142or
3143\begin{equation}
3144  \alpha(\tilde{h_i} - \bar{h_i}) > \epsilon - \bar{h_i}, \forall i
3145  \label{eq:limiter bound}
3146\end{equation}
3147
3148There are two cases:
3149\begin{enumerate}
3150  \item $\bar{h_i} \le \tilde{h_i}$: The deep water (limited using stage)
3151  vertex is at least as far away from the bed than the shallow water
3152  (limited using depth). In this case we won't need any contribution from
3153  $\bar{h_i}$ and can accept any $\alpha$.
3154
3155  E.g.\ $\alpha=1$ reduces Equation \ref{eq:limiter bound} to
3156  \[
3157    \tilde{h_i} > \epsilon
3158  \]
3159  whereas $\alpha=0$ yields
3160  \[
3161    \bar{h_i} > \epsilon
3162  \]
3163  all well and good.
3164  \item $\bar{h_i} > \tilde{h_i}$: In this case the the deep water vertex is
3165  closer to the bed than the shallow water vertex or even below the bed.
3166  In this case we need to find an $\alpha$ that will ensure a positive depth.
3167  Rearranging Equation \ref{eq:limiter bound} and solving for $\alpha$ one
3168  obtains the bound
3169  \[
3170    \alpha < \frac{\epsilon - \bar{h_i}}{\tilde{h_i} - \bar{h_i}}, \forall i
3171  \]
3172\end{enumerate}
3173
3174Ensuring Equation \ref{eq:limiter bound} holds true for all vertices one
3175arrives at the definition
3176\[
3177  \alpha = \min_{i} \frac{\bar{h_i} - \epsilon}{\bar{h_i} - \tilde{h_i}}
3178\]
3179which will guarantee that no vertex 'cuts' through the bed. Finally, should
3180$\bar{h_i} < \epsilon$ and therefore $\alpha < 0$, we suggest setting
3181$\alpha=0$ and similarly capping $\alpha$ at 1 just in case.
3182
3183%Furthermore,
3184%dropping the $\epsilon$ ensures that alpha is always positive and also
3185%provides a numerical safety {??)
3186
3187
3188
3189
3190
3191%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
3192%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
3193
3194\chapter{Basic \anuga Assumptions}
3195
3196
3197Physical model time cannot be earlier than 1 Jan 1970 00:00:00.
3198If one wished to recreate scenarios prior to that date it must be done
3199using some relative time (e.g. 0).
3200
3201
3202All spatial data relates to the WGS84 datum (or GDA94) and has been
3203projected into UTM with false easting of 500000 and false northing of
32041000000 on the southern hemisphere (0 on the northern).
3205
3206It is assumed that all computations take place within one UTM zone and
3207all locations must consequently be specified in Cartesian coordinates
3208(eastings, northings) or (x,y) where the unit is metres.
3209
3210DEMs, meshes and boundary conditions can have different origins within
3211one UTM zone. However, the computation will use that of the mesh for
3212numerical stability.
3213
3214When generating a mesh it is assumed that polygons do not cross.
3215Having polygons tht cross can cause the mesh generation to fail or bad
3216meshes being produced.
3217
3218
3219%OLD
3220%The dataflow is: (See data_manager.py and from scenarios)
3221%
3222%
3223%Simulation scenarios
3224%--------------------%
3225%%
3226%
3227%Sub directories contain scrips and derived files for each simulation.
3228%The directory ../source_data contains large source files such as
3229%DEMs provided externally as well as MOST tsunami simulations to be used
3230%as boundary conditions.
3231%
3232%Manual steps are:
3233%  Creation of DEMs from argcview (.asc + .prj)
3234%  Creation of mesh from pmesh (.tsh)
3235%  Creation of tsunami simulations from MOST (.nc)
3236%%
3237%
3238%Typical scripted steps are%
3239%
3240%  prepare_dem.py:  Convert asc and prj files supplied by arcview to
3241%                   native dem and pts formats%
3242%
3243%  prepare_pts.py: Convert netcdf output from MOST to an sww file suitable
3244%                  as boundary condition%
3245%
3246%  prepare_mesh.py: Merge DEM (pts) and mesh (tsh) using least squares
3247%                   smoothing. The outputs are tsh files with elevation data.%
3248%
3249%  run_simulation.py: Use the above together with various parameters to
3250%                     run inundation simulation.
3251
3252
3253%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
3254%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
3255
3256\appendix
3257
3258\chapter{Supporting Tools}
3259\label{ch:supportingtools}
3260
3261This section describes a number of supporting tools, supplied with \anuga, that offer a
3262variety of types of functionality and enhance the basic capabilities of \anuga.
3263
3264\section{caching}
3265\label{sec:caching}
3266
3267The \code{cache} function is used to provide supervised caching of function
3268results. A Python function call of the form
3269
3270      {\small \begin{verbatim}
3271      result = func(arg1,...,argn)
3272      \end{verbatim}}
3273
3274  can be replaced by
3275
3276      {\small \begin{verbatim}
3277      from caching import cache
3278      result = cache(func,(arg1,...,argn))
3279      \end{verbatim}}
3280
3281  which returns the same output but reuses cached
3282  results if the function has been computed previously in the same context.
3283  \code{result} and the arguments can be simple types, tuples, list, dictionaries or
3284  objects, but not unhashable types such as functions or open file objects.
3285  The function \code{func} may be a member function of an object or a module.
3286
3287  This type of caching is particularly useful for computationally intensive
3288  functions with few frequently used combinations of input arguments. Note that
3289  if the inputs or output are very large caching may not save time because
3290  disc access may dominate the execution time.
3291
3292  If the function definition changes after a result has been cached, this will be
3293  detected by examining the functions \code{bytecode (co\_code, co\_consts,
3294  func\_defaults, co\_argcount)} and the function will be recomputed.
3295  However, caching will not detect changes in modules used by \code{func}.
3296  In this case cache must be cleared manually.
3297
3298  Options are set by means of the function \code{set\_option(key, value)},
3299  where \code{key} is a key associated with a
3300  Python dictionary \code{options}. This dictionary stores settings such as the name of
3301  the directory used, the maximum
3302  number of cached files allowed, and so on.
3303
3304  The \code{cache} function allows the user also to specify a list of dependent files. If any of these
3305  have been changed, the function is recomputed and the results stored again.
3306
3307  %Other features include support for compression and a capability to \ldots
3308
3309
3310   \textbf{USAGE:} \nopagebreak
3311
3312    {\small \begin{verbatim}
3313    result = cache(func, args, kwargs, dependencies, cachedir, verbose,
3314                   compression, evaluate, test, return_filename)
3315    \end{verbatim}}
3316
3317
3318\section{ANUGA viewer - animate}
3319\label{sec:animate}
3320 The output generated by \anuga may be viewed by
3321means of the visualisation tool \code{animate}, which takes the
3322\code{SWW} file output by \anuga and creates a visual representation
3323of the data. Examples may be seen in Figures \ref{fig:runupstart}
3324and \ref{fig:runup2}. To view an \code{SWW} file with
3325\code{animate} in the Windows environment, you can simply drag the
3326icon representing the file over an icon on the desktop for the
3327\code{animate} executable file (or a shortcut to it), or set up a
3328file association to make files with the extension \code{.sww} open
3329with \code{animate}. Alternatively, you can operate \code{animate}
3330from the command line, in both Windows and Linux environments.
3331
3332On successful operation, you will see an interactive moving-picture
3333display. You can use keys and the mouse to slow down, speed up or
3334stop the display, change the viewing position or carry out a number
3335of other simple operations. Help is also displayed when you press
3336the \code{h} key.
3337
3338The main keys operating the interactive screen are:\\
3339
3340\begin{center}
3341\begin{tabular}{|ll|}   \hline
3342
3343\code{w} & toggle wireframe \\
3344
3345space bar & start/stop\\
3346
3347up/down arrows & increase/decrease speed\\
3348
3349left/right arrows & direction in time \emph{(when running)}\\
3350& step through simulation \emph{(when stopped)}\\
3351
3352left mouse button & rotate\\
3353
3354middle mouse button & pan\\
3355
3356right mouse button & zoom\\  \hline
3357
3358\end{tabular}
3359\end{center}
3360
3361\vfill
3362
3363The following table describes how to operate animate from the command line:
3364
3365Usage: \code{animate [options] swwfile \ldots}\\  \nopagebreak
3366Options:\\  \nopagebreak
3367\begin{tabular}{ll}
3368  \code{--display <type>} & \code{MONITOR | POWERWALL | REALITY\_CENTER |}\\
3369                                    & \code{HEAD\_MOUNTED\_DISPLAY}\\
3370  \code{--rgba} & Request a RGBA colour buffer visual\\
3371  \code{--stencil} & Request a stencil buffer visual\\
3372  \code{--stereo} & Use default stereo mode which is \code{ANAGLYPHIC} if not \\
3373                                    & overridden by environmental variable\\
3374  \code{--stereo <mode>} & \code{ANAGLYPHIC | QUAD\_BUFFER | HORIZONTAL\_SPLIT |}\\
3375                                    & \code{VERTICAL\_SPLIT | LEFT\_EYE | RIGHT\_EYE |}\\
3376                                     & \code{ON | OFF} \\
3377  \code{-alphamax <float 0-1>} & Maximum transparency clamp value\\
3378  \code{-alphamin <float 0-1>} & Transparency value at \code{hmin}\\
3379\end{tabular}
3380
3381\begin{tabular}{ll}
3382  \code{-cullangle <float angle 0-90>} & Cull triangles steeper than this value\\
3383  \code{-help} & Display this information\\
3384  \code{-hmax <float>} & Height above which transparency is set to
3385                                     \code{alphamax}\\
3386\end{tabular}
3387
3388\begin{tabular}{ll}
3389
3390  \code{-hmin <float>} & Height below which transparency is set to
3391                                     zero\\
3392\end{tabular}
3393
3394\begin{tabular}{ll}
3395  \code{-lightpos <float>,<float>,<float>} & $x,y,z$ of bedslope directional light ($z$ is
3396                                     up, default is overhead)\\
3397\end{tabular}
3398
3399\begin{tabular}{ll}
3400  \code{-loop}  & Repeated (looped) playback of \code{.swm} files\\
3401
3402\end{tabular}
3403
3404\begin{tabular}{ll}
3405  \code{-movie <dirname>} & Save numbered images to named directory and
3406                                     quit\\
3407
3408  \code{-nosky} & Omit background sky\\
3409
3410
3411  \code{-scale <float>} & Vertical scale factor\\
3412  \code{-texture <file>} & Image to use for bedslope topography\\
3413  \code{-tps <rate>} & Timesteps per second\\
3414  \code{-version} & Revision number and creation (not compile)
3415                                     date\\
3416\end{tabular}
3417
3418\section{utilities/polygons}
3419
3420  \declaremodule{standard}{utilities.polygon}
3421  \refmodindex{utilities.polygon}
3422
3423  \begin{classdesc}{Polygon\_function}{regions, default = 0.0, geo_reference = None}
3424  Module: \code{utilities.polygon}
3425
3426  Creates a callable object that returns one of a specified list of values when
3427  evaluated at a point \code{x, y}, depending on which polygon, from a specified list of polygons, the
3428  point belongs to. The parameter \code{regions} is a list of pairs
3429  \code{(P, v)}, where each \code{P} is a polygon and each \code{v}
3430  is either a constant value or a function of coordinates \code{x}
3431  and \code{y}, specifying the return value for a point inside \code{P}. The
3432  optional parameter \code{default} may be used to specify a value
3433  for a point not lying inside any of the specified polygons. When a
3434  point lies in more than one polygon, the return value is taken to
3435  be the value for whichever of these polygon appears later in the
3436  list.
3437  %FIXME (Howard): CAN x, y BE VECTORS?
3438
3439  \end{classdesc}
3440
3441  \begin{funcdesc}{read\_polygon}{filename}
3442  Module: \code{utilities.polygon}
3443
3444  Reads the specified file and returns a polygon. Each
3445  line of the file must contain exactly two numbers, separated by a comma, which are interpreted
3446  as coordinates of one vertex of the polygon.
3447  \end{funcdesc}
3448
3449  \begin{funcdesc}{populate\_polygon}{polygon, number_of_points, seed = None, exclude = None}
3450  Module: \code{utilities.polygon}
3451
3452  Populates the interior of the specified polygon with the specified number of points,
3453  selected by means of a uniform distribution function.
3454  \end{funcdesc}
3455
3456  \begin{funcdesc}{point\_in\_polygon}{polygon, delta=1e-8}
3457  Module: \code{utilities.polygon}
3458
3459  Returns a point inside the specified polygon and close to the edge. The distance between
3460  the returned point and the nearest point of the polygon is less than $\sqrt{2}$ times the
3461  second argument \code{delta}, which is taken as $10^{-8}$ by default.
3462  \end{funcdesc}
3463
3464  \begin{funcdesc}{inside\_polygon}{points, polygon, closed = True, verbose = False}
3465  Module: \code{utilities.polygon}
3466
3467  Used to test whether the members of a list of points
3468  are inside the specified polygon. Returns a Numeric
3469  array comprising the indices of the points in the list that lie inside the polygon.
3470  (If none of the points are inside, returns \code{zeros((0,), 'l')}.)
3471  Points on the edges of the polygon are regarded as inside if
3472  \code{closed} is set to \code{True} or omitted; otherwise they are regarded as outside.
3473  \end{funcdesc}
3474
3475  \begin{funcdesc}{outside\_polygon}{points, polygon, closed = True, verbose = False}
3476  Module: \code{utilities.polygon}
3477
3478  Exactly like \code{inside\_polygon}, but with the words `inside' and `outside' interchanged.
3479  \end{funcdesc}
3480
3481  \begin{funcdesc}{is\_inside\_polygon}{point, polygon, closed=True, verbose=False}
3482  Module: \code{utilities.polygon}
3483
3484  Returns \code{True} if \code{point} is inside \code{polygon} or
3485  \code{False} otherwise. Points on the edges of the polygon are regarded as inside if
3486  \code{closed} is set to \code{True} or omitted; otherwise they are regarded as outside.
3487  \end{funcdesc}
3488
3489  \begin{funcdesc}{is\_outside\_polygon}{point, polygon, closed=True, verbose=False}
3490  Module: \code{utilities.polygon}
3491
3492  Exactly like \code{is\_outside\_polygon}, but with the words `inside' and `outside' interchanged.
3493  \end{funcdesc}
3494
3495  \begin{funcdesc}{point\_on\_line}{x, y, x0, y0, x1, y1}
3496  Module: \code{utilities.polygon}
3497
3498  Returns \code{True} or \code{False}, depending on whether the point with coordinates
3499  \code{x, y} is on the line passing through the points with coordinates \code{x0, y0}
3500  and \code{x1, y1} (extended if necessary at either end).
3501  \end{funcdesc}
3502
3503  \begin{funcdesc}{separate\_points\_by\_polygon}{points, polygon, closed = True, verbose = False}
3504    \indexedcode{separate\_points\_by\_polygon}
3505  Module: \code{utilities.polygon}
3506
3507  \end{funcdesc}
3508
3509  \begin{funcdesc}{polygon\_area}{polygon}
3510  Module: \code{utilities.polygon}
3511
3512  Returns area of arbitrary polygon (reference http://mathworld.wolfram.com/PolygonArea.html)
3513  \end{funcdesc}
3514
3515  \begin{funcdesc}{plot\_polygons}{polygons, figname, verbose = False}
3516  Module: \code{utilities.polygon}
3517
3518  Plots each polygon contained in input polygon list, e.g.
3519 \code{polygons = [poly1, poly2, poly3]} where \code{poly1 = [[x11,y11],[x12,y12],[x13,y13]]}
3520 etc.  Each polygon is closed for plotting purposes and subsequent plot saved to \code{figname}.
3521  Returns list containing the minimum and maximum of \code{x} and \code{y},
3522  i.e. \code{[x_{min}, x_{max}, y_{min}, y_{max}]}.
3523  \end{funcdesc}
3524
3525\section{coordinate\_transforms}
3526
3527\section{geospatial\_data}
3528\label{sec:geospatial}
3529
3530This describes a class that represents arbitrary point data in UTM
3531coordinates along with named attribute values.
3532
3533%FIXME (Ole): This gives a LaTeX error
3534%\declaremodule{standard}{geospatial_data}
3535%\refmodindex{geospatial_data}
3536
3537
3538
3539\begin{classdesc}{Geospatial\_data}
3540  {data_points = None,
3541    attributes = None,
3542    geo_reference = None,
3543    default_attribute_name = None,
3544    file_name = None}
3545Module: \code{geospatial\_data}
3546
3547This class is used to store a set of data points and associated
3548attributes, allowing these to be manipulated by methods defined for
3549the class.
3550
3551The data points are specified either by reading them from a NetCDF
3552or CSV file, identified through the parameter \code{file\_name}, or
3553by providing their \code{x}- and \code{y}-coordinates in metres,
3554either as a sequence of 2-tuples of floats or as an $M \times 2$
3555Numeric array of floats, where $M$ is the number of points.
3556Coordinates are interpreted relative to the origin specified by the
3557object \code{geo\_reference}, which contains data indicating the UTM
3558zone, easting and northing. If \code{geo\_reference} is not
3559specified, a default is used.
3560
3561Attributes are specified through the parameter \code{attributes},
3562set either to a list or array of length $M$ or to a dictionary whose
3563keys are the attribute names and whose values are lists or arrays of
3564length $M$. One of the attributes may be specified as the default
3565attribute, by assigning its name to \code{default\_attribute\_name}.
3566If no value is specified, the default attribute is taken to be the
3567first one.
3568\end{classdesc}
3569
3570
3571\begin{methoddesc}{import\_points\_file}{delimiter = None, verbose = False}
3572
3573\end{methoddesc}
3574
3575
3576\begin{methoddesc}{export\_points\_file}{ofile, absolute=False}
3577
3578\end{methoddesc}
3579
3580
3581\begin{methoddesc}{get\_data\_points}{absolute = True, as\_lat\_long =
3582    False}
3583    If \code{as\_lat\_long} is\code{True} the point information
3584    returned will be in Latitudes and Longitudes.
3585
3586\end{methoddesc}
3587
3588
3589\begin{methoddesc}{set\_attributes}{attributes}
3590
3591\end{methoddesc}
3592
3593
3594\begin{methoddesc}{get\_attributes}{attribute_name = None}
3595
3596\end{methoddesc}
3597
3598
3599\begin{methoddesc}{get\_all\_attributes}{}
3600
3601\end{methoddesc}
3602
3603
3604\begin{methoddesc}{set\_default\_attribute\_name}{default_attribute_name}
3605
3606\end{methoddesc}
3607
3608
3609\begin{methoddesc}{set\_geo\_reference}{geo_reference}
3610
3611\end{methoddesc}
3612
3613
3614\begin{methoddesc}{add}{}
3615
3616\end{methoddesc}
3617
3618
3619\begin{methoddesc}{clip}{}
3620Clip geospatial data by a polygon
3621
3622Inputs are \code{polygon} which is either a list of points, an Nx2 array or
3623a Geospatial data object and \code{closed}(optional) which determines
3624whether points on boundary should be regarded as belonging to the polygon
3625(\code{closed=True}) or not (\code{closed=False}).
3626Default is \code{closed=True}.
3627
3628Returns new Geospatial data object representing points
3629inside specified polygon.
3630\end{methoddesc}
3631
3632
3633\begin{methoddesc}{clip_outside}{}
3634Clip geospatial data by a polygon
3635
3636Inputs are \code{polygon} which is either a list of points, an Nx2 array or
3637a Geospatial data object and \code{closed}(optional) which determines
3638whether points on boundary should be regarded as belonging to the polygon
3639(\code{closed=True}) or not (\code{closed=False}).
3640Default is \code{closed=True}.
3641
3642Returns new Geospatial data object representing points
3643\emph{out}side specified polygon.
3644\end{methoddesc}
3645
3646
3647\section{Graphical Mesh Generator GUI}
3648The program \code{graphical\_mesh\_generator.py} in the pmesh module
3649allows the user to set up the mesh of the problem interactively.
3650It can be used to build the outline of a mesh or to visualise a mesh
3651automatically generated.
3652
3653Graphical Mesh Generator will let the user select various modes. The
3654current allowable modes are vertex, segment, hole or region.  The mode
3655describes what sort of object is added or selected in response to
3656mouse clicks.  When changing modes any prior selected objects become
3657deselected.
3658
3659In general the left mouse button will add an object and the right
3660mouse button will select an object.  A selected object can de deleted
3661by pressing the the middle mouse button (scroll bar).
3662
3663\section{alpha\_shape}
3664\emph{Alpha shapes} are used to generate close-fitting boundaries
3665around sets of points. The alpha shape algorithm produces a shape
3666that approximates to the `shape formed by the points'---or the shape
3667that would be seen by viewing the points from a coarse enough
3668resolution. For the simplest types of point sets, the alpha shape
3669reduces to the more precise notion of the convex hull. However, for
3670many sets of points the convex hull does not provide a close fit and
3671the alpha shape usually fits more closely to the original point set,
3672offering a better approximation to the shape being sought.
3673
3674In \anuga, an alpha shape is used to generate a polygonal boundary
3675around a set of points before mesh generation. The algorithm uses a
3676parameter $\alpha$ that can be adjusted to make the resultant shape
3677resemble the shape suggested by intuition more closely. An alpha
3678shape can serve as an initial boundary approximation that the user
3679can adjust as needed.
3680
3681The following paragraphs describe the class used to model an alpha
3682shape and some of the important methods and attributes associated
3683with instances of this class.
3684
3685\begin{classdesc}{Alpha\_Shape}{points, alpha = None}
3686Module: \code{alpha\_shape}
3687
3688To instantiate this class the user supplies the points from which
3689the alpha shape is to be created (in the form of a list of 2-tuples
3690\code{[[x1, y1],[x2, y2]}\ldots\code{]}, assigned to the parameter
3691\code{points}) and, optionally, a value for the parameter
3692\code{alpha}. The alpha shape is then computed and the user can then
3693retrieve details of the boundary through the attributes defined for
3694the class.
3695\end{classdesc}
3696
3697
3698\begin{funcdesc}{alpha\_shape\_via\_files}{point_file, boundary_file, alpha= None}
3699Module: \code{alpha\_shape}
3700
3701This function reads points from the specified point file
3702\code{point\_file}, computes the associated alpha shape (either
3703using the specified value for \code{alpha} or, if no value is
3704specified, automatically setting it to an optimal value) and outputs
3705the boundary to a file named \code{boundary\_file}. This output file
3706lists the coordinates \code{x, y} of each point in the boundary,
3707using one line per point.
3708\end{funcdesc}
3709
3710
3711\begin{methoddesc}{set\_boundary\_type}{self,raw_boundary=True,
3712                          remove_holes=False,
3713                          smooth_indents=False,
3714                          expand_pinch=False,
3715                          boundary_points_fraction=0.2}
3716Module: \code{alpha\_shape},  Class: \class{Alpha\_Shape}
3717
3718This function sets flags that govern the operation of the algorithm
3719that computes the boundary, as follows:
3720
3721\code{raw\_boundary = True} returns raw boundary, i.e. the regular edges of the
3722                alpha shape.\\
3723\code{remove\_holes = True} removes small holes (`small' is defined by
3724\code{boundary\_points\_fraction})\\
3725\code{smooth\_indents = True} removes sharp triangular indents in
3726boundary\\
3727\code{expand\_pinch = True} tests for pinch-off and
3728corrects---preventing a boundary vertex from having more than two edges.
3729\end{methoddesc}
3730
3731
3732\begin{methoddesc}{get\_boundary}{}
3733Module: \code{alpha\_shape},  Class: \class{Alpha\_Shape}
3734
3735Returns a list of tuples representing the boundary of the alpha
3736shape. Each tuple represents a segment in the boundary by providing
3737the indices of its two endpoints.
3738\end{methoddesc}
3739
3740
3741\begin{methoddesc}{write\_boundary}{file_name}
3742Module: \code{alpha\_shape},  Class: \class{Alpha\_Shape}
3743
3744Writes the list of 2-tuples returned by \code{get\_boundary} to the
3745file \code{file\_name}, using one line per tuple.
3746\end{methoddesc}
3747
3748\section{Numerical Tools}
3749
3750The following table describes some useful numerical functions that
3751may be found in the module \module{utilities.numerical\_tools}:
3752
3753\begin{tabular}{|p{8cm} p{8cm}|}  \hline
3754\code{angle(v1, v2=None)} & Angle between two-dimensional vectors
3755\code{v1} and \code{v2}, or between \code{v1} and the $x$-axis if
3756\code{v2} is \code{None}. Value is in range $0$ to $2\pi$. \\
3757
3758\code{normal\_vector(v)} & Normal vector to \code{v}.\\
3759
3760\code{mean(x)} & Mean value of a vector \code{x}.\\
3761
3762\code{cov(x, y=None)} & Covariance of vectors \code{x} and \code{y}.
3763If \code{y} is \code{None}, returns \code{cov(x, x)}.\\
3764
3765\code{err(x, y=0, n=2, relative=True)} & Relative error of
3766$\parallel$\code{x}$-$\code{y}$\parallel$ to
3767$\parallel$\code{y}$\parallel$ (2-norm if \code{n} = 2 or Max norm
3768if \code{n} = \code{None}). If denominator evaluates to zero or if
3769\code{y}
3770is omitted or if \code{relative = False}, absolute error is returned.\\
3771
3772\code{norm(x)} & 2-norm of \code{x}.\\
3773
3774\code{corr(x, y=None)} & Correlation of \code{x} and \code{y}. If
3775\code{y} is \code{None} returns autocorrelation of \code{x}.\\
3776
3777\code{ensure\_numeric(A, typecode = None)} & Returns a Numeric array
3778for any sequence \code{A}. If \code{A} is already a Numeric array it
3779will be returned unaltered. Otherwise, an attempt is made to convert
3780it to a Numeric array. (Needed because \code{array(A)} can
3781cause memory overflow.)\\
3782
3783\code{histogram(a, bins, relative=False)} & Standard histogram. If
3784\code{relative} is \code{True}, values will be normalised against
3785the total and thus represent frequencies rather than counts.\\
3786
3787\code{create\_bins(data, number\_of\_bins = None)} & Safely create
3788bins for use with histogram. If \code{data} contains only one point
3789or is constant, one bin will be created. If \code{number\_of\_bins}
3790is omitted, 10 bins will be created.\\  \hline
3791
3792\end{tabular}
3793
3794
3795\chapter{Modules available in \anuga}
3796
3797
3798\section{\module{abstract\_2d\_finite\_volumes.general\_mesh} }
3799\declaremodule[generalmesh]{}{general\_mesh}
3800\label{mod:generalmesh}
3801
3802\section{\module{abstract\_2d\_finite\_volumes.neighbour\_mesh} }
3803\declaremodule[neighbourmesh]{}{neighbour\_mesh}
3804\label{mod:neighbourmesh}
3805
3806\section{\module{abstract\_2d\_finite\_volumes.domain} --- Generic module for 2D triangular domains for finite-volume computations of conservation laws}
3807\declaremodule{}{domain}
3808\label{mod:domain}
3809
3810
3811\section{\module{abstract\_2d\_finite\_volumes.quantity}}
3812\declaremodule{}{quantity}
3813\label{mod:quantity}
3814
3815\begin{verbatim}
3816Class Quantity - Implements values at each triangular element
3817
3818To create:
3819
3820   Quantity(domain, vertex_values)
3821
3822   domain: Associated domain structure. Required.
3823
3824   vertex_values: N x 3 array of values at each vertex for each element.
3825                  Default None
3826
3827   If vertex_values are None Create array of zeros compatible with domain.
3828   Otherwise check that it is compatible with dimenions of domain.
3829   Otherwise raise an exception
3830
3831\end{verbatim}
3832
3833
3834
3835
3836\section{\module{shallow\_water} --- 2D triangular domains for finite-volume
3837computations of the shallow water wave equation. This module contains a specialisation
3838of class Domain from module domain.py consisting of methods specific to the Shallow Water
3839Wave Equation
3840}
3841\declaremodule[shallowwater]{}{shallow\_water}
3842\label{mod:shallowwater}
3843
3844
3845
3846
3847%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%%
3848
3849\chapter{Frequently Asked Questions}
3850
3851
3852\section{General Questions}
3853
3854\subsubsection{What is \anuga?}
3855It is a software package suitable for simulating 2D water flows in
3856complex geometries.
3857
3858\subsubsection{Why is it called \anuga?}
3859The software was developed in collaboration between the
3860Australian National University (ANU) and Geoscience Australia (GA).
3861
3862\subsubsection{How do I obtain a copy of \anuga?}
3863See \url{https://datamining.anu.edu.au/anuga} for all things ANUGA.
3864
3865%\subsubsection{What developments are expected for \anuga in the future?}
3866%This
3867
3868\subsubsection{Are there any published articles about \anuga that I can reference?}
3869See \url{https://datamining.anu.edu.au/anuga} for links.
3870
3871
3872\section{Modelling Questions}
3873
3874\subsubsection{Which type of problems are \anuga good for?}
3875General 2D waterflows in complex geometries such as
3876dam breaks, flows amoung structurs, coastal inundation etc.
3877
3878\subsubsection{Which type of problems are beyond the scope of \anuga?}
3879See Chapter \ref{ch:limitations}.
3880
3881\subsubsection{Can I start the simulation at an arbitrary time?}
3882Yes, using \code{domain.set\_time()} you can specify an arbitrary
3883starting time. This is for example useful in conjunction with a
3884file\_boundary, which may start hours before anything hits the model
3885boundary. By assigning a later time for the model to start,
3886computational resources aren't wasted.
3887
3888\subsubsection{Can I change values for any quantity during the simulation?}
3889Yes, using \code{domain.set\_quantity()} inside the domain.evolve
3890loop you can change values of any quantity. This is for example
3891useful if you wish to let the system settle for a while before
3892assigning an initial condition. Another example would be changing
3893the values for elevation to model e.g. erosion.
3894
3895\subsubsection{Can I change boundary conditions during the simulation?}
3896Yes - see example on page \pageref{sec:change boundary code} in Section
3897\ref{sec:change boundary}.
3898
3899\subsubsection{How do I access model time during the simulation?}
3900The variable \code{t} in the evolve for loop is the model time.
3901For example to change the boundary at a particular time (instead of basing this on the state of the system as in Section \ref{sec:change boundary})
3902one would write something like
3903{\small \begin{verbatim}
3904    for t in domain.evolve(yieldstep = 0.2, duration = 40.0):
3905
3906        if Numeric.allclose(t, 15):
3907            print 'Changing boundary to outflow'
3908            domain.set_boundary({'right': Bo})
3909
3910\end{verbatim}}
3911The model time can also be accessed through the public interface \code{domain.get\_time()}, or changed (at your own peril) through \code{domain.set\_time()}.
3912
3913
3914\subsubsection{Why does a file\_function return a list of numbers when evaluated?}
3915Currently, file\_function works by returning values for the conserved
3916quantities \code{stage}, \code{xmomentum} and \code{ymomentum} at a given point in time
3917and space as a triplet. To access e.g.\ \code{stage} one must specify element 0 of the
3918triplet returned by file\_function.
3919
3920\subsubsection{Which diagnostics are available to troubleshoot a simulation?}
3921
3922\subsubsection{How do I use a DEM in my simulation?}
3923You use \code{dem2pts} to convert your DEM to the required .pts format. This .pts file is then called
3924when setting the elevation data to the mesh in \code{domain.set_quantity}
3925
3926\subsubsection{What sort of DEM resolution should I use?}
3927Try and work with the \emph{best} you have available. Onshore DEMs
3928are typically available in 25m, 100m and 250m grids. Note, offshore
3929data is often sparse, or non-existent.
3930
3931\subsubsection{What sort of mesh resolution should I use?}
3932The mesh resolution should be commensurate with your DEM - it does not make sense to put in place a mesh which is finer than your DEM. As an example,
3933if your DEM is on a 25m grid, then the cell resolution should be of the order of 315$m^2$ (this represents half the area of the square grid). Ideally,
3934you need a fine mesh over regions where the DEM changes rapidly, and other areas of significant interest, such as the coast.
3935If meshes are too coarse, discretisation errors in both stage and momentum may lead to unphysical results. All studies should include sensitivity and convergence studies based on different resolutions.
3936
3937
3938\subsubsection{How do I tag interior polygons?}
3939At the moment create_mesh_from_regions does not allow interior
3940polygons with symbolic tags. If tags are needed, the interior
3941polygons must be created subsequently. For example, given a filename
3942of polygons representing solid walls (in Arc Ungenerate format) can
3943be tagged as such using the code snippet:
3944\begin{verbatim}
3945  # Create mesh outline with tags
3946  mesh = create_mesh_from_regions(bounding_polygon,
3947                                  boundary_tags=boundary_tags)
3948  # Add buildings outlines with tags set to 'wall'. This would typically
3949  # bind to a Reflective boundary
3950  mesh.import_ungenerate_file(buildings_filename, tag='wall')
3951
3952  # Generate and write mesh to file
3953  mesh.generate_mesh(maximum_triangle_area=max_area)
3954  mesh.export_mesh_file(mesh_filename)
3955\end{verbatim}
3956
3957Note that a mesh object is returned from \code{create_mesh_from_regions}
3958when file name is omitted.
3959
3960\subsubsection{How often should I store the output?}
3961This will depend on what you are trying to answer with your model and how much memory you have available on your machine. If you need
3962to look in detail at the evolution, then you will need to balance your storage requirements and the duration of the simulation.
3963If the SWW file exceeds 1Gb, another SWW file will be created until the end of the simulation. As an example, to store all the conserved
3964quantities on a mesh with approximately 300000 triangles on a 2 min interval for 5 hours will result in approximately 350Mb SWW file
3965(as for the \file{run\_sydney\_smf.py} example).
3966
3967\subsection{Boundary Conditions}
3968
3969\subsubsection{How do I create a Dirichlet boundary condition?}
3970
3971A Dirichlet boundary condition sets a constant value for the
3972conserved quantities at the boundaries. A list containing
3973the constant values for stage, xmomentum and ymomentum is constructed
3974and used in the function call, e.g. \code{Dirichlet_boundary([0.2,0.,0.])}
3975
3976\subsubsection{How do I know which boundary tags are available?}
3977The method \code{domain.get\_boundary\_tags()} will return a list of
3978available tags for use with
3979\code{domain.set\_boundary\_condition()}.
3980
3981\subsubsection{What is the difference between file_boundary and field_boundary?}
3982The only difference is field_boundary will allow you to change the level of the stage height when you read in the boundary condition.
3983This is very useful when running different tide heights in the same area as you need only to convert
3984one boundary condition to a SWW file, ideally for tide height of 0 m (saving disk space). Then you can
3985use field_boundary to read this SWW file and change the stage height (tide) on the fly depending on the scenario.
3986
3987
3988
3989
3990\section{Analysing Questions}
3991
3992\subsubsection{How do I easily plot "tide gauges" timeseries from the SWW files?}
3993
3994This is two ways to do this.
3995
39961) Create csv files from the sww file using \code{sww2timeseries} and then use
3997\code{anuga.abstract_2d_finite_volumes.util make_plots_from_csv_file} to create
3998the plots
3999
4000Or
4001
40022) Use \code{anuga.abstract_2d_finite_volumes.util sww2timeseries} to do the whole thing
4003however this don't have a much control on the file name and plots....
4004
4005More detail to be added
4006
4007Read the doc string for more information.
4008
4009\chapter{Glossary}
4010
4011\begin{tabular}{|lp{10cm}|c|}  \hline
4012%\begin{tabular}{|llll|}  \hline
4013    \emph{Term} & \emph{Definition} & \emph{Page}\\  \hline
4014
4015    \indexedbold{\anuga} & Name of software (joint development between ANU and
4016    GA) & \pageref{def:anuga}\\
4017
4018    \indexedbold{bathymetry} & offshore elevation &\\
4019
4020    \indexedbold{conserved quantity} & conserved (stage, x and y
4021    momentum) & \\
4022
4023%    \indexedbold{domain} & The domain of a function is the set of all input values to the
4024%    function.&\\
4025
4026    \indexedbold{Digital Elevation Model (DEM)} & DEMs are digital files consisting of points of elevations,
4027sampled systematically at equally spaced intervals.& \\
4028
4029    \indexedbold{Dirichlet boundary} & A boundary condition imposed on a differential equation
4030 that specifies the values the solution is to take on the boundary of the
4031 domain. & \pageref{def:dirichlet boundary}\\
4032
4033    \indexedbold{edge} & A triangular cell within the computational mesh can be depicted
4034    as a set of vertices joined by lines (the edges). & \\
4035
4036    \indexedbold{elevation} & refers to bathymetry and topography &\\
4037
4038    \indexedbold{evolution} & integration of the shallow water wave equations
4039    over time &\\
4040
4041    \indexedbold{finite volume method} & The method evaluates the terms in the shallow water
4042    wave equation as fluxes at the surfaces of each finite volume. Because the
4043    flux entering a given volume is identical to that leaving the adjacent volume,
4044    these methods are conservative. Another advantage of the finite volume method is
4045    that it is easily formulated to allow for unstructured meshes. The method is used
4046    in many computational fluid dynamics packages. & \\
4047
4048    \indexedbold{forcing term} & &\\
4049
4050    \indexedbold{flux} & the amount of flow through the volume per unit
4051    time & \\
4052
4053    \indexedbold{grid} & Evenly spaced mesh & \\
4054
4055    \indexedbold{latitude} & The angular distance on a mericlear north and south of the
4056    equator, expressed in degrees and minutes. & \\
4057
4058    \indexedbold{longitude} & The angular distance east or west, between the meridian
4059    of a particular place on Earth and that of the Prime Meridian (located in Greenwich,
4060    England) expressed in degrees or time.& \\
4061
4062    \indexedbold{Manning friction coefficient} & &\\
4063
4064    \indexedbold{mesh} & Triangulation of domain &\\
4065
4066    \indexedbold{mesh file} & A TSH or MSH file & \pageref{def:mesh file}\\
4067
4068    \indexedbold{NetCDF} & &\\
4069
4070    \indexedbold{node} & A point at which edges meet & \\
4071
4072    \indexedbold{northing} & A rectangular (x,y) coordinate measurement of distance
4073    north from a north-south reference line, usually a meridian used as the axis of
4074    origin within a map zone or projection. Northing is a UTM (Universal Transverse
4075    Mercator) coordinate. & \\
4076
4077    \indexedbold{points file} & A PTS or CSV file & \\  \hline
4078
4079    \end{tabular}
4080
4081    \begin{tabular}{|lp{10cm}|c|}  \hline
4082
4083    \indexedbold{polygon} & A sequence of points in the plane. \anuga represents a polygon
4084    either as a list consisting of Python tuples or lists of length 2 or as an $N \times 2$
4085    Numeric array, where $N$ is the number of points.
4086
4087    The unit square, for example, would be represented either as
4088    \code{[ [0,0], [1,0], [1,1], [0,1] ]} or as \code{array( [0,0], [1,0], [1,1],
4089    [0,1] )}.
4090
4091    NOTE: For details refer to the module \module{utilities/polygon.py}. &
4092    \\     \indexedbold{resolution} &  The maximal area of a triangular cell in a
4093    mesh & \\
4094
4095
4096    \indexedbold{reflective boundary} & Models a solid wall. Returns same conserved
4097    quantities as those present in the neighbouring volume but reflected. Specific to the
4098    shallow water equation as it works with the momentum quantities assumed to be the
4099    second and third conserved quantities. & \pageref{def:reflective boundary}\\
4100
4101    \indexedbold{stage} & &\\
4102
4103%    \indexedbold{try this}
4104
4105    \indexedbold{animate} & visualisation tool used with \anuga &
4106    \pageref{sec:animate}\\
4107
4108    \indexedbold{time boundary} & Returns values for the conserved
4109quantities as a function of time. The user must specify
4110the domain to get access to the model time. & \pageref{def:time boundary}\\
4111
4112    \indexedbold{topography} & onshore elevation &\\
4113
4114    \indexedbold{transmissive boundary} & & \pageref{def:transmissive boundary}\\
4115
4116    \indexedbold{vertex} & A point at which edges meet. & \\
4117
4118    \indexedbold{xmomentum} & conserved quantity (note, two-dimensional SWW equations say
4119    only \code{x} and \code{y} and NOT \code{z}) &\\
4120
4121    \indexedbold{ymomentum}  & conserved quantity & \\  \hline
4122
4123    \end{tabular}
4124
4125
4126%The \code{\e appendix} markup need not be repeated for additional
4127%appendices.
4128
4129
4130%
4131%  The ugly "%begin{latexonly}" pseudo-environments are really just to
4132%  keep LaTeX2HTML quiet during the \renewcommand{} macros; they're
4133%  not really valuable.
4134%
4135%  If you don't want the Module Index, you can remove all of this up
4136%  until the second \input line.
4137%
4138
4139%begin{latexonly}
4140%\renewcommand{\indexname}{Module Index}
4141%end{latexonly}
4142\input{mod\jobname.ind}        % Module Index
4143%
4144%begin{latexonly}
4145%\renewcommand{\indexname}{Index}
4146%end{latexonly}
4147\input{\jobname.ind}            % Index
4148
4149
4150
4151\begin{thebibliography}{99}
4152\bibitem[nielsen2005]{nielsen2005}
4153{\it Hydrodynamic modelling of coastal inundation}.
4154Nielsen, O., S. Roberts, D. Gray, A. McPherson and A. Hitchman.
4155In Zerger, A. and Argent, R.M. (eds) MODSIM 2005 International Congress on
4156Modelling and Simulation. Modelling and Simulation Society of Australia and
4157New Zealand, December 2005, pp. 518-523. ISBN: 0-9758400-2-9.\\
4158http://www.mssanz.org.au/modsim05/papers/nielsen.pdf
4159
4160\bibitem[grid250]{grid250}
4161Australian Bathymetry and Topography Grid, June 2005.
4162Webster, M.A. and Petkovic, P.
4163Geoscience Australia Record 2005/12. ISBN: 1-920871-46-2.\\
4164http://www.ga.gov.au/meta/ANZCW0703008022.html
4165
4166\bibitem[ZR1999]{ZR1999}
4167\newblock {Catastrophic Collapse of Water Supply Reservoirs in Urban Areas}.
4168\newblock C.~Zoppou and S.~Roberts.
4169\newblock {\em ASCE J. Hydraulic Engineering}, 125(7):686--695, 1999.
4170
4171\bibitem[Toro1999]{Toro1992}
4172\newblock Riemann problems and the waf method for solving the two-dimensional
4173  shallow water equations.
4174\newblock E.~F. Toro.
4175\newblock {\em Philosophical Transactions of the Royal Society, Series A},
4176  338:43--68, 1992.
4177 
4178\bibitem{KurNP2001}
4179\newblock Semidiscrete central-upwind schemes for hyperbolic conservation laws
4180  and hamilton-jacobi equations.
4181\newblock A.~Kurganov, S.~Noelle, and G.~Petrova.
4182\newblock {\em SIAM Journal of Scientific Computing}, 23(3):707--740, 2001.
4183\end{thebibliography}{99}
4184
4185\end{document}
Note: See TracBrowser for help on using the repository browser.