Swan Use
Swan Use
USER MANUAL
e-mail : [email protected]
home page : http://www.swan.tudelft.nl
Permission is granted to copy, distribute and/or modify this document under the terms of
the GNU Free Documentation License, Version 1.2 or any later version published by the
Free Software Foundation; with no Invariant Sections, no Front-Cover Texts, and no Back-
Cover Texts. A copy of the license is available at http://www.gnu.org/licenses/fdl.html#TOC1.
iv
Contents
4 Description of commands 23
4.1 List of available commands . . . . . . . . . . . . . . . . . . . . . . . . . . . 23
4.2 Sequence of commands . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
4.3 Command syntax and input / output limitations . . . . . . . . . . . . . . . 26
4.4 Start-up . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
PROJECT . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
SET . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
MODE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
COORDINATES . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
4.5 Model description . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30
4.5.1 Computational grid . . . . . . . . . . . . . . . . . . . . . . . . . . . 30
CGRID . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30
v
vi
READGRID COORDINATES . . . . . . . . . . . . . . . . . . . . . 33
READGRID UNSTRUCTURED . . . . . . . . . . . . . . . . . . . 34
4.5.2 Input grids and data . . . . . . . . . . . . . . . . . . . . . . . . . . 35
INPGRID . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
READINP . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 40
WIND . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
4.5.3 Boundary and initial conditions . . . . . . . . . . . . . . . . . . . . 45
BOUND SHAPE . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
BOUNDSPEC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46
BOUNDNEST1 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50
BOUNDNEST2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51
BOUNDNEST3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53
INITIAL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54
4.5.4 Physics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55
GEN1 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 55
GEN2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56
GEN3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 56
SSWELL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60
NEGATINP . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61
WCAPPING . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61
QUADRUPL . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61
BREAKING . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62
FRICTION . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 63
TRIAD . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64
VEGETATION . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 65
TURBULENCE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66
MUD . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66
IC4M2 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67
LIMITER . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 68
OBSTACLE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 68
SETUP . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72
DIFFRACTION . . . . . . . . . . . . . . . . . . . . . . . . . . . . 72
OFF . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 73
4.5.5 Numerics . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 74
PROP . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 74
NUMERIC . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 75
4.6 Output . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78
4.6.1 Output locations . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79
FRAME . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79
GROUP . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79
CURVE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80
RAY . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81
ISOLINE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82
vii
POINTS . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82
NGRID . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83
4.6.2 Write or plot computed quantities . . . . . . . . . . . . . . . . . . . 84
QUANTITY . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84
OUTPUT . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 87
BLOCK . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 87
TABLE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 96
SPECOUT . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97
NESTOUT . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99
4.6.3 Write or plot intermediate results . . . . . . . . . . . . . . . . . . . 99
TEST . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99
4.7 Lock-up . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101
COMPUTE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101
HOTFILE . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 103
STOP . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 104
Bibliography 133
Index 134
viii
Chapter 1
The information about the SWAN package is distributed over four different documents.
This User Manual describes the complete input and usage of the SWAN package. The
Implementation Manual explains the installation procedure of SWAN on a single- or multi-
processor machine with shared or distributed memory. The Programming rules is meant
for programmers who want to develop SWAN. The Scientific/Technical documentation
discusses the physical and mathematical details and the discretizations that are used in
the SWAN program. The mapping of these numerical techniques in SWAN code is also
discussed.
In Chapter 2 general description of the model and some instructions concerning the usage
of SWAN, the treatment of grids, boundary conditions, etc. is given. It is advised to
read this chapter before consulting the rest of the manual. Chapter 3 gives some remarks
concerning the input and output files of SWAN. Chapter 4 describes the complete set of
commands of the program SWAN.
It is strongly advised that users who are not so experienced in the use of SWAN first read
Chapters 2 and 3.
This Manual also contains some appendices. In Appendix A definitions of several output
parameters are given. Appendix B outlines the syntax of the command file (or input
file). A complete set of all the commands use in SWAN can be found in Appendix C.
Appendix D described the format of the files for spectral input and output by SWAN.
1
2 Chapter 1
Chapter 2
2.1 Introduction
The purpose of this chapter is to give some general advice in choosing the basic input for
SWAN computations.
SWAN is a third-generation wave model for obtaining realistic estimates of wave paramet-
ers in coastal areas, lakes and estuaries from given wind, bottom and current conditions.
However, SWAN can be used on any scale relevant for wind-generated surface gravity
waves. The model is based on the wave action balance equation with sources and sinks.
An important question addressed is how to choose various grids in SWAN (resolution, ori-
entation, etc.) including nesting. In general, we consider two types of grids: structured
and unstructured. Structured grids may be rectilinear and uniform or curvilinear. They
always consist of quadrilaterals in which the number of grid cells that meet each other in
an internal grid point is 4. In unstructured grids, this number can be arbitrarily (usu-
ally between 4 and 10). For this reason, the level of flexibility with respect to the grid
point distribution of unstructured grids is far more optimal compared to structured grids.
Unstructured grids may contain triangles or a combination of triangles and quadrilaterals
(so-called hybrid grids). In the current version of SWAN, however, only triangular meshes
can be employed.
Often, the characteristic spatial scales of the wind waves propagating from deep to shallow
waters are very diverse and would required to allow local refinement of the mesh near the
coast without incurring overhead associated with grid adaptation at some distance offshore.
Traditionally, this can be achieved by employing a nesting approach.
The idea of nesting is to first compute the waves on a coarse grid for a larger region and
then on a finer grid for a smaller region. The computation on the fine grid uses bound-
ary conditions that are generated by the computation on the coarse grid. Nesting can be
3
4 Chapter 2
repeated on ever decreasing scales using the same type of coordinates for the coarse compu-
tations and the nested computations (Cartesian or spherical). Note that curvilinear grids
can be used for nested computations but the boundaries should always be rectangular.
The use of unstructured grids in SWAN offers a good alternative to nested models not only
because of the ease of optimal adaption of mesh resolution but also the modest effort needed
to generate grids about complicated geometries, e.g. islands and irregular shorelines. This
type of flexible meshes is particularly useful in coastal regions where the water depth varies
greatly. As a result, this variable spatial meshing gives the highest resolution where it is
most needed. The use of unstructured grids facilitates to resolve the model area with a
relative high accuracy but with a much fewer grid points than with regular grids.
It must be pointed out that the application of SWAN on ocean scales is not recommended
from an efficiency point of view. The WAM model and the WAVEWATCH III model,
which have been designed specifically for ocean applications, are probably one order of
magnitude more efficient than SWAN. SWAN can be run on large scales (much larger than
coastal scales) but this option is mainly intended for the transition from ocean scales to
coastal scales (transitions where nonstationarity is an issue and spherical coordinates are
convenient for nesting).
A general suggestion is: start simple. SWAN helps in this with default options. Further-
more, suggestions are given that should help the user to choose among the many options
conditions and in which mode to run SWAN (first-, second- or third-generation mode,
stationary or nonstationary and 1D or 2D).
2.2 Limitations
The DIA approximation for the quadruplet wave-wave interactions depends on the
width of the directional distribution of the wave spectrum. It seems to work reasonably
in many cases but it is a poor approximation for long-crested waves (narrow directional
distribution). It also depends on the frequency resolution. It seems to work reasonably in
many cases but it is a poor approximation for frequency resolutions with ratios very dif-
ferent from 10% (see command CGRID). This is a fundamental problem that SWAN shares
with other third-generation wave models such as WAM and WAVEWATCH III.
The LTA approximation for the triad wave-wave interactions depends on the width
of the directional distribution of the wave spectrum. The present tuning in SWAN (the
default settings, see command TRIAD) seems to work reasonably in many cases but it has
been obtained from observations in a narrow wave flume (long-crested waves).
of water from outside the domain, e.g. nearshore coasts and estuaries) in contrast to closed
basin, e.g. lakes, where this option should not be used. The effects of wave-induced cur-
rents are always ignored.
SWAN does not calculate wave-induced currents. If relevant, such currents should be
provided as input to SWAN, e.g. from a circulation model which can be driven by waves
from SWAN in an iteration procedure.
In areas where variations in wave height are large within a horizontal scale of a few wave
lengths, diffraction should be used. However, the computation of diffraction in arbitrary
geophysical conditions is rather complicated and requires considerable computing effort.
To avoid this, a phase-decoupled approach is employed in SWAN so that same qualitative
behaviour of spatial redistribution and changes in wave direction is obtained. This ap-
proach, however, does not properly handle diffraction in harbours or in front of reflecting
obstacles.
SWAN can be used on any scale relevant for wind generated surface gravity waves. How-
ever, SWAN is specifically designed for coastal applications that should actually not require
such flexibility in scale. The reasons for providing SWAN with such flexibility are:
• to allow SWAN to be used from laboratory conditions to shelf seas and
• to nest SWAN in the WAM model or the WAVEWATCH III model which are for-
mulated in terms of spherical coordinates.
Nevertheless, these facilities are not meant to support the use of SWAN on oceanic scales
because SWAN is less efficient on oceanic scales than WAVEWATCH III and probably also
less efficient than WAM.
Examples are:
• The user can request that refraction over one spatial grid step is limited to at most
the length of a directional sector associated with one sweep (which in the absence
of a current is 90o ). See command NUMERIC. This may be relevant when the depth
varies considerably over one spatial grid step (e.g. at the edge of oceans or near
oceanic islands with only one or two grid steps to go from oceanic depths to a shallow
coast). This implies inaccurate refraction computations in such grid steps. This
may be acceptable when refraction has only local effects that can be ignored but,
depending on the topography, the inaccurately computed effects may radiate far into
the computational area.
• SWAN cannot handle wave propagation on super-critical current flow. If such flow is
encountered during SWAN computations, the current is locally reduced to sub-critical
flow.
• If the water depth is less than some user-provided limit, the depth is set at that limit
(default is 0.05 m, see command SET).
• The user-imposed wave boundary conditions may not be reproduced by SWAN, as
SWAN replaces the imposed waves at the boundaries that propagate into the com-
putational area with the computed waves that move out of the computational area
at the boundaries.
• SWAN may have convergence problems. There are three iteration processes in
SWAN:
1. an iteration process for the spatial propagation of the waves,
2. if ambient currents are present, an iteration process for spectral propagation
(current-induced refraction and frequency shift) and
3. if wave-induced set-up is requested by the user, an iteration process for solving
the set-up equation.
ad 1 For spatial propagation the change of the wave field over one iteration is limited
to some realistic value (usually several iterations for stationary conditions or one
iteration or upgrade per time step for nonstationary conditions; see command
NUMERIC). This is a common problem for all third-generation wave models (such
as WAM, WAVEWATCH III and also SWAN). It does not seem to affect the
result seriously in many cases but sometimes SWAN fails to converge properly.
For curvilinear grids, convergence problems may occur locally where in some
points in the grid, the directions separating the 4 sweeping quadrants coincide
with the given spectral directions.
ad 2 For spectral propagation (but only current-induced refraction and frequency
shift) SWAN may also not converge.
General description and instructions for use 7
Because of the issues described above, the results may look realistic, but they may (locally)
not be accurate. Any change in these scenarios, limiters or shortcomings, in particular
newly discovered coding bugs and their fixes, are published on the SWAN web site and
implemented in new releases of SWAN.
• SWAN can be readily nested in WAM and WAVEWATCH III (the formulations of
WAVEWATCH III have not yet been implemented in SWAN).
When SWAN is nested in WAM or WAVEWATCH III, it must be noted that the boundary
conditions for SWAN provided by WAM or WAVEWATCH III may not be model consistent
even if the same physics are used. The potential reasons are manifold such as differences
in numerical techniques employed and implementation for the geographic area (spatial and
spectral resolutions, coefficients, etc.). Generally, the deep water boundary of the SWAN
nest must be located in WAM or WAVEWATCH III where shallow water effects do not
dominate (to avoid too large discontinuities between the two models). Also, the spatial and
spectral resolutions should not differ more than a factor two or three. If a finer resolution
is required, a second or third nesting may be needed.
(W). Consequently, the wave height and water depth are in m, wave period in s, etc. For
wind and wave direction both the Cartesian and a nautical convention can be used (see
below). Directions and spherical coordinates are in degrees (0 ) and not in radians.
For the output of wave energy the user can choose between variance (m2 ) or energy (spa-
tial) density (Joule/m2 , i.e. energy per unit sea surface) and the equivalents in case of
energy transport (m3 /s or W/m, i.e. energy transport per unit length) and spectral energy
density (m2 /Hz/Degr or Js/m2 /rad, i.e. energy per unit frequency and direction per unit
sea surface area). The wave−induced stress components (obtained as spatial derivatives of
wave-induced radiation stress) are always expressed in N/m2 even if the wave energy is in
terms of variance. Note that the energy density is also in Joule/m2 in the case of spherical
coordinates.
In the input and output of SWAN the direction of wind and waves are defined according
to either
• the Cartesian convention, i.e. the direction to where the vector points, measured
counterclockwise from the positive x−axis of this system (in degrees) or
• a nautical convention (there are more such conventions), i.e. the direction where the
wind or the waves come from, measured clockwise from geographic North.
All other directions, such as orientation of grids, are according to the Cartesian convention!
For regular grids, i.e. uniform and rectangular, Figure 4.1 (in Section 4.5) shows how the
locations of the various grids are determined with respect to the problem coordinates. All
grid points of curvilinear and unstructured grids are relative to the problem coordinate
system.
General description and instructions for use 9
The spectral grid that need to be defined by the user is a computational spectral grid on
which SWAN performs the computations.
SWAN has the option to make computations that can be nested in (coarse) SWAN, WAM
or WAVEWATCH III. In such cases, the spectral grid need not be equal to the spectral
grid in the coarse SWAN, WAM or WAVEWATCH III run.
The spatial grids that need to be defined by the user are (if required):
• one (or more) spatial input grid(s) for the bottom, current field, water level, bottom
friction, vegetation, mud, sea ice and wind (each input grid may differ from the
others) and
• one (or more) spatial output grid(s) on which the user requires output of SWAN.
The wind, bottom friction, vegetation, mud and sea ice do not require a grid if they are
uniform over the area of interest.
If a uniform, rectangular computational spatial grid is chosen in SWAN, then all input and
output grids must be uniform and rectangular too, but they may all be different from each
other.
If a curvilinear computational spatial grid is chosen in SWAN, then each input grid should
be either uniform, rectangular or identical to the used curvilinear grid or staggered with
respect to the curvilinear computational grid.
If an unstructured computational spatial grid is chosen in SWAN, then each input grid
should be either uniform, rectangular or identical to the used unstructured grid.
SWAN has the option to make computations that are nested in (coarse) SWAN, WAM or
WAVEWATCH III. In such runs, SWAN interpolates the spatial boundary of the SWAN,
WAM or WAVEWATCH III grid to the (user provided) grid of SWAN (that needs to
(nearly) coincide along the grid lines of WAM or WAVEWATCH III or the output nest
grid boundaries of SWAN). Since, the computational grids of WAM and WAVEWATCH
10 Chapter 2
SWAN using an unstructured mesh may be nested in SWAN employing a regular grid and
vice versa. However, SWAN using an unstructured grid cannot be nested in WAM or
WAVEWATCH III.
Similarly, the wind fields may be available in different time windows than the current and
water level fields and the computations may need to be carried out at other times than
these input fields. For these reasons SWAN operates with different time windows with
different time steps (each may have a different start and end time and time step):
• one (or more) input time window(s) in which the bottom, current field, water level,
bottom friction, vegetation, mud, sea ice and wind field (if present) are given by the
user (each input window may differ form the others) and
• one (or more) output time window(s) in which the user requires output of SWAN.
In case of nesting, SWAN searches the boundary conditions in the relevant output file of
the previous SWAN, WAM or WAVEWATCH III runs to take the boundary conditions
at the start time of the nested run. It will not take the initial condition (i.e. over the
entire computational grid) for the nested run from the previous SWAN, WAM or WAVE-
WATCH III run.
During the computation SWAN obtains bottom, current, water level, wind, bottom fric-
tion, vegetation, mud and sea ice information by tri-linear interpolation from the given
input grid(s) and time window(s). The output is in turn obtained in SWAN by bi-linear
interpolation in space from the computational grid; there is no interpolation in time, the
output time is shifted to the nearest computational time level. Interpolation errors can
be reduced by taking the grids and windows as much as equal to one another as possible
(preferably identical). It is recommended to choose output times such that they coincide
with computational time levels.
make an input grid so large that it completely covers the computational grid.
In the region outside the input grid SWAN assumes that the bottom level, the water level,
bottom friction, vegetation, mud and ice are identical to those at the nearest boundary of
the input grid (lateral shift of that boundary). In the regions not covered by this lateral
shift (i.e. in the outside quadrants of the corners of the input grid), a constant field equal
to the value at the nearest corner point of the input grid is taken. For the current and
wind velocity, SWAN takes 0 m/s for points outside the input grid.
In SWAN, the bathymetry, current, water level, wind, bottom friction, vegetation, mud
and sea ice may be time varying. In that case they need to be provided to SWAN in
so-called input time windows (they need not be identical with the computational, output
or other input windows). It is best to make an input window larger than the computa-
tional time window. SWAN assumes zero values at times before the earliest begin time
of the input parameters (which may be the begin time of any input parameter such as
wind). SWAN assumes constant values (the last values) at times after the end time of each
input parameter. The input windows should start early enough so that the initial state of
SWAN has propagated through the computational area before reliable output of SWAN is
expected.
One should choose the spatial resolution for the input grids such that relevant spatial
details in the bathymetry, currents, bottom friction, vegetation, mud, ice and wind are
properly resolved. Special care is required in cases with sharp and shallow ridges (sand
bars, shoals) in the sea bottom and extremely steep bottom slopes. Very inaccurate ba-
thymetry can result in very inaccurate refraction computations the results of which can
propagate into areas where refraction as such is not significant (the results may appear to
be unstable). For instance, waves skirting an island that is poorly resolved may propagate
beyond the island with entirely wrong directions. In such a case it may even be better to
deactivate the refraction computations (if refraction is irrelevant for the problem at hand
e.g. because the refracted waves will run into the coast anyway and one is not interested
in that part of the coast). In such cases the ridges are vitally important to obtain good
SWAN results (at sea the waves are ’clipped’ by depth-induced breaking over the ridges
which must therefore represented in SWAN computation). This requires not only that
these ridges should be well represented on the input grid but also after interpolation on
the computational grid. This can be achieved by choosing the grid lines of the input grid
along the ridges (even if this may require some slight ”shifting” of the ridges) and choosing
the computational grid to be identical to the input grid (otherwise the ridge may be ”lost”
in the interpolation from the bottom input grid to the computational grid).
Finally, one should use a time step that is small enough that time variations in the bathy-
metry, current, water level, wind and bottom friction are well resolved.
12 Chapter 2
The computational spatial grid must be defined by the user. The orientation (direction)
can be chosen arbitrarily.
The boundaries of the computational spatial grid in SWAN are either land or water. In the
case of land there is no problem: the land does not generate waves and in SWAN it absorbs
all incoming wave energy. But in the case of a water boundary there may be a problem.
Often no wave conditions are known along such a boundary and SWAN then assumes
that no waves enter the area and that waves can leave the area freely. These assumptions
obviously contain errors which propagate into the model. These boundaries must therefore
be chosen sufficiently far away from the area where reliable computations are needed so
that they do not affect the computational results there. This is best established by varying
the location of these boundaries and inspect the effect on the results. Sometimes the waves
at these boundaries can be estimated with a certain degree of reliability. This is the case if
(a) results of another model run are available (nested computations) or, (b) observations
are available. If model results are available along the boundaries of the computational
spatial grid, they are usually from a coarser resolution than the computational spatial grid
under consideration. This implies that this coarseness of the boundary propagates into
the computational grid. The problem is therefore essentially the same as if no waves are
assumed along the boundary except that now the error may be more acceptable (or the
boundaries are permitted to be closer to the area of interest). If observations are available,
they can be used as input at the boundaries. However, this usually covers only part of the
boundaries so that the rest of the boundaries suffer from the same error as above.
A special case occurs near the coast. Here it is often possible to identify an up-wave
boundary (with proper wave information) and two lateral boundaries (with no or partial
wave information). The affected areas with errors are typically regions with the apex
at the corners of the water boundary with wave information, spreading towards shore at
an angle of 30o to 45o for wind sea conditions to either side of the imposed mean wave
direction (less for swell conditions; the angle is essentially the one-sided width of the
directional distribution of wave energy). For propagation of short crested waves (wind sea
condtions) an example is given in Figure 2.1. For this reason the lateral boundaries should
be sufficiently far away from the area of interest to avoid the propagation of this error
into this area. Such problems do not occur if the lateral boundaries contain proper wave
information over their entire length e.g. obtained from a previous SWAN computation or
if the lateral boundaries are coast.
When output is requested along a boundary of the computational grid, it may occur that
this output differs from the boundary conditions that are imposed by the user. The reason
is that SWAN accepts only the user-imposed incoming wave components and that it re-
places the user-imposed outgoing wave components with computed outgoing components
(propagating to the boundary from the interior region). The user is informed by means of
General description and instructions for use 13
yp − axis
o
app. 30
o
app. 30
yc − axis mean wave direction
11111
00000
00000
11111
00000
11111
00000
11111 11111
00000
00000
11111 00000
11111
00000
11111
00000
11111
00000
11111 00000
11111
00000
11111 00000
11111 xc − axis
00000
11111 00000
11111
00000
11111
computational grid
xp − axis
Figure 2.1: Disturbed regions in the computational grid due to erroneous boundary con-
ditions are indicated with shaded areas.
a warning in the output when the computed significant wave height differs more than 10%,
say (10% is default), from the user-imposed significant wave height (command BOUND...).
The actual value of this difference can be set by the user (see the SET command). Note
that this warning will not apply in the case of unstructured grids.
If the computational grid extends outside the input grid, the reader is referred to Sec-
tion 2.6.2 to find the assumptions of SWAN on depth, current, water level, wind, bottom
friction, vegetation, mud, and ice in the non-overlapping area.
The spatial resolution of the computational grid should be sufficient to resolve relevant
details of the wave field. Usually a good choice is to take the resolution of the compu-
tational grid approximately equal to that of the bottom or current grid. If necessary, an
unstructured grid may be used.
SWAN may not use the entire user-provided computational grid if the user defines ex-
ception values on the depth grid (see command INPGRID BOTTOM) or on the curvilinear
computational grid (see command CGRID). A computational grid point is either
• wet, i.e. the grid point is included in the computations since it represents water; this
may vary with time-dependent or wave-induced water levels or
• dry, i.e. the grid point is excluded from the computations since it represents land
which may vary with time-dependent or wave-induced water levels or
• exceptional, i.e. the grid point is permanently excluded from the computations since
14 Chapter 2
• each wet computational grid point that is linked to only one other wet computational
grid point, is removed and
• each wet computational grid point that has no wet links is removed.
The effect of this filter is that if exception values are used for the depth grid or the
curvilinear computational grid, one-dimensional water features are ignored in the SWAN
computations (results at these locations with a width of about one grid step may be
unrealistic). If no exception values are used, the above described filter will not be applied.
As a consequence, one-dimensional features may appear or disappear due to changing
water levels (flooding may create them, drying may reduce two-dimensional features to
one-dimensional features).
It must be noted that for parallel runs using MPI the user must indicate an exception value
when reading the bottom levels (by means of command INPGRID BOTTOM EXCEPTION), if
appropriate, in order to obtain good load balancing.
The computational time window must be defined by the user in case of nonstationary
runs. The computational window in time must start at a time that is early enough that
the initial state of SWAN has propagated through the computational area before reliable
output of SWAN is expected. Before this time the output may not be reliable since usually
the initial state is not known and only either no waves or some very young sea state is
assumed for the initial state. This is very often erroneous and this erroneous initial state
is propagated into the computational area.
The computational time step must be given by the user in case of nonstationary runs. Since,
SWAN is based on implicit numerical schemes, it is not limited by the Courant stability
criterion (which couples time and space steps). In this sense, the time step in SWAN is
not restricted. However, the accuracy of the results of SWAN are obviously affected by
the time step. Generally, the time step in SWAN should be small enough to resolve the
time variations of computed wave field itself. Usually, it is enough to consider the time
variations of the driving fields (wind, currents, water depth, wave boundary conditions).
But be careful: relatively(!) small time variations in depth (e.g. by tide) can result in
relatively(!) large variations in the wave field.
As default, the first guess conditions of a stationary run of SWAN are determined with the
2nd generation mode of SWAN. The initial condition of a nonstationary run of SWAN is
by default a JONSWAP spectrum with a cos2 (θ) directional distribution centred around
General description and instructions for use 15
The computational spectral grid needs to be provided by the user. In frequency space,
it is simply defined by a minimum and a maximum frequency and the frequency resolution
which is proportional to the frequency itself (i.e. logarithmic, e.g., ∆ f = 0.1 f ). The
frequency domain may be specified as follows (see command CGRID):
• The lowest frequency, the highest frequency and the number of frequencies can be
chosen.
• Only the lowest frequency and the number of frequencies can be chosen. The highest
frequency will be computed by SWAN such that ∆ f = 0.1 f . This resolution is
required by the DIA method for the approximation of nonlinear 4-wave interactions
(the so-called quadruplets).
• Only the highest frequency and the number of frequencies can be chosen. The lowest
frequency will be computed by SWAN such that ∆ f = 0.1 f . This resolution is
required by the DIA method for the approximation of nonlinear 4-wave interactions.
• Only the lowest frequency and the highest frequency can be chosen. The number of
frequencies will be computed by SWAN such that ∆ f = 0.1 f . This resolution is
required by the DIA method for the approximation of nonlinear 4-wave interactions.
The value of lowest frequency must be somewhat smaller than 0.7 times the value of the
lowest peak frequency expected. The value of highest frequency must be at least 2.5 to 3
times the highest peak frequency expected. For the XNL approach, however, this should
be 6 times the highest peak frequency. Usually, it is chosen less than or equal to 1 Hz.
SWAN has the option to make computations that can be nested in WAM or WAVE-
WATCH III. In such runs SWAN interpolates the spectral grid of WAM or WAVEWATCH III
to the (user provided) spectral grid of SWAN. The WAM Cycle 4 source term in SWAN has
been retuned for a highest prognostic frequency (that is explicitly computed by SWAN) of
1 Hz. It is therefore recommended that for cases where wind generation is important and
WAM Cycle 4 formulations are chosen, the highest prognostic frequency is about 1 Hz.
In directional space, the directional range is the full 360o unless the user specifies a limited
directional range. This may be convenient (less computer time and/or memory space), for
example, when waves travel towards a coast within a limited sector of 180o . The directional
resolution is determined by the number of discrete directions that is provided by the user.
For wind seas with a directional spreading of typically 30o on either side of the mean wave
direction, a resolution of 10o seems enough whereas for swell with a directional spreading
of less than 10o , a resolution of 2o or less may be required. If the user is confident that no
energy will occur outside a certain directional sector (or is willing to ignore this amount
16 Chapter 2
of energy), then the computations by SWAN can be limited to the directional sector that
does contain energy. This may often be the case of waves propagating to shore within a
sector of 180o around some mean wave direction.
The numerical schemes in the SWAN model require a minimum number of discrete grid
points in each spatial directions of 2. The minimum number of directional bins is 3 per
directional quadrant and the minimum number of frequencies should be 4.
A final remark on the choice of spatial and spectral resolution. SWAN should not shift
energy more than one spectral bin (∆f and/or ∆θ) when propagating over one spatial grid
cell (∆x and/or ∆y). This is for reasons for accuracy and not stability. See for details
Section 3.8 of the Scientific/Technical documentation. This implies that although SWAN
will be stable, whatever resolution you choose, you need to balance spectral and spatial
resolution. This could mean, i.e. not necessarily, that you have to refine your spatial
resolution when you refine your spectral resolution.
In a situation with currents this is particularly important at the highest frequencies where
the Doppler shifts are largest. However, it may well be that inaccuracies thus generated
will be removed by the source terms. In other words, accurate Doppler shifts at high
frequencies require high spectral and spatial resolution, but the effects may be dominated
by white capping. Hence, at the high frequencies, the problem is perhaps masked by white
capping. The inaccuracies may only appear at the lowest frequencies, where usually the
source terms are relatively weak at these frequencies.
Another issue concerns the excessive wave turning of relatively long waves at shallow water,
or cases with depth varies considerably over one spatial grid step, e.g. at the edge of shelf
break or seamount at deep ocean. As the refraction becomes excessive in a region with
steep bottom gradients, it is possible that the wave energy focus toward a single grid point,
creating unrealistically large wave heights and long periods; see Dietrich et al. (2013).
SWAN can optionally uses a Courant-type limiter (see command NUMERIC). This limiter
is locally in geographic space for cosmetic reasons, but it avoids propagating a large error
to the rest of the geographic domain and thus improve the solution there. However, if the
limiter is activated, the computation is still inaccurate, but less so as you are farther from
the location with poor resolution. The common mistake people often make is that the
limiter may affect the model results negatively, which is, however, not entirely true. As
General description and instructions for use 17
the resolution is too coarse, the model results are inaccurate anyway. Hence, the proper
solution to this problem is to choose the right resolution, both spectral and spatial, and
one can thus avoid the use of the limiter.
In the regions where the output grid does not cover the computational grid, SWAN assumes
output values equal to the corresponding exception value. For example, the default excep-
tion value for the significant wave height is −9. The exception values of output quantities
can be changed by means of the QUANTITY command.
After it has been established that a certain physical process is important, it may be worth-
while to modify coefficients. In the case of wind input one may at first try to vary the
wind velocity. Concerning the bottom friction, the best coefficients to vary are the friction
coefficients. Switching off the depth-induced breaking term is usually not wise, since this
may lead to unacceptably high wave heights near beaches (the computed wave heights
’explode’ due to shoaling effects).
3.1 General
SWAN is one single computer program. The names of the files provided by the user should
comply with the rules of file identification of the computer system on which SWAN is
run. In addition: SWAN does not permit file names longer than 36 characters. Moreover,
the maximum length of the lines in the input files for SWAN is 180 positions.
The user should provide SWAN with a number of files (input files) with the following
information:
• a file containing the instructions of the user to SWAN (the command file),
• file(s) containing: grid, bottom, current, friction, and wind (if relevant) and
• file(s) containing the wave field at the model boundaries (if relevant).
SWAN is fairly flexible with respect to output processing. Output is available for many
different wave parameters and wave related parameters (e.g., wave-induced stresses and
bottom orbital motion). However, the general rule is that output is produced by SWAN
only at the user’s request. The instructions of the user to control output are separated
into three categories:
21
22 Chapter 3
• Definitions of the geographic location(s) of the output. The output locations may be
either on a geographic grid, or along user specified lines (e.g., a given depth contour
line) or at individual output locations.
The print file contains an echo of the command file, an overview of the actual physical
and numerical parameters to be used in the simulation run, and possibly warning and
error messages. These messages are usually self-explanatory. The print file also contains
computational results if the user so requests (with command BLOCK or TABLE).
Description of commands
Start-up commands
INPGRID defines dimensions of bottom, water level, current and friction grids
READINP reads input fields
WIND activates constant wind option
23
24 Chapter 4
BOUND defines the shape of the spectra at the boundary of geographic grid
BOUNDSPEC defines (parametric) spectra at the boundary of geographic grid
BOUNDNEST1 defines boundary conditions obtained from (coarse) SWAN run
BOUNDNEST2 defines boundary conditions obtained from WAM run
BOUNDNEST3 defines boundary conditions obtained from WAVEWATCH III run
INITIAL specifies an initial wave field
Output commands
Lock-up commands
Many commands provide the user with the opportunity to assign values to coefficients of
SWAN (e.g. the bottom friction coefficient). If the user does not use such option SWAN
will use a default value.
Some commands cannot be used in 1D-mode (see individual command descriptions below).
Limitations:
• The maximum length of the input lines is 180 characters. A line may be continued on
the next line while it is terminated with a continuation mark &. See also Section B.4.
• The maximum number of file names is 99. This can be extended (edit the file
swaninit to change highest unit number of 99 to a higher number).
4.4 Start-up
’title1’
Description of commands 27
’title2’
’title3’
With this required command the user defines a number of strings to identify the SWAN
run (project name e.g., an engineering project) in the print and plot file.
SET [level] [nor] [depmin] [maxmes] [maxerr] [grav] [rho] [cdcap] &
| NAUTical |
[inrhog] [hsrerr] < > [pwtail] [froudmax] [icewind]
| -> CARTesian |
With this optional command the user assigns values to various general parameters.
[level] increase in water level that is constant in space and time can be given with
this option, [level] is the value of this increase (in m). For a variable water
level reference is made to the commands INPGRID and READINP.
Default: [level]=0.
[nor] direction of North with respect to the x−axis (measured counterclockwise);
default [nor]= 90o , i.e. x−axis of the problem coordinate system
points East.
When spherical coordinates are used (see command COORD) the value
of [nor] may not be modified.
[depmin] threshold depth (in m). In the computation any positive depth smaller than
[depmin] is made equal to [depmin].
Default: [depmin] = 0.05.
[maxmes] maximum number of error messages (not necessarily the number of errors!)
during the computation at which the computation is terminated. During the
28 Chapter 4
With this optional command the user indicates that the run will be either stationary
or nonstationary and one-dimensional (1D-mode) or two-dimensional (2D-mode). Non-
stationary means either (see command COMPUTE):
| -> CARTesian |
COORDINATES < | -> CCM | > REPeating
| SPHErical < > |
| QC |
30 Chapter 4
Command to choose between Cartesian and spherical coordinates (see Section 2.5).
A nested SWAN run must use the same coordinate system as the coarse grid SWAN run.
CARTESIAN all locations and distances are in m. Coordinates are given with respect
to x− and y−axes chosen by the user in the various commands.
SPHERICAL all coordinates of locations and geographical grid sizes are given in degrees;
x is longitude with x = 0 being the Greenwich meridian and x > 0 is East of
this meridian; y is latitude with y > 0 being the Northern hemisphere. Input
and output grids have to be oriented with their x−axis to the East; mesh sizes
are in degrees. All other distances are in meters.
CCM defines the projection method in case of spherical coordinates. CCM means
central conformal Mercator. The horizontal and vertical scales are uniform
in terms of cm/degree over the area shown. In the centre of the scale is
identical to that of the conventional Mercator projection (but only at that
centre). The area in the projection centre is therefore exactly conformal.
QC the projection method is quasi-cartesian, i.e. the horizontal and vertical scales
are equal to one another in terms of cm/degree.
REPEATING this option is only for academic cases. It means that wave energy leaving at one
end of the domain (in computational x−direction) enter at the other side; it is
as if the wave field repeats itself in x−direction with the length of the domain
in x−direction.
This option cannot be used in combination with computation of set-up (see
command SETUP). This option is available only with regular grids.
Note that spherical coordinates can also be used for relatively small areas, say 10 or 20
km horizontal dimension. This may be useful if one obtains the boundary conditions by
nesting in an oceanic model which is naturally formulated in spherical coordinates.
Note that in case of spherical coordinates regular grids must always be oriented E-W, N-S,
i.e. [alpc]=0, [alpinp]=0, [alpfr]=0 (see commands CGRID, INPUT GRID and FRAME,
respectively).
| |
| UNSTRUCtured |
| -> CIRcle |
< > [mdc] [flow] [fhigh] [msc]
| SECtor [dir1] [dir2] |
With this required command the user defines the geographic location, size, resolution and
orientation of the computational grid in the problem coordinate system (see Section 2.6.3)
in case of a uniform, rectilinear computational grid, a curvilinear grid or unstructured
mesh. The origin of the regular grid and the direction of the positive x−axis of this grid
can be chosen arbitrary by the user. Must be used for nested runs. Note that in a nested
case, the geographic and spectral range (directional sector inclusive) and resolution may
differ from the previous run (outside these ranges zero’s are used).
REGULAR this option indicates that the computational grid is to be taken as uniform and
rectangular.
CURVILINEAR this option indicates that the computational grid is to be taken as curvilinear.
The user must provide the coordinates of the grid points with command
READGRID COOR.
UNSTRUCTURE this option indicates that the computational grid is to be taken as unstructured.
The user must provide the coordinates of the vertices and the numbering of
triangles with the associated connectivity table with vertices with command
READGRID UNSTRUC.
[xpc] geographic location of the origin of the computational grid in the problem
coordinate system (x−coordinate, in m). See command COORD.
Default: [xpc] = 0.0 (Cartesian coordinates).
In case of spherical coordinates there is no default, the user must give a value.
[ypc] geographic location of the origin of the computational grid in the problem
coordinate system (y−coordinate, in m). See command COORD.
Default: [ypc] = 0.0 (Cartesian coordinates).
In case of spherical coordinates there is no default, the user must give a value.
[alpc] direction of the positive x−axis of the computational grid (in degrees, Cartesian
convention). In 1D-mode, [alpc] should be equal to the direction [alpinp]
(see command INPGRID).
Default: [alpc] = 0.0.
[xlenc] length of the computational grid in x−direction (in m). In case of spherical
coordinates [xlenc] is in degrees.
[ylenc] length of the computational grid in y−direction (in m). In 1D-mode, [ylenc]
should be 0. In case of spherical coordinates [ylenc] is in degrees.
[mxc] number of meshes in computational grid in x−direction for a uniform, rectilinear
grid or ξ−direction for a curvilinear grid (this number is one less than the
number of grid points in this domain!).
32 Chapter 4
in frequency-space between the lowest discrete frequency [flow] and the highest
discrete frequency [fhigh]. This resolution is not constant, since the frequencies
are distributed logarithmical: fi+1 = γfi with γ is a constant. The minimum
number of frequencies is 4.
The value of [msc] depends on the frequency resolution ∆f that the user requires.
Since, the frequency distribution on the frequency axis is logarithmic, the
relationship is:
1/[msc]
[fhigh]
∆f = −1 + [flow] f
Vice versa, if the user chooses the value of ∆f /f (= γ − 1.), then the value of
[msc] is given by:
In this respect, it must be observed that the DIA approximation of the quadruplet
interactions (see command GEN3) is based on a frequency resolution of ∆f /f = 0.1
and hence, γ = 1.1. The actual resolution in the computations should therefore
not deviate too much from this. Alternatively, the user may only specifies one of
the following possibilities:
• [flow] and [msc]; SWAN will compute [fhigh], such that γ = 1.1,
and write it to the PRINT file.
• [fhigh] and [msc]; SWAN will compute [flow], such that γ = 1.1,
and write it to the PRINT file.
• [flow] and [fhigh]; SWAN will compute [msc], such that γ = 1.1,
and write it to the PRINT file.
Note that [fhigh] = 1 Hz is often ok. But more importantly, the first frequency bin should
be empty, i.e. it should not contain energy. For instance, a value of [flow] = 0.03 Hz is
recommended (especially when simulating a strong hurricane).
For illustration of a regular grid with its dimensions, see Figure 4.1.
| -> FREe |
| |
| | ’form’ | |
< FORmat < > >
| | [idfm] | |
34 Chapter 4
problem
coordinates
yp−axis
(mxc,myc)
yc−axis
xc−axis
(0,myc) computational grid
(mxc,0)
alpc
ypc (0,0)
Figure 4.1: Coordinates of the origin [xpc] and [ypc], the orientation [alpc] and the
grid point numbering of the computational grid with respect to the problem coordinates
system. Note that in case of spherical coordinates the xc− and xp−axes both point East.
| |
| UNFormatted |
This command READGRID COOR must follow a command CGRID CURV. With this command
(required if the computational grid is curvilinear; not allowed in case of a regular grid) the
user controls the reading of the co-ordinates of the computational grid points. These co-
ordinates must be read from a file as a vector (x−coordinate, y−coordinate of each single
grid point). See command READINP for the description of the options in this command
READGRID. SWAN will check whether all angles in the grid are > 0 and < 180 degrees. If
not, it will print an error message giving the coordinates of the grid points involved. It is
recommended to use grids with angles between 45 and 135 degrees.
| -> ADCirc
|
READgrid UNSTRUCtured < TRIAngle |
| > ’fname’
| EASYmesh |
Description of commands 35
This command READGRID UNSTRUC must follow a command CGRID UNSTRUC. With this com-
mand (required if the computational grid is unstructured; not allowed in case of a regular
or curvilinear grid) the user controls the reading of the (x, y) co-ordinates of the vertices
including boundary markers and a connectivity table for triangles (or elements). This
table contains three corner vertices around each triangle in counterclockwise order. This
information should be provided by a number of files generated by one of the following grid
generators currently supported by SWAN:
• ADCIRC (http://www.adcirc.org)
• Triangle (http://www.cs.cmu.edu/afs/cs/project/quake/public/www/triangle.html)
• Easymesh (http://www-dinma.univ.trieste.it/nirftc/research/easymesh/easymesh.html)
After setting up the vertices and the connectivity tables for cells and faces (automatically
done in SWAN), SWAN will print some information concerning the used mesh, among
others, number of vertices, cells and faces and minimum and maximum gridsizes. Further-
more, SWAN will check at two levels for a possible occurence of badly shaped triangles.
Firstly, the number of triangles that meet at each vertex inside the mesh should not be
smaller than 4 or larger than 10. Secondly, the angles inside each triangle should not be
higher than 143o . If, at least, one of these two situations occur, SWAN will print an error
message.
ADCIRC the necessary grid information is read from file fort.14 as used by ADCIRC.
This file also contains the depth information that is read as well.
TRIANGLE the necessary grid information is read from two files as produced by Triangle.
The .node and .ele files are required. The basename of these files must be
indicated with parameter ’fname’.
EASYMESH the necessary grid information is read from two files as produced by
Easymesh. The .n and .e files are required. The basename of these files
must be indicated with parameter ’fname’.
’fname’ basename of the required files, i.e. without extension. Only meant for
Triangle and Easymesh.
| BOTtom |
| |
| WLEVel |
| |
36 Chapter 4
| | CURrent |
| < |
| | VX |
| | VY |
| |
| |
| FRiction |
INPgrid (< >) &
| | WInd |
| < |
| | WX |
| | WY |
| |
| NPLAnts |
| |
| TURBvisc |
| |
| MUDLayer |
| |
| AICE |
| -> Sec |
(NONSTATionary [tbeginp] [deltinp] < MIn > [tendinp])
| HR |
| DAy |
With this required command the user defines the geographic location, size and orient-
ation of an input grid and also the time characteristics of the variable if it is not sta-
tionary. If this is the case (the variable is not stationary), the variable should be given
in a sequence of fields, one for each time step [deltinp]. The actual reading of val-
ues of bottom levels, currents, etc. from file is controlled by the command READINP.
This command INPGRID must precede the following command READINP.
Description of commands 37
There can be different grids for bottom level (BOTTOM), flow current (CURRENT), bottom
friction coefficient (FRICTION), wind velocity (WIND), vegetation density (NPLANTS), tur-
bulent viscosity (TURB), mud layer thickness (MUDLAY) and sea ice fraction (AICE). If the
current velocity components are available on different grids, then option VX, VY can define
these different grids for the x− and y−component of the current, respectively (but the
grids must have identical orientation). Different grids for VX and VY may be useful if the
data are generated by a circulation model using a staggered grid. The same holds for the
wind velocity components, i.e. WX and WY.
In case of a regular grid (option REGULAR in the INPGRID command) the current and wind
velocity vectors are defined with the x− and y−component of the current or wind vector
with respect to the x−axis of the input grid. So, these velocity components are grid ori-
ented.
In case of a curvilinear grid (option CURVILINEAR in the INPGRID command) the current
and wind velocity vectors are defined with the x− and y−component of the current or
wind vector with respect to the x−axis of the problem coordinate system.
In case of an unstructured grid (option UNSTRUC in the INPGRID command) the current and
wind velocity vectors are defined with the x− and y−component of the current or wind
vector with respect to the x−axis of the problem coordinate system.
For wind velocity, friction coefficient, vegetation density, mud layer and sea ice fraction
(between 0 and 1) it is also possible to use a constant value over the computational field
(see commands WIND, VEGE, FRICTION, MUD and IC4M2, respectively). No grid definition
for wind, friction, vegetation density, mud layer, or sea ice concentration is then required.
Note that in case of option BOTTOM only stationary input field is allowed.
Note that in 1D mode, both x− and y−components of the current and/or wind must be
specified. Also, VX and WX must always be followed by VY and WY, respectively.
If the computational grid is unstructured, the input grids can be either regular or identical
to the used computational grid.
Do not use the command INP BOTTOM when the unstructured grid of ADCIRC is employed!
The file fort.14 contains the bottom levels and will be read by SWAN through the com-
mand READ UNSTRUC ADCIRC.
If land points remain dry during the computation (no flooding!), then these points can be
ignored. In this way, turn-around time and internal memory can be saved. This can be
done by indicating bottom level in these points as exception value. See command INPGRID
BOTTOM EXCEPTION. For parallel runs using MPI, an exception value for bottom levels
should be prescribed in order to have a good load-balancing!
38 Chapter 4
BOTTOM defines the input grid of the bottom level. (For the definition of the bottom
level, see command READINP).
WLEV defines the input grid of the water level. (For the definition of the water
level, see command READINP).
CURRENT defines the input grid of the current field (same grid for x− and y−components).
VX defines the input grid of the x−component of the current field (different grid
than y−component but same orientation).
VY defines the input grid of the y−component of the current field (different grid
than x−component but same orientation).
FRICTION defines the input grid of the bottom friction coefficient (defined in command
FRICTION, not to be confused with this option FRICTION!).
WIND defines the input grid of the wind velocity field (same grid for x− and
y−component).
If neither of the commands WIND and READINP WIND is used it is
assumed that there is no wind.
WX defines the input grid of the x−component of the wind velocity field
(different grid than y−component but same orientation).
WY defines the input grid of the y−component of the wind velocity field
(different grid than x−component but same orientation).
NPLANTS defines input grid of the horizontally varying vegetation density (defined
in command VEGETATION).
TURBVISC defines input grid of the horizontally varying turbulent viscosity (defined
in command TURBULENCE).
MUDLAYER defines input grid of the horizontally varying mud layer thickness (defined
in command MUD).
AICE defines the input grid of ice concentration as a fraction from 0 to 1 (defined
in command IC4M2).
REGULAR means that the input grid is uniform and rectangular.
CURVILINEAR means that the input grid is curvilinear; this option is available only if the
computational grid is curvilinear as well. The input grid is identical
(which is default) to the computational grid, or it is staggered in x− and/or
y−direction.
NOT FOR 1D-MODE.
UNSTRUCTURE means that the input grid is unstructured; this option is available only if the
computational grid is unstructured as well. The input grid must be identical
to the computational grid.
NOT FOR 1D-MODE.
| BOTtom |
| |
| WLEVel |
| |
| CURrent |
| |
| WInd |
| | | ’fname1’ |
READinp < FRiction > [fac] < > [idla] &
Description of commands 41
| | | SERIes ’fname2’ |
| NPLAnts |
| |
| TURBvisc |
| |
| MUDLayer |
| |
| AICE |
| -> FREe |
| |
| | ’form’ | |
[nhedf] ([nhedt]) ([nhedvec]) < FORmat < > >
| | [idfm] | |
| |
| UNFormatted |
With this required command the user controls the reading of values of the indicated vari-
ables from file. This command READINP must follow a command INPGRID. Note that for
each stationary or nonstationary field, one combination of INPGRID and READINP suffices
if one has more than one COMPUTE command in a run.
If the variables are in one file, then the READINP commands should be given in the same
sequence as the sequence in which the variables appear in the file.
BOTTOM with this option the user indicates that bottom levels (in m) are to be read from
file (bottom level positive downward relative to an arbitrary horizontal datum
level). The sign of the input can be changed with option [fac] = −1. (see below).
WLEV with this option the user indicates that water levels (in m) are to be read from
file (water level positive upward relative to the same datum level as used in
option BOTTOM). Sign of input can be changed with option [fac] = −1. If the
water level is constant in space and time, the user can use the command SET
to add this water level to the water depth.
CURRENT rectilinear (curvilinear) input grid: with this option the user indicates that
the x− and y−component (ξ− and η−component) (in m/s) are to be read from
one and the same file (with one READINP command). With this option SWAN
reads first all x−components (ξ−components), and then all y−components
(η−components) (see [idla]). The first component (x− or ξ−component) is
always eastward oriented and the second one (y− or η−component) is always
northward oriented. The components ξ and η are taken along the directions of
the grid lines of the curvilinear
√ grid! If the current velocity is relatively large,
i.e. the Froude number U/ gd is larger than 0.8, it will be reduced such
that the Froude number becomes equal to 0.8.
42 Chapter 4
unstructured input grid: with this option the user indicates that the x− and
y−component (in m/s) are to be read from one and the same file (with one
READINP command). With this option SWAN reads first all x−components,
and then all y−components. The order of these values to be read is identical
to that of the unstructured computational grid.
WIND rectilinear (curvilinear) input grid: with this option the user indicates that
the x− and y−component (ξ− and η−component) (in m/s) are to be read from
one and the same file (with one READINP command). With this option SWAN
reads first all x−components (ξ−components), and then all y−component
(η−components) (see [idla]). The components ξ and η are taken along the
directions of the grid lines of the curvilinear grid! If the wind is constant, see
command WIND.
unstructured input grid: with this option the user indicates that the x− and
y−component (in m/s) are to be read from one and the same file (with one
READINP command). With this option SWAN reads first all x−components,
and then all y−components. The order of these values to be read is identical
to that of the unstructured computational grid.
FRICTION with this option the user indicates that friction coefficient is to be read from
file for Collins: [cfw] and for Madsen: [kn] (no space- or time-variable
coefficient for the Jonswap expression, see command FRICTION). If the
coefficients are constant in space and time: see command FRICTION.
NPLANTS with this option the user indicates that horizontally varying vegetation
density (per m2 ) is to be read from file. If the density is constant then
see command VEGETATION for specification.
TURBVISC with this option the user indicates that horizontally varying turbulent
viscosity (m2 /s) is to be read from file. If the viscosity is constant
then see command TURBULENCE for specification.
MUDLAYER with this option the user indicates that horizontally varying mud layer
thickness (in m) is to be read from file. If the thickness is constant then
see command MUD for specification.
AICE with this option the user indicates that ice fraction (between 0 and 1) is
to be read from file. If the concentration is constant then see command
IC4M2 for specification.
[fac] SWAN multiplies all values that are read from file with [fac]. For instance
if the bottom levels are given in unit decimeter, one should make [fac]=0.1 to
obtain levels in m. To change sign of bottom level use a negative value of [fac].
Note that [fac] = 0 is not allowed!
Default: [fac]=1.
’fname1’ name of the file with the values of the variable.
SERIES with this option (only for MODE NONSTATIONARY) the user indicates that the
names of the files containing the nonstationary variable(s) are located in a
separate file with name ’fname2’ (see below).
Description of commands 43
’fname2’ name of file that contains the names of the files where the variables
are given. These names are to be given in proper time sequence. SWAN reads
the next file when the previous file end has been encountered. In these files the
input should be given in the same format as in the above file ’fname1’ (that
implies that a file should start with the start of an input time step).
[idla] prescribes the order in which the values of bottom levels and other fields
should be given in the file.
=1: SWAN reads the map from left to right starting in the upper-left-hand
corner of the map (it is assumed that the x−axis of the grid is pointing
to the right and the y−axis upwards). A new line in the map should
start on a new line in the file. The lay-out is as follows:
=2: as [idla]=1 but a new line in the map need not start on a new line in
the file.
=3: SWAN reads the map from left to right starting in the lower-left-hand
corner of the map. A new line in the map should start on a new line in
the file. The lay-out is as follows:
=4: as [idla]=3 but a new line in the map need not start on a new line
in the file.
=5: SWAN reads the map from top to bottom starting in the lower-left-hand
corner of the map. A new column in the map should start on a new line in
the file. The lay-out is as follows:
=6: as [idla]=5 but a new column in the map need not start on a new line
in the file.
Default: [idla]=1.
ONLY MEANT FOR STRUCTURED GRIDS.
44 Chapter 4
[nhedf] is the number of header lines at the start of the file. The text in the header
lines is reproduced in the print file created by SWAN (see Section 3.3). The
file may start with more header lines than [nhedf] because the start of the
file is often also the start of a time step and possibly also of a vector
variable (each having header lines, see below, [nhedt] and [nhedvec]).
Default: [nhedf]=0.
[nhedt] only if variable is time dependent: number of header lines in the file at the
start of each time level. A time step may start with more header lines than
[nhedt] because the variable may be a vector variable which has its own header
lines (see below [nhedvec]).
Default: [nhedt]=0.
[nhedvec] for each vector variable: number of header lines in the file at the start of
each component (e.g., x− or y−component).
Default: [nhedvec]=0.
FREE With this option the user indicates that the values are to be read with free
format. Free format is a standard of the computer programming language
FORTRAN. The free format conventions in reading from a file are almost the
same as the conventions for the command syntax given elsewhere in this manual;
the most important differences are:
1. There are no continuation marks, reading continues until the required
number of data has been read, or until a slash (/) is encountered.
2. Input lines can be longer than 80 characters (depending on the operating
system of the computer).
3. Comment is not allowed.
With free format empty fields, repetition factors, and closure of a line by a slash,
can be used.
FORMAT with this option the user indicates that fixed format (FORTRAN convention) is
to be used when reading the values from file. The format can be defined in one
of two ways, by giving the format number [idfm] or the format string ’form’.
’form’ a user−specified format string according to Fortran convention, e.g.
’(10X,12F5.0)’.
[idfm] this format number is interpreted as follows:
=1: Format according to BODKAR convention (a standard of the Ministry
of Transport and Public Works in the Netherlands).
Format string: (10X,12F5.0).
=5: Format (16F5.0), i.e. an input line consists of 16 fields of 5 places each.
=6: Format (12F6.0), i.e. an input line consists of 12 fields of 6 places each.
=8: Format (10F8.0), i.e. an input line consists of 10 fields of 8 places each.
UNFORMATTED is a form of reading without conversion (binary files). Not recommended for
ordinary use.
If the file does not contain a sufficient number of data (i.e. less than the number of grid
Description of commands 45
points of the input grid), SWAN will write an error message to the PRINT file, and if
[itest]>0 (see command TEST) it will reproduce the data in the PRINT file, using the lay-
out according to [idla]=1. This echo of the data to print file is also made if the READINP
command is embedded between two TEST commands in the command file as follows:
TEST 120
READINP ....
TEST 0
With this optional command the user indicates that the wind is constant.
Both quantities [vel] and [dir] are required if this command is used except when the
command READINP WIND is specified.
| -> POWer |
DSPR < >
| DEGRees |
This command BOUND SHAPESPEC defines the shape of the spectra (both in frequency and
direction) at the boundary of the computational grid in case of parametric spectral input
(see command BOUNDSPEC).
46 Chapter 4
If this command is not used, the JONSWAP option will be used by SWAN with [gamma]=3.3
and POWER for the directional width.
|North |
|NW |
|West |
|SW | | -> CCW |
| -> SIDE < South > < > |
| | SE | | CLOCKWise | |
| | East | |
| | NE | |
| | | |
BOUndspec < | [k] | > &
| |
| |
| | -> XY < [x] [y] > | |
| | | |
| SEGMent < | < [i] [j] > | > |
| IJ < > |
| | < [k] > | |
Description of commands 47
This command BOUNDSPEC defines parametric spectra at the boundary. It consists of two
parts, the first part defines the boundary side or segment where the spectra will be given,
the second part defines the spectral parameters of these spectra. Note that in fact only the
incoming wave components of these spectra are used by SWAN. The fact that complete
spectra are calculated at the model boundaries from the spectral parameters should not
be misinterpreted. Only the incoming components are effective in the computation.
There are two ways to define the part of the boundary at which the spectra are imposed.
The first (SIDE) is easiest if the boundary is one full side of the computational grid,
although it should not be used for curvilinear grids. The second (SEGMENT) can be used if
the boundary segment goes around the corner of the grid, or if the segment is only part of
one side of the grid.
This BOUNDSPEC command can be given a number of times, i.e. to define incident wave
fields on various sides or segments of the boundary. One BOUNDSPEC command can be used
for only one side or one contiguous segment.
SIDE the boundary is one full side of the computational grid (in 1D cases either
of the two ends of the 1D-grid).
SHOULD NOT BE USED IN CASE OF CURVILINEAR GRIDS!
NORTH, ... indicates on which side the boundary condition is applied. N means the
boundary is the north edge (if present) of the computational area, likewise
for W is west, S is south, E is east, NW is northwest, NE is northeast,
SW is southwest and SE is southeast. The side does not have to face exactly
the given direction (the nearest direction of the normal to the side is taken;
this direction is determined as the normal to the sum of the vectors joining
the grid points on the boundary; there is an interruption in the boundary
(due to the occurrence of exception values) then this interruption is ignored
in the summation).
Note: in case of Cartesian coordinates, the direction of the problem coordinate
system must be defined by the user (see the SET ...[north] command), by
default the positive x−axis points East.
48 Chapter 4
| -> CLOSed |
BOUndnest1 NEst ’fname’ < >
| OPEN |
With this optional command a nested SWAN run can be carried out with the boundary con-
ditions obtained from a coarse grid SWAN run (generated in that previous SWAN run with
command NESTOUT not to be confused with option NEST in this command BOUNDNEST1).
For this nested SWAN run the user has to give the CGRID command to define the com-
putational grid before this BOUNDNEST1 command. The computational grid for SWAN in
geographic space is the area bounded by the SWAN coarse run nest (SWAN boundary
points of the nest). This implies that the boundaries of the SWAN coarse run nest and
the boundaries of the SWAN nested computational area should be (nearly) identical (see
below). The spectral frequencies and directions of the coarse grid run do not have to co-
incide with the frequencies and directions used in the nested SWAN run (as defined in the
CGRID command); SWAN will interpolate to these frequencies and directions in the nested
run (see Section 2.6.3).
To generate the nest boundary in the coarse grid run, use command NGRID. For the nested
run, use the command CGRID with identical geographical information except the number
of meshes (which will be much higher for the nested run).
This BOUNDNEST1 command is not available for 1D computations; in such cases the com-
Description of commands 51
mands SPECOUT and BOUNDSPEC can be used for the same purpose.
A nested SWAN run must use the same coordinate system as the coarse grid SWAN run.
For a curvilinear grid, it is advised to use the commands POINTS or CURVE and SPECOUT
instead of NGRID and NESTOUT.
NEST with this option the user indicates that the boundary conditions (all four sides
of the computational grid) are to be retrieved from a file created by a previous
SWAN run (the present SWAN run is a nested run). The spectral frequencies (and
directions in the case of a 2D spectrum) of the previous run do not have to
coincide with the frequencies and directions used in the present SWAN run (see
command CGRID); SWAN will interpolate the energy densities to these frequencies
and directions (see Section 2.6.3).
’fname’ name of the file containing the boundary conditions for the present run, created
by the previous SWAN coarse grid run. This file is structured according to the
rules given in Appendix D for 2D spectra.
CLOSED the boundary represented in the file is a closed rectangle; this is always the
case if the NESTOUT command was used to generate the boundary condition file.
OPEN the boundary represented in the file is not a closed rectangle.
|-> CRAY |
| UNFormatted < > |
| | WKstat | |
| |
BOUndnest2 WAMNest ’fname’ < > [xgc] [ygc] [lwdate]
| |
| FREE |
With this optional command (not fully tested) a nested SWAN run can be carried out
with the boundary conditions obtained from a coarse grid WAM run (WAM Cycle 4.5,
source code as distributed by the Max Planck Institute in Hamburg). For this nested
SWAN run the user has to give the CGRID command to define the computational grid
before this BOUNDNEST2 command. The computational grid for SWAN in geographic space
is the area bounded by the WAM coarse run nest (WAM boundary points of the nest).
This implies that the boundaries of the WAM nest and the boundaries of the SWAN
computational area should be (nearly) identical (see below). The spectral frequencies and
directions of the coarse grid run do not have to coincide with the frequencies and directions
used in the nested SWAN run (as defined in the CGRID command); SWAN will interpolate
to these frequencies and directions in the nested run (see Section 2.6.3).
52 Chapter 4
Note that SWAN will accept output of a WAM output location only if the SWAN grid
point on the nest boundary lies within a rectangle between two consecutive WAM output
locations with a width equal to 0.1 times the distance between these output locations on
either side of the line between these WAM output locations.
Only boundary conditions generated by WAM Cycle 4.5 can be read properly by SWAN.
A nested SWAN run may use either Cartesian or spherical coordinates. A curvilinear grid
may be used in the nested grid but the boundaries of this nest should conform to the
rectangular course grid nest boundaries.
WAM output files are unformatted (binary); this usually implies that WAM and SWAN
have to run on the same computer. For those cases where WAM and SWAN run on different
types of machines (binary files do not transfer properly), the option FREE is available in
this command. The distributed version of WAM does not support the required free format
nesting output; WAM users who modify WAM such that it can make formatted output,
must modify WAM such that the files made by WAM can be read in free format, i.e. with
at least a blank or comma between numbers.
’fname’ a file name that contains all the names of WAM files containing the nested
boundary conditions in time-sequence (usually one file per day). For example,
the contents of ’fname’ can look like:
CBO9212010000
CBO9212020000
CBO9212030000
....
SWAN will read the boundary data from these WAM files one after the other.
UNFORMATTED the user indicates that the WAM files are binary.
CRAY input will be read from file created by the CRAY version of WAM.
WKSTAT input will be read from file created by the WORKSTATION version of WAM.
FREE the user indicates that the WAM files can be read with free format (these files
are not generated standard by WAM!).
[xgc] if SWAN is used with Cartesian coordinates:
longitude of south-west corner of SWAN computational grid (in degrees); if the
south-west corner of the nest in the WAM computation is on land this value is
required.
If SWAN is used with spherical coordinates then [xgc] is ignored by SWAN.
Default: the location of the first spectrum encountered in the nest file.
[ygc] if SWAN is used with Cartesian coordinates:
longitude of south-west corner of SWAN computational grid (in degrees); if the
south-west corner of the nest in the WAM computation is on land this value is
required.
Description of commands 53
With this optional command a nested SWAN run can be carried out with the boundary
conditions obtained from a coarse grid WAVEWATCH III run. For this nested SWAN
run the user has to give the CGRID command to define the computational grid before this
BOUNDNEST3 command. The computational grid for SWAN in geographic space is the area
bounded by the WAVEWATCH III nest (WAVEWATCH III boundary points of the nest).
This implies that the boundaries of the WAVEWATCH III nest and the boundaries of the
SWAN computational area should be (nearly) identical (see below). The spectral frequen-
cies and directions of the coarse grid run do not have to coincide with the frequencies and
directions used in the nested SWAN run (as defined in the CGRID command); SWAN will
interpolate to these frequencies and directions in the nested run (see Section 2.6.3).
The output files of WAVEWATCH III have to be created with the post-processor of WAVE-
WATCH III as output transfer files (formatted or unformatted) with
WW_3 OUTP (output type 1 sub type 3)
at the locations along the nest boundary (i.e. computational grid points in WAVE-
WATCH III). These locations are equal to the corner points of the SWAN nested grid
and optionally also distributed between the corner points of the SWAN nested grid (the
boundary of the WAVEWATCH III nested grid need not be closed and may cover land).
The locations should be output by WAVEWATCH III in sequence (going along the nest
boundary, clockwise or counterclockwise). Note that SWAN will accept output of a WAVE-
WATCH III output location only if the SWAN grid point on the nest boundary lies within a
rectangle between two consecutive WAVEWATCH III output locations with a width equal
to 0.1 times the distance between these output locations on either side of the line between
these WAVEWATCH III output locations.
A nested SWAN run may use either Cartesian or spherical coordinates. A curvilinear grid
54 Chapter 4
may be used in the nested grid but the boundaries of this nest should conform to the
rectangular course grid nest boundaries.
’fname’ the name of the file that contains the spectra computed by WAVEWATCH III.
UNFORMATTED the input WW3 files are binary.
FREE the input WW3 files are formatted.
CLOSED the boundary condition represented in the file is defined on a closed rectangle.
OPEN the curve on which the boundary condition is given, is not closed.
[xgc] if SWAN is used with Cartesian coordinates:
longitude of south-west corner of SWAN computational grid (in degrees); if the
south-west corner of the nest in the WW3 computation is on land this value is
required.
If SWAN is used with spherical coordinates then [xgc] is ignored by SWAN.
Default: the location of the first spectrum encountered in the nest file.
[ygc] if SWAN is used with Cartesian coordinates:
longitude of south-west corner of SWAN computational grid (in degrees); if the
south-west corner of the nest in the WW3 computation is on land this value is
required.
If SWAN is used with spherical coordinates then [ygc] is ignored by SWAN.
Default: the location of the first spectrum encountered in the nest file.
Note that [xgc] and [ygc] are ignored if SWAN is used with spherical coordinates; if
SWAN is used with Cartesian coordinates the values must be provided by the user.
| -> DEFault
|
INITial < ZERO
|
| PAR [hs] [per] [dir] [dd]
|
| | -> MULTiple | | -> FREE
| HOTStart < > ’fname’ <
| | SINGle | | UNFormatted
This command can be used to specify the initial values for a stationary (INITIAL HOTSTART
only) or nonstationary computation. The initial values thus specified override the default
initialization (see Section 2.6.3). Note that it is possible to obtain an initial state by
carrying out a previous stationary or nonstationary computation.
DEFAULT the initial spectra are computed from the local wind velocities, using the
deep-water growth curve of Kahma and Calkoen (1992), cut off at values of
significant wave height and peak frequency from Pierson and Moskowitz (1964).
Description of commands 55
The average (over the model area) spatial step size is used as fetch with local
wind. The shape of the spectrum is default JONSWAP with a cos2 -directional
distribution (options are available: see command BOUND SHAPE).
ZERO the initial spectral densities are all 0; note that if waves are generated in the
model only by wind, waves can become non-zero only by the presence of the
”A” term in the growth model; see the keyword AGROW in command GEN3.
PAR the spectra in the entire computational area are generated from integral
parameters [hs] etc. in the same way as done for the boundary using the
command BOUNDSPEC.
[hs] the significant wave height.
[per] characteristic wave period of the energy spectrum (either peak or mean period,
as determined by the options PEAK and MEAN in the command BOUND SHAPE).
[dir] the peak wave direction (direction in degrees, Nautical or Cartesian convention,
see command SET).
[dd] the coefficient of directional spreading; a cosm (θ) distribution is assumed.
See the options DEGREES and POWER in the command BOUND SHAPE.
HOTSTART initial wave field is read from file; this file was generated in a previous SWAN
run by means of the HOTFILE command. If the previous run was nonstationary,
the time found on the file will be assumed to be the initial time of computation. It
can also be used for stationary computation as first guess. The computational grid
(both in geographical space and in spectral space) must be identical to the one in
the run in which the initial wave field was computed.
MULTIPLE input will be read from multiple hotfiles obtained from a previous parallel MPI run.
The number of files equals the number of processors. Hence, for the present run the
same number of processors must be chosen.
SINGLE input will be read from a single (concatenated) hotfile.
In the case of a previous parallel MPI run, the concatenated hotfile can be created
from a set of multiple hotfiles using the program hcat.exe, see Implementation
Manual.
Note: with this option you may change the number of processors when restart a
parallel MPI run.
ONLY MEANT FOR STRUCTURED GRIDS.
’fname’ name of the file containing the initial wave field.
FREE the user indicates that the hotfile can be read with free format.
This option is default.
UNFORMATTED the user indicates that the hotfile is binary.
4.5.4 Physics
With this command the user indicates that SWAN should run in first-generation mode
(see Scientific/Technical documentation).
GEN2 [cf10] [cf20] [cf30] [cf40] [cf50] [cf60] [edmlpm] [cdrag] [umin] [cfpm]
With this command the user indicates that SWAN should run in second-generation mode
(see Scientific/Technical documentation). The variables are identical to those in the GEN1
command except that [cf50] and [cf60] are added.
| |
| WESTHuysen |
| |
| ST6 [a1sds] [a2sds] [p1sds] [p2sds] & |
GEN3 < > (AGROW [a])
| | -> UP | | -> HWANG | |
| < > < FAN > VECTAU|SCATAU & |
| | DOWN | | ECMWF | |
| |
| | TRUE10 | |
| < > DEBias [cdfac] |
| | -> U10Proxy [windscaling] | |
With this command the user indicates that SWAN should run in third-generation mode for
wind input, quadruplet interactions and whitecapping. Triads, bottom friction and depth-
induced breaking are not activated by this command. See also the Scientific/Technical
documentation for more information. The option GEN3 KOMEN is default.
The choices with respect to option GEN3 ST6 are elaborated on here. Some background
information on these choices can be found in Rogers et al. (2012) (henceforth denoted as
RBW12).
• HWANG, FAN, or ECMWF. This corresponds to the selection of the wind drag formula.
HWANG is the default and is unchanged from RBW12. FAN is from Fan et al. (2012).
ECMWF follows the WAM Cycle 4 (Janssen) methodology. FAN and ECMWF use iterative
procedures. The user is warned that selection of non-default FAN or ECMWF will
significantly change outcome, e.g. a Hs decrease from 2.48 to 2.28 m. All calibrations
were performed using the default HWANG. Also note that the usual drag formula, either
Wu (1982) or Zijlema et al. (2012), will not be applied.
• VECTAU vs. SCATAU. The command VECTAU is default and strongly recommended. It
permits vector calculation for the stress calculation, rather than the simplified scalar
calculation of Eq. (12) in RBW12.
58 Chapter 4
GEN3 ST6 2.8E-6 3.5E-5 4.0 4.0 UP HWANG VECTAU U10PROXY 32.0 AGROW
GEN3 ST6 2.8E-6 3.5E-5 4.0 4.0 UP HWANG VECTAU U10PROXY 32.0 DEBIAS 0.89 AGROW
GEN3 ST6 6.5E-6 8.5E-5 4.0 4.0 UP HWANG VECTAU U10PROXY 35.0 AGROW
Note the different values of coefficients [a1sds] and [a2sds] in case of different U10PROXY
settings! Usually one of the following two lines is recommended in regular SWAN simula-
tions. Here, the command SSWELL for swell dissipation must be indicated using a separate
line (see below).
Description of commands 59
With this command the user can influence the type of swell dissipation included in the com-
putations. The Zieger option is intended for use with negative wind input via the NEGATINP
command. Zieger non-breaking dissipation follows the method used in WAVEWATCH III
version 4 and does not include the steepness-dependent swell coefficient introduced in
WAVEWATCH III version 5. As noted already, if GEN3 ST6... command is used, this
SSWELL command should be provided.
Examples:
SSWELL ARDHUIN 1.2
NEGatinp [rdcoef]
With this optional command the user activates negative wind input. This is intended
only for use with non-breaking swell dissipation SSWELL ZIEGER. Parameter [rdcoef] is a
fraction between 0 and 1, representing the strength of negative wind input. As an example,
with [rdcoef]=0.04, for a spectral bin that is opposed to the wind direction, the wind
input factor W (k, θ) is negative, and its magnitude is 4% of the corresponding value of
the spectral bin that is in the opposite direction (i.e. in the wind direction). See Zieger
et al. (2015) eq. 11, where a0 is their notation for [rdcoef]. Default [rdcoef]=0.0 and
[rdcoef]=0.04 is recommended, though as implied by Zieger et al. (2015), this value is
not well-established, so the user is encouraged to experiment with other values.
With this command the user can influence whitecapping which is usually included in the
computations. Can be de-activated with command OFF WCAP.
With this option the user can influence the computation of nonlinear quadruplet wave
interactions. Default: the quadruplets are included in the computations. Can be de-
activated with command OFF QUAD.
Note that the DIA approximation of the quadruplet interactions is a poor approximation
for long-crested waves and frequency resolutions that are deviating much more than 10%
(see command CGRID).
Note that DIA is usually updated per sweep, either semi-implicit ([iquad] = 1) or explicit
([iquad] = 2). However, when ambient current is included, the bounds of the directional
sector within a sweep may be different for each frequency bin (particularly the higher
frequencies are modified by the current). So there may be some overlap of frequency bins
between the sweeps, which is not energy conservative. To prevent this the user is advised
to choose the integration of DIA per iteration instead of per sweep, i.e. [iquad] = 3.
If you want to speed up your computation a bit more, than the choice [iquad] = 8 is a
good one.
With this command the user can influence depth-induced wave breaking in shallow water
in the SWAN model.
If this command is not used, SWAN will account for wave breaking anyhow (with default
options and values). If the user wants to specifically ignore wave breaking, he should use
the command: OFF BREAKING.
With this optional command the user can activate bottom friction. If this command is not
used, SWAN will not account for bottom friction.
64 Chapter 4
In SWAN four different formulations are available, i.e., that of Hasselmann et al. (1973,
JONSWAP), Collins (1972), Madsen et al. (1988) and Smith et al. (2011).
The default option is: JONSWAP with a constant friction coefficient. The recommended
value for typical sandy bottoms is 0.038 m2 s−3 . Note that this value is to be applied for
both wind sea and swell conditions. (The use of the previous default value of 0.067 m2 s−3 is
discouraged, even for wind sea conditions!) For smoother seafloors, like the Gulf of Mexico,
a lower value of 0.019 m2 s−3 is advised.
JONSWAP indicates that the semi-empirical expression derived from the JONSWAP results
for bottom friction dissipation (Hasselmann et al., 1973, JONSWAP) should be
activated. This option is default.
CONSTANT this default option indicates that the JONSWAP coefficient is constant.
[cfjon] coefficient of the JONSWAP formulation.
Default: [cfjon] = 0.038.
COLLINS indicates that the expression of Collins (1972) should be activated.
[cfw] Collins bottom friction coefficient.
Default: [cfw] = 0.015.
Note that [cfw] is allowed to vary over the computational region; in that
case use the commands INPGRID FRICTION and READINP FRICTION to define
and read the friction data. The command FRICTION is still required to define
the type of friction expression. The value of [cfw] in this command is then
not required (it will be ignored).
MADSEN indicates that the expression of Madsen et al. (1988) should be activated.
[kn] equivalent roughness length scale of the bottom (in m).
Default: [kn] = 0.05.
Note that [kn] is allowed to vary over the computational region; in that case
use the commands INPGRID FRICTION and READINP FRICTION to define and read
the friction data. This command FRICTION is still required to define the type of
friction expression. The value of [kn] in this command is then not required
(it will be ignored).
RIPPLES indicates that the expression of Smith et al. (2011) should be activated.
Here friction depends on the formation of bottom ripples and sediment size.
[S] the specific gravity of the sediment.
Default: [S] = 2.65.
[D] the sediment diameter (in m).
Default: [D] = 0.0001.
With this command the user can activate the triad wave-wave interactions using either the
LTA method or the SPB method. If this command is not used, SWAN will not account
for triads.
With this command the user can activate wave damping due to vegetation based on the
Dalrymple’s formula (1984). If this command is not used, SWAN will not account for
vegetation effects.
The vegetation (rigid plants) can be divided over a number of vertical segments and so,
the possibility to vary the vegetation vertically is included. Each vertical layer represents
some characteristics of the plants. These variables as indicated below can be repeated as
many vertical layers to be chosen.
66 Chapter 4
With this optional command the user can activate turbulent viscosity. This physical effect
is also activated by reading values of the turbulent viscosity using the READGRID TURB
command, but then with the default value of [ctb]. The command READGRID TURB is
necessary if this command TURB is used since the value of the viscosity is assumed to vary
over space.
With this command the user can activate wave damping due to mud based on Ng (2000).
If this command or the commands INPGRID MUDLAY and READINP MUDLAY are not used,
SWAN will not account for muddy bottom effects.
Description of commands 67
Using this command, the user activates a sink term to represent the dissipation of wave
energy by sea ice. The IC4M2 method is empirical/parametric: a polynomial based on wave
frequency (Collins and Rogers, 2017). This polynomial (in 1/m) has seven dimensional
coefficients (see Scientific/Technical documentation for details). If this command or the
commands INPGRID AICE and READINP AICE are not used, SWAN will not account for sea
ice effects.
An example is the case of c2=1.06 × 10−3 and c4=2.3 × 10−2 . This recovers the polynomial
of Meylan et al. (2014).
The Meylan case is for ice floes, mostly 10 to 25 m in diameter, in the marginal ice zone
near Antarctica. Other polynomials are provided in Rogers et al. (2018). An example
is for a case of pancake and frazil ice, where both coefficients are, of course, smaller:
c2=0.284 × 10−3 and c4=1.53 × 10−2 .
[c5] polynomial coefficient (in s5 /m) for determining the rate of sea ice dissipation.
[c6] polynomial coefficient (in s6 /m) for determining the rate of sea ice dissipation.
With this command the user can de-activate permanently the quadruplets when the actual
Ursell number exceeds [ursell]. Moreover, as soon as the actual fraction of breaking
waves exceeds [qb] then the action limiter will not be used in case of decreasing action
density.
| -> RSPEC |
( REFL [reflc] < > ) &
| RDIFF [pown] |
With this optional command the user provides the characteristics of a (line of) sub-grid
obstacle(s) through which waves are transmitted or against which waves are reflected (pos-
sibly both at the same time). The obstacle is sub-grid in the sense that it is narrow
compared to the spatial meshes; its length should be at least one mesh length.
Description of commands 69
The location of the obstacle is defined by a sequence of corner points of a line. The
obstacles interrupt the propagation of the waves from one grid point to the next wherever
this obstacle line is located between two neighbouring grid points (of the computational
grid; the resolution of the obstacle is therefore equal to the computational grid spacing).
This implies that an obstacle to be effective must be located such that it crosses at least
one grid line. This is always the case when an obstacle is larger than one mesh length.
1. If a straight line is defined with more than two points, then the sum of the reflection
of the parts may differ from the situation when you define it with just two points.
This is due to the way obstacles are handled numerically in SWAN. It defines from
computational grid point to its neighbor whether there is a crossing with an obstacle.
In defining which directions of the wave spectrum should be reflected, i.e which direc-
tions are pointed towards the obstacle, it uses the obstacle coordinates as defined by
the user to define the angle of inclusion. This angle will be smaller if more points are
defined, and so the reflected energy will be less for the computational grid point. This
problem becomes smaller if the computational grid points are closer to the obstacle.
So the advise is to define obstacles with the least amount of points pos-
sible.
2. In case of sharp angles in the obstacles, it is very likely that there are more than one
crossing between two computational grid points. In this case SWAN does not give
correct reflection results.
3. At the boundaries of the computational area, the reflected spectrum is not taken into
account. This can only be resolved by a different treatment of the boundaries in the
program. Until this time, it is recommended to place obstacles at the inner area of
the computational grid, not at or through the boundaries.
4. Obstacle lines are only effective when the obstacle line is bordered by wet points on
both sides. In practice, this may give problems when a reflection line is also used to
specify a boundary between wet and land points. This can be avoided by shifting
the position of the reflection line or by creating wet points on the land side of the
obstacle line.
The computation of transmission and reflection is problematic if an obstacle runs exactly
through one or more grid points of the computational structured grid; SWAN will move
the obstacle over a small distance (1% of the mesh size) if this occurs. Note that this will
not be done in case of unstructured grids.
The reflection results are incorrect if more than one obstacle crosses the same grid line
70 Chapter 4
between two neighbouring grid points. SWAN is not able to detect this, so the user must
check if his model fulfills this condition.
TRANSM with this option the user indicates that the transmission coefficient is a constant.
[trcoef] constant transmission coefficient, formulated in terms of wave height, i.e. ratio
of transmitted significant wave height over incoming significant wave height.
Default: [trcoef]=0.0 (no transmission = complete blockage).
TRANS1D with this option the user indicates that the transmission coefficient is frequency
dependent. For each frequency the user can specify a transmission coefficient as
indicated below. The number of these transmission values must be equal to the
number of frequencies, i.e. [msc] + 1.
[trcoef] transmission coefficient per frequency, formulated in terms of wave height, i.e.
ratio of transmitted significant wave height over incoming significant wave height.
TRANS2D with this option the user indicates that the transmission coefficient is frequency
and direction dependent. For each direction the user can assign different trans-
mission coefficients to frequencies. The number of these transmission values must
be equal to the number of frequencies multiplied with the number of directions.
[trcoef] transmission coefficient per frequency for each direction, formulated in terms of
wave height, i.e. ratio of transmitted significant wave height over incoming
significant wave height. It is advised to put the values assigned to all frequencies
on a single line for each direction. So the number of lines equals the number of
directions. Each line may be terminated with a continuation mark &.
DAM with this option the user indicates that the transmission coefficient depends on
the incident wave conditions at the obstacle and on the obstacle height (which
may be submerged).
GODA with this option the user indicates to use the Goda/Seelig formula (1979) for
computing transmission coefficient.
[hgt] the elevation of the top of the obstacle above reference level (same reference
level as for bottom etc.); use a negative value if the top is below that reference
level. If this command is used, this value is required.
[alpha] coefficient determining the transmission coefficient for Goda’s transmission formula.
Default: [alpha]=2.6.
[beta] another coefficient determining the transmission coefficient for Goda’s transmission
formula.
Default: [beta]=0.15.
DANGREMOND with this option the user indicates to use the d’Angremond/Van der Meer formula
(1996) for computing the transmission coefficient.
[hgt] the elevation of the top of the obstacle above reference level (same reference
level as for bottom etc.); use a negative value if the top is below that reference
level. If this command is used, this value is required.
[slope] the slope of the obstacle (in degrees). If this command is used, this value is required.
[Bk] the crest width of the obstacle. If this command is used, this value is required.
REFL if this keyword is present the obstacle will reflect wave energy (possibly in
Description of commands 71
SETUP [supcor]
If this optional command is given, the wave-induced set-up is computed and accounted for
in the wave computations (during the computation it is added to the depth that is obtained
from the READ BOTTOM and READ WLEVEL commands). This approximation in SWAN can
only be applied to open coast (unlimited supply of water from outside the domain, e.g.
nearshore coasts) in contrast to closed basin, e.g. lakes and estuaries, where this option
should not be used. Note that set-up is not computed correctly with spherical coordinates.
Note that set-up is not supported in case of parallel runs using either MPI or OpenMP!
[supcor] by default the wave-induced set-up is computed with a constant added such that the
set-up is zero in the deepest point in the computational grid. The user can modify
this constant by the value of [supcor]. The user can thus impose a set-up in any
one point (and only one) in the computational grid by first running SWAN, then
reading the set-up in that point and adding or subtracting the required value of
[supcor] (in m; positive if the set-up has to rise).
Default: [supcor]=0.
If this optional command is given, the diffraction is included in the wave computation. But
the diffraction approximation in SWAN does not properly handle diffraction in harbours or
in front of reflecting obstacles (see Scientific/Technical documentation). Behind breakwa-
ters with a down-wave beach, the SWAN results seem reasonable. The spatial resolution
near (the tip of) the diffraction obstacle should be 1/5 to 1/10 of the dominant wave length.
Without extra measures, the diffraction computations with SWAN often converge poorly
or not at all. Two measures can be taken:
Description of commands 73
Default: [smnum] = 0.
[cgmod] adaption of propagation velocities in geographic space due to diffraction.
If [cgmod]=0 then no adaption.
Default: [cgmod]=1.
| WINDGrowth |
| |
| QUADrupl |
| |
| WCAPping |
OFF < >
| BREaking |
| |
| REFrac |
| |
| FSHift |
| |
| BNDCHK |
74 Chapter 4
With this optional command the user can change the default inclusion of various physical
processes (e.g. for research purposes). This command is not recommended for operational
use.
WINDGROWTH switches off wind growth (in commands GEN1, GEN2 and GEN3).
QUADRUPL switches off quadruplet wave-wave interactions (in command GEN3).
WCAPPING switches off whitecapping (in command GEN3).
BREAKING switches off depth-induced breaking dissipation. Caution: wave heights may
diverge in very shallow water.
REFRAC switches off refraction (action transport in θ−direction).
FSHIFT switches off frequency shifting in frequency space (action transport in σ−space).
BNDCHK switches off the checking of the difference between imposed and computed
significant wave height at the boundary of the computational grid (see also
command SET).
4.5.5 Numerics
| BSBT
PROP < | Sec |
| GSE [waveage] < MIn >
| | HR |
| | DAy |
Command to choose:
• the BSBT scheme (stationary and nonstationary) instead of the default S&L scheme
(in case of nonstationary cases) or the default SORDUP scheme (in case of stationary
cases) or
Notes:
• All schemes (BSBT, SORDUP and S&L) can be used in combination with curvilinear
grids. With the higher order schemes (S&L and SORDUP) it is important to use
a gradually varying grid, otherwise there may be a severe loss of accuracy. If sharp
transitions in the grid cannot be avoided it is safer to use the BSBT scheme.
• In the computation with unstructured meshes, a lowest order upwind scheme will
be employed. This scheme is very robust but rather diffusive. This may only be
significant for the case when swell waves propagate over relative large distances (in
the order of thousands of kilometers) within the model domain. However and most
fortunately, in such a case, this will alleviate the garden-sprinkler effect.
• Alleviating the garden-sprinkler effect by adding some diffusion makes the SWAN
computation conditionally stable. You can either use i) a smaller time step, ii) a
lower value of [waveage], iii) better resolution in the directional space, or iv) worse
resolution in the geographic space, in order of preference, to make the model stable
when necessary.
With this optional command the user can influence some of the numerical properties of
SWAN.
76 Chapter 4
STOPC With this option the user can influence the criterion for terminating the
iterative procedure in the SWAN computations (both stationary and
nonstationary). The criterion make use of the second derivative, or curvature,
of the iteration curve of the significant wave height. As the solution of a
simulation approaches full convergence, the curvature of the iteration curve will
tend to zero. SWAN stops the process if the absolute change in Hs from one
iteration to the next is less than [dabs] or the relative change in Hs from one
iteration to the next is less than [drel] and the curvature of the iteration
curve of Hs normalized with Hs is less than [curvat]. Both conditions need to
be fulfilled in more than fraction [npnts]% of all wet grid points.
[dabs] Default: [dabs] = 0.005 [−]
[drel] Default: [drel] = 0.01 [−]
[curvat] Default: [curvat] = 0.005 [−]
[npnts] Default: [npnts] = 99.5 [−]
STAT indicates the use of parameters in a stationary computation.
[mxitst] the maximum number of iterations for stationary computations.
The computation stops when this number is exceeded.
Default: [mxitst] = 50.
Note that [mxitst] can be set to 0 if one wants to check the input to the
model without making computations.
[alfa] proportionality constant used in the frequency-dependent under-relaxation
technique. Based on experiences, a suggestion for this parameter is [alfa] = 0.01.
In case of diffraction computations, the use of this parameter is recommended.
Default: [alfa] = 0.00.
NOT MEANINGFUL FOR NONSTATIONARY COMPUTATIONS.
NONSTAT indicates the use of parameters in a nonstationary computation.
[mxitns] the maximum number of iterations per time step for nonstationary computations.
The computation moves to the next time step when this number is exceeded.
Default: [mxitns] = 1.
Note that [mxitns] can be set to 0 if one wants to check the input to the
model without making computations.
[limiter] determines, in both stationary and nonstationary runs, the maximum change per
iteration of the energy density per spectral (σ,θ)-bin, given in
terms of a fraction of the omni-directional Phillips level (see Scientific/
Technical documentation).
Default: [limiter] = 0.1.
DIRIMPL this option is used to influence the numerical scheme for refraction.
[cdd] A value of [cdd]=0 corresponds to a central scheme and has the largest
accuracy (diffusion ≈ 0) but the computation may more easily generate
spurious fluctuations. A value of [cdd]=1. corresponds to a first order
upwind scheme and it is more diffusive and therefore preferable if (strong)
gradients in depth or current are present.
Default: [cdd] = 0.5.
Description of commands 77
SIGIMPL controls the accuracy of computing the frequency shifting and the stopping criterion
and amount of output for the SIP solver (used in the computations in the presence
of currents or time varying depth).
CTHETA this option prevents an excessive directional turning at a single grid point or vertex
due to a very coarse bathymetry or current locally. This option limits the directional
turning rate cθ based on the CFL restriction. (See Eq. 3.41 of Scientific/
Technical documentation). See also the final remark in Section 2.6.3.
Note that if this command is not specified, then the limiter is not activated.
[cfl] upper limit for the CFL restriction for cθ . A suggestion for this parameter is
[cfl] = 0.9.
Default: [cfl] = 0.9 (when command CTHETA is activated).
CSIGMA this option prevents an excessive frequency shifting at a single grid point or vertex
due to a very coarse bathymetry or current locally. This option limits the frequency
shifting rate cσ based on the CFL restriction. See also the final remark in Section
2.6.3. Note that if this command is not specified, then the limiter is not activated.
[cfl] upper limit for the CFL restriction for cσ . A suggestion for this parameter is
[cfl] = 0.9.
Default: [cfl] = 0.9 (when command CSIGMA is activated).
SETUP controls the stopping criterion and amount of output for the SOR solver in the
computation of the wave-induced set-up.
[css] A value of [css]=0 corresponds to a central scheme and has the largest
accuracy (diffusion ≈ 0) but the computation may more easily generate
spurious fluctuations. A value of [css]=1. corresponds to a first order upwind
scheme and it is more diffusive and therefore preferable if (strong) gradients in
depth or current are present.
Default: [css] = 0.5.
[eps2] Relative stopping criterion to terminate the linear solver (SIP or SOR). The
criterion for the SIP solver is based on kAN ~ k − ~bk2 ≤ [eps2] k~bk2
where A is a matrix, N ~ is the action density vector, ~b is the right hand vector
and k is the iteration number.
The criterion for the SOR solver is based on kη k+1 − η k k∞ ≤ [eps2] where
η is the set-up.
Default: [eps2] = 1.e-4 in case of SIP and [eps2] = 1.e-6 in case of SOR.
[outp] output for the iterative solver:
0 = no output
1 = additional information about the iteration process is written to the PRINT file
2 = gives a maximal amount of output concerning the iteration process
3 = summary of the iteration process
Default: [outp] = 0.
[niter] maximum number of iterations for the linear solver.
Default: [niter] = 20 in case of SIP and [niter] = 1000 in case of SOR.
78 Chapter 4
4.6 Output
There are two categories of output commands:
1. Locations
commands defining sets of output locations at which the user requires output. Each
set is indicated with a name (’sname’ in this manual) which must be unique and not
more than 8 characters long.
Commands FRAME, GROUP, RAY, ISOLINE and NGRID cannot be used in 1D-MODE
and command GROUP cannot be used in case of unstructured meshes. If one gives one
name for two sets of output locations, the first set is lost (first in the sequence in the
command file). Two special names BOTTGRID and COMPGRID are reserved for use by
SWAN (see below). The user may not define sets with these names.
2. Write / plot
commands defining data file output (write) at the above defined set(s) of output
locations:
With this optional command the user defines output on a rectangular, uniform grid in a
regular frame.
If the set of output locations is identical to a part of the computational grid, then the user
can use the alternative command GROUP.
Some output may be required on a frame that is identical with the input (bottom/current)
grid or with the computational grid (e.g. for test purposes or to avoid interpolation
errors in the output). These frames need not be defined by the user with this com-
mand FRAME; the frames are always generated automatically by SWAN under the names
’sname’ = ’BOTTGRID’ (for the bottom/current grid) and ’sname’ = ’COMPGRID’ (for
the computational grid).
80 Chapter 4
With this optional command the user defines a group of output locations on a rectangular
or curvilinear grid that is identical with (part of) the computational grid (rectilinear or
curvilinear). Such a group may be convenient for the user to obtain output that is not
affected by interpolation errors (which would occur when an output grid is used that is
not identical with (part of) the computational grid).
The subgrid contains those points (ix,iy) of the computational grid for which:
[ix1] ≤ ix ≤ [ix2] and [iy1] ≤ iy ≤ [iy2]
For convenience the size of the group, the corner coordinates and the angle with the
problem coordinate system are written to PRINT file. The origin of the computational grid
is (ix=0,iy=0)!
Limitations:
[ix1]≥0, [ix2]≤[mxc], [iy1]≥0, [iy2]≤[myc] ([mxc] and [myc] as defined in the
command CGRID).
With this optional command the user defines output along a curved line. Actually this
curve is a broken line, defined by the user with its corner points. The values of the output
quantities along the curve are interpolated from the computational grid. This command
may be used more than once to define more curves.
In some cases output is required on (part of) the boundary. To make this easier the
following output curves are pre-defined (i.e. they do not have to be defined by the user): the
curve BOUNDARY which corresponds to the whole outer boundary, and the curves BOUND 01,
BOUND 02, etc. corresponding to parts of the boundary. In regular and curvilinear grids
these parts are the four sides of the computational grid; in unstructured grids they are
defined in the grid definition file. Examples:
Description of commands 81
RAY ’rname’ [xp1] [yp1] [xq1] [yq1] < [int] [xp] [yp] [xq] [yq] >
With this optional command the user provides SWAN with information to determine out-
put locations along the depth contour line(s) defined subsequently in command ISOLINE
(see below).
These locations are determined by SWAN as the intersections of the depth contour line(s)
and the set of straight rays defined in this command RAY. These rays are characterized by a
set of master rays defined by their start and end positions ([xp],[yp]) and ([xq],[yq]).
Between each pair of sequential master rays thus defined SWAN generates [int]−1 inter-
mediate rays by linear interpolation of the start and end positions.
Note that the rays thus defined have nothing in common with wave rays (e.g. as obtained
from conventional refraction computations).
Also note that when using rays, the input grid for bottom and water level should not be
curvilinear.
| -> DEPth |
ISOline ’sname’ ’rname’ < > [dep]
| BOTtom |
With this optional command the user defines a set of output locations along one depth or
bottom level contour line (in combination with command RAY).
The set of output locations along the depth contour lines created with this command is of
the type CURVE.
With this optional command the user defines a set of individual output locations (points).
The coordinates of these points are given in the command itself or read from a file (option
FILE).
If the user wishes to carry out nested SWAN run(s), a separate coarse-grid SWAN run is
required. With this optional command NGRID, the user defines in the present coarse-grid
run, a set of output locations along the boundary of the subsequent nested computational
grid. The set of output locations thus defined is of the type NGRID.
Command NESTOUT is required after this command NGRID to generate some data for the
(subsequent) nested run (not with command BLOCK because a set of locations of the type
NGRID does represent an outline and not a geographic region).
’sname’ name of the set of output locations along the boundaries of the following nested
computational grid defined by this command
[xpn] geographic location of the origin of the computational grid of this coarse-grid
run in the problem coordinate system (x−coordinate)
if Cartesian coordinates are used in m
if spherical coordinates are used in degrees (see command COORD)
[ypn] geographic location of the origin of the computational grid of this coarse-grid
run in the problem coordinate system (y−coordinate)
if Cartesian coordinates are used in m
if spherical coordinates are used in degrees (see command COORD)
[alpn] direction of the positive x−axis of the computational grid of this coarse-grid
run (in degrees, Cartesian convention).
[xlenn] length in the x−direction of the nested grid
if Cartesian coordinates are used in m
if spherical coordinates are used in degrees (see command COORD)
[ylenn] length in the y−direction of the nested grid
if Cartesian coordinates are used in m
if spherical coordinates are used in degrees (see command COORD)
[mxn] number of meshes of the output grid in the x−direction of this grid (this number
is one less than the number of grid points in this direction!). [mxn] does not
have to be equal to the number of meshes in the nested computation; SWAN will
interpolate the required information.
Default: [mxn] is chosen such that the mesh size of the output grid is
(roughly) equal to the mesh size of the coarse grid, but at least 1.
84 Chapter 4
[myn] number of meshes of the output grid in the y−direction of this grid (this number
is one less than the number of grid points in this direction!). [myn] does not
have to be equal to the number of meshes in the nested computation; SWAN will
interpolate the required information.
Default: [myn] is chosen such that the mesh size of the output grid is
(roughly) equal to the mesh size of the coarse grid, but at least 1.
UNSTRUCTURE with this option the user indicates that the subsequent nested grid is an
unstructured one. Only grids generated by Triangle and Easymesh are
supported by SWAN.
TRIANGLE the necessary grid information is read from two files as produced by Triangle.
The .node and .ele files are required. The basename of these files must be
indicated with parameter ’fname’.
EASYMESH the necessary grid information is read from two files as produced by
Easymesh. The .n and .e files are required. The basename of these files
must be indicated with parameter ’fname’.
’fname’ basename of the required files, i.e. without extension.
WARNING:
When integral parameters are computed by the user from the output spectrum of SWAN,
differences with the SWAN-computed parameters may occur. The reasons are:
• SWAN accepts at the boundaries of the computational grid only the user-imposed
incoming wave components and it replaces the user-imposed outgoing wave com-
ponents with computed components (propagating to the boundary from the interior
region).
• during the computation of the parameters, SWAN adds an analytical (diagnostic)
high-frequency tail to the discrete spectrum.
• SWAN has an option to only compute within a pre-set directional sector (pre-set by
the user). Wave components outside this sector are totally ignored by SWAN (no
additions or replacements).
This is particularly relevant along the boundaries of SWAN where the user-imposed integral
parameters (boundary conditions) may differ from the SWAN-computed parameters. The
user is informed by means of a warning in the output (PRINT file) when the computed
significant wave height differs more than 10%, say, from the user-imposed significant wave
height (command BOUNDSPEC). The actual value of this difference can be set by the user
(see the SET command; Section 4.4).
Description of commands 85
| ..........|
QUANTity < > ’short’ ’long’ [lexp] [hexp] [excv] &
| ..........|
[fmin] [fmax] (For all integral parameters, like HS, (R)TM01 ...) &
|-> PROBLEMcoord |
< > (For directions (DIR, TDIR, PDIR)
| FRAME | and vectors (FORCE, WIND, VEL, TRANSP))
|...|
< > the output parameters are the same as given in command BLOCK.
|...|
‘short’ user preferred short name of the output quantity (e.g. the name appearing in
the heading of a table written by SWAN). If this option is not used, SWAN
will use a realistic name.
‘long’ long name of the output quantity (e.g. the name appearing in the heading of a
block output written by SWAN). If this option is not used, SWAN will use a
realistic name.
[lexp] lowest expected value of the output quantity.
[hexp] highest expected value of the output quantity; the highest expected value is
used by SWAN to determine the number of decimals in a table with heading.
So the QUANTITY command can be used in case the default number of decimals
in a table is unsatisfactory.
[excv] in case there is no valid value (e.g. wave height in a dry point) this
exception value of the output quantity is written in a table or block output.
86 Chapter 4
The following data are accepted only in combination with some specific output quantities.
Examples:
OUTPut OPTIons ’comment’ (TABle [field]) (BLOck [ndec] [len]) (SPEC [ndec])
This command enables the user to influence the format of block, table and spectral output.
| -> HEADer |
BLOck ’sname’ < > ’fname’ (LAYout [idla])
| NOHEADer |
| HSign |
| |
| HSWEll |
| |
| DIR |
| |
| PDIR |
| |
| TDIR |
| |
| TM01 |
| |
| RTM01 |
| |
88 Chapter 4
| RTP |
| |
| TPS |
| |
| PER |
| |
| RPER |
| |
| TMM10 |
| |
| RTMM10 |
| |
| TM02 |
| |
| FSPR |
| |
| DSPR |
| |
| QP |
| |
| DEPth |
| |
| WATLev |
| |
| BOTLev |
| |
| VEL |
| |
| FRCoef |
| |
| WIND |
| |
| AICE |
| |
| PROPAgat |
| |
| PROPXy |
| |
| PROPTheta |
| |
| PROPSigma |
| |
| GENErat |
Description of commands 89
| |
| GENWind |
| |
| REDIst |
| |
| REDQuad |
| |
| REDTriad | | -> Sec |
< < > [unit] > (OUTput [tbegblk] [deltblk]) < MIn >
| DISSip | | HR |
| | | DAy |
| DISBot |
| |
| DISSUrf |
| |
| DISWcap |
| |
| DISSWell |
| |
| DISVeg |
| |
| DISMud |
| |
| DISIce |
| |
| RADStr |
| |
| QB |
| |
| TRAnsp |
| |
| FORce |
| |
| UBOT |
| |
| URMS |
| |
| TMBOT |
| |
| WLENgth |
| |
| LWAVP |
| |
90 Chapter 4
| STEEpness |
| |
| BFI |
| |
| NPLants |
| |
| DHSign |
| |
| DRTM01 |
| |
| LEAK |
| |
| TIME |
| |
| TSEC |
| |
| XP |
| |
| YP |
| |
| DIST |
| |
| SETUP |
| |
| PTHSign |
| |
| PTRTP |
| |
| PTWLEN |
| |
| PTDIR |
| |
| PTDSPR |
| |
| PTWFRAC |
| |
| PTSTEEpne |
| |
| PARTITion |
With this optional command the user indicates that one or more spatial distributions
Description of commands 91
Note that the wave parameters in the output of SWAN are computed from the wave
spectrum over the prognostic part of the spectrum with the diagnostic tail added. Their
value may therefore deviate slightly from values computed by the user from the output
spectrum of SWAN which does not contain the diagnostic tail.
92 Chapter 4
The quantities below are the contributions to the energy balance equation, containing both
transport terms and source terms. These output quantities are defined as the integral over
all frequencies and directions of the absolute value of each term in the equation. In this
way we can estimate the associated time scale. Besides these terms we may also compute
energy transfer between waves and currents due to radiation stress. Further details can be
found in the ICCE paper of
TIME Full date-time string as part of line used in TABLE only. Useful only in case of
nonstationary computations.
TSEC Time in seconds with respect to a reference time (see command QUANTITY).
Useful only in case of nonstationary computations.
XP user instructs SWAN to write the x−coordinate in the problem coordinate system
of the output location.
YP user instructs SWAN to write the y−coordinate in the problem coordinate system
of the output location.
DIST if output has been requested along a curve (see command CURVE) then the distance
along the curve can be obtained with the command TABLE. DIST is the distance
along the curve measured from the first point on the curve to the output location
on the curve in meters (also in the case of spherical coordinates).
SETUP Set-up due to waves (in m).
PTHSIGN user requests partition of the significant wave height (in m).
Partition of wave spectra is based on the watershed algorithm of
Hanson and Phillips (2001). First partition is due to wind sea and
the remaining partitions are the swell, from highest to lowest
significant wave height. There will be at most 10 partitions.
PTRTP user requests partition of the relative peak period (in s).
PTWLEN user requests partition of the average wave length (in m).
PTDIR user requests partition of the peak wave direction in degrees.
For Cartesian convention: relative to x−axis of the problem coordinate system
(counterclockwise); possible exception: in the case of output with BLOCK
command in combination with command FRAME, see command QUANTITY.
PTDSPR user requests partition of the directional spreading (in degrees).
PTWFRAC user requests partition of the wind fraction (dimensionless).
This indicates the fraction of that partition that is actively being forced
by the wind.
PTSTEEP user requests partition of the wave steepness (dimensionless).
PARTIT user instructs SWAN to generate the raw spectral partition file meant
for wave system tracking post-processing.
Details on the file format and meaning of different parameters may be found in
http://polar.ncep.noaa.gov/waves/workshop/pdfs/
WW3-workshop-exercises-day4-wavetracking.pdf.
Note that this command should not be combined with any other parameters
in BLOCK, although the following parameters will be automatically included,
namely: coordinates, depth, wind, current, Hs, Tp, wave direction, directional
spreading, and wave length. Also note that PARTIT cannot be used as an
output parameter in TABLE.
[unit] this controls the scaling of output. The program divides computed values by [unit]
before writing to file, so the user should multiply the written value by [unit] to
obtain the proper value.
Default: if HEADER is selected, value is written as a 5 position integer.
96 Chapter 4
SWAN takes [unit] such that the largest number occurring in the block
can be printed.
If NOHEADER is selected, values are printed in floating-point format, [unit] = 1.
OUTPUT the user requests output at various times. If the user does not use this option, the
program will give BLOCK output for the last time step of the computation.
[tbegblk] begin time of the first field of the variable, the format is:
1 : ISO-notation 19870530.153000
2 : (as in HP compiler) ’30−May−87 15:30:00’
3 : (as in Lahey compiler) 05/30/87.15:30:00
4 : 15:30:00
5 : 87/05/30 15:30:00’
6 : as in WAM 8705301530
This format is installation dependent. See Implementation Manual or ask the
person who installed SWAN on your computer. Default is ISO-notation.
[deltblk] time interval between fields, the unit is indicated in the next option:
SEC unit seconds
MIN unit minutes
HR unit hours
DAY unit days
| -> HEADer |
| |
TABle ’sname’ < NOHEADer > ’fname’ &
| |
| INDexed |
With this optional command the user indicates that for each location of the output location
set ’sname’ (see commands POINTS, CURVE, FRAME or GROUP) one or more variables should
be written to a file. The keywords HEADER and NOHEADER determine the appearance of the
table; the filename determines the destination of the data.
Unless specifying (see command BLOCK), the x− and y−components of the vectorial quant-
ities VEL, FORCE and TRANSPORT are always given with respect to the problem coordinate
system.
The number of decimals in the table varies for the output parameters; it depends on the
value of [hexp], given in the command QUANTITY.
| -> Sec |
OUTput [tbegspc] [deltspc] < MIn >
| HR |
| DAy |
With this optional command the user indicates that for each location of the output location
set ’sname’ (see commands POINTS, CURVE, FRAME or GROUP) the 1D or 2D variance /
energy (see command SET) density spectrum (either the relative frequency or the absolute
frequency spectrum) is to be written to a data file. The name ’fname’ is required in this
command.
| -> Sec |
NESTout ’sname’ ’fname’ OUTput [tbegnst] [deltnst] < MIn >
| HR |
| DAy |
With this optional command the user indicates that the 2D spectra along a nest boundary
’sname’ (see command NGRID) should be written to a data file with name ’fname’. This
name is required in this command.
If SWAN produces unexpected results, this optional command can be used to instruct
the program to produce intermediate results during a SWAN run (test output). A TEST
command may change between commands in the file to change the level of test output
during a SWAN run. This change occurs during the execution of the run. A TEST command
controls the test output until the next TEST command. Such a next TEST command may
have level 0, thus stopping test output.
[itest] the level of test output. For values under 100 the amount is usually reasonable,
for values above 200 it can be very large. For values of [itest] up to 50 the
test output can be interpreted by the user. For higher values of [itest] the
test output can only be interpreted by those who have the program source listing
at their disposal. Note that for sequential or parallel runs, it might be interesting
to print the timings (both wall-clock and CPU times in seconds) in the PRINT file;
for this [itest] should be set to 1.
Default: [itest] = 1.
[itrace] SWAN writes a message (name of subroutine) to the PRINT file at the first
[itrace] entries of each subroutine.
Default: [itrace] = 0.
POINTS if this option is used, the user instructs SWAN to produce detailed print output
during the computational process for a grid point of the computational grid.
Output at a maximum of 50 grid points is possible. This option can be used
only after the bathymetry has been read (see command READINP BOTTOM).
IJ the test points are defined by means of grid indices.
[i], [j] grid indices of a test point. Values of [i] range between 0 and [mxc]
(see command CGRID), values of [j] between 0 and [myc] (inclusive).
ONLY MEANT FOR STRUCTURED GRIDS.
[k] vertex index of a test point. This can be obtained in a grid generator file
(fort.14, .node and .n files of ADCIRC, Triangle and Easymesh, respectively).
ONLY MEANT FOR UNSTRUCTURED GRIDS.
XY the test points are defined in terms of problem coordinates; SWAN will determine
the nearest grid points. Output will be made for this selected grid point.
[x], [y] coordinates of a test point (problem coordinates in m in case of Cartesian
coordinates, or longitude and latitude in degrees in case of spherical coordinates,
see command COORD).
Description of commands 101
PAR integral parameters for test points are written: HSIGN, RTM01 (see
Appendix A for definitions) and Swind, Swcap, Ssurf, Sfric, Snl3
and Snl4 which are the integrals over frequency and direction of the respective
source terms (wind input, whitecapping, depth-induced breaking, bottom friction,
absolute value of the triad wave-wave interactions and absolute value of the
quadruplet wave-wave interactions).
S1D if the keyword S1D appears variance densities and 6 source terms (see end of
this list of options) as computed will be printed as 1D spectral (frequency) output.
The definition of this file is given in Appendix D. This output will be made after
every iteration in the case of MODE STATIONARY, and after every time step
in the case MODE NONSTATIONARY (see command MODE).
‘fname’ name of the file to which the output is written; default filename: SWSRC1D.
S2D if the keyword S2D appears variance densities and 6 source terms (see end of
this list of options) as computed will be printed as 2D (frequency and direction)
spectral output. The format of this file is defined in Appendix D. This output will
be made after every iteration in the case of MODE STATIONARY, and after every
time step in the case MODE NONSTATIONARY (see command MODE).
‘fname’ name of the file to which the output is written; default filename: SWSRC2D.
Note that the keywords PAR, S1D and S2D need to be given in that order.
The source terms written due to the presence of the keyword S1D or S2D are source terms
of variance density. The 6 source terms are: wind input, whitecapping, bottom friction,
breaking, 3-wave interactions and 4-wave interactions.
When a number [maxmes] of error messages, see command SET, have been written to the
PRINT file, the computation will stop. If necessary make [maxmes] larger using command
SET, and rerun the program.
4.7 Lock-up
| STATionary [time] |
COMPute ( < > )
| | -> Sec | |
| -> NONSTat [tbegc] [deltc] < MIn > [tendc] |
| HR |
| DAy |
If the SWAN mode is stationary (see command MODE), then only the command COMPUTE
102 Chapter 4
To verify input to SWAN (e.g., all input fields such as water depth, wind fields, etc.),
SWAN can be run without computations (that is: zero iterations by using command NUM
ACCUR MXITST = 0).
In the case MODE NONSTATIONARY several commands COMPUTE can appear, where the wave
state at the end of one computation is used as initial state for the next one, unless a
command INIT appears in between the two COMPUTE commands. This enables the user to
make a stationary computation to obtain the initial state for a nonstationary computation
and/or to change the computational time step during a computation, to change a boundary
condition etc. This also has the advantage of not using a hotfile since, it can be very large
in size.
For small domains, i.e. less than 100 km or 1 deg, a stationary computation is recommen-
ded. Otherwise, a nonstationary computation is advised.
For a nonstationary computation, a time step of at most 10 minutes is advised. (When you
are choosing a time step larger than 10 minutes, the action density limiter (see command
NUM) becomes probably a part of the physics.)
Also, the time step should be chosen such that the Courant number is smaller than 10 for
the fastest (or dominant) wave. Otherwise, a first order upwind scheme is recommended
in that case; see command PROP BSBT. If you want to run a high resolution model with a
very large time step, e.g. 1 hour, you may apply multiple COMPUT STAT commands.
For a sufficiently small time step (≤ 10 minutes), no more than 1 iteration per time step
is recommended (see command NUM ... NONSTAT [mxitns]).
[tbegc] the start date and time of the nonstationary computation, format see [time].
Default: the time read from a hotfile (see command INIT HOTSTART), or the
end time [tendc] of the previous nonstationary computation or the [time]
of the previous stationary computation in the same SWAN run (if any).
[deltc] the time step of the nonstationary computation, the unit is indicated in the
next option:
SEC unit seconds
MIN unit minutes
HR unit hours
DAY unit days
[tendc] the end time of the nonstationary computation, format see [time].
| -> FREE
HOTFile ’fname’ <
| UNFormatted
This command can be used to write the entire wave field at the end of a computation to
a so-called hotfile, to be used as initial condition in a subsequent SWAN run (see com-
mand INITIAL HOTSTART) This command must be entered immediately after a COMPUTE
command.
The user may choose the format of the hotfile to be written either as free or unformatted.
If the free format is chosen, then this format is identical to the format of the files written
by the SPECOUT command (option SPEC2D). This hotfile is therefore an ASCII file which
is human readable.
An unformatted (or binary) file usually requires less space on your computer than an AS-
CII file. Moreover, it can be readed by a subsequent SWAN run much faster than an
ASCII file. Especially, when the hotfile might become a big file, the choice for unformatted
is preferable. Note that your compiler and OS should follow the same ABI (Application
Binary Interface) conventions (e.g. word size, endianness), so that unformatted hotfiles
may transfer properly between different OS or platforms. This implies that the present
and subsequent SWAN runs do not have to be carried out on the same operating system
(e.g. Windows, Linux) or on the same computer, provided that distinct ABI conventions
have been followed.
’fname’ name of the file to which the wave field is written.
Note: for parallel MPI runs, more than one hotfile will be generated depending
on the number of processors (fname-001, fname-002, etc.).
FREE the user indicates that the hotfile is written with free format.
This option is default.
104 Chapter 4
STOP
This required command marks the end of the commands in the command file. Note that
the command STOP may be the last command in the input file; any information in the
input file beyond this command is ignored.
Appendix A
Definitions of variables
In SWAN a number of variables are used in input and output. Most of them are related
to waves. The definitions of these variables are mostly conventional.
HSWELL Significant wave height associated with the low frequency part of
the spectrum, denoted as Hs,swell in meters, and defined as
qR
ωswell R 2π
Hs,swell = 4 0 0 E(ω, θ)dωdθ
with ωswell = 2πfswell and fswell = 0.1 Hz by default (this can be changed
with the command QUANTITY).
TMM10 Mean absolute wave period (in s) of E(ω, θ), defined as
R R −1 R R −1
ω E(ω,θ)dωdθ ω E(σ,θ)dσdθ
Tm−10 = 2π R R = 2π R R
E(ω,θ)dωdθ E(σ,θ)dσdθ
105
106 Appendix A
R σhigh
2π R
|Stot − ∂E ~ )E] − ∇(σ,θ) · (~c(σ,θ) E)|dσdθ
− ∇~x · [(~cg + U
∂t
0 σlow
∂Sxy
Fx = − ∂S∂xxx − ∂y
Fy = − ∂S∂xyx − ∂Syy
∂y
R
Sxy = Syx = ρg n sin θ cos θEdσdθ
110 Appendix A
Command syntax
B.2 Command
B.2.1 Keywords
Each command instructs SWAN to carry out a certain action which SWAN executes before
it reads the next command. A command must always start with a keyword (which is also
the name of the command) which indicates the primary function of that command; see list
in Section 4.1). A simple command may appear in its command scheme as:
KEYword data
A command may contain more than one keyword (which refines the instructions to SWAN),
e.g.,
111
112 Appendix B
Spelling of keywords
In every command scheme, keywords appear as words in both lower- and upper-case letters.
When typing the command or keyword in the command file, the user must at least
copy literally the part with upper-case letters. SWAN reads only this part. SWAN is
case insensitive except for one instance (character strings), see below. When typing the
keyword in the command file, any extension of the part with upper-case letters is at the
users discretion as long as the extension is limited to letters or digits, as well as the
characters − and . So, in the first command outlined above one may write: KEY or KEYW
or KEY−word or keyhole, etc., whereas with the abovementioned second command scheme,
key1 KEY2 data may appear in the command file.
Optional keywords are indicated in the command scheme with the following signs enclosing
the keywords concerned:
| KEY2word data |
KEY1word < >
| KEY3word data |
In case the user does not indicate an option in a command, SWAN chooses the alternative
indicated with an arrow (->) appearing in the command scheme (the default option). In
the above example, it may appear as:
| KEY2word data |
KEY1word < >
| -> KEY3word data |
In the actual command in the command file the user must give such a sequence. It ends
with either
• end of line
• the character / or ;
If more than one line is required for a command, the user may continue on the next line as
described in Section B.4. The repetition may consist of one instance (in fact, no repetition
at all).
B.2.2 Data
Most commands contain data, either character data or numerical data.
Numerical data are represented in the command schemes by names enclosed in square
brackets ([ ]).
As a rule, an error message will result if numerical data is given where character data
should be given.
Spelling of data
Character data are represented as character strings (sequence of characters and blanks)
between quotes (in the command scheme and in the command file). SWAN interprets an
end of line as an end quote (a character data field can therefore never extend over more
than one line).
In a command scheme the character string is always a name (which is placed between
quotes as indicated). In the command file such a name can be entered in two ways:
114 Appendix B
• Replace the name by another character string at the users discretion (between quotes;
this is the only occurrence where SWAN is case sensitive; e.g. for text to appear in
a plot.
Example:
command scheme: KEYword ’City’ data
command file: KEY ’Amsterdam’ data
• Copy the name of the variable (without the quotes) literally followed by an = sign
and a name at the users discretion (between quotes). SWAN interprets the copied
name in the command file as a keyword with all the characteristics of a keyword such
as ending a sequence of optional data (see below). As with other keywords the name
of the variable is case-insensitive.
Example:
command scheme: KEYword ’City’ data
command file: KEY city=’Amsterdam’ data
As a rule, an error message will result if numerical data is given where character data
should be given.
Numerical data are simple numbers, e.g. 15 or −7 (integer data), or 13.7 or 0.8E−4 (real
data). Whether or not integer number or real number should be given by the user is
indicated in the description of the command scheme.
Note that a decimal point is not permitted in an integer number. On the other hand, an
integer number is accepted by SWAN where a real number should be given.
In a command scheme, the number is always indicated with a name (which is placed
between square brackets). In the command file such a name can be entered in two ways:
• Copy the name of the variable (without the quotes) literally followed by an = sign
and the number (not between square brackets). SWAN interprets the copied name
in the command file as a keyword with all the characteristics of a keyword such as
ending a sequence of optional data (see below). As with other keywords the name of
the variable is case-insensitive.
Example:
command scheme: KEYword [nnn]
command file: KEY nnn=314
Command syntax 115
Required data (indicated in the description of each individual command) must be given
explicitly as character string or numbers.
( data )
For example:
or
(c) some optional data are indicate in the same way as optional keywords are indicated:
| .....data.....|
< >
| .....data.....|
Optional data of the kind (a) or (b) may be omitted by giving blanks between comma’s
(SWAN then substitutes reasonable default values). If after a required datum all data is
optional (till the next keyword or the next end-of-line), then the comma’s may be omitted
too. Optional data of the kind (c) are to be treated in the same way as optional keywords.
File swan.edt
Below the file swan.edt is presented in which all the commands that can be used with
SWAN are specified.
117
118 Appendix C
!
! | REG [xpinp] [ypinp] [alpinp] [mxinp] [myinp] [dxinp] [dyinp] |
! | |
! < CURVilinear [stagrx] [stagry] [mxinp] [myinp] > &
! | |
! | UNSTRUCtured |
!
! (EXCeption [excval]) &
!
! (NONSTATionary [tbeginp] [deltinp] SEC|MIN|HR|DAY [tendinp])
!
! | -> ADCirc
! READgrid UNSTRUCtured < TRIAngle \
! | EASYmesh / ’fname’
!
! READinp BOTtom | WLevel | CURrent | FRiction | WInd | COOR | NPLAnts &
! TURB | MUDL | AICE | HICE &
!
! [fac] / ’fname1’ \
! \ SERIES ’fname2’ / [idla] [nhedf] ([nhedt]) (nhedvec]) &
!
! FREE | FORMAT ’form’ | [idfm] | UNFORMATTED
!
! | WU
! WIND [vel] [dir] DRAG < -> FIT
! | SWELL
!
! | JONswap [gamma] |
! BOUnd SHAPespec | PM |
! < GAUSs [sigfr] > PEAK|MEAN DSPR POWer|DEGRees
! | BIN |
!
! / -> SIDE N|NW|W|SW|S|SE|E|NE | [k] CCW|CLOCKWise \
! BOUndspec < > &
! \ SEGment / -> XY < [x] [y] > \ /
! \ IJ < [i] [j] > | < [k] > /
!
! / UNIForm / PAR [hs] [per] [dir] [dd]
! < \ FILE ’fname’ [seq]
! \ VARiable / PAR < [len] [hs] [per] [dir] [dd] >
! \ FILE < [len] ’fname’ [seq] >
!
! BOUndnest1 NEst ’fname’ CLOSed|OPEN
File swan.edt 119
!
! BOUndnest2 WAMNest ’fname’ / UNFormatted CRAY|WKstat \
! \ FREE / [xgc] [ygc] [lwdate]
!
! | UNFormatted | | -> CLOS |
! BOUndnest3 WW3 ’fname’ < > < > [xgc] [ygc]
! | FREe | | OPEN |
!
! | -> DEFault
! |
! INITial < ZERO
! |
! | PAR [hs] [per] [dir] [dd]
! |
! | | -> MULTiple | | -> FREE
! | HOTStart < > ’fname’ <
! | | SINGle | | UNFormatted
!
! GEN1 [cf10] [cf20] [cf30] [cf40] [edmlpm] [cdrag] [umin]
!
! GEN2 [cf10] [cf20] [cf30] [cf40] [cf50] [cf60] [edmlpm] [cdrag] [umin]
!
! | JANSsen [cds1] [delta] |
! | |
! | -> KOMen [cds2] [stpm] |
! | |
! | YAN |
! | |
! | WESTHuysen [cds2] [br] [p0] [powst] [powk] |
! | |
! | BABANIN [a1sds] [a2sds] [p1sds] [p2sds] [cdsv] & |
! | | -> UP | |
! GEN3 < [feswell] < > VECTAU TRUE10 > (AGROW [a])
! | | DOWN | |
! | |
! | ST6 [a1sds] [a2sds] [p1sds] [p2sds] & |
! | | -> UP | | -> HWANG | |
! | < > < FAN > VECTAU|SCATAU & |
! | | DOWN | | ECMWF | |
! | | TRUE10 | |
! | < > DEBias [cdfac] |
! | | -> U10Proxy [windscaling] | |
!
120 Appendix C
! FRICtion <
! | COLLins [cfw] [cfc]
! |
! | MADsen [kn]
! |
! | RIPples [S] [D]
!
! TRIad [itriad] [trfac] [cutfr] [a] [b] [p] [urcrit] [urslim]
!
! VEGEtation < [height] [diamtr] [nstems] [drag] >
!
! TURBulence [ctb] (CURrent [tbcur])
!
! MUD [layer] [rhom] [viscm] [rhow] [viscw]
!
! IC4M2 [aice] [c0] [c1] [c2] [c3] [c4] [c5] [c6]
!
! LIMiter [ursell] [qb]
!
! | -> TRANSm [trcoef] |
! | TRANS1d < [trcoef] > |
! | TRANS2d < [trcoef] > |
! OBSTacle < > &
! | | -> GODA [hgt] [alpha] [beta] |
! | DAM < |
! | DANGremond [hgt] [slope] [Bk] |
!
! | -> RSPEC |
! ( REFLec [reflc] < > ) &
! | RDIFF [pown] |
!
! ( FREEboard [hgt] [gammat] [gammar] Quay ) &
!
! LINe < [xp] [yp] >
!
! SETUP [supcor]
!
! DIFFRac [idiffr] [smpar] [smnum] [cgmod]
!
! OFF WINDGrowth | QUADrupl | WCAPping | BREaking | REFrac | FSHift | BNDCHK
!
! PROP / BSBT
! \ GSE [waveage] SEC|MIN|HR|DAY
122 Appendix C
!
! | -> STOPC [dabs] [drel] [curvat] [npnts] [dtabs] [curvt] |
! NUMeric (< > &
! | ACCUR [drel] [dhoval] [dtoval] [npnts] |
!
! | -> STAT [mxitst] [alfa] |
! < > [limiter] ) &
! | NONSTat [mxitns] |
!
! ( DIRimpl [cdd] DEP|WNUM ) &
!
! ( REFRLim [frlim] [power] ) &
!
! | -> SIGIMpl [css] [eps2] [outp] [niter]
! ( < ) &
! | SIGEXpl [css] [cfl]
!
! ( CTheta [cfl] ) &
!
! ( CSigma [cfl] ) &
!
! ( SETUP [eps2] [outp] [niter] )
!
! FRAME ’sname’ [xpfr] [ypfr] [alpfr] [xlenfr] [ylenfr] [mxfr] [myfr]
!
! GROUP ’sname’ SUBGRID [ix1] [ix2] [iy1] [iy2]
!
! CURVE ’sname’ [xp1] [yp1] < [int] [xp] [yp] >
!
! RAY ’rname’ [xp1] [yp1] [xq1] [yq1] &
! < [int] [xp] [yp] [xq] [yq] >
!
! ISOLINE ’sname’ ’rname’ DEPTH|BOTTOM [dep]
!
! POINTS ’sname’ < [xp] [yp] > | FILE ’fname’
!
! | [xpn] [ypn] [alpn] [xlenn] [ylenn] [mxn] [myn]
! NGRID ’sname’ <
! | UNSTRUCtured / -> TRIAngle \
! \ EASYmesh / ’fname’
!
! |...|
! QUANTity < > ’short’ ’long’ [lexp] [hexp] [excv] &
File swan.edt 123
! |...|
!
! [power] [ref] [fswell] [fmin] [fmax] &
!
! / -> PROBLEMcoord \
! \ FRAME /
!
! OUTPut OPTIons ’comment’ (TABle [field]) (BLOck [ndec] [len]) &
! (SPEC [ndec])
!
! BLOCK ’sname’ HEADER | NOHEADER ’fname’ (LAY-OUT [idla]) &
! < HSIGN|HSWELL|DIR|PDIR|TDIR|TM01|RTM01|RTP|TM02|FSPR|DSPR|VEL| &
! FRCOEF|WIND|DISSIP|QB|TRANSP|FORCE|UBOT|URMS|WLEN|STEEPNESS| &
! DHSIGN|DRTM01|LEAK|TSEC|XP|YP|DIST|SETUP|TMM10|RTMM10|DEPTH| &
! TMBOT|QP|BFI|NPLANT|WATLEV|BOTLEV|TPS|DISBOT|DISSURF|DISWCAP| &
! GENE|GENW|REDI|REDQ|REDT|PROPA|PROPX|PROPT|PROPS|RADS|LWAVP| &
! DISTUR|TURB|DISMUD|DISSWELL|AICE|DISICE| &
! PTHSIGN|PTRTP|PTWLEN|PTDIR|PTDSPR|PTWFRAC|PTSTEEP|PARTIT > &
! ([unit]) (OUTPUT [tbegblk] [deltblk] SEC|MIN|HR|DAY)
!
! TABLE ’sname’ HEADER | NOHEADER | INDEXED ’fname’ &
! < HSIGN|HSWELL|DIR|PDIR|TDIR|TM01|RTM01|RTP|TM02|FSPR|DSPR|VEL| &
! FRCOEF|WIND|DISSIP|QB|TRANSP|FORCE|UBOT|URMS|WLEN|STEEPNESS| &
! DHSIGN|DRTM01|LEAK|TIME|TSEC|XP|YP|DIST|SETUP|TMM10|RTMM10| &
! DEPTH|TMBOT|QP|BFI|WATLEV|BOTLEV|TPS|DISBOT|DISSURF|DISWCAP| &
! GENE|GENW|REDI|REDQ|REDT|PROPA|PROPX|PROPT|PROPS|RADS|LWAVP| &
! DISTUR|TURB|DISMUD|DISSWELL|AICE|DISICE| &
! PTHSIGN|PTRTP|PTWLEN|PTDIR|PTDSPR|PTWFRAC|PTSTEEP > &
! ([unit]) (OUTPUT [tbegtbl] [delttbl] SEC|MIN|HR|DAY)
!
! SPECout ’sname’ SPEC1D|SPEC2D ABS|REL ’fname’ &
! MONth ESCAle COMPress &
! (OUTput [tbeg] [delt] SEC|MIN|HR|DAY)
!
! NESTout ’sname’ ’fname’ &
! (OUTput [tbeg] [delt] SEC|MIN|HR|DAY)
!
! / -> IJ < [i] [j] > | < [k] > \
! TEST [itest] [itrace] POINTS < > &
! \ XY < [x] [y] > /
!
! PAR ’fname’ S1D ’fname’ S2D ’fname’
!
124 Appendix C
! | STATionary [time] |
! COMPute ( < > )
! | | -> Sec | |
! | ([tbegc] [deltc] < MIn > [tendc]) |
! | HR |
! | DAy |
!
! | -> FREE
! HOTFile ’fname’ <
! | UNFormatted
!
! STOP
Appendix D
This appendix described the format of the files for spectral input (command BOUNdspec)
and output (commands SPECout and NESTout) by SWAN. The files are recognized by
SWAN or another reading program by the presence of the keyword SWAN and a version
number on the first line of the file. This description is valid for version number 1.
• frequencies
• spectral energy or variance densities (and average direction and direction spreading
if 1D)
Example of a 1D nonstationary spherical coordinates file
125
126 Appendix D
0.0545
0.0622
0.0710
0.0810
0.0924
0.1055
0.1204
0.1375
0.1569
0.1791
0.2045
0.2334
0.2664
0.3040
0.3470
0.3961
0.4522
0.5161
0.5891
0.6724
0.7675
0.8761
1.0000
QUANT
3 number of quantities in table
VaDens variance densities in m2/Hz
m2/Hz unit
-0.9900E+02 exception value
CDIR average Cartesian direction in degr
degr unit
-0.9990E+03 exception value
DSPRDEGR directional spreading
degr unit
-0.9000E+01 exception value
19680606.030000 date and time
LOCATION 1
0.3772E-03 190.1 6.3
0.1039E-02 190.2 6.5
0.2281E-02 190.3 6.7
0.3812E-02 190.3 6.7
0.4255E-02 190.3 6.6
0.2867E-02 190.1 6.3
0.1177E-02 189.6 5.8
Spectrum files, input and output 127
150.0000
180.0000
210.0000
240.0000
270.0000
300.0000
330.0000
360.0000
QUANT
1 number of quantities in table
VaDens variance densities in m2/Hz/degr
m2/Hz/degr unit
-0.9900E+02 exception value
FACTOR
0.675611E-06
51 242 574 956 1288 1482 1481 1286 957 579 244 51
129 610 1443 2402 3238 3725 3724 3234 2406 1454 613 128
273 1287 3054 5084 6846 7872 7869 6837 5091 3076 1295 271
665 3152 7463 12402 16712 19229 19221 16690 12419 7518 3172 662
1302 6159 14608 24275 32688 37618 37603 32644 24309 14716 6198 1296
2328 10989 26020 43341 58358 67109 67080 58281 43401 26213 11058 2317
3365 15922 37712 62733 84492 97150 97110 84380 62820 37991 16021 3349
3426 16230 38440 63939 86109 99010 98969 85995 64027 38724 16331 3410
2027 9612 22730 37790 50909 58529 58505 50841 37843 22898 9672 2018
672 3178 7538 12535 16892 19440 19432 16870 12552 7594 3198 669
101 479 1135 1890 2542 2924 2923 2539 1892 1144 482 101
2 11 26 43 57 66 66 57 43 26 11 2
0 0 0 1 1 1 1 1 1 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 0 0 0 0 0
Note that the true variance or energy densities are obtained by multiplying each number
with the factor given under the keyword FACTOR.
130 Appendix D
The description of the file to write or read source terms is identical to this description
except that the quantities obviously differ.
The format that is used by SWAN or should be used by the user when offering the file
to SWAN is free format (FORTRAN convention) except that all keywords and names of
quantities (see below) should start on the first position of the line on which they appear
(see Appendix B for the syntax of keywords). This format implies that all information
on each line after the required input for SWAN is ignored by SWAN. This can be used to
enter user’s information at the discretion of the user.
[3] SWAN – Scientific and Technical documentation. Delft University of Technology, En-
vironmental Fluid Mechanics Section, available from http://www.swan.tudelft.nl (Ver-
sion 41.31, May 2019).
133
Index
134
135
Jonswap, 42 shoaling, 18
SORDUP, 74, 75
latitude, 8, 30, 100, 124 SPECOUT, 97
LIMITER, 68 specular, 71
limiter, 5, 7, 16, 17, 68, 76, 77, 102 spherical, 4, 5, 8, 10, 23, 27, 30, 31, 34, 39,
longitude, 8, 30, 52, 54, 100, 124 49, 52–54, 72, 79, 81–83, 95, 100,
119, 124
MODE, 29
SSWELL, 60
MUD, 66
stability, 14, 16, 74
nautical, 8, 124, 125 stationary, 4, 6, 9, 14, 15, 17, 18, 22, 23,
NEGATINP, 61 28, 29, 36, 37, 40–42, 49, 50, 54, 55,
NESTOUT, 99 60, 74, 76, 82, 95, 101–103, 119, 122,
NGRID, 83 124, 125
NUMERIC, 75 steepness, 59–61, 94, 95, 109
STOP, 104
OBSTACLE, 68 swell, 12, 15, 16, 58, 60, 61, 64, 75, 86, 87,
obstacle, 5, 17, 24, 68–72 92, 93, 95, 105
ocean, 4–6, 16, 30
OFF, 73 TABLE, 96
OUTPUT, 87 TEST, 99
transmission, 17–19, 69–71
plant, 65, 66, 94 TRIAD, 64
POINTS, 82 triads, 17, 65, 93, 108
PROJECT, 26 triangular, 3, 17
PROP, 74 TURBULENCE, 66
propagation, 6, 12, 24, 69, 73, 74, 93, 108
unstructured, 3, 4, 8–10, 13, 23, 31, 35, 37,
QUADRUPL, 61 38, 42, 48, 69, 73–75, 78, 80, 84, 91
quadruplets, 15, 17, 24, 62, 68, 93, 108
VEGETATION, 65
QUANTITY, 84
vegetation, 9–11, 13, 17, 24, 37, 38, 42, 65,
RAY, 81 66, 94
READGRID COORDINATES, 33
WAM, 4–7, 9, 10, 15, 18, 24, 40, 50–53, 57,
READGRID UNSTRUCTURED, 34
59, 61, 62, 96–99, 102
READINP, 40
WAVEWATCH, 4–7, 9, 10, 15, 24, 50, 53,
rectilinear, 3, 17, 31, 32, 41, 42, 80
54, 60
reflection, 69, 71
WCAPPING, 61
refraction, 6, 11, 16, 74, 76, 81
whitecapping, 7, 17, 24, 57, 59, 61, 74, 93,
regular, 4, 8, 10, 17, 24, 30, 31, 33–35, 37,
101, 108
58, 74, 78–80
WIND, 45
SET, 27 wind, 3, 5, 7–19, 21, 23, 28, 29, 37, 38, 42,
set-up, 4, 6, 7, 17–19, 24, 30, 72, 77 45, 54–61, 64, 74–77, 92, 93, 95, 101,
SETUP, 72 102, 108, 110