GMSH
GMSH
GMSH
22 August 2018
Christophe Geuzaine
Jean-François Remacle
Copyright
c 1997-2018 Christophe Geuzaine, Jean-François Remacle
Permission is granted to make and distribute verbatim copies of this manual provided the
copyright notice and this permission notice are preserved on all copies.
i
Short Contents
Obtaining Gmsh . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1
Copying conditions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3
1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5
2 How to read this reference manual? . . . . . . . . . . . . . . . . . . . . . . . 9
3 Running Gmsh on your system . . . . . . . . . . . . . . . . . . . . . . . . . 11
4 General tools . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
5 Geometry module . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
6 Mesh module . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
7 Solver module . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71
8 Post-processing module . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 73
9 File formats . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 107
A Tutorial . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 127
B Options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 155
C Compiling the source code . . . . . . . . . . . . . . . . . . . . . . . . . . . . 235
D Gmsh API . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 239
E Information for developers . . . . . . . . . . . . . . . . . . . . . . . . . . . . 275
F Frequently asked questions . . . . . . . . . . . . . . . . . . . . . . . . . . . . 277
G Version history . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 285
H Copyright and credits . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 301
I License . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 305
Concept index . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 313
Syntax index . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 315
iii
Table of Contents
Obtaining Gmsh . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1
Copying conditions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3
1 Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5
1.1 Geometry: geometrical entity definition . . . . . . . . . . . . . . . . . . . . . . . . . 5
1.2 Mesh: finite element mesh generation . . . . . . . . . . . . . . . . . . . . . . . . . . . 5
1.3 Solver: external solver interface. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6
1.4 Post-processing: scalar, vector and tensor field visualization . . . . . 6
1.5 What Gmsh is pretty good at . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6
1.6 . . . and what Gmsh is not so good at . . . . . . . . . . . . . . . . . . . . . . . . . . 7
1.7 Bug reports . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8
4 General tools . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
4.1 Comments . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
4.2 Expressions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
4.2.1 Floating point expressions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
4.2.2 Character expressions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24
4.2.3 Color expressions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
4.3 Operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
4.4 Built-in functions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
4.5 User-defined macros . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
4.6 Loops and conditionals . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
4.7 General commands . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
4.8 General options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34
iv Gmsh 4.0
5 Geometry module . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
5.1 Geometry commands . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
5.1.1 Points. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
5.1.2 Curves . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
5.1.3 Surfaces . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
5.1.4 Volumes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
5.1.5 Extrusions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
5.1.6 Boolean operations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
5.1.7 Transformations . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42
5.1.8 Miscellaneous . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43
5.2 Geometry options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44
6 Mesh module . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
6.1 Choosing the right unstructured algorithm . . . . . . . . . . . . . . . . . . . . 45
6.2 Elementary vs. physical entities . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46
6.3 Mesh commands . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47
6.3.1 Specifying mesh element sizes . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47
6.3.2 Structured grids . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64
6.3.3 Miscellaneous . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66
6.4 Mesh options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69
7 Solver module . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71
7.1 Solver options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71
8 Post-processing module . . . . . . . . . . . . . . . . . . . . . . . 73
8.1 Post-processing commands . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 74
8.2 Post-processing plugins . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 78
8.3 Post-processing options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 105
Obtaining Gmsh
The source code and various pre-compiled versions of Gmsh (for Windows, Mac and Unix)
can be downloaded from http://gmsh.info. Gmsh is also directly available in pre-packaged
form in various Linux and BSD distributions (Debian, Ubuntu, FreeBSD, ...).
If you use Gmsh, we would appreciate that you mention it in your work by citing the
following paper: “C. Geuzaine and J.-F. Remacle, Gmsh: a three-dimensional finite element
mesh generator with built-in pre- and post-processing facilities. International Journal for
Numerical Methods in Engineering, Volume 79, Issue 11, pages 1309-1331, 2009”. A preprint
of that paper as well as other references and the latest news about Gmsh development are
available on http://gmsh.info.
Copying conditions 3
Copying conditions
Gmsh is “free software”; this means that everyone is free to use it and to redistribute it on
a free basis. Gmsh is not in the public domain; it is copyrighted and there are restrictions
on its distribution, but these restrictions are designed to permit everything that a good
cooperating citizen would want to do. What is not allowed is to try to prevent others from
further sharing any version of Gmsh that they might get from you.
Specifically, we want to make sure that you have the right to give away copies of Gmsh,
that you receive source code or else can get it if you want it, that you can change Gmsh or
use pieces of Gmsh in new free programs, and that you know you can do these things.
To make sure that everyone has such rights, we have to forbid you to deprive anyone else of
these rights. For example, if you distribute copies of Gmsh, you must give the recipients all
the rights that you have. You must make sure that they, too, receive or can get the source
code. And you must tell them their rights.
Also, for our own protection, we must make certain that everyone finds out that there is
no warranty for Gmsh. If Gmsh is modified by someone else and passed on, we want their
recipients to know that what they have is not what we distributed, so that any problems
introduced by others will not reflect on our reputation.
The precise conditions of the license for Gmsh are found in the General Public
License that accompanies the source code (see Appendix I [License], page 305).
Further information about this license is available from the GNU Project webpage
http://www.gnu.org/copyleft/gpl-faq.html. Detailed copyright information can be
found in Appendix H [Copyright and credits], page 301.
If you want to integrate parts of Gmsh into a closed-source software, or want to sell a
modified closed-source version of Gmsh, you will need to obtain a different license. Please
contact us directly for more information.
Chapter 1: Overview 5
1 Overview
Gmsh is a three-dimensional finite element grid generator with a build-in CAD engine and
post-processor. Its design goal is to provide a fast, light and user-friendly meshing tool with
parametric input and advanced visualization capabilities.
Gmsh is built around four modules: geometry, mesh, solver and post-processing. All ge-
ometrical, mesh, solver and post-processing instructions are prescribed either interactively
using the graphical user interface (GUI) or in text files using Gmsh’s own scripting lan-
guage. Interactive actions generate language bits in the input files, and vice versa. This
makes it possible to automate all treatments, using loops, conditionals and external system
calls. A programming API is also available, for integrating Gmsh as a library in your own
C++, C, Python or Julia code: see Appendix D [Gmsh API], page 239. A brief description
of the four modules is given hereafter.
it is explicitly told to do so (see Section 6.3.3 [Miscellaneous mesh commands], page 66).
Every meshing step is constrained by a “size field” (sometimes called “characteristic length
field”), which prescribes the desired size of the elements in the mesh. This size field can be
uniform, specified by values associated with points in the geometry, or defined by general
“fields” (for example related to the distance to some boundary, to a arbitrary scalar field
defined on another mesh, etc.).
For each meshing step, all structured mesh directives are executed first, and serve as addi-
tional constraints for the unstructured parts1 .
• specify target element sizes accurately. Gmsh provides several mechanisms to control
the size of the elements in the final mesh: through interpolation from sizes specified at
geometry points or using flexible mesh size fields (see Section 6.3 [Mesh commands],
page 47);
• create simple extruded geometries and meshes (see Section 5.1 [Geometry commands],
page 35, and Section 6.3 [Mesh commands], page 47);
• interact with external solvers through a simple client-server architecture (see Chapter 7
[Solver module], page 71);
• visualize and export computational results in a great variety of ways. Gmsh can display
scalar, vector and tensor datasets, perform various operations on the resulting post-
processing views (see Chapter 8 [Post-processing module], page 73), can export plots
in many different formats (see Section B.1 [General options list], page 155), and can
generate complex animations (see Chapter 4 [General tools], page 21, and Section A.8
[t8.geo], page 141);
• run on low end machines and/or machines with no graphical interface. Gmsh can
be compiled with or without the GUI (see Appendix C [Compiling the source code],
page 235), and all versions can be used either interactively or directly from the com-
mand line (see Chapter 3 [Running Gmsh on your system], page 11);
• configure your preferred options. Gmsh has a large number of configuration options
that can be set interactively using the GUI, scattered inside command files, changed on
the fly in scripts, set in per-user configuration files, or specified on the command-line
(see Chapter 3 [Running Gmsh on your system], page 11 and Appendix B [Options],
page 155);
• and do all the above on various platforms (Windows, Mac and Unix), for free (see
[Copying conditions], page 3), using simple script files and/or a small but powerful
GUI.
If you have the skills and some free time, feel free to join the project: we gladly accept any
code contributions (see Appendix E [Information for developers], page 275) to remedy the
aforementioned (and all other) shortcomings!
8 Gmsh 4.0
Note that all the options specified interactively can also be directly specified in the script
files. You can save the current options of the current active model with the ‘File->Save
Model Options’. This will create a new option file with the same filename as the active
model, but with an extra ‘.opt’ extension added. The next time you open this model, the
associated options will be automatically loaded, too. To save the current options as your
default preferences for all future Gmsh sessions, use the ‘File->Save Options As Default’
menu instead. Finally, you can also save the current options in an arbitrary file by choosing
the ‘Gmsh options’ format in ‘File->Export’.
For more information about available options (and how to reset them to their default values),
see Appendix B [Options], page 155. A full list of options with their current values is also
available in the ‘Help->Current Options’ menu.
2
If you compile Gmsh without the GUI (see Appendix C [Compiling the source code], page 235), this is the
only mode you have access to.
Chapter 3: Running Gmsh on your system 13
-format string
Select output mesh format (auto, msh1, msh2, msh3, msh4, msh, unv, vtk, wrl,
mail, stl, p3d, mesh, bdf, cgns, med, diff, ir3, inp, ply2, celum, su2, x3d, dat,
neu, m)
-bin Create binary files when possible
-refine Perform uniform mesh refinement, then exit
-barycentric_refine
Perform barycentric mesh refinement, then exit
-reclassify
Reclassify mesh, then exit
-part int Partition after batch mesh generation
-part_weight tri|quad|tet|hex|pri|pyr|trih int
Weight of a triangle/quad/etc. during partitioning
-part_split
Save mesh partitions in separate files
-part_[no_]topo
Create the partition topology
-part_[no_]ghosts
Create ghost cells
-part_[no_]physicals
Create phsyical groups for partitions
-part_topo_pro
Save the partition topology .pro file
-preserve_numbering_msh2
Preserve element numbering in MSH2 format
-save_all
Save all elements (discard physical group definitions)
-save_parametric
Save nodes with their parametric coordinates
-save_topology
Save model topology
-algo string
Select mesh algorithm (meshadapt, del2d, front2d, delquad, del3d, front3d,
mmg3d, pack)
-smooth int
Set number of mesh smoothing steps
-order int
Set mesh order (1, ..., 5)
14 Gmsh 4.0
-optimize[_netgen]
Optimize quality of tetrahedral elements
-optimize_threshold
Optimize tetrahedral elements that have a quality less than a threshold
-optimize_ho
Optimize high order meshes
-ho_[min,max,nlayers]
High-order optimization parameters
-clscale float
Set global mesh element size scaling factor
-clmin float
Set minimum mesh element size
-clmax float
Set maximum mesh element size
-aniso_max float
Set maximum anisotropy (for bamg)
-smooth_ratio float
Set smoothing ration between mesh sizes at nodes of a same edge (for bamg)
-clcurv Automatically compute element sizes from curvatures
-epslc1d Set accuracy of evaluation of mesh size field for 1D mesh
-swapangle
Set the threshold angle (in degree) between two adjacent faces below which a
swap is allowed
-rand float
Set random perturbation factor
-bgm file Load background mesh from file
-check Perform various consistency checks on mesh
-ignore_periocity
Ignore periodic boundaries
Post-processing options:
-link int Select link mode between views (0, 1, 2, 3, 4)
-combine Combine views having identical names into multi-time-step views
Solver options:
-listen Always listen to incoming connection requests
-minterpreter string
Name of Octave interpreter
-pyinterpreter string
Name of Python interpreter
Chapter 3: Running Gmsh on your system 15
-option file
Parse option file at startup
-convert files
Convert files into latest binary formats, then exit
-nt int Set number of threads
-cpu Report CPU times for all operations
-version Show version number
-info Show detailed version information
-help Show command line usage
-help_options
Show all options
Alt+Shift+y
Set -Y view
Alt+Shift+z
Set -Z view
Chapter 4: General tools 21
4 General tools
This chapter describes the general commands and options that can be used in Gmsh’s script
files. By “general”, we mean “not specifically related to one of the geometry, mesh, solver
or post-processing modules”. Commands peculiar to these modules will be introduced in
Chapter 5 [Geometry module], page 35, Chapter 6 [Mesh module], page 45, Chapter 7
[Solver module], page 71, and Chapter 8 [Post-processing module], page 73, respectively.
4.1 Comments
Gmsh script files support both C and C++ style comments:
1. any text comprised between /* and */ pairs is ignored;
2. the rest of a line after a double slash // is ignored.
These commands won’t have the described effects inside double quotes or inside keywords.
Also note that ‘white space’ (spaces, tabs, new line characters) is ignored inside all expres-
sions.
4.2 Expressions
The two constant types used in Gmsh scripts are real and string (there is no integer type).
These types have the same meaning and syntax as in the C or C++ programming languages.
FileExists(char-expression ) |
StringToName(char-expression ) | S2N(char-expression ) |
GetNumber(char-expression <,expression >) |
GetValue("string ", expression ) |
DefineNumber(expression, onelab-options ) |
Such expressions are used in most of Gmsh’s scripting commands. When ~{expression }
is appended to a string string, the result is a new string formed by the concatenation of
string, _ (an underscore) and the value of the expression. This is most useful in loops (see
Section 4.6 [Loops and conditionals], page 28), where it permits to define unique strings
automatically. For example,
For i In {1:3}
x~{i} = i;
EndFor
is the same as
x_1 = 1;
x_2 = 2;
x_3 = 3;
The brackets [] permit to extract one item from a list (parentheses can also be used instead
of brackets). The # permits to get the size of a list. The operators operator-unary-left,
operator-unary-right, operator-binary, operator-ternary-left and operator-ternary-right are
defined in Section 4.3 [Operators], page 25. For the definition of built-in-functions, see
Section 4.4 [Built-in functions], page 27. The various real-options are listed in Appendix B
[Options], page 155. Find searches for occurrences of the first expression in the second
(both of which can be lists). StrFind searches the first char-expression for any occurrence
of the second char-expression. StrCmp compares the two strings (returns an integer greater
than, equal to, or less than 0, according as the first string is greater than, equal to, or less
than the second string). StrCmp returns the length of the string. TextAttributes creates
attributes for text strings. Exists checks if a variable with the given name exists (i.e.,
has been defined previously), and FileExists checks if the file with the given name exists.
StringToName creates a name from the provided string. GetNumber allows to get the value
of a ONELAB variable (the optional second argument is the default value returned if the
variable does not exist). GetValue allows to ask the user for a value interactively (the
second argument is the value returned in non-interactive mode). For example, inserting
GetValue("Value of parameter alpha?", 5.76) in an input file will query the user for
the value of a certain parameter alpha, assuming the default value is 5.76. If the option
General.NoPopup is set (see Section B.1 [General options list], page 155), no question is
asked and the default value is automatically used.
DefineNumber allows to define a ONELAB variable in-line. The expression given as
the first argument is the default value; this is followed by the various ONELAB options. See
https://gitlab.onelab.info/doc/tutorials/wikis/ONELAB-syntax-for-Gmsh-and-GetDP
for more information.
List of expressions are also widely used, and are defined as:
expression-list :
expression-list-item <, expression-list-item > ...
with
Chapter 4: General tools 23
expression-list-item :
expression |
expression : expression |
expression : expression : expression |
string [ ] | string ( ) |
List [ string ] |
List [ expression-list-item ] |
List [ { expression-list } ] |
Unique [ expression-list-item ] |
Abs [ expression-list-item ] |
ListFromFile [ expression-char ] |
LinSpace[ expression, expression, expression ] |
LogSpace[ expression, expression, expression ] |
string [ { expression-list } ] |
Point { expression } |
transform |
extrude |
boolean |
Point|Curve|Surface|Volume In BoundingBox { expression-list } |
BoundingBox Point|Curve|Surface|Volume { expression }
Point { expression } |
Physical Point|Curve|Surface|Volume { expression-list } |
<Physical> Point|Curve|Surface|Volume { : } |
The second case in this last definition permits to create a list containing the range of numbers
comprised between two expressions, with a unit incrementation step. The third case also
permits to create a list containing the range of numbers comprised between two expressions,
but with a positive or negative incrementation step equal to the third expression. The
fourth, fifth and sixth cases permit to reference an expression list (parentheses can also be
used instead of brackets). Unique sorts the entries in the list and removes all duplicates.
Abs takes the absolute value of all entries in the list. ListFromFile reads a list of numbers
from a file. LinSpace and LogSpace construct lists using linear or logarithmic spacing.
The next two cases permit to reference an expression sublist (whose elements are those
corresponding to the indices provided by the expression-list). The next cases permit to
retrieve the indices of entities created through geometrical transformations, extrusions and
boolean operations (see Section 5.1.7 [Transformations], page 42, Section 5.1.5 [Extrusions],
page 39 and Section 5.1.6 [Boolean operations], page 41). The next two cases allow to
retrieve entities in a given bounding box, or get the bounding box of a given entity. The
last three cases permit to retrieve the coordinates of a given geometry point (see Section 5.1.1
[Points], page 35), to retrieve the elementary entities making up physical groups, and to
retrieve the tags of all (physical or elementary) points, curves, surfaces or volumes in the
model,
To see the practical use of such expressions, have a look at the first couple of examples in
Appendix A [Tutorial], page 127. Note that, in order to lighten the syntax, you can omit
the braces {} enclosing an expression-list if this expression-list only contains a single item.
Also note that a braced expression-list can be preceded by a minus sign in order to change
the sign of all the expression-list-items.
24 Gmsh 4.0
For some commands it makes sense to specify all the possible expressions in a list. This is
achieved with expression-list-or-all, defined as:
expression-list-or-all :
expression-list | :
The meaning of “all” (:) depends on context. For example, Curve { : } will get the ids
of all the existing curves in the model, while Surface { : } will get the ids of all existing
surfaces.
char-expression is a format string that can contain floating point formatting characters: %e,
%g, etc.) The various char-options are listed in Appendix B [Options], page 155. GetEnvThe
gets the value of an environment variable from the operating system. GetString allows to
get a ONELAB string value (the second optional argument is the default value returned if
the variable does not exist). GetStringValue asks the user for a value interactively (the
second argument is the value used in non-interactive mode). StrReplace’s arguments are:
input string, old substring, new substring (brackets can be used instead of parentheses in
Str and Sprintf). NameToString converts a variable name into a string.
DefineString allows to define a ONELAB variable in-line. The char-expression given as
the first argument is the default value; this is followed by the various ONELAB options. See
https://gitlab.onelab.info/doc/tutorial/wikis/ONELAB-syntax-for-Gmsh-and-GetDP
for more information.
Character expressions are mostly used to specify non-numeric options and input/output file
names. See Section A.8 [t8.geo], page 141, for an interesting usage of char-expressions in
an animation script.
List of character expressions are defined as:
char-expression-list :
char-expression <,...>
4.3 Operators
Gmsh’s operators are similar to the corresponding operators in C and C++. Here is the list
of the unary, binary and ternary operators currently implemented.
operator-unary-left:
- Unary minus.
! Logical not.
operator-unary-right:
++ Post-incrementation.
26 Gmsh 4.0
-- Post-decrementation.
operator-binary:
^ Exponentiation.
* Multiplication.
/ Division.
% Modulo.
+ Addition.
- Subtraction.
== Equality.
!= Inequality.
> Greater.
>= Greater or equality.
< Less.
<= Less or equality.
&& Logical ‘and’.
|| Logical ‘or’. (Warning: the logical ‘or’ always implies the evaluation of both
arguments. That is, unlike in C or C++, the second operand of || is evaluated
even if the first one is true).
operator-ternary-left:
?
operator-ternary-right:
: The only ternary operator, formed by operator-ternary-left and operator-
ternary-right, returns the value of its second argument if the first argument is
non-zero; otherwise it returns the value of its third argument.
The evaluation priorities are summarized below1 (from stronger to weaker, i.e., * has a
highest evaluation priority than +). Parentheses () may be used anywhere to change the
order of evaluation:
1. (), [], ., #
2. ^
3. !, ++, --, - (unary)
4. *, /, %
5. +, -
6. <, >, <=, >=
7. ==, !=
1
The affectation operators are introduced in Section 4.7 [General commands], page 29.
Chapter 4: General tools 27
8. &&
9. ||
10. ?:
11. =, +=, -=, *=, /=
Log10 ( expression )
Base 10 logarithm of expression (expression > 0).
Modulo ( expression, expression )
see Fmod( expression, expression ).
Rand ( expression )
Random number between zero and expression.
Round ( expression )
Rounds expression to the nearest integer.
Sqrt ( expression )
Square root of expression (expression >= 0).
Sin ( expression )
Sine of expression.
Sinh ( expression )
Hyperbolic sine of expression.
Tan ( expression )
Tangent of expression.
Tanh ( expression )
Hyperbolic tangent of expression.
GMSH_MINOR_VERSION
Returns Gmsh’s minor version number.
GMSH_PATCH_VERSION
Returns Gmsh’s patch version number.
MPI_Size Returns the number of processors on which Gmsh is running. It
is always 1, except if you compiled Gmsh with ENABLE_MPI (see
Appendix C [Compiling the source code], page 235).
MPI_Rank Returns the rank of the current processor.
Cpu Returns the current CPU time (in seconds).
Memory Returns the current memory usage (in Mb).
TotalMemory
Returns the total memory available (in Mb).
newp Returns the next available point tag. As explained in Chapter 5
[Geometry module], page 35, a unique tag must be associated with
every geometrical point: newp permits to know the highest tag
already attributed (plus one). This is mostly useful when writing
user-defined macros (see Section 4.5 [User-defined macros], page 28)
or general geometric primitives, when one does not know a priori
which tags are already attributed, and which ones are still available.
newl Returns the next available curve tag.
news Returns the next available surface tag.
newv Returns the next available volume tag.
newll Returns the next available curve loop tag.
newsl Returns the next available surface loop tag.
newreg Returns the next available region tag. That is, newreg returns the
maximum of newp, newl, news, newv, newll, newsl and all physical
entity tags2 .
string = { };
Creates a new expression list identifier string with an empty list.
string [] = { expression-list };
Creates a new expression list identifier string with the list expression-list, or
affects expression-list to an existing expression list identifier. Parentheses are
also allowed instead of square brackets; although not recommended, brackets
and parentheses can also be completely ommitted.
string [ { expression-list } ] = { expression-list };
Affects each item in the right hand side expression-list to the elements (indexed
by the left hand side expression-list) of an existing expression list identifier.
The two expression-lists must contain the same number of items. Parentheses
can also be used instead of brackets.
2
For compatibility purposes, the behavior of newl, news, newv and newreg can be modified with the
Geometry.OldNewReg option (see Section B.2 [Geometry options list], page 184).
Chapter 4: General tools 31
string += expression ;
Adds and affects expression to an existing expression identifier.
string -= expression ;
Subtracts and affects expression to an existing expression identifier.
string *= expression ;
Multiplies and affects expression to an existing expression identifier.
string /= expression ;
Divides and affects expression to an existing expression identifier.
string += { expression-list };
Appends expression-list to an existing expression list or creates a new expression
list with expression-list.
string -= { expression-list };
Removes the items in expression-list from the existing expression list.
string [ { expression-list } ] += { expression-list };
Adds and affects, item per item, the right hand side expression-list to an existing
expression list identifier. Parentheses can also be used instead of brackets.
string [ { expression-list } ] -= { expression-list };
Subtracts and affects, item per item, the right hand side expression-list to
an existing expression list identifier. Parentheses can also be used instead of
brackets.
string [ { expression-list } ] *= { expression-list };
Multiplies and affects, item per item, the right hand side expression-list to
an existing expression list identifier. Parentheses can also be used instead of
brackets.
string [ { expression-list } ] /= { expression-list };
Divides and affects, item per item, the right hand side expression-list to an ex-
isting expression list identifier. Parentheses can also be used instead of brackets.
string = char-expression ;
Creates a new character expression identifier string with a given
char-expression.
string [] = Str( char-expression-list ) ;
Creates a new character expression list identifier string with a given char-
expression-list. Parentheses can also be used instead of brackets.
string [] += Str( char-expression-list ) ;
Appends a character expression list to an existing list. Parentheses can also be
used instead of brackets.
DefineConstant[ string = expression |char-expression <, ...>];
Creates a new expression identifier string, with value expression, only if has not
been defined before.
32 Gmsh 4.0
5 Geometry module
Geometries can be constructed in Gmsh using different underlying CAD kernels, specified
in .geo files with the SetFactory command.
The built-in CAD kernel (SetFactory("built-in")) provides a simple CAD engine based
on a boundary representation (“BRep”) approach: you need to first define points (using
the Point command: see below), then curves (using Line, Circle, Spline, . . . , commands
or by extruding points), then surfaces (using for example the Plane Surface or Surface
commands, or by extruding curves), and finally volumes (using the Volume command or
by extruding surfaces). The OpenCASCADE CAD kernel (SetFactory("OpenCASCADE"))
uses the open source OpenCASCADE
These geometrical entities are called “elementary” in Gmsh’s jargon, and are assigned tags
(stricly positive identification numbers) when they are created:
1. each elementary point must possess a unique tag;
2. each elementary curve must possess a unique tag;
3. each elementary surface must possess a unique tag;
4. each elementary volume must possess a unique tag.
Elementary geometrical entities can then be manipulated in various ways, for example
using the Translate, Rotate, Scale or Symmetry commands. They can be deleted with
the Delete command, provided that no higher-dimension entity references them. Zero or
negative tags are reserved by the system for special uses: do not use them in your scripts.
Groups of elementary geometrical entities can also be defined and are called “physical”
entities. These physical entities cannot be modified by geometry commands: their only
purpose is to assemble elementary entities into larger groups so that they can be referred to
by the mesh module as single entities. As is the case with elementary entities, each physical
point, physical curve, physical surface or physical volume must be assigned a unique tag.
See Chapter 6 [Mesh module], page 45, for more information about how physical entities
affect the way meshes are saved.
5.1.1 Points
Point ( expression ) = { expression, expression, expression <, expression > };
Creates an elementary point. The expression inside the parentheses is the
point’s tag; the three first expressions inside the braces on the right hand side
give the three X, Y and Z coordinates of the point in the three-dimensional
Euclidean space; the optional last expression sets the prescribed mesh element
size at that point. See Section 6.3.1 [Specifying mesh element sizes], page 47,
for more information about how this value is used in the meshing process.
36 Gmsh 4.0
5.1.2 Curves
Line ( expression ) = { expression, expression };
Creates a straight line segment. The expression inside the parentheses is the
line segment’s tag; the two expressions inside the braces on the right hand side
give tags of the start and end points of the segment.
Bezier ( expression ) = { expression-list };
Creates a Bezier curve. The expression-list contains the tags of the control
points.
BSpline ( expression ) = { expression-list };
Creates a cubic BSpline. The expression-list contains the tags of the control
points. Creates a periodic curve if the first and last points are identical.
Spline ( expression ) = { expression-list };
Creates a spline going through the points in expression-list. With the built-in
geometry kernel this constructs a Catmull-Rom spline. With the OpenCAS-
CADE kernel, this constructs a C2 BSpline. Creates a periodic curve if the first
and last points are identical.
Circle ( expression ) = { expression, expression, expression <, ...> };
Creates a circle arc. The three expressions on the right-hand-side define the
start point, the center and the end point of the arc. With the built-in geometry
kernel the arc should be strictly smaller than Pi. With the OpenCASCADE ker-
nel additional expressions can be provided to define a full circle (4th expression
is the radius) or a circle arc between two angles (next 2 expressions).
Ellipse ( expression ) = { expression, expression, expression, expression <,
...> };
Creates an ellipse arc. The four expressions on the right-hand-side define the
start point, the center point, a major axis point and the end point of the
ellipse. The third point can be omitted with the OpenCASCADE kernel. With
the OpenCASCADE kernel additional expressions can be provided to define a
full ellipse (4th and 5th expressions define the radii along X and Y) or en ellipse
arc (next 2 expressions).
Curve Loop ( expression ) = { expression-list };
Creates an oriented loop of curves, i.e. a closed wire. The expression inside the
parentheses is the curve loop’s tag; the expression-list on the right hand side
should contain the tags of all the elementary curves that constitute the curve
Chapter 5: Geometry module 37
loop. A curve loop must be a closed loop, and the elementary curves should be
ordered and oriented (using negative tags to specify reverse orientation). If the
orientation is correct, but the ordering is wrong, Gmsh will actually reorder the
list internally to create a consistent loop. Although Gmsh supports it, it is not
recommended to specify multiple curve loops (or subloops) in a single Curve
Loop command. (Curve loops are used to create surfaces: see Section 5.1.3
[Surfaces], page 37.)
Wire ( expression ) = { expression-list };
Creates a path made of curves. Wires are only available with the OpenCAS-
CADE kernel. They are used to create ThruSections and extrusions along
paths.
Physical Curve ( expression | char-expression <, expression > ) <+|->= {
expression-list };
Creates a physical curve. The expression inside the parentheses is the physical
curve’s tag; the expression-list on the right hand side should contain the tags of
all the elementary curves that need to be grouped inside the physical curve. If
a char-expression is given instead instead of expression inside the parentheses,
a string label is associated with the physical tag, which can be either provided
explicitly (after the comma) or not (in which case a unique tag is automatically
created). Specifying negative tags in the expression-list will reverse the orien-
tation of the mesh elements belonging to the corresponding elementary curves
in the saved mesh file.
5.1.3 Surfaces
Plane Surface ( expression ) = { expression-list };
Creates a plane surface. The expression inside the parentheses is the plane
surface’s tag; the expression-list on the right hand side should contain the
tags of all the curve loops defining the surface. The first curve loop defines
the exterior boundary of the surface; all other curve loops define holes in the
surface. A curve loop defining a hole should not have any curves in common
with the exterior curve loop (in which case it is not a hole, and the two surfaces
should be defined separately). Likewise, a curve loop defining a hole should not
have any curves in common with another curve loop defining a hole in the same
surface (in which case the two curve loops should be combined).
Surface ( expression ) = { expression-list } < In Sphere { expression } >;
Creates a surface filling. With the built-in kernel, the first curve loop should be
composed of either three or four elementary curves. With the built-in kernel,
the optional In Sphere argument forces the surface to be a spherical patch (the
extra parameter gives the tag of the center of the sphere).
Disk ( expression ) = { expression-list };
Creates a disk. When four expressions are provided on the right hand side (3
coordinates of the center and the radius), the disk is circular. A fifth expression
defines the radius along Y, leading to an ellipse. Disk is only available with the
OpenCASCADE kernel.
38 Gmsh 4.0
5.1.4 Volumes
Volume ( expression ) = { expression-list };
Creates a volume. The expression inside the parentheses is the volume’s tag;
the expression-list on the right hand side should contain the tags of all the
surface loops defining the volume. The first surface loop defines the exterior
boundary of the volume; all other surface loops define holes in the volume. A
surface loop defining a hole should not have any surfaces in common with the
exterior surface loop (in which case it is not a hole, and the two volumes should
be defined separately). Likewise, a surface loop defining a hole should not have
any surfaces in common with another surface loop defining a hole in the same
volume (in which case the two surface loops should be combined).
Sphere ( expression ) = { expression-list };
Creates a sphere, defined by the 3 coordinates of its center and a radius. Ad-
ditional expressions define 3 angle limits. Sphere is only available with the
OpenCASCADE kernel.
Box ( expression ) = { expression-list };
Creates a box, defined by the 3 coordinates of a point and the 3 extents. Box
is only available with the OpenCASCADE kernel.
Cylinder ( expression ) = { expression-list };
Creates a cylinder, defined by the 3 coordinates of the center of the first cir-
cular face, the 3 components of the vector defining its axis and its radius. An
Chapter 5: Geometry module 39
5.1.5 Extrusions
Curves, surfaces and volumes can also be created through extrusion of points, curves and
surfaces, respectively. Here is the syntax of the geometrical extrusion commands (go to
Section 6.3.2 [Structured grids], page 64, to see how these commands can be extended in
order to also extrude the mesh):
extrude:
extrude-list :
<Physical> Point | Curve | Surface { expression-list-or-all }; ...
As explained in Section 4.2.1 [Floating point expressions], page 21, extrude can be used in
an expression, in which case it returns a list of tags. By default, the list contains the “top”
of the extruded entity at index 0 and the extruded entity at index 1, followed by the “sides”
of the extruded entity at indices 2, 3, etc. For example:
Point(1) = {0,0,0};
Point(2) = {1,0,0};
Line(1) = {1, 2};
out[] = Extrude{0,1,0}{ Curve{1}; };
Printf("top curve = %g", out[0]);
Printf("surface = %g", out[1]);
Printf("side curves = %g and %g", out[2], out[3]);
This behaviour can be changed with the Geometry.ExtrudeReturnLateralEntities op-
tion (see Section B.2 [Geometry options list], page 184).
5.1.7 Transformations
Geometrical transformations can be applied to elementary entities, or to copies of elemen-
tary entities (using the Duplicata command: see below). The syntax of the transformation
commands is:
transform:
Dilate { { expression-list }, expression } { transform-list }
Scales all elementary entities in transform-list by a factor expression. The
expression-list should contain three expressions giving the X, Y, and Z coordi-
nates of the center of the homothetic transformation.
Dilate { { expression-list }, { expression, expression, expression } } {
transform-list }
Scales all elementary entities in transform-list using different factors along X,
Y and Z (the three expressions). The expression-list should contain three
expressions giving the X, Y, and Z coordinates of the center of the homoth-
etic transformation.
Rotate { { expression-list }, { expression-list }, expression } {
transform-list }
Rotates all elementary entities in transform-list by an angle of expression radi-
ans. The first expression-list should contain three expressions giving the X, Y
and Z direction of the rotation axis; the second expression-list should contain
three expressions giving the X, Y and Z components of any point on this axis.
Symmetry { expression-list } { transform-list }
Transforms all elementary entities symmetrically to a plane. The expression-list
should contain four expressions giving the coefficients of the plane’s equation.
Translate { expression-list } { transform-list }
Translates all elementary entities in transform-list. The expression-list should
contain three expressions giving the X, Y and Z components of the translation
vector.
Boundary { transform-list }
(Not a transformation per-se.) Returns the entities on the boundary of the ele-
mentary entities in transform-list, with signs indicating their orientation in the
Chapter 5: Geometry module 43
boundary. To get unsigned tags (e.g. to reuse the output in other commands),
apply the Abs function on the returned list.
CombinedBoundary { transform-list }
(Not a transformation per-se.) Returns the boundary of the elementary entities,
combined as if a single entity, in transform-list. Useful to compute the boundary
of a complex part.
PointsOf { transform-list }
(Not a transformation per-se.) Returns all the geometrical points on the bound-
ary of the elementary entities. Useful to compute the boundary of a complex
part.
with
transform-list :
<Physical> Point | Curve | Surface | Volume { expression-list-or-all }; ... |
Duplicata { <Physical> Point | Curve | Surface | Volume { expression-
list-or-all }; ... } |
transform
5.1.8 Miscellaneous
Here is a list of all other geometry commands currently available:
Coherence;
Removes all duplicate elementary geometrical entities (e.g., points having iden-
tical coordinates). Note that with the built-in geometry kernel Gmsh executes
the Coherence command automatically after each geometrical transformation,
unless Geometry.AutoCoherence is set to zero (see Section B.2 [Geometry op-
tions list], page 184). With the OpenCASCADE geoemtry kernel, Coherence
is simply a shortcut for a BooleanFragments operation on all entities.
< Recursive > Delete { <Physical> Point | Curve | Surface | Volume {
expression-list-or-all }; ... }
Deletes all elementary entities whose tags are given in expression-list-or-all. If
an entity is linked to another entity (for example, if a point is used as a control
point of a curve), Delete has no effect (the curve will have to be deleted before
the point can). The Recursive variant deletes the entities as well as all its
sub-entities of lower dimension.
< Recursive > Hide { <Physical> Point | Curve | Surface | Volume {
expression-list-or-all }; ... }
Hide the entities listed in expression-list-or-all, if General.VisibilityMode is
set to 0 or 1.
Hide { : }
Hide all entities, if General.VisibilityMode is set to 0 or 1.
< Recursive > Show { <Physical> Point | Curve | Surface | Volume {
expression-list-or-all }; ... }
Show the entities listed in expression-list-or-all, if General.VisibilityMode is
set to 0 or 1.
44 Gmsh 4.0
Show { : }
Show all entities, if General.VisibilityMode is set to 0 or 1.
6 Mesh module
Gmsh’s mesh module regroups several 1D, 2D and 3D meshing algorithms, all producing
grids conforming in the sense of finite elements (see Section 1.2 [Mesh], page 5):
• The 2D unstructured algorithms generate triangles or both triangles and quadrangles
(when Recombine Surface is used: see Section 6.3.3 [Miscellaneous mesh commands],
page 66). The 3D unstructured algorithms generate tetrahedra.
• The 2D structured algorithms (transfinite and extrusion) generate triangles by default,
but quadrangles can be obtained by using the Recombine commands (see Section 6.3.2
[Structured grids], page 64, and Section 6.3.3 [Miscellaneous mesh commands], page 66).
The 3D structured algorithms generate tetrahedra, hexahedra, prisms and pyramids,
depending on the type of the surface meshes they are based on.
All meshes can be subdivided to generate fully quadrangular or fully hexahedral meshes
with the Mesh.SubdivisionAlgorihm option (see Section B.3 [Mesh options list], page 192).
However, beware that the quality of subdivided elements initially generated with an un-
structured algorithm can be quite poor.
The purpose of physical entities is to assemble elementary entities into larger, possibly
overlapping groups, and to control the orientation of the elements in these groups when
they are save into a mesh file. The introduction of physical entities in large models usually
greatly facilitates the manipulation of the model (e.g., using ‘Tools->Visibility’ in the GUI)
and the interfacing with external solvers.
In the MSH file format (see Chapter 9 [File formats], page 107), if physical entities are
defined, the output mesh only contains those elements that belong to physical entities.
Other file formats each treat physical entities in slightly different ways, depending on their
capability to define groups.
Note that in some mesh file formats Gmsh reindexes the mesh nodes and elements so that
they are numbered in a continuous sequence in the output files. Note that the numbers
displayed on screen after mesh generation can thus differ from the ones saved in the mesh
files, depending on the format. To check the actual numbers saved in the output file just
load the file back using ‘File->Open’.
used, since the mesh used to define the field will be destroyed during the meshing
process).
(Note that you can also load a background mesh directly from the command line
using the -bgm option (see Section 3.3 [Command-line options], page 12), or in the
GUI by selecting ‘Apply as background mesh’ in the post-processing view option
menu.)
• A Box field specifies the size of the elements inside and outside of a parallelepipedic
region.
• A Threshold field specifies the size of the mesh according to the distance to some
geometrical entities. These entities can for example be geometry points and curves
specified by an Attractor field.
• A MathEval field specifies the size of the mesh using an explicit mathematical
function.
• A Min field specifies the size as the minimum of the sizes computed using other
fields
• ...
Fields are supported by all the algorithms except those based on Netgen. The list of
available fields with their options is given below.
The three aforementioned methods can be used simultaneously, in which case the smallest
element size is selected at any given point.
All element sizes are further constrained by the Mesh.CharacteristicLengthMin,
Mesh.CharacteristicLengthMax and Mesh.CharacteristicLengthFactor options (see
Section B.3 [Mesh options list], page 192)
Here are the mesh commands that are related to the specification of mesh element sizes:
Characteristic Length { expression-list } = expression ;
Modify the prescribed mesh element size of the points whose tags are listed in
expression-list. The new value is given by expression.
Field[expression ] = string ;
Create a new field (with tag expression), of type string.
Field[expression ].string = char-expression | expression | expression-list ;
Set the option string of the expression-th field.
Background Field = expression ;
Select the expression-th field as the one used to compute element sizes. Only
one background field can be given; if you want to combine several field, use the
Min or Max field (see below).
Here is the list of all available fields with their associated options:
Attractor
Compute the distance from the nearest node in a list. It can also be used to
compute the distance from curves, in which case each curve is replaced by NN-
odesByEdge equidistant nodes and the distance from those nodes is computed.
Options:
Chapter 6: Mesh module 49
EdgesList
Indices of curves in the geometric model
type: list
default value: {}
FacesList
Indices of surfaces in the geometric model (Warning, this feature is
still experimental. It might (read: will probably) give wrong results
for complex surfaces)
type: list
default value: {}
FieldX Id of the field to use as x coordinate.
type: integer
default value: -1
FieldY Id of the field to use as y coordinate.
type: integer
default value: -1
FieldZ Id of the field to use as z coordinate.
type: integer
default value: -1
NNodesByEdge
Number of nodes used to discretized each curve
type: integer
default value: 20
NodesList
Indices of nodes in the geometric model
type: list
default value: {}
AttractorAnisoCurve
Compute the distance from the nearest curve in a list. Then the mesh size
can be specified independently in the direction normal to the curve and in
the direction parallel to the curve (Each curve is replaced by NNodesByEdge
equidistant nodes and the distance from those nodes is computed.)
Options:
EdgesList
Indices of curves in the geometric model
type: list
default value: {}
NNodesByEdge
Number of nodes used to discretized each curve
type: integer
default value: 20
50 Gmsh 4.0
dMax Maxmium distance, above this distance from the curves, prescribe
the maximum mesh sizes.
type: float
default value: 0.5
dMin Minimum distance, below this distance from the curves, prescribe
the minimum mesh sizes.
type: float
default value: 0.1
lMaxNormal
Maximum mesh size in the direction normal to the closest curve.
type: float
default value: 0.5
lMaxTangent
Maximum mesh size in the direction tangeant to the closest curve.
type: float
default value: 0.5
lMinNormal
Minimum mesh size in the direction normal to the closest curve.
type: float
default value: 0.05
lMinTangent
Minimum mesh size in the direction tangeant to the closest curve.
type: float
default value: 0.5
Ball The value of this field is VIn inside a spherical ball, VOut outside. The ball is
defined by
Radius Radius
type: float
default value: 0
VIn Value inside the ball
type: float
default value: 0
VOut Value outside the ball
type: float
default value: 0
XCenter X coordinate of the ball center
type: float
default value: 0
Chapter 6: Mesh module 51
AnisoMax Threshold angle for creating a mesh fan in the boundary layer
type: float
default value: 10000000000
EdgesList
Indices of curves in the geometric model for which a boundary layer
is needed
type: list
default value: {}
FanNodesList
Indices of vertices in the geometric model for which a fan is created
type: list
default value: {}
IntersectMetrics
Intersect metrics of all faces
type: integer
default value: 0
NodesList
Indices of vertices in the geometric model for which a BL ends
type: list
default value: {}
Quads Generate recombined elements in the boundary layer
type: integer
default value: 0
hfar Element size far from the wall
type: float
default value: 1
hwall_n Mesh Size Normal to the The Wall
type: float
default value: 0.1
hwall_n_nodes
Mesh Size Normal to the The Wall at nodes (overwrite hwall n
when defined)
52 Gmsh 4.0
Curvature
Compute the curvature of Field[IField]:
F = div(norm(grad(Field[IField])))
Options:
Radius Radius
type: float
default value: 0
VIn Value inside the cylinder
type: float
default value: 0
VOut Value outside the cylinder
type: float
default value: 0
XAxis X component of the cylinder axis
type: float
default value: 0
XCenter X coordinate of the cylinder center
type: float
default value: 0
YAxis Y component of the cylinder axis
type: float
default value: 0
YCenter Y coordinate of the cylinder center
type: float
default value: 0
54 Gmsh 4.0
EdgesList
Indices of curves in the geometric model
type: list
default value: {}
FacesList
Indices of surfaces in the geometric model (Warning, this feature is
still experimental. It might (read: will probably) give wrong results
for complex surfaces)
type: list
default value: {}
FieldX Id of the field to use as x coordinate.
type: integer
default value: -1
FieldY Id of the field to use as y coordinate.
type: integer
default value: -1
FieldZ Id of the field to use as z coordinate.
type: integer
default value: -1
NNodesByEdge
Number of nodes used to discretized each curve
type: integer
default value: 20
NodesList
Indices of nodes in the geometric model
type: list
default value: {}
ExternalProcess
**This Field is experimental**
Call an external process that received coordinates triple (x,y,z) as binary double
precision numbers on stdin and is supposed to write the field value on stdout
Chapter 6: Mesh module 55
#include <fcntl.h>
int main(int argc, char **argv) {
double xyz[3];
setmode(fileno(stdin),O BINARY);
setmode(fileno(stdout),O BINARY);
while(read(fileno(stdin), &xyz, 3*sizeof(double)) == 3*sizeof(double)) {
if (xyz[0] != xyz[0])
break;
double f = f = 0.01 + 0.09 * xyz[1];
write(fileno(stdout), &f, sizeof(double));
}
}
Options:
CommandLine
Command line to launch.
type: string
default value: ""
Frustum This field is an extended cylinder with inner (i) and outer (o) radiuseson both
endpoints (1 and 2). Length scale is bilinearly interpolated betweenthese loca-
tions (inner and outer radiuses, endpoints 1 and 2)The field values for a point
P are given by : u = P1P.P1P2/||P1P2|| r = || P1P - u*P1P2 || Ri =
(1-u)*R1i + u*R2i Ro = (1-u)*R1o + u*R2o v = (r-Ri)/(Ro-Ri) lc = (1-v)*(
(1-u)*v1i + u*v2i ) + v*( (1-u)*v1o + u*v2o ) where (u,v) in [0,1]x[0,1]
Options:
IntersectAniso
Take the intersection of 2 anisotropic fields according to Alauzet.
Options:
FieldsList
Field indices
type: list
default value: {}
Laplacian
Compute finite difference the Laplacian of Field[IField]:
F = G(x+d,y,z) + G(x-d,y,z) +
G(x,y+d,z) + G(x,y-d,z) +
G(x,y,z+d) + G(x,y,z-d) - 6 * G(x,y,z),
F = Field[IField](atan(y/x), asin(z/sqrt(x^2+y^2+z^2))
Options:
FromStereo
if = 1, the mesh is in stereographic coordinates. xi = 2Rx/(R+z),
eta = 2Ry/(R+z)
type: integer
default value: 0
IField Index of the field to evaluate.
type: integer
default value: 1
RadiusStereo
radius of the sphere of the stereograpic coordinates
type: float
default value: 6371000
MathEval Evaluate a mathematical expression. The expression can contain x, y, z for
spatial coordinates, F0, F1, ... for field values, and and mathematical functions.
Chapter 6: Mesh module 59
Options:
FieldsList
Field indices
type: list
default value: {}
MaxEigenHessian
Compute the maximum eigenvalue of the Hessian matrix of Field[IField], with
the gradients evaluated by finite differences:
F = max(eig(grad(grad(Field[IField]))))
Options:
60 Gmsh 4.0
F = (G(x+delta,y,z) + G(x-delta,y,z) +
G(x,y+delta,z) + G(x,y-delta,z) +
G(x,y,z+delta) + G(x,y,z-delta) +
G(x,y,z)) / 7,
where G=Field[IField]
Options:
FieldsList
Field indices
type: list
default value: {}
MinAniso Take the intersection of a list of possibly anisotropic fields.
Options:
FieldsList
Field indices
type: list
default value: {}
Octree Pre compute another field on an octree to speed-up evalution
Options:
F = Field[IField](FX,FY,FZ)
See the MathEval Field help to get a description of valid FX, FY and FZ
expressions.
Options:
CropNegativeValues
return LC MAX instead of a negative value (this option is needed
for backward compatibility with the BackgroundMesh option
type: boolean
default value: 1
IView Post-processing view index
type: integer
default value: 0
ViewTag Post-processing view tag
type: integer
default value: -1
Restrict Restrict the application of a field to a given list of geometrical points, curves,
surfaces or volumes.
Options:
EdgesList
Curve indices
type: list
default value: {}
62 Gmsh 4.0
FacesList
Surface indices
type: list
default value: {}
RegionsList
Volume indices
type: list
default value: {}
VerticesList
Point indices
type: list
default value: {}
Structured
Linearly interpolate between data provided on a 3D rectangular structured grid.
Ox Oy Oz
Dx Dy Dz
nx ny nz
v(0,0,0) v(0,0,1) v(0,0,2) ...
v(0,1,0) v(0,1,1) v(0,1,2) ...
v(0,2,0) v(0,2,1) v(0,2,2) ...
... ... ...
v(1,0,0) ... ...
where O are the coordinates of the first node, D are the distances between nodes
in each direction, n are the numbers of nodes in each direction, and v are the
values on each node.
Options:
OutsideValue
Value of the field outside the grid (only used if the "SetOutside-
Value" option is true).
type: float
default value: 0
Chapter 6: Mesh module 63
SetOutsideValue
True to use the "OutsideValue" option. If False, the last values of
the grid are used.
type: boolean
default value: 0
TextFormat
True for ASCII input files, false for binary files (4 bite signed inte-
gers for n, double precision floating points for v, D and O)
type: boolean
default value: 0
Threshold
F = LCMin if Field[IField] <= DistMin,
F = LCMax if Field[IField] >= DistMax,
F = interpolation between LcMin and LcMax if DistMin < Field[IField] < Dist-
Max
Options:
DistMax Distance from entity after which element size will be LcMax
type: float
default value: 10
StopAtDistMax
True to not impose element size outside DistMax (i.e., F = a very
big value if Field[IField] > DistMax)
type: boolean
default value: 0
64 Gmsh 4.0
by a warning message sent for each instance; however, the mesh will still be
valid and conformal.
Both QuadTriNoNewVerts and QuadTriAddVerts can be used with the optional
RecombLaterals keyword. By default, the QuadTri algorithms will mesh any
free laterals as triangles, if possible. RecombLaterals forces any free laterals
to remain as quadrangles, if possible. Lateral surfaces between two QuadTri
regions will always be meshed as quadrangles.
Note that the QuadTri algorithms will handle all potential meshing conflicts
along the lateral surfaces of the extrusion. In other words, QuadTri will not
subdivide a lateral that must remain as quadrangles, nor will it leave a lateral
as quadrangles if it must be divided. The user should therefore feel free to mix
different types of neighboring regions with a QuadTri meshed region; the mesh
should work. However, be aware that the top surface of the QuadTri extrusion
will always be meshed as triangles, unless it is extruded back onto the original
source in a toroidal loop (a case which also works with QuadTri).
QuadTriNoNewVerts and QuadTriAddVerts may be used interchangeably, but
QuadTriAddVerts often gives better element quality.
If the user wishes to interface a structured extrusion to a tetrahedral volume
without modifying the original structured mesh, the user may create dedicated
interface volumes around the structured geometry and apply a QuadTri algo-
rithm to those volumes only.
Extrude { { expression-list }, { expression-list }, expression } {
extrude-list layers }
Extrudes both the geometry and the mesh using a rotation (see Section 5.1.5
[Extrusions], page 39). The layers option is defined as above.
Extrude { { expression-list }, { expression-list }, { expression-list },
expression } { extrude-list layers }
Extrudes both the geometry and the mesh using a combined translation and
rotation (see Section 5.1.5 [Extrusions], page 39). The layers option is defined
as above.
Extrude { Surface { expression-list }; layers < Using Index[expr ]; > < Using
View[expr ]; > < ScaleLastLayer; > }
Extrudes a boundary layer from the specified surfaces. If no view is speci-
fied, the boundary layer is created using gouraud-shaped (smoothed) normal
field. Specifying a boundary layer index allows to extrude several independent
boundary layers (with independent normal smoothing).
ScaleLastLayer scales the height of the last (top) layer of each normal’s extru-
sion by the average length of the edges in all the source elements that contain
the source node (actually, the average of the averages for each element–edges
actually touching the source node are counted twice). This allows the height
of the last layer to vary along with the size of the source elements in order to
achieve better element quality. For example, in a boundary layer extruded with
the Layers definition ’Layers{ {1,4,2}, {0.5, 0.6, 1.6} },’ a source node adjacent
to elements with an overall average edge length of 5.0 will extrude to have a
last layer height = (1.6-0.6) * 5.0 = 5.0.
66 Gmsh 4.0
6.3.3 Miscellaneous
Here is a list of all other mesh commands currently available:
Mesh expression ;
Generates expression-D mesh.
RefineMesh;
Refines the current mesh by splitting all elements. If Mesh.SecondOrderLinear
is set, the new nodes are inserted by linear interpolatinon. Otherwise they are
snapped on the actual geometry.
OptimizeMesh char-expression ;
Optimizes the current mesh with the given algorithm (currently "Gmsh" or
"Netgen").
Chapter 6: Mesh module 67
SetOrder expression ;
Changes the order of the elements in the current mesh.
PartitionMesh expression ;
Partitions the mesh into expression, using current partitioning options.
Coherence Mesh;
Removes all duplicate mesh nodes.
68 Gmsh 4.0
CreateTopology;
Creates a boundary representation from the mesh if the model does not have
one (e.g. when imported from mesh file formats with no BRep representation
of the underlying model).
CreateGeometry;
Creates a parametrization for curves and surfaces that do not have one (i.e.
discrete curves and surfaces represented solely by meshes, without an underlying
CAD description).
SetPartition expression { <Physical> Point | Curve | Surface | Volume {
expression-list-or-all }; ... }
Sets the partition tag of the mesh elements in the entities in expression-list to
expression.
< Recursive > Color color-expression { <Physical> Point | Curve | Surface |
Volume { expression-list-or-all }; ... }
Sets the mesh color of the entities in expression-list to color-expression.
< Recursive > Hide { <Physical> Point | Curve | Surface | Volume {
expression-list-or-all }; ... }
Hides the mesh of the entities in expression-list, if General.VisibilityMode
is set to 0 or 2.
Hide { : }
Hide the mesh of all entities, if General.VisibilityMode is set to 0 or 2.
Recombine Surface { expression-list-or-all } < = expression >;
Recombines the triangular meshes of the surfaces listed in expression-list into
mixed triangular/quadrangular meshes. The optional expression on the right
hand side specifies the maximum difference (in degrees) allowed between the
largest angle of a quadrangle and a right angle (a value of 0 would only accept
quadrangles with right angles; a value of 90 would allow degenerate quadrangles;
default value is 45).
MeshAlgorithm Surface { expression-list } = expression ;
Forces the meshing algorithm per surface.
Compound Curve | Surface { expression-list-or-all } ;
Treats the given entities as a single entity when meshing, i.e. perform cross-
patch meshing of the entities.
ReverseMesh Curve | Surface { expression-list-or-all } ;
Reverses the mesh of the given curve(s) or surface(s).
ReorientMesh Volume { expression-list } ;
Reorients the meshes of the bounding surfaces of the given volumes so that
the normals point outward to the volumes. Currently only available with the
OpenCASCADE kernel, as it relies on the STL triangulation.
Save char-expression ;
Saves the mesh in a file named char-expression, using the current Mesh.Format
(see Section B.3 [Mesh options list], page 192). If the path in char-expression
is not absolute, char-expression is appended to the path of the current file.
Chapter 6: Mesh module 69
7 Solver module
External solvers can be driven by Gmsh through the ONELAB http://www.onelab.info
interface. To add a new solver in the solver module, you need to specify its
name (Solver.Name0, Solver.Name1, etc.) and the path to the executable
(Solver.Executable0, Solver.Executable1, etc.); see Section B.4 [Solver options list],
page 209).
The client-server API for the solver interface is defined in the onelab.h header.
See utils/solvers/c++/solver.cpp for a simple example on how to use the ONELAB
programming interface. See the sources of GetDP (http://getdp.info for a more
comprehensive example.
8 Post-processing module
Gmsh’s post-processing module can handle multiple scalar, vector or tensor datasets along
with the geometry and the mesh. The datasets can be given in several formats: in human-
readable “parsed” format (these are just part of a standard input script, but are usually
put in separate files with a ‘.pos’ extension), in native MSH files (ASCII or binary files
with ‘.msh’ extensions: see Chapter 9 [File formats], page 107), or in standard third-party
formats (like MED: http://www.code-aster.org/outils/med/).
Once loaded into Gmsh, scalar fields can be displayed as iso-value curves and surfaces or
color maps, whereas vector fields can be represented either by three-dimensional arrows
or by displacement maps. (Tensor fields are currently displayed as Von-Mises effective
stresses, min/max eigenvalues, eigenvectors, ellipsis or ellipsoid. To display other (combi-
nations of) components, you can use the Force scalar or Force vector options, or use
Plugin(MathEval): see Section 8.2 [Post-processing plugins], page 78.)
In Gmsh’s jargon, each dataset is called a “view”. Each view is given a name, and can
be manipulated either individually (each view has its own button in the GUI and can be
referred to by its index in a script) or globally (see the PostProcessing.Link option in
Section B.5 [Post-processing options list], page 214).
By default, Gmsh treats all post-processing views as three-dimensional plots, i.e., draws
the scalar, vector and tensor primitives (points, curves, triangles, tetrahedra, etc.) in 3D
space. But Gmsh can also represent each post-processing view containing scalar points as
two-dimensional (“X-Y”) plots, either space- or time-oriented:
• in a ‘2D space’ plot, the scalar points are taken in the same order as they are defined
in the post-processing view: the abscissa of the 2D graph is the curvilinear abscissa
of the curve defined by the point series, and only one curve is drawn using the values
associated with the points. If several time steps are available, each time step generates
a new curve;
• in a ‘2D time’ plot, one curve is drawn for each scalar point in the view and the abscissa
is the time step.
Although visualization is usually mostly an interactive task, Gmsh exposes all the post-
processing commands and options to the user in its scripting language to permit a complete
automation of the post-processing process (see e.g., Section A.8 [t8.geo], page 141, and
Section A.9 [t9.geo], page 144).
The two following sections summarize all available post-processing commands and options.
Most options apply to both 2D and 3D plots (colormaps, point/line sizes, interval types,
time step selection, etc.), but some are peculiar to 3D (lightning, element selection, etc.) or
2D plots (abscissa labels, etc.). Note that 2D plots can be positioned explicitly inside the
graphical window, or be automatically positioned in order to avoid overlaps.
Sample post-processing files in human-readable “parsed” format and in the native MSH
file format are available in the tutorial directory of Gmsh’s distribution (‘.pos’ and ‘.msh’
files). The “parsed” format is defined in the next section (cf. the View command); the MSH
format is defined in Chapter 9 [File formats], page 107.
74 Gmsh 4.0
Delete View[expression ];
Deletes (removes) the expression-th post-processing view. Note that post-
processing view indices start at 0.
Delete Empty Views;
Deletes (removes) all the empty post-processing views.
Background Mesh View[expression ];
Applies the expression-th post-processing view as the current background mesh.
Note that post-processing view indices start at 0.
Plugin (string ) . Run;
Executes the plugin string. The list of default plugins is given in Section 8.2
[Post-processing plugins], page 78.
Plugin (string ) . string = expression | char-expression ;
Sets an option for a given plugin. See Section 8.2 [Post-processing plugins],
page 78, for a list of default plugins and Section A.9 [t9.geo], page 144, for
some examples.
Save View[expression ] char-expression ;
Saves the the expression-th post-processing view in a file named char-expression.
If the path in char-expression is not absolute, char-expression is appended to
the path of the current file.
View "string " { string < ( expression-list ) > { expression-list }; ... };
Creates a new post-processing view, named "string ". This is an easy and quite
powerful way to import post-processing data: all the values are expressions,
you can embed datasets directly into your geometrical descriptions (see, e.g.,
Section A.4 [t4.geo], page 133), the data can be easily generated “on-the-fly”
(there is no header containing a priori information on the size of the dataset).
The syntax is also very permissive, which makes it ideal for testing purposes.
However this “parsed format” is read by Gmsh’s script parser, which makes
it inefficient if there are many elements in the dataset. Also, there is no con-
nectivity information in parsed views and all the elements are independent (all
fields can be discontinuous), so a lot of information can be duplicated. For
large datasets, you should thus use the mesh-based post-processing file format
described in Chapter 9 [File formats], page 107, or use one of the standard
formats like MED.
More explicitly, the syntax for a parsed View is the following
View "string " {
type ( list-of-coords ) { list-of-values }; ...
< TIME { expression-list }; >
< INTERPOLATION_SCHEME { val-coef-matrix } { val-exp-matrix }
< { geo-coef-matrix } { geo-exp-matrix } > ; >
};
where the 47 object types that can be displayed are:
type #list-of-coords #list-of-values
--------------------------------------------------------------------
Scalar point SP 3 1 * nb-time-steps
76 Gmsh 4.0
lower bits give the font size, whose eight next bits select the font (the index
corresponds to the position in the font menu in the GUI), and whose eight next
bits define the text alignment (0=bottom-left, 1=bottom-center, 2=bottom-
right, 3=top-left, 4=top-center, 5=top-right, 6=center-left, 7=center-center,
8=center-right).
For the 3D text objects, the three first expressions in list-of-coords give the XYZ
position of the string in model (real world) coordinates. The fourth expression
has the same meaning as the third expression in 2D text objects.
For both 2D and 3D text objects, the list-of-values can contain an arbitrary
number of char-expressions. If the char-expression starts with file://, the
remainder of the string is interpreted as the name of an image file, and the
image is displayed instead of the string. A format string in the form @wxh or
@wxh,wx,wy,wz,hx,hy,hz, where w and h are the width and height (in model
coordinates for T3 or in pixels for T2) of the image, wx,wy,wz is the direction
of the bottom edge of the image and hx,hy,hz is the direction of the left edge
of the image.
The optional TIME list can contain a list of expressions giving the value of the
time (or any other variable) for which an evolution was saved.
The optional INTERPOLATION_SCHEME lists can contain the interpolation matri-
ces used for high-order adaptive visualization.
Let us assume that the approximation of the view’s value over an element
is written as a linear combination of d basis functions f [i], i=0, ..., d-1 (the
coefficients being stored in list-of-values). Defining f [i] = Sum(j=0, ..., d-1)
F[i][j] p[j], with p[j] = u^P[j][0] v^P[j][1] w^P[j][2] (u, v and w being the
coordinates in the element’s parameter space), then val-coef-matrix denotes
the d x d matrix F and val-exp-matrix denotes the d x 3 matrix P.
In the same way, let us also assume that the coordinates x, y and z of the
element are obtained through a geometrical mapping from parameter space as
a linear combination of m basis functions g[i], i=0, ..., m-1 (the coefficients
being stored in list-of-coords). Defining g[i] = Sum(j=0, ..., m-1) G[i][j] q[j],
with q[j] = u^Q[j][0] v^Q[j][1] w^Q[j][2], then geo-coef-matrix denotes the m
x m matrix G and geo-exp-matrix denotes the m x 3 matrix Q.
Here are for example the interpolation matrices for a first order quadrangle:
INTERPOLATION_SCHEME
{
{1/4,-1/4, 1/4,-1/4},
{1/4, 1/4,-1/4,-1/4},
{1/4, 1/4, 1/4, 1/4},
{1/4,-1/4,-1/4, 1/4}
}
{
{0, 0, 0},
{1, 0, 0},
{0, 1, 0},
{1, 1, 0}
};
78 Gmsh 4.0
Plugin(AnalyseCurvedMesh)
Plugin(AnalyseCurvedMesh) analyse all elements of a given dimension. Accord-
ing to what is asked, it computes the minimum of the Jacobian determinant
(J), the IGE quality measure (Inverse Gradient Error) and/or the ICN quality
measure (Inverse Condition Number). Statistics are printed and, if asked, a
Pview is created for each measure. The plugin hides elements for which the
measure mu > ’Hiding threshold’, where mu is the ICN measure if asked other-
wise the IGE measure if asked otherwise the Jacobian determinant.
J is faster to compute but gives information only on validity while the other
measure gives also information on quality.
The IGE measure is related to the error on the gradient of the finite element
solution. It is the scaled Jacobian for quads and hexes and a new measure for
triangles and tetrahedra.
The ICN measure is related to the condition number of the stiffness matrix.
(See article "Efficient computation of the minimum of shape quality measures
on curvilinear finite elements" for details.)
Parameters:
- JacobianDeterminant = {0, 1}
- IGEMeasure = {0, 1}
- ICNMeasure = {0, 1}
- HidingThreshold = [0, 1]: Hides all element for which min(mu) is strictly
greater than the threshold, where mu is the ICN if ICN measure == 1, oth-
erwise mu is the IGE it IGE measure == 1, otherwise mu is the Jacobian
determinant.
If threshold == 0, hides all elements except invalid.
Plugin(CurvedBndDist)
Plugin(CurvedBndDist) ...
Plugin(CutBox)
Plugin(CutBox) cuts the view ‘View’ with a rectangular box defined by the
4 points (‘X0’,‘Y0’,‘Z0’) (origin), (‘X1’,‘Y1’,‘Z1’) (axis of U), (‘X2’,‘Y2’,‘Z2’)
(axis of V) and (‘X3’,‘Y3’,‘Z3’) (axis of W).
If ‘ConnectPoints’ is zero, the plugin creates points; otherwise, the plugin gen-
erates hexahedra, quadrangles, lines or points depending on the values of ‘Num-
PointsU’, ‘NumPointsV’ and ‘NumPointsW’.
If ‘Boundary’ is zero, the plugin interpolates the view inside the box; otherwise
the plugin interpolates the view at its boundary.
The number of points along U and V is set with the options ‘NumPointsU’ and
‘NumPointsV’.
If ‘ConnectPoints’ is zero, the plugin creates points; otherwise, the plugin gen-
erates quadrangles, lines or points depending on the values of ‘NumPointsU’
and ‘NumPointsV’.
If ‘Split’ is nonzero, the plugin splits the meshalong the edges of the cut elements
Chapter 8: Post-processing module 83
If ‘ExtractVolume’ is nonzero, the plugin extracts the elements inside (if ‘Ex-
tractVolume’ < 0) or outside (if ‘ExtractVolume’ > 0) the sphere.
Plugin(DiscretizationError)
Plugin(DiscretizationError) computes the error between the mesh and the ge-
ometry. It does so by supersampling the elements and computing the distance
between the supersampled points dans their projection on the geometry. Nu-
meric options:
SuperSamplingNodes
Default value: 10
Plugin(Distance)
Plugin(Distance) computes distances to physical entities in a mesh.
Min Scale and max Scale, scale the distance function. If min Scale<0 and max
Scale<0, then no scaling is applied to the distance function.
Plugin(Distance) creates a new distance view and also saves the view in the
fileName.pos file. String options:
Filename Default value: "distance.pos"
Numeric options:
PhysPoint
Default value: 0
PhysLine Default value: 0
PhysSurface
Default value: 0
Computation
Default value: -1
MinScale Default value: -1
MaxScale Default value: -1
Orthogonal
Default value: -1
Plugin(Divergence)
Plugin(Divergence) computes the divergence of the field in the view ‘View’.
‘Thickness’ is the thickness of the flat quadrangles. Set a value different to zero
can be helpful to check the connectivity.
‘Prefix’ is the prefix of the name of physicals containing the new embedded. All
physicals containing embedded lines are replaced by physicals containing the
corresponding joint elements. String options:
Prefix Default value: "FAMI_"
Numeric options:
SurfaceTag
Default value: 1
Thickness
Default value: 0
Plugin(FieldFromAmplitudePhase)
Plugin(FieldFromAmplitudePhase) builds a complex field ’u’ from amplitude
’a’ (complex) and phase ’phi’ given in two different ’Views’ u = a * exp(k*phi),
with k the wavenumber.
Plugin(GaussPoints)
Given an input mesh, Plugin(GaussPoints) creates a view containing the Gauss
points for a given polynomial ‘Order’.
If ‘PhysicalGroup’ is nonzero, the plugin only creates points for the elements
belonging to the group. Numeric options:
Order Default value: 0
Dimension
Default value: 2
PhysicalGroup
Default value: 0
Plugin(Gradient)
Plugin(Gradient) computes the gradient of the field in the view ‘View’.
Define physical groups in order to specify the computation domain and the
relative subdomain. Otherwise the whole mesh is the domain and the relative
subdomain is empty.
Plugin(HomologyPostProcessing)
Plugin(HomologyPostProcessing) operates on representative basis chains of ho-
mology and cohomology spaces. Functionality:
Options:
’PhysicalGroupsToTraceResults’: Trace the resulting (co)chains to the given
physical groups.
’PhysicalGroupsToProjectResults’: Project the resulting (co)chains to the com-
plement of the given physical groups.
’NameForResultChains’: Post-processing view name prefix for the results.
’ApplyBoundaryOperatorToResults’: Apply boundary operator to the result-
ing chains.
String options:
TransformationMatrix
Default value: "1, 0; 0, 1"
PhysicalGroupsOfOperatedChains
Default value: "1, 2"
PhysicalGroupsOfOperatedChains2
Default value: ""
PhysicalGroupsToTraceResults
Default value: ""
PhysicalGroupsToProjectResults
Default value: ""
NameForResultChains
Default value: "c"
Numeric options:
ApplyBoundaryOperatorToResults
Default value: 0
Chapter 8: Post-processing module 91
Plugin(Integrate)
Plugin(Integrate) integrates a scalar field over all the elements of the view
‘View’ (if ‘Dimension’ < 0), or over all elements of the prescribed dimension (if
‘Dimension’ > 0). If the field is a vector field,the circulation/flux of the field
over line/surface elements is calculated.
If ‘OverTime’ = i > -1 , the plugin integrates the scalar view over time instead
of over space, starting at iteration i.If ‘Visible’ = 1, the plugin only integrates
overvisible entities.
If ‘OtherTimeStep’ < 0, the plugin uses, for each time step in ‘View’, the corre-
sponding time step in ‘OtherView’. If ‘OtherView’ < 0, the plugin uses ‘View’
as the value source.
OtherTimeStep
Default value: -1
OtherView
Default value: -1
Plugin(Lambda2)
Plugin(Lambda2) computes the eigenvalues Lambda(1,2,3) of the tensor (S ik
S kj + Om ik Om kj), where S ij = 0.5 (ui,j + uj,i) and Om ij = 0.5 (ui,j - uj,i)
are respectively the symmetric and antisymmetric parts of the velocity gradient
tensor.
If ‘View’ contains tensor elements, the plugin directly uses the tensors as the
values of the velocity gradient tensor; if ‘View’ contains vector elements, the
plugin uses them as the velocities from which to derive the velocity gradient
tensor.
In addition to the usual mathematical functions (Exp, Log, Sqrt, Sin, Cos,
Fabs, etc.) and operators (+, -, *, /, ^), all expressions can contain:
- the symbols v0, v1, v2, ..., vn, which represent the n components in ‘View’;
- the symbols w0, w1, w2, ..., wn, which represent the n components of
‘OtherView’, at time step ‘OtherTimeStep’;
If ‘TimeStep’ < 0, the plugin extracts data from all the time steps in the view.
If ‘View’ < 0, the plugin is run on the current view. If ‘OverTime’ = 1, the
plugin calculates the min/max over space and time. If ‘Argument’ = 1, the
plugin calculates the min/max and the argmin/argmax. If ‘Visible’ = 1, the
plugin is only applied to visible entities.
- the usual mathematical functions (Log, Sqrt, Sin, Cos, Fabs, ...) and operators
(+, -, *, /, ^);
- the symbols Time and TimeStep, to retrieve the current time and time step
values;
- the symbols v0, v1, v2, ..., v8, to retrieve each component of the field in ‘View’
at the ‘TimeStep’-th time step;
- the symbols w0, w1, w2, ..., w8, to retrieve each component of the field in
‘OtherView’ at the ‘OtherTimeStep’-th time step. If ‘OtherView’ and ‘View’ are
based on different spatial grids, or if their data types are different, ‘OtherView’
is interpolated onto ‘View’.
If ‘TimeStep’ < 0, the plugin automatically loops over all the time steps in
‘View’ and evaluates the expressions for each one.
Expression7
Default value: ""
Expression8
Default value: ""
Numeric options:
TimeStep Default value: -1
View Default value: -1
OtherTimeStep
Default value: -1
OtherView
Default value: -1
ForceInterpolation
Default value: 0
Plugin(ModulusPhase)
Plugin(ModulusPhase) interprets the time steps ‘realPart’ and ‘imaginaryPart’
in the view ‘View’ as the real and imaginary parts of a complex field and replaces
them with their corresponding modulus and phase.
Parameters: the wavenumber, the angular discretisation (phi in [0, 2*Pi] and
theta in [0, Pi]) of the far field sphere and the indices of the views containing the
complex-valued E and H fields. If ‘Normalize’ is set, the far field is normalized
to 1. If ‘dB’ is set, the far field is computed in dB. If ‘NegativeTime’ is set,
E and H are assumed to have exp(-iwt) time dependency; otherwise they are
assume to have exp(+iwt) time dependency. If ‘MatlabOutputFile’ is given the
raw far field data is also exported in Matlab format.
Wavenumber
Default value: 1
PhiStart Default value: 0
PhiEnd Default value: 6.28319
NumPointsPhi
Default value: 60
ThetaStart
Default value: 0
ThetaEnd Default value: 3.14159
NumPointsTheta
Default value: 30
EView Default value: 0
HView Default value: 1
Normalize
Default value: 1
dB Default value: 1
NegativeTime
Default value: 0
RFar Default value: 0
Plugin(NearestNeighbor)
Plugin(NearestNeighbor) computes the distance from each point in ‘View’ to
its nearest neighbor.
If ‘ViewTag’ is positive, force that tag for the created view. String options:
Type Default value: "NodeData"
Numeric options:
NumComp Default value: 1
ViewTag Default value: -1
Plugin(Particles)
Plugin(Particles) computes the trajectory of particules in the force field given
by the ‘TimeStep’-th time step of a vector view ‘View’.
98 Gmsh 4.0
The number of particles along U and V that are to be transported is set with
the options ‘NumPointsU’ and ‘NumPointsV’. The equation
is then solved with the initial conditions X(t=0) chosen as the grid,
dX/dt(t=0)=0, and with F interpolated from the vector view.
Time stepping is done using a Newmark scheme with step size ‘DT’ and
‘MaxIter’ maximum number of iterations.
Plugin(Probe)
Plugin(Probe) gets the value of the view ‘View’ at the point (‘X’,‘Y’,‘Z’).
NameNewView
Default value: "NewView"
Numeric options:
NumberOfComponents
Default value: 9
View0 Default value: -1
View1 Default value: -1
View2 Default value: -1
View3 Default value: -1
View4 Default value: -1
View5 Default value: -1
View6 Default value: -1
View7 Default value: -1
View8 Default value: -1
Plugin(Scal2Vec)
Plugin(Scal2Vec) converts the scalar fields into a vectorial field. The new view
’NameNewView’ contains it. If the number of a view is -1, the value of the
corresponding component of the vector field is 0. String options:
NameNewView
Default value: "NewView"
Numeric options:
ViewX Default value: -1
ViewY Default value: -1
ViewZ Default value: -1
Plugin(ShowNeighborElements)
Plugin(ShowNeighborElements) allows to set visible some given elements and a
layer of elements around them, the other being set invisible. Numeric options:
NumLayers
Default value: 1
Element1 Default value: 0
Element2 Default value: 0
Element3 Default value: 0
Element4 Default value: 0
Element5 Default value: 0
Chapter 8: Post-processing module 101
Plugin(SimplePartition)
Plugin(SimplePartition) partitions the current mesh into ‘NumSlices’ slices,
along the X-, Y- or Z-axis depending on the value of ‘Direction’ (0,1,2). The
plugin creates partition topology if ‘CreateTopology’ is set. String options:
Mapping Default value: "t"
Numeric options:
NumSlices
Default value: 4
Direction
Default value: 0
CreateTopology
Default value: 1
Plugin(Skin)
Plugin(Skin) extracts the boundary (skin) of the current mesh (if ‘FromMesh’
= 1), or from the the view ‘View’ (in which case it creates a new view). If
‘View’ < 0 and ‘FromMesh’ = 0, the plugin is run on the current view.
If ‘Visible’ is set, the plugin only extracts the skin of visible entities. Numeric
options:
Visible Default value: 1
FromMesh Default value: 0
View Default value: -1
Plugin(Smooth)
Plugin(Smooth) averages the values at the nodes of the view ‘View’.
Instead of elevating the nodes along the X, Y and Z axes as with the
View[‘View’].RaiseX, View[‘View’].RaiseY and View[‘View’].RaiseZ options,
the raise is applied along the radius of a sphere centered at (‘Xc’, ‘Yc’, ‘Zc’).
Xc Default value: 0
Yc Default value: 0
Zc Default value: 0
Raise Default value: 1
Offset Default value: 0
TimeStep Default value: 0
View Default value: -1
Plugin(StreamLines)
Plugin(StreamLines) computes stream lines from the ‘TimeStep’-th time step
of a vector view ‘View’ and optionally interpolates the scalar view ‘OtherView’
on the resulting stream lines.
The plugin takes as input a grid defined by the 3 points (‘X0’,‘Y0’,‘Z0’) (origin),
(‘X1’,‘Y1’,‘Z1’) (axis of U) and (‘X2’,‘Y2’,‘Z2’) (axis of V).
The number of points along U and V that are to be transported is set with the
options ‘NumPointsU’ and ‘NumPointsV’. The equation
dX(t)/dt = V(x,y,z)
is then solved with the initial condition X(t=0) chosen as the grid and with
V(x,y,z) interpolated on the vector view.
The time stepping scheme is a RK44 with step size ‘DT’ and ‘MaxIter’ maxi-
mum number of iterations.
If ‘TimeStep’ < 0, the plugin tries to compute streamlines of the unsteady flow.
Plugin(StreamLines) creates one new view. This view contains multi-step vec-
tor points if ‘OtherView’ < 0, or single-step scalar lines if ‘OtherView’ >= 0.
Numeric options:
X0 Default value: 0
Y0 Default value: 0
Z0 Default value: 0
X1 Default value: 1
Y1 Default value: 0
Z1 Default value: 0
X2 Default value: 0
Chapter 8: Post-processing module 103
Y2 Default value: 1
Z2 Default value: 0
NumPointsU
Default value: 10
NumPointsV
Default value: 1
DT Default value: 0.1
MaxIter Default value: 100
TimeStep Default value: 0
View Default value: -1
OtherView
Default value: -1
Plugin(Summation)
Plugin(Summation) sums every time steps of ’Reference View’ and (every)
’Other View X’and store the result in a new view.
If ’View 0’ < 0 then the current view is selected.
If ’View 1...8’ < 0 then this view is skipped.
Views can have diffrent number of time steps
Warning: the Plugin assume that every views sharethe same mesh and that
meshes do not move between time steps! String options:
Resuling View Name
Default value: "default"
Numeric options:
View 0 Default value: -1
View 1 Default value: -1
View 2 Default value: -1
View 3 Default value: -1
View 4 Default value: -1
View 5 Default value: -1
View 6 Default value: -1
View 7 Default value: -1
Plugin(Tetrahedralize)
Plugin(Tetrahedralize) tetrahedralizes the points in the view ‘View’.
Plugin(ThinLayerFixMesh)
Fix the mesh in thin parts
Plugin(Transform)
Plugin(Transform) transforms the homogeneous node coordinates (x,y,z,1) of
the elements in the view ‘View’ by the matrix
String options:
SeedsFile
Default value: "seeds.txt"
Numeric options:
ComputeBestSeeds
Default value: 0
ComputeMicrostructure
Default value: 1
Plugin(Warp)
Plugin(Warp) transforms the elements in the view ‘View’ by adding to their
node coordinates the vector field stored in the ‘TimeStep’-th time step of the
view ‘OtherView’, scaled by ‘Factor’.
If ‘OtherView’ < 0, the vector field is taken as the field of surface normals
multiplied by the ‘TimeStep’ value in ‘View’. (The smoothing of the surface
normals is controlled by the ‘SmoothingAngle’ parameter.)
The list of all post-processing and view options is given in Section B.5 [Post-processing
options list], page 214. See Section A.8 [t8.geo], page 141, and Section A.9 [t9.geo], page 144,
for some examples.
Chapter 9: File formats 107
9 File formats
This chapter describes Gmsh’s native “MSH” file format, used to store meshes and associ-
ated post-processing datasets. The MSH format exists in two flavors: ASCII and binary.
The format has a version number that is independent of Gmsh’s main version number.
(Remember that for small post-processing datasets you can also use human-readable
“parsed” post-processing views, as described in Section 8.1 [Post-processing commands],
page 74. Such “parsed” views do not require an underlying mesh, and can therefore be
easier to use in some cases.)
$Entities
numPoints(unsigned long) numCurves(unsigned long)
numSurfaces(unsigned long) numVolumes(unsigned long)
// points
tag(int) boxMinX(double) boxMinY(double) boxMinZ(double)
boxMaxX(double) boxMaxY(double) boxMaxZ(double)
108 Gmsh 4.0
<$PartitionedEntities>
numPartitions(int)
numGhostEntities(int)
ghostTag(int) ghostPart(int)
...
numPoints(unsigned long) numCurves(unsigned long)
numSurfaces(unsigned long) numVolumes(unsigned long)
// points
tag(int) parentDim(int) parentTag(int) numPartitions(int) partitionTag[...](int)
boxMinX(double) boxMinY(double) boxMinZ(double)
boxMaxX(double) boxMaxY(double) boxMaxZ(double)
numPhyiscals(unsigned long) physicalTag[...](int)
...
// curves
tag(int) parentDim(int) parentTag(int) numPartitions(int) partitionTag[...](int)
boxMinX(double) boxMinY(double) boxMinZ(double)
boxMaxX(double) boxMaxY(double) boxMaxZ(double)
numPhysicals(unsigned long) physicalTag[...](int)
numBREPVert(unsigned long) tagBREPVert[...](int)
...
// surfaces
tag(int) parentDim(int) parentTag(int) numPartitions(int) partitionTag[...](int)
boxMinX(double) boxMinY(double) boxMinZ(double)
boxMaxX(double) boxMaxY(double) boxMaxZ(double)
numPhysicals(unsigned long) physicalTag[...](int)
Chapter 9: File formats 109
$Nodes
numEntityBlocks(unsigned long) numNodes(unsigned long)
tagEntity(int) dimEntity(int) typeNode(int) numNodes(unsigned long)
tag(int) x(double) y(double) z(double)
...
...
$EndNodes
$Elements
numEntityBlocks(unsigned long) numElements(unsigned long)
tagEntity(int) dimEntity(int) typeEle(int) numElements(unsigned long)
tag(int) numVert[...](int)
...
...
$EndElements
<$GhostElements>
numGhostElement(int)
elementTag(int) partition(int) GhostCellOwner(int) GhostCellOwnerPartition(int) ...
<$EndGhostElements>
<$NodeData>
numStringTags(int)
stringTag(string) ...
numRealTags(int)
realTag(double) ...
110 Gmsh 4.0
numIntegerTags(int)
integerTag(int) ...
nodeNumber(int) value(double) ...
<$EndNodeData>
<$ElementData>
numStringTags(int)
stringTag(string) ...
numRealTags(int)
realTag(double) ...
numIntegerTags(int)
integerTag(int) ...
elementNumber(int) value(double) ...
<$EndElementData>
<$ElementNodeData>
numStringTags(int)
stringTag(string) ...
numRealTags(int)
realTag(double) ...
numIntegerTags(int)
integerTag(int) ...
elementNumber(int) numNodesPerElement(int) value(double) ...
<$EndElementNodeData>
<$InterpolationScheme>
name(string)
numElementTopologies(int)
elementTopology
numInterpolationMatrices(int)
numRows(int) numColumns(int) value(double) ...
<$EndInterpolationScheme>
typeEle is e.g.:
1 2-node line.
2 3-node triangle.
3 4-node quadrangle.
4 4-node tetrahedron.
5 8-node hexahedron.
6 6-node prism.
7 5-node pyramid.
8 3-node second order line (2 nodes associated with the vertices and 1 with the
edge).
Chapter 9: File formats 111
9 6-node second order triangle (3 nodes associated with the vertices and 3 with
the edges).
10 9-node second order quadrangle (4 nodes associated with the vertices, 4 with
the edges and 1 with the face).
11 10-node second order tetrahedron (4 nodes associated with the vertices and 6
with the edges).
12 27-node second order hexahedron (8 nodes associated with the vertices, 12 with
the edges, 6 with the faces and 1 with the volume).
13 18-node second order prism (6 nodes associated with the vertices, 9 with the
edges and 3 with the quadrangular faces).
14 14-node second order pyramid (5 nodes associated with the vertices, 8 with the
edges and 1 with the quadrangular face).
15 1-node point.
16 8-node second order quadrangle (4 nodes associated with the vertices and 4
with the edges).
17 20-node second order hexahedron (8 nodes associated with the vertices and 12
with the edges).
18 15-node second order prism (6 nodes associated with the vertices and 9 with
the edges).
19 13-node second order pyramid (5 nodes associated with the vertices and 8 with
the edges).
20 9-node third order incomplete triangle (3 nodes associated with the vertices, 6
with the edges)
21 10-node third order triangle (3 nodes associated with the vertices, 6 with the
edges, 1 with the face)
22 12-node fourth order incomplete triangle (3 nodes associated with the vertices,
9 with the edges)
23 15-node fourth order triangle (3 nodes associated with the vertices, 9 with the
edges, 3 with the face)
24 15-node fifth order incomplete triangle (3 nodes associated with the vertices,
12 with the edges)
25 21-node fifth order complete triangle (3 nodes associated with the vertices, 12
with the edges, 6 with the face)
26 4-node third order edge (2 nodes associated with the vertices, 2 internal to the
edge)
27 5-node fourth order edge (2 nodes associated with the vertices, 3 internal to the
edge)
28 6-node fifth order edge (2 nodes associated with the vertices, 4 internal to the
edge)
112 Gmsh 4.0
29 20-node third order tetrahedron (4 nodes associated with the vertices, 12 with
the edges, 4 with the faces)
30 35-node fourth order tetrahedron (4 nodes associated with the vertices, 18 with
the edges, 12 with the faces, 1 in the volume)
31 56-node fifth order tetrahedron (4 nodes associated with the vertices, 24 with
the edges, 24 with the faces, 4 in the volume)
92 64-node third order hexahedron (8 nodes associated with the vertices, 24 with
the edges, 24 with the faces, 8 in the volume)
93 125-node fourth order hexahedron (8 nodes associated with the vertices, 36 with
the edges, 54 with the faces, 27 in the volume)
The post-processing sections are identical to the ones in the version 2 file format (see
below). These sections will be reworked in a future minor revision of the version 4 format
(e.g. version 4.1 or 4.2).
v
^ 2
| | \
2 2 2 9 8
|‘\ |‘\ | \ | \
| ‘\ | ‘\ 7 6 10 (14) 7
| ‘\ 5 ‘4 | \ | \
| ‘\ | ‘\ 8 (9) 5 11 (12) (13) 6
| ‘\ | ‘\ | \ | \
0----------1 --> u 0-----3----1 0---3---4---1 0---3---4---5---1
Chapter 9: File formats 113
v
^
|
3-----------2 3-----6-----2 3-----6-----2
| | | | | | |
| | | | | | |
| +---- | --> u 7 5 7 8 5
| | | | | |
| | | | | |
0-----------1 0-----4-----1 0-----4-----1
Tetrahedron: Tetrahedron10:
v
.
,/
/
2 2
,/|‘\ ,/|‘\
,/ | ‘\ ,/ | ‘\
,/ ’. ‘\ ,6 ’. ‘5
,/ | ‘\ ,/ 8 ‘\
,/ | ‘\ ,/ | ‘\
0-----------’.--------1 --> u 0--------4--’.--------1
‘\. | ,/ ‘\. | ,/
‘\. | ,/ ‘\. | ,9
‘\. ’. ,/ ‘7. ’. ,/
‘\. |/ ‘\. |/
‘3 ‘3
‘\.
‘ w
v
3----------2 3----13----2 3----13----2
|\ ^ |\ |\ |\ |\ |\
| \ | | \ | 15 | 14 |15 24 | 14
| \ | | \ 9 \ 11 \ 9 \ 20 11 \
| 7------+---6 | 7----19+---6 | 7----19+---6
| | +-- |-- | -> u | | | | |22 | 26 | 23|
0---+---\--1 | 0---+-8----1 | 0---+-8----1 |
\ | \ \ | \ 17 \ 18 \ 17 25 \ 18
\ | \ \ | 10 | 12| 10 | 21 12|
\| w \| \| \| \| \|
4----------5 4----16----5 4----16----5
114 Gmsh 4.0
w
^
|
3 3 3
,/|‘\ ,/|‘\ ,/|‘\
,/ | ‘\ 12 | 13 12 | 13
,/ | ‘\ ,/ | ‘\ ,/ | ‘\
4------+------5 4------14-----5 4------14-----5
| | | | 8 | | 8 |
| ,/|‘\ | | | | | ,/|‘\ |
| ,/ | ‘\ | | | | | 15 | 16 |
|,/ | ‘\| | | | |,/ | ‘\|
,| | |\ 10 | 11 10-----17-----11
,/ | 0 | ‘\ | 0 | | 0 |
u | ,/ ‘\ | v | ,/ ‘\ | | ,/ ‘\ |
| ,/ ‘\ | | ,6 ‘7 | | ,6 ‘7 |
|,/ ‘\| |,/ ‘\| |,/ ‘\|
1-------------2 1------9------2 1------9------2
4 4 4
,/|\ ,/|\ ,/|\
,/ .’|\ ,/ .’|\ ,/ .’|\
,/ | | \ ,/ | | \ ,/ | | \
,/ .’ | ‘. ,/ .’ | ‘. ,/ .’ | ‘.
,/ | ’. \ ,7 | 12 \ ,7 | 12 \
,/ .’ w | \ ,/ .’ | \ ,/ .’ | \
,/ | ^ | \ ,/ 9 | 11 ,/ 9 | 11
0----------.’--|-3 ‘. 0--------6-.’----3 ‘. 0--------6-.’----3 ‘.
‘\ | | ‘\ \ ‘\ | ‘\ \ ‘\ | ‘\ \
‘\ .’ +----‘\ - \ -> v ‘5 .’ 10 \ ‘5 .’ 13 10 \
‘\ | ‘\ ‘\ \ ‘\ | ‘\ \ ‘\ | ‘\ \
‘\.’ ‘\ ‘\‘ ‘\.’ ‘\‘ ‘\.’ ‘\‘
1----------------2 1--------8-------2 1--------8-------2
‘\
u
The numbering for internal nodes is recursive, i.e. the numbering follows that of the nodes
of an embedded edge/face/volume of lower order. The higher order nodes are assumed
to be equispaced. Edges and faces are numbered following the lowest order template that
generates a single high-order on this edge/face. Furthermore, an edge is oriented from
Chapter 9: File formats 115
the node with the lowest to the highest index. The orientation of a face is such that the
computed normal points outward; the starting point is the node with the lowest index.
where
version-number
is a real number equal to 2.2
file-type
is an integer equal to 0 in the ASCII file format.
Chapter 9: File formats 117
data-size
is an integer equal to the size of the floating point numbers used in the file
(currently only data-size = sizeof(double) is supported).
number-of-nodes
is the number of nodes in the mesh.
node-number
is the number (index) of the n-th node in the mesh; node-number must be a
postive (non-zero) integer. Note that the node-numbers do not necessarily have
to form a dense nor an ordered sequence.
x-coord y-coord z-coord
are the floating point values giving the X, Y and Z coordinates of the n-th node.
number-of-elements
is the number of elements in the mesh.
elm-number
is the number (index) of the n-th element in the mesh; elm-number must be a
postive (non-zero) integer. Note that the elm-numbers do not necessarily have
to form a dense nor an ordered sequence.
elm-type defines the geometrical type of the n-th element: see Section 9.1 [MSH file
format (version 4)], page 107.
number-of-tags
gives the number of integer tags that follow for the n-th element. By default, the
first tag is the tag of the physical entity to which the element belongs; the second
is the tag of the elementary geometrical entity to which the element belongs; the
third is the number of mesh partitions to which the element belongs, followed
by the partition ids (negative partition ids indicate ghost cells). A zero tag is
equivalent to no tag. Gmsh and most codes using the MSH 2 format require at
least the first two tags (physical and elementary tags).
node-number-list
is the list of the node numbers of the n-th element. The ordering of the nodes
is given in Section 9.2 [Node ordering], page 112.
number-of-string-tags
gives the number of string tags that follow. By default the first string-tag
is interpreted as the name of the post-processing view and the second as the
name of the interpolation scheme. The interpolation scheme is provided in the
$InterpolationScheme section (see below).
number-of-real-tags
gives the number of real number tags that follow. By default the first real-tag
is interpreted as a time value associated with the dataset.
number-of-integer-tags
gives the number of integer tags that follow. By default the first integer-tag is
interpreted as a time step index (starting at 0), the second as the number of
field components of the data in the view (1, 3 or 9), the third as the number of
118 Gmsh 4.0
entities (nodes or elements) in the view, and the fourth as the partition index
for the view data (0 for no partition).
number-of-nodes-per-elements
gives the number of node values for an element in an element-based view.
value is a real number giving the value associated with a node or an element. For
NodeData (respectively ElementData) views, there are ncomp values per node
(resp. per element), where ncomp is the number of field components. For
ElementNodeData views, there are ncomp times number-of-nodes-per-elements
values per element.
number-of-element-topologies
is the number of element topologies for which interpolation matrices are pro-
vided
elm-topology
is the id tag of a given element topology: 1 for points, 2 for lines, 3 for triangles,
4 for quadrangles, 5 for tetrahedra, 6 for pyramids, 7 for prisms, 8 for hexahedra,
9 for polygons and 10 for polyhedra.
number-of-interpolation-matrices
is the number of interpolation matrices provided for the element topology elm-
topology. Currently you should provide 2 matrices, i.e., the matrices that spec-
ify how to interpolate the data (they have the same meaning as in Section 8.1
[Post-processing commands], page 74). The matrices are specified by 2 integers
(num-rows and num-columns) followed by the values.
Below is a small example (a mesh consisting of two quadrangles with an associated nodal
scalar dataset; the comments are not part of the actual file!):
$MeshFormat
2.2 0 8
$EndMeshFormat
$Nodes
6 six mesh nodes:
1 0.0 0.0 0.0 node #1: coordinates (0.0, 0.0, 0.0)
2 1.0 0.0 0.0 node #2: coordinates (1.0, 0.0, 0.0)
3 1.0 1.0 0.0 etc.
4 0.0 1.0 0.0
5 2.0 0.0 0.0
6 2.0 1.0 0.0
$EndNodes
$Elements
2 two elements:
1 3 2 99 2 1 2 3 4 quad #1: type 3, physical 99, elementary 2, nodes 1 2 3 4
2 3 2 99 2 2 5 6 3 quad #2: type 3, physical 99, elementary 2, nodes 2 5 6 3
$EndElements
$NodeData
1 one string tag:
"A scalar view" the name of the view ("A scalar view")
1 one real tag:
0.0 the time value (0.0)
3 three integer tags:
0 the time step (0; time steps always start at 0)
1 1-component (scalar) field
Chapter 9: File formats 119
nodes-binary
is the list of nodes in binary form, i.e., a array of number-of-nodes * (4 + 3 *
data-size) bytes. For each node, the first 4 bytes contain the node number and
the next (3 * data-size) bytes contain the three floating point coordinates.
Here is a pseudo C code to write nodes-binary:
for(i = 0; i < number_of_nodes; i++){
fwrite(&num_i, sizeof(int), 1, file);
double xyz[3] = {node_i_x, node_i_y, node_i_z};
fwrite(xyz, sizeof(double), 3, file);
}
number-of-elements
has the same meaning as in the ASCII file format.
element-header-binary
is a list of 3 integers in binary form, i.e., an array of (3 * 4) bytes: the first
four bytes contain the type of the elements that follow (same as elm-type in the
ASCII format), the next four contain the number of elements that follow, and
the last four contain the number of tags per element (same as number-of-tags
in the ASCII format).
Here is a pseudo C code to write element-header-binary:
int header[3] = {elm_type, num_elm_follow, num_tags};
fwrite(header, sizeof(int), 3, file);
elements-binary
is a list of elements in binary form, i.e., an array of “number of elements that
follow” * (4 + number-of-tags * 4 + #node-number-list * 4) bytes. For each
element, the first four bytes contain the element number, the next (number-of-
tags * 4) contain the tags, and the last (#node-number-list * 4) contain the
node indices.
Here is a pseudo C code to write elements-binary for triangles with the 2 stan-
dard tags (the physical and elementary regions):
for(i = 0; i < number_of_triangles; i++){
int data[6] = {num_i, physical, elementary,
node_i_1, node_i_2, node_i_3};
fwrite(data, sizeof(int), 6, file);
}
$ELM
number-of-elements
elm-number elm-type reg-phys reg-elem number-of-nodes node-number-list
...
$ENDELM
where
number-of-nodes
is the number of nodes in the mesh.
node-number
is the number (index) of the n-th node in the mesh; node-number must be a
postive (non-zero) integer. Note that the node-numbers do not necessarily have
to form a dense nor an ordered sequence.
x-coord y-coord z-coord
are the floating point values giving the X, Y and Z coordinates of the n-th node.
number-of-elements
is the number of elements in the mesh.
elm-number
is the number (index) of the n-th element in the mesh; elm-number must be a
postive (non-zero) integer. Note that the elm-numbers do not necessarily have
to form a dense nor an ordered sequence.
elm-type defines the geometrical type of the n-th element:
1 2-node line.
2 3-node triangle.
3 4-node quadrangle.
4 4-node tetrahedron.
5 8-node hexahedron.
6 6-node prism.
7 5-node pyramid.
8 3-node second order line (2 nodes associated with the vertices and
1 with the edge).
9 6-node second order triangle (3 nodes associated with the vertices
and 3 with the edges).
10 9-node second order quadrangle (4 nodes associated with the ver-
tices, 4 with the edges and 1 with the face).
11 10-node second order tetrahedron (4 nodes associated with the ver-
tices and 6 with the edges).
12 27-node second order hexahedron (8 nodes associated with the ver-
tices, 12 with the edges, 6 with the faces and 1 with the volume).
122 Gmsh 4.0
data-size
is an integer equal to the size of the floating point numbers used in the file
(usually, data-size = sizeof(double)).
view-name
is a string containing the name of the view (max. 256 characters).
nb-time-steps
is an integer giving the number of time steps in the view.
nb-scalar-points
nb-vector-points
... are integers giving the number of scalar points, vector points, . . . , in the view.
nb-text2d
nb-text3d
are integers giving the number of 2D and 3D text strings in the view.
nb-text2d-chars
nb-text3d-chars
are integers giving the total number of characters in the 2D and 3D strings.
time-step-values
is a list of nb-time-steps double precision numbers giving the value of the time
(or any other variable) for which an evolution was saved.
scalar-point-value
vector-point-value
... are lists of double precision numbers giving the node coordinates and the values
associated with the nodes of the nb-scalar-points scalar points, nb-vector-points
vector points, . . . , for each of the time-step-values.
For example, vector-triangle-value is defined as:
coord1-node1 coord1-node2 coord1-node3
coord2-node1 coord2-node2 coord2-node3
coord3-node1 coord3-node2 coord3-node3
comp1-node1-time1 comp2-node1-time1 comp3-node1-time1
comp1-node2-time1 comp2-node2-time1 comp3-node2-time1
comp1-node3-time1 comp2-node3-time1 comp3-node3-time1
comp1-node1-time2 comp2-node1-time2 comp3-node1-time2
comp1-node2-time2 comp2-node2-time2 comp3-node2-time2
comp1-node3-time2 comp2-node3-time2 comp3-node3-time2
...
The ordering of the nodes is given in Section 9.2 [Node ordering], page 112.
text2d is a list of 4 double precision numbers:
coord1 coord2 style index
where coord1 and coord2 give the X-Y position of the 2D string in screen co-
ordinates (measured from the top-left corner of the window) and where index
gives the starting index of the string in text2d-chars. If coord1 (respectively
coord2) is negative, the position is measured from the right (respectively bot-
tom) edge of the window. If coord1 (respectively coord2) is larger than 99999,
Chapter 9: File formats 125
fprintf(file, "$PostFormat\n");
fprintf(file, "%g %d %d\n", 1.4, 1, sizeof(double));
fprintf(file, "$EndPostFormat\n");
fprintf(file, "$View\n");
fprintf(file, "%s %d "
"%d %d %d %d %d %d %d %d %d "
"%d %d %d %d %d %d %d %d %d "
"%d %d %d %d %d %d %d %d %d "
"%d %d %d %d %d %d %d %d %d "
"%d %d %d %d %d %d %d %d %d "
"%d %d %d %d\n",
view-name, nb-time-steps,
nb-scalar-points, nb-vector-points, nb-tensor-points,
nb-scalar-lines, nb-vector-lines, nb-tensor-lines,
126 Gmsh 4.0
Appendix A Tutorial
The following examples introduce new features gradually, starting with Section A.1 [t1.geo],
page 127. The files corresponding to these examples are available in the tutorial directory
of the Gmsh distribution.
To learn how to run Gmsh on your computer, see Chapter 3 [Running Gmsh on
your system], page 11. Screencasts that show how to use the GUI are available on
http://gmsh.info/screencasts/.
A.1 t1.geo
/*********************************************************************
*
* Gmsh tutorial 1
*
* Variables, elementary entities (points, curves, surfaces), physical
* entities (points, curves, surfaces)
*
*********************************************************************/
lc = 1e-2;
// We can then define some additional points as well as our first curve. Curves
// are Gmsh’s second type of elementery entities, and, amongst curves, straight
// lines are the simplest. A straight line is defined by a list of point
// numbers. In the commands below, for example, the line 1 starts at point 1 and
// ends at point 2:
Line(1) = {1,2} ;
Line(2) = {3,2} ;
Line(3) = {3,4} ;
Line(4) = {4,1} ;
// We can then define the surface as a list of curve loops (only one here, since
// there are no holes--see ‘t4.geo’):
// At this level, Gmsh knows everything to display the rectangular surface 6 and
// to mesh it. An optional step is needed if we want to associate specific
// region numbers to the various elements in the mesh (e.g. to the line segments
// discretizing curves 1 to 4 or to the triangles discretizing surface 1). This
// is achieved by the definition of ‘physical entities’. Physical entities will
// group elements belonging to several elementary entities by giving them a
// common number (a region number).
// We can for example group the points 1 and 2 into the physical entity 1:
// Consequently, two punctual elements will be saved in the output mesh file,
// both with the region number 1. The mechanism is identical for curve or surface
// elements:
MY_CURVE = 2;
Physical Curve(MY_CURVE) = {1,2} ;
Physical Curve("My second curve (automatic physical tag)") = {3} ;
Physical Curve("My third curve (physical tag 5)", 5) = {4} ;
Physical Surface("My surface") = {1} ;
// All the line elements created during the meshing of curves 1 and 2 will be
// saved in the output mesh file with the physical tag 2. The elements from curve
// 3 will be saved in the output mesh file with an automatic physical id,
// associated with the label "My second curve (automatic physical tag)". The
// elements from curve 4 will be saved with physical tag 5, associated with the
// label "My third curve (physical tag 5)". And finally, all the triangular
// elements resulting from the discretization of surface 6 will be given an
// automatic physical id associated with the label "My surface").
Appendix A: Tutorial 129
//
// Note that if no physical entities are defined, then all the elements in the
// mesh will be saved "as is", with their default orientation.
// Starting with Gmsh 3.0, models can also be built using constructive solid
// geometry. Instead of the built-in geometry kernel, you need to use the
// OpenCASCADE kernel:
//
// SetFactory("OpenCASCADE");
//
// In addition to the "bottom-up" geometry commands, you can now use "top-down"
// commands, like e.g.
//
// Rectangle(2) = {.2, 0, 0, 0.1, 0.3};
//
// See tutorial/t16.geo for an example, and demos/boolean for more.
A.2 t2.geo
/*********************************************************************
*
* Gmsh tutorial 2
*
* Includes, geometrical transformations, extruded geometries,
* elementary entities (volumes), physical entities (volumes)
*
*********************************************************************/
Include "t1.geo";
// We can then add new points and curves in the same way as we did in ‘t1.geo’:
// The resulting point can also be duplicated and translated by 0.1 along the y
// axis:
130 Gmsh 4.0
// This command created a new point with an automatically assigned id. This id
// can be obtained using the graphical user interface by hovering the mouse over
// it and looking at the bottom of the graphic window: in this case, the new
// point has id "6". Point 6 can then be used to create new entities, e.g.:
// Using the graphical user interface to obtain the ids of newly created
// entities can sometimes be cumbersome. It can then be advantageous to use the
// return value of the transformation commands directly. For example, the
// Translate command returns a list containing the ids of the translated
// entities. For example, we can translate copies of the two surfaces 6 and 11
// to the right with the following command:
// my_new_surfs[] (note the square brackets) denotes a list, which in this case
// contains the ids of the two new surfaces (check ‘Tools->Message console’ to
// see the message):
// In Gmsh lists use square brackets for their definition (mylist[] = {1,2,3};)
// as well as to access their elements (myotherlist[] = {mylist[0],
// mylist[2]};). Note that list indexing starts at 0.
// Volumes are the fourth type of elementary entities in Gmsh. In the same way
// one defines curve loops to build surfaces, one has to define surface loops
// (i.e. ‘shells’) to build volumes. The following volume does not have holes
// and thus consists of a single surface loop:
Point(100) = {0., 0.3, 0.13, lc}; Point(101) = {0.08, 0.3, 0.1, lc};
Point(102) = {0.08, 0.4, 0.1, lc}; Point(103) = {0., 0.4, 0.13, lc};
// When a volume can be extruded from a surface, it is usually easier to use the
// Extrude command directly instead of creating all the points, curves and
// surfaces by hand. For example, the following command extrudes the surface 11
// along the z axis and automatically creates a new volume (as well as all the
// needed points, curves and surfaces):
// To save all the tetrahedra discretizing the volumes 129 and 130 with a common
// region number, we finally define a physical volume:
A.3 t3.geo
/*********************************************************************
*
* Gmsh tutorial 3
*
* Extruded meshes, parameters, options
*
*********************************************************************/
Include "t1.geo";
132 Gmsh 4.0
h = 0.1;
Extrude {0,0,h} {
Surface{1}; Layers{ {8,2}, {0.5,1} };
}
// We can then define a new physical volume to save all the tetrahedra with a
// common region number (101):
// Let us now change some options... Since all interactive options are
// accessible in Gmsh’s scripting language, we can for example make point tags
// visible or redefine some colors directly in the input file:
Appendix A: Tutorial 133
Geometry.PointNumbers = 1;
Geometry.Color.Points = Orange;
General.Color.Text = White;
Mesh.Color.Points = {255,0,0};
Geometry.Color.Surfaces = Geometry.Color.Points;
// You can use the ‘Help->Current options’ menu to see the current values of all
// options. To save all the options in a file, use ‘File->Export->Gmsh
// options’. To associate the current options with the current file use
// ‘File->Save Options->For Current File’. To save the current options for all
// future Gmsh sessions use ‘File->Save Options->As default’.
A.4 t4.geo
/*********************************************************************
*
* Gmsh tutorial 4
*
* Built-in functions, surface holes, annotations, mesh colors
*
*********************************************************************/
cm = 1e-02;
e1 = 4.5 * cm; e2 = 6 * cm / 2; e3 = 5 * cm / 2;
h1 = 5 * cm; h2 = 10 * cm; h3 = 5 * cm; h4 = 2 * cm; h5 = 4.5 * cm;
R1 = 1 * cm; R2 = 1.5 * cm; r = 1 * cm;
Lc1 = 0.01;
Lc2 = 0.003;
// We can use all the usual mathematical functions (note the capitalized first
// letters), plus some useful functions like Hypot(a, b) := Sqrt(a^2 + b^2):
// Then we define some points and some lines using these variables:
134 Gmsh 4.0
Line(1) = {1 , 17};
Line(2) = {17, 16};
// Gmsh provides other curve primitives than straight lines: splines, B-splines,
// circle arcs, ellipse arcs, etc. Here we define a new circle arc, starting at
// point 14 and ending at point 16, with the circle’s center being the point 15:
Circle(3) = {14,15,16};
// Note that, in Gmsh, circle arcs should always be smaller than Pi. We can then
// define additional lines and circles, as well as a new surface:
// But we still need to define the exterior surface. Since this surface has a
// hole, its definition now requires two curves loops:
View "comments" {
// Add a text string in window coordinates, 10 pixels from the left and 10
// pixels from the bottom, using the StrCat function to concatenate strings:
T2(10, -10, 0){ StrCat("Created on ", Today, " with Gmsh") };
// Add a text string in model coordinates centered at (X,Y,Z) = (0, 0.11, 0):
T3(0, 0.11, 0, TextAttributes("Align", "Center", "Font", "Helvetica")){ "Hole" };
// The image can also be drawn in "billboard" mode, i.e. always parallel to
// the camera, by using the ‘#’ symbol:
T3(0, 0.12, 0, TextAttributes("Align", "Center")){ "file://image.png@0.01x0#" };
A.5 t5.geo
/*********************************************************************
*
* Gmsh tutorial 5
*
* Characteristic lengths, arrays of variables, macros, loops
*
*********************************************************************/
lcar1 = .1;
lcar2 = .0005;
lcar3 = .055;
// If we wanted to change these mesh sizes globally (without changing the above
// definitions), we could give a global scaling factor for all characteristic
// lengths on the command line with the ‘-clscale’ option (or with
// ‘Mesh.CharacteristicLengthFactor’ in an option file). For example, with:
//
// > gmsh t5.geo -clscale 1
//
// this input file produces a mesh of approximately 1,300 nodes and 11,000
// tetrahedra. With
//
// > gmsh t5.geo -clscale 0.2
//
// the mesh counts approximately 350,000 nodes and 2.1 million tetrahedra. You
// can check mesh statistics in the graphical user interface with the
// ‘Tools->Statistics’ menu.
Macro CheeseHole
// In the following commands we use the reserved variable name ‘newp’, which
// automatically selects a new point number. This number is chosen as the
// highest current point number, plus one. (Note that, analogously to ‘newp’,
// the variables ‘newl’, ‘news’, ‘newv’ and ‘newreg’ select the highest number
// amongst currently defined curves, surfaces, volumes and ‘any entities other
// than points’, respectively.)
// We need non-plane surfaces to define the spherical holes. Here we use ruled
// surfaces, which can have 3 or 4 sides:
// We then store the surface loops identification numbers in a list for later
// reference (we will need these to define the final volume):
theloops[t] = newreg ;
thehole = newreg ;
Volume(thehole) = theloops[t] ;
Return
x = 0 ; y = 0.75 ; z = 0 ; r = 0.09 ;
For t In {1:5}
x += 0.166 ;
z += 0.166 ;
Call CheeseHole ;
// We also print some variables on the terminal (note that, since all
// variables are treated internally as floating point numbers, the format
// string should only contain valid floating point format specifiers like
// ‘%g’, ‘%f’, ’%e’, etc.):
EndFor
// We can then define the surface loop for the exterior surface of the cube:
theloops[0] = newreg ;
Appendix A: Tutorial 139
// The volume of the cube, without the 5 holes, is now defined by 6 surface
// loops: the first surface loop defines the exterior surface; the surface loops
// other than the first one define holes. (Again, to reference an array of
// variables, its identifier is followed by square brackets):
Volume(186) = {theloops[]} ;
// We finally define a physical volume for the elements discretizing the cube,
// without the holes (whose elements were already tagged with numbers 1 to 5 in
// the ‘For’ loop):
// We could make only part of the model visible to only mesh this subset:
//
// Hide {:}
// Recursive Show { Volume{129}; }
// Mesh.MeshOnlyVisible=1;
A.6 t6.geo
/*********************************************************************
*
* Gmsh tutorial 6
*
* Transfinite meshes
*
*********************************************************************/
// Let’s use the geometry from the first tutorial as a basis for this one
Include "t1.geo";
// Create surface
Curve Loop(2) = {2, -1, l1, l2, l3, -3};
140 Gmsh 4.0
// Put 20 points total on combination of curves l1, l2 and l3 (beware that the
// points p1 and p2 are shared by the curves, so we do not create 6 + 6 + 10 =
// 22 points, but 20!)
Transfinite Curve{l1} = 6;
Transfinite Curve{l2} = 6;
Transfinite Curve{l3} = 10;
// (Note that the list on the right hand side refers to points, not curves. When
// the surface has only 3 or 4 points on its boundary the list can be
// omitted. The way triangles are generated can be controlled by appending
// "Left", "Right" or "Alternate" after the list.)
Physical Surface(1) = 1;
// When the surface has only 3 or 4 control points, the transfinite constraint
// can be applied automatically (without specifying the corners explictly).
A.7 t7.geo
/*********************************************************************
*
* Gmsh tutorial 7
*
* Background mesh
*
*********************************************************************/
A.8 t8.geo
/*********************************************************************
*
* Gmsh tutorial 8
*
* Post-processing, scripting, animations, options
*
*********************************************************************/
Include "t1.geo";
Include "view1.pos";
Include "view1.pos";
Include "view4.pos";
General.Trackball = 0;
General.RotationX = 0; General.RotationY = 0; General.RotationZ = 0;
142 Gmsh 4.0
v0 = PostProcessing.NbViews-4;
v1 = v0+1; v2 = v0+2; v3 = v0+3;
View[v0].IntervalsType = 2;
View[v0].OffsetZ = 0.05;
View[v0].RaiseZ = 0;
View[v0].Light = 1;
View[v0].ShowScale = 0;
View[v0].SmoothNormals = 1;
View[v1].IntervalsType = 1;
View[v1].ColorTable = { Green, Blue };
View[v1].NbIso = 10;
View[v1].ShowScale = 0;
View[v2].Name = "Test...";
View[v2].Axes = 1;
View[v2].Color.Axes = Black;
View[v2].IntervalsType = 2;
View[v2].Type = 2;
View[v2].IntervalsType = 2;
View[v2].AutoPosition = 0;
View[v2].PositionX = 85;
View[v2].PositionY = 50;
View[v2].Width = 200;
View[v2].Height = 130;
View[v3].Visible = 0;
// We then loop from 1 to 3 with a step of 1. (To use a different step, just add
// a third argument in the list. For example, ‘For num In {0.5:1.5:0.1}’ would
// increment num from 0.5 to 1.5 with a step of 0.1.)
t = 0;
View[v0].TimeStep = t;
View[v1].TimeStep = t;
View[v2].TimeStep = t;
Appendix A: Tutorial 143
View[v3].TimeStep = t;
View[v0].RaiseZ += 0.01/View[v0].Max * t;
If (num == 3)
// We want to create 640x480 frames when num == 3:
General.GraphicsWidth = General.MenuWidth + 640;
General.GraphicsHeight = 480;
EndIf
frames = 50;
General.RotationX += 10;
General.RotationY = General.RotationX / 3;
General.RotationZ += 0.1;
If (num == 3)
// The ‘Print’ command saves the graphical window; the ‘Sprintf’ function
// permits to create the file names on the fly:
//Print Sprintf("t8-%02g.gif", num2);
//Print Sprintf("t8-%02g.ppm", num2);
//Print Sprintf("t8-%02g.jpg", num2);
EndIf
EndFor
If(num == 3)
// Here we could make a system call to generate a movie. For example,
// with whirlgif:
/*
System "whirlgif -minimize -loop -o t8.gif t8-*.gif";
*/
// with mencoder:
/*
System "mencoder ’mf://*.jpg’ -mf fps=5 -o t8.mpg -ovc lavc
-lavcopts vcodec=mpeg1video:vhq";
System "mencoder ’mf://*.jpg’ -mf fps=5 -o t8.mpg -ovc lavc
-lavcopts vcodec=mpeg4:vhq";
*/
// with ffmpeg:
/*
System "ffmpeg -hq -r 5 -b 800 -vcodec mpeg1video
-i t8-%02d.jpg t8.mpg"
System "ffmpeg -hq -r 5 -b 800 -i t8-%02d.jpg t8.asf"
*/
EndIf
EndFor
A.9 t9.geo
/*********************************************************************
*
* Gmsh tutorial 9
*
* Post-processing plugins (levelsets, sections, annotations)
*
Appendix A: Tutorial 145
*********************************************************************/
Include "view3.pos" ;
// We then set some options for the ‘Isosurface’ plugin (which extracts an
// isosurface from a 3D scalar view), and run it:
// We also set some options for the ‘CutPlane’ plugin (which computes a section
// of a 3D view using the plane A*x+B*y+C*z+D=0), and then run it:
Plugin(CutPlane).A = 0 ;
Plugin(CutPlane).B = 0.2 ;
Plugin(CutPlane).C = 1 ;
Plugin(CutPlane).D = 0 ;
Plugin(CutPlane).View = 0 ;
Plugin(CutPlane).Run ;
// Add a title (By convention, for window coordinates a value greater than 99999
// represents the center. We could also use ‘General.GraphicsWidth / 2’, but
// that would only center the string for the current window size.):
Plugin(Annotate).FontSize = 12 ;
Plugin(Annotate).Run ;
View[0].Light = 1;
View[0].IntervalsType = 1;
View[0].NbIso = 6;
View[0].SmoothNormals = 1;
View[1].IntervalsType = 2;
View[2].IntervalsType = 2;
A.10 t10.geo
/*********************************************************************
*
* Gmsh tutorial 10
*
* General mesh size fields
*
*********************************************************************/
// Say we would like to obtain mesh elements with size lc/30 near curve 2 and
// point 5, and size lc elsewhere. To achieve this, we can use two fields:
// "Distance", and "Threshold". We first define an Distance field (Field[1])
// on points 5 and on curve 2. This field returns the distance to point 5 and to
// (100 equidistant points on) curve 2.
Field[1] = Distance;
Field[1].NodesList = {5};
Field[1].NNodesByEdge = 100;
Field[1].EdgesList = {2};
// We then define a Threshold field, which uses the return value of the Distance
Appendix A: Tutorial 147
// Say we want to modulate the mesh element sizes using a mathematical function
// of the spatial coordinates. We can do this with the MathEval field:
Field[3] = MathEval;
Field[3].F = "Cos(4*3.14*x) * Sin(4*3.14*y) / 10 + 0.101";
// We could also combine MathEval with values coming from other fields. For
// example, let’s define an Attractor around point 1
Field[4] = Attractor;
Field[4].NodesList = {1};
// We can then create a MathEval field with a function that depends on the
// return value of the Attractr Field[4], i.e., depending on the distance to
// point 1 (here using a cubic law, with minumum element size = lc / 100)
Field[5] = MathEval;
Field[5].F = Sprintf("F4^3 + %g", lc / 100);
// We could also use a Box field to impose a step change in element sizes inside
// a box
Field[6] = Box;
Field[6].VIn = lc / 15;
Field[6].VOut = lc;
Field[6].XMin = 0.3;
Field[6].XMax = 0.6;
Field[6].YMin = 0.3;
Field[6].YMax = 0.6;
// Many other types of fields are available: see the reference manual for a
// complete list. You can also create fields directly in the graphical user
// interface by selecting Define->Fields in the Mesh module.
148 Gmsh 4.0
// Finally, let’s use the minimum of all the fields as the background mesh field
Field[7] = Min;
Field[7].FieldsList = {2, 3, 5, 6};
Background Field = 7;
// If the boundary mesh size was too small, we could ask not to extend the
// elements sizes from the boundary inside the domain:
// Mesh.CharacteristicLengthExtendFromBoundary = 0;
A.11 t11.geo
/*********************************************************************
*
* Gmsh tutorial 11
*
* Unstructured quadrangular meshes
*
*********************************************************************/
// We have seen in tutorials t3 and t6 that extruded and transfinite meshes can
// be "recombined" into quads/prisms/hexahedra by using the "Recombine"
// keyword. Unstructured meshes can be recombined in the same way. Let’s define
// a simple geometry with an analytical mesh size field:
Field[1] = MathEval;
Field[1].F = "0.01*(1.0+30.*(y-x*x)*(y-x*x) + (1-x)*(1-x))";
Background Field = 1;
// If we’d had several surfaces, we could have used ’Recombine Surface {:};’.
// Yet another way would be to specify the global option "Mesh.RecombineAll =
// 1;".
// For even better quadrilateral meshes, you can try the experimental "Delaunay
// for quads" (DelQuad) meshing algorithm: DelQuad is a triangulation algorithm
// that enables to create right triangles almost everywhere. Uncomment the
// following line to try DelQuad: Mesh.Algorithm = 8;
A.12 t12.geo
/*********************************************************************
*
* Gmsh tutorial 12
*
* Cross-patch meshing with compounds
*
*********************************************************************/
lc = 0.1;
A.13 t13.geo
/*********************************************************************
*
* Gmsh tutorial 13
*
* Remeshing without an underlying CAD model
*
*********************************************************************/
// Let’s merge a mesh that we would like to remesh. This mesh was reclassified
// ("colored") from an initial STL triangulation using the "Reclassify 2D" tool
// in Gmsh, so that we could split it along sharp geometrical features.
Merge "t13_data.msh";
// Create a geometry for all the curves and surfaces in the mesh, by computing a
// parametrization for each entity
CreateGeometry;
A.14 t14.geo
/*********************************************************************
*
* Gmsh tutorial 14
*
* Homology and cohomology computation
*
*********************************************************************/
// Create physical groups, which are used to define the domain of the
// (co)homology computation and the subdomain of the relative (co)homology
// computation.
// Whole domain
Physical Volume(1) = {1};
// Find bases for relative homology spaces of the domain modulo the four
// terminals.
Homology {{1}, {70, 71, 72, 73}};
152 Gmsh 4.0
// Find homology space bases isomorphic to the previous bases: homology spaces
// modulo the non-terminal domain surface, a.k.a the thin cuts.
Homology {{1}, {75}};
// More examples:
// Homology {1};
// Homology;
// Homology {{1}, {80}};
// Homology {{}, {80}};
A.15 t15.geo
/*********************************************************************
*
* Gmsh tutorial 15
*
* Embedded points, lines and surfaces
*
*********************************************************************/
// One can force this point to be included ("embedded") in the 2D mesh, using
// the "Point In Surface" command:
Point{5} In Surface{1};
// In the same way, one can force a curve to be embedded in the 2D mesh using
// the "Curve in Surface" command:
Point(6) = {0.02, 0.12, 0, lc};
Point(7) = {0.04, 0.18, 0, lc};
Line(5) = {6, 7};
Curve{5} In Surface{1};
// One can also embed points and curves in a volume using the "Curve/Point In
Appendix A: Tutorial 153
// Volume" commands:
Extrude {0, 0, 0.1}{ Surface {1}; }
p = newp;
Point(p) = {0.07, 0.15, 0.025, lc};
Point{p} In Volume {1};
l = newl;
Point(p+1) = {0.025, 0.15, 0.025, lc};
Line(l) = {7, p+1};
Curve{l} In Volume {1};
// Finally, one can also embed a surface in a volume using the "Surface In
// Volume" command:
Point(p+2) = {0.02, 0.12, 0.05, lc};
Point(p+3) = {0.04, 0.12, 0.05, lc};
Point(p+4) = {0.04, 0.18, 0.05, lc};
Point(p+5) = {0.02, 0.18, 0.05, lc};
Line(l+1) = {p+2, p+3};
Line(l+2) = {p+3, p+4};
Line(l+3) = {p+4, p+5};
Line(l+4) = {p+5, p+2};
ll = newll;
Curve Loop(ll) = {l+1:l+4};
s = news;
Plane Surface(s) = {ll};
Surface{s} In Volume{1};
A.16 t16.geo
/*********************************************************************
*
* Gmsh tutorial 16
*
* Constructive Solid Geometry, OpenCASCADE geometry kernel
*
*********************************************************************/
SetFactory("OpenCASCADE");
// And let’s build the same model as in t5.geo, but using constructive solid
// geometry:
154 Gmsh 4.0
lcar1 = .1;
lcar2 = .0005;
lcar3 = .055;
eps = 1e-3;
Appendix B Options
This appendix lists all the available options. Gmsh’s default behavior is to save some of these
options in a per-user “session resource” file (cf. “Saved in: General.SessionFileName” in
the lists below) every time Gmsh is shut down. This permits for example to automatically
remember the size and location of the windows or which fonts to use. A second set of
options can be saved (automatically or manually with the ‘File->Save Options->As Default’
menu) in a per-user “option” file (cf. “Saved in: General.OptionsFileName” in the lists
below), automatically loaded by Gmsh every time it starts up. Finally, other options are
only saved to disk manually, either by explicitely saving an option file with ‘File->Export’,
or when saving per-model options with ‘File->Save Options->For Current File’ (cf. “Saved
in: -” in the lists below).
To reset all options to their default values, use the ‘Restore default options’ button
in ‘Tools->Options->General->Advanced’, or erase the General.SessionFileName and
General.OptionsFileName files by hand.
General.AxesFormatY
Number format for Y-axis (in standard C form)
Default value: "%.3g"
Saved in: General.OptionsFileName
General.AxesFormatZ
Number format for Z-axis (in standard C form)
Default value: "%.3g"
Saved in: General.OptionsFileName
General.AxesLabelX
X-axis label
Default value: ""
Saved in: General.OptionsFileName
General.AxesLabelY
Y-axis label
Default value: ""
Saved in: General.OptionsFileName
General.AxesLabelZ
Z-axis label
Default value: ""
Saved in: General.OptionsFileName
156 Gmsh 4.0
General.BackgroundImageFileName
Background image file in JPEG, PNG or PDF format
Default value: ""
Saved in: General.OptionsFileName
General.BuildOptions
Gmsh build options (read-only)
Default value: " 64Bit Ann Bamg Bfgs Blas(VecLib) Blossom Cairo
Cgns DIntegration Dlopen Fltk GMP Gmm Hxt Jpeg(Fltk) Kbipack
Lapack(VecLib) MathEx Med Mesh Metis Mmg3d Mpeg NativeFileChooser
Netgen ONELAB ONELABMetamodel OpenCASCADE OpenGL OptHom PETSc
Parser Plugins Png(Fltk) Post SLEPc Solver TetGen/BR Voro++ Zlib"
Saved in: -
General.DefaultFileName
Default project file name
Default value: "untitled.geo"
Saved in: General.OptionsFileName
General.Display
X server to use (only for Unix versions)
Default value: ""
Saved in: -
General.ErrorFileName
File into which the log is saved if a fatal error occurs
Default value: ".gmsh-errors"
Saved in: General.OptionsFileName
General.ExecutableFileName
File name of the Gmsh executable (read-only)
Default value: ""
Saved in: General.SessionFileName
General.FileName
Current project file name (read-only)
Default value: ""
Saved in: -
General.FltkTheme
FLTK user interface theme (try e.g. plastic or gtk+)
Default value: ""
Saved in: General.SessionFileName
General.GraphicsFont
Font used in the graphic window
Default value: "Helvetica"
Saved in: General.OptionsFileName
General.GraphicsFontEngine
Set graphics font engine (Native, Cairo)
Default value: "Native"
Saved in: General.OptionsFileName
Appendix B: Options 157
General.GraphicsFontTitle
Font used in the graphic window for titles
Default value: "Helvetica"
Saved in: General.OptionsFileName
General.OptionsFileName
Option file created with ‘Tools->Options->Save’; automatically read on startup
Default value: ".gmsh-options"
Saved in: General.SessionFileName
General.RecentFile0
Most recent opened file
Default value: "untitled.geo"
Saved in: General.SessionFileName
General.RecentFile1
2nd most recent opened file
Default value: "untitled.geo"
Saved in: General.SessionFileName
General.RecentFile2
3rd most recent opened file
Default value: "untitled.geo"
Saved in: General.SessionFileName
General.RecentFile3
4th most recent opened file
Default value: "untitled.geo"
Saved in: General.SessionFileName
General.RecentFile4
5th most recent opened file
Default value: "untitled.geo"
Saved in: General.SessionFileName
General.RecentFile5
6th most recent opened file
Default value: "untitled.geo"
Saved in: General.SessionFileName
General.RecentFile6
7th most recent opened file
Default value: "untitled.geo"
Saved in: General.SessionFileName
General.RecentFile7
8th most recent opened file
Default value: "untitled.geo"
Saved in: General.SessionFileName
158 Gmsh 4.0
General.RecentFile8
9th most recent opened file
Default value: "untitled.geo"
Saved in: General.SessionFileName
General.RecentFile9
10th most recent opened file
Default value: "untitled.geo"
Saved in: General.SessionFileName
General.SessionFileName
Option file into which session specific information is saved; automatically read
on startup
Default value: ".gmshrc"
Saved in: -
General.TextEditor
System command to launch a text editor
Default value: "open -t %s"
Saved in: General.OptionsFileName
General.TmpFileName
Temporary file used by the geometry module
Default value: ".gmsh-tmp"
Saved in: General.SessionFileName
General.Version
Gmsh version (read-only)
Default value: "3.0.7-git-4294b937e"
Saved in: -
General.WatchFilePattern
Pattern of files to merge as they become available
Default value: ""
Saved in: -
General.AlphaBlending
Enable alpha blending (transparency) in post-processing views
Default value: 1
Saved in: General.OptionsFileName
General.Antialiasing
Use multisample antialiasing (will slow down rendering)
Default value: 0
Saved in: General.OptionsFileName
General.ArrowHeadRadius
Relative radius of arrow head
Default value: 0.12
Saved in: General.OptionsFileName
Appendix B: Options 159
General.ArrowStemLength
Relative length of arrow stem
Default value: 0.56
Saved in: General.OptionsFileName
General.ArrowStemRadius
Relative radius of arrow stem
Default value: 0.02
Saved in: General.OptionsFileName
General.Axes
Axes (0=none, 1=simple axes, 2=box, 3=full grid, 4=open grid, 5=ruler)
Default value: 0
Saved in: General.OptionsFileName
General.AxesMikado
Mikado axes style
Default value: 0
Saved in: General.OptionsFileName
General.AxesAutoPosition
Position the axes automatically
Default value: 1
Saved in: General.OptionsFileName
General.AxesForceValue
Force values on axes (otherwise use natural coordinates)
Default value: 0
Saved in: General.OptionsFileName
General.AxesMaxX
Maximum X-axis coordinate
Default value: 1
Saved in: General.OptionsFileName
General.AxesMaxY
Maximum Y-axis coordinate
Default value: 1
Saved in: General.OptionsFileName
General.AxesMaxZ
Maximum Z-axis coordinate
Default value: 1
Saved in: General.OptionsFileName
General.AxesMinX
Minimum X-axis coordinate
Default value: 0
Saved in: General.OptionsFileName
160 Gmsh 4.0
General.AxesMinY
Minimum Y-axis coordinate
Default value: 0
Saved in: General.OptionsFileName
General.AxesMinZ
Minimum Z-axis coordinate
Default value: 0
Saved in: General.OptionsFileName
General.AxesTicsX
Number of tics on the X-axis
Default value: 5
Saved in: General.OptionsFileName
General.AxesTicsY
Number of tics on the Y-axis
Default value: 5
Saved in: General.OptionsFileName
General.AxesTicsZ
Number of tics on the Z-axis
Default value: 5
Saved in: General.OptionsFileName
General.AxesValueMaxX
Maximum X-axis forced value
Default value: 1
Saved in: General.OptionsFileName
General.AxesValueMaxY
Maximum Y-axis forced value
Default value: 1
Saved in: General.OptionsFileName
General.AxesValueMaxZ
Maximum Z-axis forced value
Default value: 1
Saved in: General.OptionsFileName
General.AxesValueMinX
Minimum X-axis forced value
Default value: 0
Saved in: General.OptionsFileName
General.AxesValueMinY
Minimum Y-axis forced value
Default value: 0
Saved in: General.OptionsFileName
Appendix B: Options 161
General.AxesValueMinZ
Minimum Z-axis forced value
Default value: 0
Saved in: General.OptionsFileName
General.BackgroundGradient
Draw background gradient (0=none, 1=vertical, 2=horizontal, 3=radial)
Default value: 1
Saved in: General.OptionsFileName
General.BackgroundImage3D
Create background image in the 3D model (units = model units) or as 2D
background (units = pixels)
Default value: 0
Saved in: General.OptionsFileName
General.BackgroundImagePage
Page to render in the background image (for multi-page PDFs)
Default value: 0
Saved in: General.OptionsFileName
General.BackgroundImagePositionX
X position of background image (for 2D background: < 0: measure from right
window edge; >= 1e5: centered)
Default value: 0
Saved in: General.OptionsFileName
General.BackgroundImagePositionY
Y position of background image (for 2D background: < 0: measure from bottom
window edge; >= 1e5: centered)
Default value: 0
Saved in: General.OptionsFileName
General.BackgroundImageWidth
Width of background image (0: actual width if height = 0, natural scaling if
not; -1: graphic window width)
Default value: -1
Saved in: General.OptionsFileName
General.BackgroundImageHeight
Height of background image (0: actual height if width = 0, natural scaling if
not; -1: graphic window height)
Default value: -1
Saved in: General.OptionsFileName
General.BoundingBoxSize
Overall bounding box size (read-only)
Default value: 1
Saved in: General.OptionsFileName
162 Gmsh 4.0
General.Camera
Enable camera view mode
Default value: 0
Saved in: General.OptionsFileName
General.CameraAperture
Camera aperture in degrees
Default value: 40
Saved in: General.OptionsFileName
General.CameraEyeSeparationRatio
Eye separation ratio in % for stereo rendering
Default value: 1.5
Saved in: General.OptionsFileName
General.CameraFocalLengthRatio
Camera Focal length ratio
Default value: 1
Saved in: General.OptionsFileName
General.Clip0A
First coefficient in equation for clipping plane 0 (‘A’ in ‘AX+BY+CZ+D=0’)
Default value: 1
Saved in: -
General.Clip0B
Second coefficient in equation for clipping plane 0 (‘B’ in ‘AX+BY+CZ+D=0’)
Default value: 0
Saved in: -
General.Clip0C
Third coefficient in equation for clipping plane 0 (‘C’ in ‘AX+BY+CZ+D=0’)
Default value: 0
Saved in: -
General.Clip0D
Fourth coefficient in equation for clipping plane 0 (‘D’ in ‘AX+BY+CZ+D=0’)
Default value: 0
Saved in: -
General.Clip1A
First coefficient in equation for clipping plane 1
Default value: 0
Saved in: -
General.Clip1B
Second coefficient in equation for clipping plane 1
Default value: 1
Saved in: -
Appendix B: Options 163
General.Clip1C
Third coefficient in equation for clipping plane 1
Default value: 0
Saved in: -
General.Clip1D
Fourth coefficient in equation for clipping plane 1
Default value: 0
Saved in: -
General.Clip2A
First coefficient in equation for clipping plane 2
Default value: 0
Saved in: -
General.Clip2B
Second coefficient in equation for clipping plane 2
Default value: 0
Saved in: -
General.Clip2C
Third coefficient in equation for clipping plane 2
Default value: 1
Saved in: -
General.Clip2D
Fourth coefficient in equation for clipping plane 2
Default value: 0
Saved in: -
General.Clip3A
First coefficient in equation for clipping plane 3
Default value: -1
Saved in: -
General.Clip3B
Second coefficient in equation for clipping plane 3
Default value: 0
Saved in: -
General.Clip3C
Third coefficient in equation for clipping plane 3
Default value: 0
Saved in: -
General.Clip3D
Fourth coefficient in equation for clipping plane 3
Default value: 1
Saved in: -
164 Gmsh 4.0
General.Clip4A
First coefficient in equation for clipping plane 4
Default value: 0
Saved in: -
General.Clip4B
Second coefficient in equation for clipping plane 4
Default value: -1
Saved in: -
General.Clip4C
Third coefficient in equation for clipping plane 4
Default value: 0
Saved in: -
General.Clip4D
Fourth coefficient in equation for clipping plane 4
Default value: 1
Saved in: -
General.Clip5A
First coefficient in equation for clipping plane 5
Default value: 0
Saved in: -
General.Clip5B
Second coefficient in equation for clipping plane 5
Default value: 0
Saved in: -
General.Clip5C
Third coefficient in equation for clipping plane 5
Default value: -1
Saved in: -
General.Clip5D
Fourth coefficient in equation for clipping plane 5
Default value: 1
Saved in: -
General.ClipFactor
Near and far clipping plane distance factor (decrease value for better z-buffer
resolution)
Default value: 5
Saved in: -
General.ClipOnlyDrawIntersectingVolume
Only draw layer of elements that intersect the clipping plane
Default value: 0
Saved in: General.OptionsFileName
Appendix B: Options 165
General.ClipOnlyVolume
Only clip volume elements
Default value: 0
Saved in: General.OptionsFileName
General.ClipPositionX
Horizontal position (in pixels) of the upper left corner of the clipping planes
window
Default value: 650
Saved in: General.SessionFileName
General.ClipPositionY
Vertical position (in pixels) of the upper left corner of the clipping planes win-
dow
Default value: 150
Saved in: General.SessionFileName
General.ClipWholeElements
Clip whole elements
Default value: 0
Saved in: General.OptionsFileName
General.ColorScheme
Default color scheme for graphics (0=dark, 1=light, 2=grayscale, 3=reverse)
Default value: 1
Saved in: General.SessionFileName
General.ConfirmOverwrite
Ask confirmation before overwriting files?
Default value: 1
Saved in: General.OptionsFileName
General.ContextPositionX
Horizontal position (in pixels) of the upper left corner of the contextual windows
Default value: 650
Saved in: General.SessionFileName
General.ContextPositionY
Vertical position (in pixels) of the upper left corner of the contextual windows
Default value: 150
Saved in: General.SessionFileName
General.DetachedMenu
Should the menu window be detached from the graphic window?
Default value: 0
Saved in: General.SessionFileName
General.DisplayBorderFactor
Border factor for model display (0: model fits window size exactly)
Default value: 0.2
Saved in: General.OptionsFileName
166 Gmsh 4.0
General.DoubleBuffer
Use a double buffered graphic window (on Unix, should be set to 0 when working
on a remote host without GLX)
Default value: 1
Saved in: General.OptionsFileName
General.DrawBoundingBoxes
Draw bounding boxes
Default value: 0
Saved in: General.OptionsFileName
General.ExpertMode
Enable expert mode (to disable all the messages meant for inexperienced users)
Default value: 0
Saved in: General.OptionsFileName
General.ExtraPositionX
Horizontal position (in pixels) of the upper left corner of the generic extra
window
Default value: 650
Saved in: General.SessionFileName
General.ExtraPositionY
Vertical position (in pixels) of the upper left corner of the generic extra window
Default value: 350
Saved in: General.SessionFileName
General.ExtraHeight
Height (in pixels) of the generic extra window
Default value: 100
Saved in: General.SessionFileName
General.ExtraWidth
Width (in pixels) of the generic extra window
Default value: 100
Saved in: General.SessionFileName
General.FastRedraw
Draw simplified model while rotating, panning and zooming
Default value: 0
Saved in: General.OptionsFileName
General.FieldPositionX
Horizontal position (in pixels) of the upper left corner of the field window
Default value: 650
Saved in: General.SessionFileName
General.FieldPositionY
Vertical position (in pixels) of the upper left corner of the field window
Default value: 550
Saved in: General.SessionFileName
Appendix B: Options 167
General.FieldHeight
Height (in pixels) of the field window
Default value: 320
Saved in: General.SessionFileName
General.FieldWidth
Width (in pixels) of the field window
Default value: 420
Saved in: General.SessionFileName
General.FileChooserPositionX
Horizontal position (in pixels) of the upper left corner of the file chooser windows
Default value: 200
Saved in: General.SessionFileName
General.FileChooserPositionY
Vertical position (in pixels) of the upper left corner of the file chooser windows
Default value: 200
Saved in: General.SessionFileName
General.FltkColorScheme
FLTK user interface color theme (0: standard, 1:dark)
Default value: 0
Saved in: General.SessionFileName
General.FontSize
Size of the font in the user interface, in pixels (-1: automatic)
Default value: -1
Saved in: General.OptionsFileName
General.GraphicsFontSize
Size of the font in the graphic window, in pixels
Default value: 15
Saved in: General.OptionsFileName
General.GraphicsFontSizeTitle
Size of the font in the graphic window for titles, in pixels
Default value: 18
Saved in: General.OptionsFileName
General.GraphicsHeight
Height (in pixels) of the graphic window
Default value: 600
Saved in: General.SessionFileName
General.GraphicsPositionX
Horizontal position (in pixels) of the upper left corner of the graphic window
Default value: 50
Saved in: General.SessionFileName
168 Gmsh 4.0
General.GraphicsPositionY
Vertical position (in pixels) of the upper left corner of the graphic window
Default value: 50
Saved in: General.SessionFileName
General.GraphicsWidth
Width (in pixels) of the graphic window
Default value: 800
Saved in: General.SessionFileName
General.HighOrderToolsPositionX
Horizontal position (in pixels) of the upper left corner of the high order tools
window
Default value: 650
Saved in: General.SessionFileName
General.HighOrderToolsPositionY
Vertical position (in pixels) of the upper left corner of the high order tools
window
Default value: 150
Saved in: General.SessionFileName
General.HighResolutionGraphics
Use high-resolution OpenGL graphics (e.g. for Macs with retina displays)
Default value: 1
Saved in: General.OptionsFileName
General.HighResolutionPointSizeFactor
Point size factor when using high-resolution OpenGL graphics
Default value: 2
Saved in: General.OptionsFileName
General.InitialModule
Module launched on startup (0=automatic, 1=geometry, 2=mesh, 3=solver,
4=post-processing)
Default value: 0
Saved in: General.OptionsFileName
General.Light0
Enable light source 0
Default value: 1
Saved in: General.OptionsFileName
General.Light0X
X position of light source 0
Default value: 0.65
Saved in: General.OptionsFileName
General.Light0Y
Y position of light source 0
Default value: 0.65
Saved in: General.OptionsFileName
Appendix B: Options 169
General.Light0Z
Z position of light source 0
Default value: 1
Saved in: General.OptionsFileName
General.Light0W
Divisor of the X, Y and Z coordinates of light source 0 (W=0 means infinitely
far source)
Default value: 0
Saved in: General.OptionsFileName
General.Light1
Enable light source 1
Default value: 0
Saved in: General.OptionsFileName
General.Light1X
X position of light source 1
Default value: 0.5
Saved in: General.OptionsFileName
General.Light1Y
Y position of light source 1
Default value: 0.3
Saved in: General.OptionsFileName
General.Light1Z
Z position of light source 1
Default value: 1
Saved in: General.OptionsFileName
General.Light1W
Divisor of the X, Y and Z coordinates of light source 1 (W=0 means infinitely
far source)
Default value: 0
Saved in: General.OptionsFileName
General.Light2
Enable light source 2
Default value: 0
Saved in: General.OptionsFileName
General.Light2X
X position of light source 2
Default value: 0.5
Saved in: General.OptionsFileName
General.Light2Y
Y position of light source 2
Default value: 0.3
Saved in: General.OptionsFileName
170 Gmsh 4.0
General.Light2Z
Z position of light source 2
Default value: 1
Saved in: General.OptionsFileName
General.Light2W
Divisor of the X, Y and Z coordinates of light source 2 (W=0 means infinitely
far source)
Default value: 0
Saved in: General.OptionsFileName
General.Light3
Enable light source 3
Default value: 0
Saved in: General.OptionsFileName
General.Light3X
X position of light source 3
Default value: 0.5
Saved in: General.OptionsFileName
General.Light3Y
Y position of light source 3
Default value: 0.3
Saved in: General.OptionsFileName
General.Light3Z
Z position of light source 3
Default value: 1
Saved in: General.OptionsFileName
General.Light3W
Divisor of the X, Y and Z coordinates of light source 3 (W=0 means infinitely
far source)
Default value: 0
Saved in: General.OptionsFileName
General.Light4
Enable light source 4
Default value: 0
Saved in: General.OptionsFileName
General.Light4X
X position of light source 4
Default value: 0.5
Saved in: General.OptionsFileName
General.Light4Y
Y position of light source 4
Default value: 0.3
Saved in: General.OptionsFileName
Appendix B: Options 171
General.Light4Z
Z position of light source 4
Default value: 1
Saved in: General.OptionsFileName
General.Light4W
Divisor of the X, Y and Z coordinates of light source 4 (W=0 means infinitely
far source)
Default value: 0
Saved in: General.OptionsFileName
General.Light5
Enable light source 5
Default value: 0
Saved in: General.OptionsFileName
General.Light5X
X position of light source 5
Default value: 0.5
Saved in: General.OptionsFileName
General.Light5Y
Y position of light source 5
Default value: 0.3
Saved in: General.OptionsFileName
General.Light5Z
Z position of light source 5
Default value: 1
Saved in: General.OptionsFileName
General.Light5W
Divisor of the X, Y and Z coordinates of light source 5 (W=0 means infinitely
far source)
Default value: 0
Saved in: General.OptionsFileName
General.LineWidth
Display width of lines (in pixels)
Default value: 1
Saved in: General.OptionsFileName
General.ManipulatorPositionX
Horizontal position (in pixels) of the upper left corner of the manipulator win-
dow
Default value: 650
Saved in: General.SessionFileName
General.ManipulatorPositionY
Vertical position (in pixels) of the upper left corner of the manipulator window
Default value: 150
Saved in: General.SessionFileName
172 Gmsh 4.0
General.MaxX
Maximum model coordinate along the X-axis (read-only)
Default value: 0
Saved in: -
General.MaxY
Maximum model coordinate along the Y-axis (read-only)
Default value: 0
Saved in: -
General.MaxZ
Maximum model coordinate along the Z-axis (read-only)
Default value: 0
Saved in: -
General.MenuWidth
Width (in pixels) of the menu tree
Default value: 200
Saved in: General.SessionFileName
General.MenuHeight
Height (in pixels) of the (detached) menu tree
Default value: 200
Saved in: General.SessionFileName
General.MenuPositionX
Horizontal position (in pixels) of the (detached) menu tree
Default value: 400
Saved in: General.SessionFileName
General.MenuPositionY
Vertical position (in pixels) of the (detached) menu tree
Default value: 400
Saved in: General.SessionFileName
General.MeshDiscrete
Mesh discrete surfaces through automatic parametrization (MUMPS required
for efficiency) (0)
Default value: 0
Saved in: General.OptionsFileName
General.MessageFontSize
Size of the font in the message window, in pixels (-1: automatic)
Default value: -1
Saved in: General.OptionsFileName
General.MessageHeight
Height (in pixels) of the message console when it is visible (should be > 0)
Default value: 300
Saved in: General.SessionFileName
Appendix B: Options 173
General.MinX
Minimum model coordinate along the X-axis (read-only)
Default value: 0
Saved in: -
General.MinY
Minimum model coordinate along the Y-axis (read-only)
Default value: 0
Saved in: -
General.MinZ
Minimum model coordinate along the Z-axis (read-only)
Default value: 0
Saved in: -
General.MouseHoverMeshes
Enable mouse hover on meshes
Default value: 0
Saved in: General.OptionsFileName
General.MouseSelection
Enable mouse selection
Default value: 1
Saved in: General.OptionsFileName
General.NonModalWindows
Force all control windows to be on top of the graphic window ("non-modal")
Default value: 1
Saved in: General.SessionFileName
General.NoPopup
Disable interactive dialog windows in scripts (and use default values instead)
Default value: 0
Saved in: General.OptionsFileName
General.NumThreads
Set (maximum) number of threads
Default value: 1
Saved in: General.OptionsFileName
General.OptionsPositionX
Horizontal position (in pixels) of the upper left corner of the option window
Default value: 650
Saved in: General.SessionFileName
General.OptionsPositionY
Vertical position (in pixels) of the upper left corner of the option window
Default value: 150
Saved in: General.SessionFileName
174 Gmsh 4.0
General.Orthographic
Orthographic projection mode (0=perspective projection)
Default value: 1
Saved in: General.OptionsFileName
General.PluginPositionX
Horizontal position (in pixels) of the upper left corner of the plugin window
Default value: 650
Saved in: General.SessionFileName
General.PluginPositionY
Vertical position (in pixels) of the upper left corner of the plugin window
Default value: 550
Saved in: General.SessionFileName
General.PluginHeight
Height (in pixels) of the plugin window
Default value: 320
Saved in: General.SessionFileName
General.PluginWidth
Width (in pixels) of the plugin window
Default value: 420
Saved in: General.SessionFileName
General.PointSize
Display size of points (in pixels)
Default value: 3
Saved in: General.OptionsFileName
General.PolygonOffsetAlwaysOn
Always apply polygon offset, instead of trying to detect when it is required
Default value: 0
Saved in: General.OptionsFileName
General.PolygonOffsetFactor
Polygon offset factor (offset = factor * DZ + r * units)
Default value: 0.5
Saved in: General.OptionsFileName
General.PolygonOffsetUnits
Polygon offset units (offset = factor * DZ + r * units)
Default value: 1
Saved in: General.OptionsFileName
General.ProgressMeterStep
Increment (in percent) of the progress meter bar
Default value: 20
Saved in: General.OptionsFileName
Appendix B: Options 175
General.QuadricSubdivisions
Number of subdivisions used to draw points or lines as spheres or cylinders
Default value: 6
Saved in: General.OptionsFileName
General.RotationX
First Euler angle (used if Trackball=0)
Default value: 0
Saved in: -
General.RotationY
Second Euler angle (used if Trackball=0)
Default value: 0
Saved in: -
General.RotationZ
Third Euler angle (used if Trackball=0)
Default value: 0
Saved in: -
General.RotationCenterGravity
Rotate around the (pseudo) center of mass instead of (RotationCenterX, Rota-
tionCenterY, RotationCenterZ)
Default value: 1
Saved in: General.OptionsFileName
General.RotationCenterX
X coordinate of the center of rotation
Default value: 0
Saved in: -
General.RotationCenterY
Y coordinate of the center of rotation
Default value: 0
Saved in: -
General.RotationCenterZ
Z coordinate of the center of rotation
Default value: 0
Saved in: -
General.SaveOptions
Automatically save current options in General.OptionsFileName (1) or per
model (2)each time you quit Gmsh?
Default value: 0
Saved in: General.SessionFileName
General.SaveSession
Automatically save session specific information in General.SessionFileName
each time you quit Gmsh?
Default value: 1
Saved in: General.SessionFileName
176 Gmsh 4.0
General.ScaleX
X-axis scale factor
Default value: 1
Saved in: -
General.ScaleY
Y-axis scale factor
Default value: 1
Saved in: -
General.ScaleZ
Z-axis scale factor
Default value: 1
Saved in: -
General.Shininess
Material shininess
Default value: 0.4
Saved in: General.OptionsFileName
General.ShininessExponent
Material shininess exponent (between 0 and 128)
Default value: 40
Saved in: General.OptionsFileName
General.ShowOptionsOnStartup
Show option window on startup
Default value: 0
Saved in: General.OptionsFileName
General.ShowMessagesOnStartup
Show message window on startup
Default value: 0
Saved in: General.OptionsFileName
General.SmallAxes
Display the small axes
Default value: 1
Saved in: General.OptionsFileName
General.SmallAxesPositionX
X position (in pixels) of small axes (< 0: measure from right window edge; >=
1e5: centered)
Default value: -60
Saved in: General.OptionsFileName
General.SmallAxesPositionY
Y position (in pixels) of small axes (< 0: measure from bottom window edge;
>= 1e5: centered)
Default value: -40
Saved in: General.OptionsFileName
Appendix B: Options 177
General.SmallAxesSize
Size (in pixels) of small axes
Default value: 30
Saved in: General.OptionsFileName
General.StatisticsPositionX
Horizontal position (in pixels) of the upper left corner of the statistic window
Default value: 650
Saved in: General.SessionFileName
General.StatisticsPositionY
Vertical position (in pixels) of the upper left corner of the statistic window
Default value: 150
Saved in: General.SessionFileName
General.Stereo
Use stereo rendering
Default value: 0
Saved in: General.OptionsFileName
General.SystemMenuBar
Use the system menu bar on Mac OS X?
Default value: 1
Saved in: General.SessionFileName
General.Terminal
Should information be printed on the terminal (if available)?
Default value: 0
Saved in: General.OptionsFileName
General.Tooltips
Show tooltips in the user interface
Default value: 1
Saved in: General.OptionsFileName
General.Trackball
Use trackball rotation mode
Default value: 1
Saved in: General.OptionsFileName
General.TrackballHyperbolicSheet
Use hyperbolic sheet away from trackball center for z-rotations
Default value: 1
Saved in: General.OptionsFileName
General.TrackballQuaternion0
First trackball quaternion component (used if General.Trackball=1)
Default value: 0
Saved in: -
178 Gmsh 4.0
General.TrackballQuaternion1
Second trackball quaternion component (used if General.Trackball=1)
Default value: 0
Saved in: -
General.TrackballQuaternion2
Third trackball quaternion component (used if General.Trackball=1)
Default value: 0
Saved in: -
General.TrackballQuaternion3
Fourth trackball quaternion component (used if General.Trackball=1)
Default value: 1
Saved in: -
General.TranslationX
X-axis translation (in model units)
Default value: 0
Saved in: -
General.TranslationY
Y-axis translation (in model units)
Default value: 0
Saved in: -
General.TranslationZ
Z-axis translation (in model units)
Default value: 0
Saved in: -
General.VectorType
Default vector display type (for normals, etc.)
Default value: 4
Saved in: General.OptionsFileName
General.Verbosity
Level of information printed during processing (0=no information)
Default value: 5
Saved in: General.OptionsFileName
General.VisibilityPositionX
Horizontal position (in pixels) of the upper left corner of the visibility window
Default value: 650
Saved in: General.SessionFileName
General.VisibilityPositionY
Vertical position (in pixels) of the upper left corner of the visibility window
Default value: 150
Saved in: General.SessionFileName
Appendix B: Options 179
General.ZoomFactor
Middle mouse button zoom acceleration factor
Default value: 4
Saved in: General.OptionsFileName
General.Color.Background
Background color
Default value: {255,255,255}
Saved in: General.OptionsFileName
General.Color.BackgroundGradient
Background gradient color
Default value: {208,215,255}
Saved in: General.OptionsFileName
General.Color.Foreground
Foreground color
Default value: {85,85,85}
Saved in: General.OptionsFileName
General.Color.Text
Text color
Default value: {0,0,0}
Saved in: General.OptionsFileName
General.Color.Axes
Axes color
Default value: {0,0,0}
Saved in: General.OptionsFileName
General.Color.SmallAxes
Small axes color
Default value: {0,0,0}
Saved in: General.OptionsFileName
General.Color.AmbientLight
Ambient light color
Default value: {25,25,25}
Saved in: General.OptionsFileName
General.Color.DiffuseLight
Diffuse light color
Default value: {255,255,255}
Saved in: General.OptionsFileName
General.Color.SpecularLight
Specular light color
Default value: {255,255,255}
Saved in: General.OptionsFileName
Print.ParameterCommand
Command parsed when the print parameter is changed
Default value: "Mesh.Clip=1; View.Clip=1; General.ClipWholeElements=1;
180 Gmsh 4.0
General.Clip0D=Print.Parameter; SetChanged;"
Saved in: General.OptionsFileName
Print.Parameter
Current value of the print parameter
Default value: 0
Saved in: General.OptionsFileName
Print.ParameterFirst
First value of print parameter in loop
Default value: -1
Saved in: General.OptionsFileName
Print.ParameterLast
Last value of print parameter in loop
Default value: 1
Saved in: General.OptionsFileName
Print.ParameterSteps
Number of steps in loop over print parameter
Default value: 10
Saved in: General.OptionsFileName
Print.Background
Print background (gradient and image)?
Default value: 0
Saved in: General.OptionsFileName
Print.CompositeWindows
Composite all window tiles in the same output image (for bitmap output only)
Default value: 0
Saved in: General.OptionsFileName
Print.PgfTwoDim
Output PGF format for two dimensions. Mostly irrelevant if ‘PgfExpor-
tAxis=0‘. Default ‘1‘ (yes).
Default value: 1
Saved in: General.OptionsFileName
Print.PgfExportAxis
Include axis in export pgf code (not in the png). Default ‘0‘ (no).
Default value: 0
Saved in: General.OptionsFileName
Print.PgfHorizontalBar
Use a horizontal color bar in the pgf output. Default ‘0‘ (no).
Default value: 0
Saved in: General.OptionsFileName
Print.DeleteTemporaryFiles
Delete temporary files used during printing
Default value: 1
Saved in: General.OptionsFileName
Appendix B: Options 181
Print.EpsBestRoot
Try to minimize primitive splitting in BSP tree sorted PostScript/PDF output
Default value: 1
Saved in: General.OptionsFileName
Print.EpsCompress
Compress PostScript/PDF output using zlib
Default value: 0
Saved in: General.OptionsFileName
Print.EpsLineWidthFactor
Width factor for lines in PostScript/PDF output
Default value: 1
Saved in: General.OptionsFileName
Print.EpsOcclusionCulling
Cull occluded primitives (to reduce PostScript/PDF file size)
Default value: 1
Saved in: General.OptionsFileName
Print.EpsPointSizeFactor
Size factor for points in PostScript/PDF output
Default value: 1
Saved in: General.OptionsFileName
Print.EpsPS3Shading
Enable PostScript Level 3 shading
Default value: 0
Saved in: General.OptionsFileName
Print.EpsQuality
PostScript/PDF quality (0=bitmap, 1=vector (simple sort), 2=vector (accurate
sort), 3=vector (unsorted)
Default value: 1
Saved in: General.OptionsFileName
Print.Format
File format (10=automatic)
Default value: 10
Saved in: General.OptionsFileName
Print.GeoLabels
Save labels in unrolled Gmsh geometries
Default value: 1
Saved in: General.OptionsFileName
Print.GeoOnlyPhysicals
Only save entities that belong to physical groups
Default value: 0
Saved in: General.OptionsFileName
182 Gmsh 4.0
Print.GifDither
Apply dithering to GIF output
Default value: 0
Saved in: General.OptionsFileName
Print.GifInterlace
Interlace GIF output
Default value: 0
Saved in: General.OptionsFileName
Print.GifSort
Sort the colormap in GIF output
Default value: 1
Saved in: General.OptionsFileName
Print.GifTransparent
Output transparent GIF image
Default value: 0
Saved in: General.OptionsFileName
Print.Height
Height of printed image; use (possibly scaled) current height if < 0
Default value: -1
Saved in: General.OptionsFileName
Print.JpegQuality
JPEG quality (between 1 and 100)
Default value: 100
Saved in: General.OptionsFileName
Print.JpegSmoothing
JPEG smoothing (between 0 and 100)
Default value: 0
Saved in: General.OptionsFileName
Print.PostElementary
Save elementary region tags in mesh statistics exported as post-processing views
Default value: 1
Saved in: General.OptionsFileName
Print.PostElement
Save element numbers in mesh statistics exported as post-processing views
Default value: 0
Saved in: General.OptionsFileName
Print.PostGamma
Save Gamma quality measure in mesh statistics exported as post-processing
views
Default value: 0
Saved in: General.OptionsFileName
Appendix B: Options 183
Print.PostEta
Save Eta quality measure in mesh statistics exported as post-processing views
Default value: 0
Saved in: General.OptionsFileName
Print.PostSICN
Save SICN (signed inverse condition number) quality measure in mesh statistics
exported as post-processing views
Default value: 0
Saved in: General.OptionsFileName
Print.PostSIGE
Save SIGE (signed inverse gradient error) quality measure in mesh statistics
exported as post-processing views
Default value: 0
Saved in: General.OptionsFileName
Print.PostDisto
Save Disto quality measure in mesh statistics exported as post-processing views
Default value: 0
Saved in: General.OptionsFileName
Print.TexAsEquation
Print all TeX strings as equations
Default value: 0
Saved in: General.OptionsFileName
Print.Text
Print text strings?
Default value: 1
Saved in: General.OptionsFileName
Print.X3dCompatibility
Produce highliy compatible X3D output (no scale bar)
Default value: 0
Saved in: General.OptionsFileName
Print.X3dPrecision
Precision of X3D output
Default value: 1e-09
Saved in: General.OptionsFileName
Print.X3dRemoveInnerBorders
Remove inner borders in X3D output
Default value: 0
Saved in: General.OptionsFileName
Print.X3dTransparency
Transparency for X3D output
Default value: 0
Saved in: General.OptionsFileName
184 Gmsh 4.0
Print.Width
Width of printed image; use (possibly scaled) current width if < 0)
Default value: -1
Saved in: General.OptionsFileName
Geometry.DoubleClickedEntityTag
Tag of last double-clicked geometrical entity
Default value: 0
Saved in: -
Geometry.ExactExtrusion
Use exact extrusion formula in interpolations (set to 0 to allow geometrical
transformations of extruded entities)
Default value: 1
Saved in: General.OptionsFileName
Geometry.ExtrudeReturnLateralEntities
Add lateral entities in lists returned by extrusion commands?
Default value: 1
Saved in: General.OptionsFileName
Geometry.ExtrudeSplinePoints
Number of control points for splines created during extrusion
Default value: 5
Saved in: General.OptionsFileName
Geometry.HighlightOrphans
Highlight orphan entities (lines connected to a single surface, etc.)?
Default value: 0
Saved in: General.OptionsFileName
Geometry.LabelType
Type of entity label (0=description, 1=elementary number, 2=physical num-
ber)
Default value: 0
Saved in: General.OptionsFileName
Geometry.Light
Enable lighting for the geometry
Default value: 1
Saved in: General.OptionsFileName
Geometry.LightTwoSide
Light both sides of surfaces (leads to slower rendering)
Default value: 1
Saved in: General.OptionsFileName
Geometry.Lines
Display geometry curves?
Default value: 1
Saved in: General.OptionsFileName
Geometry.LineNumbers
Display curve numbers?
Default value: 0
Saved in: General.OptionsFileName
186 Gmsh 4.0
Geometry.LineSelectWidth
Display width of selected curves (in pixels)
Default value: 3
Saved in: General.OptionsFileName
Geometry.LineType
Display curves as solid color segments (0), 3D cylinders (1) or tapered cylinders
(2)
Default value: 0
Saved in: General.OptionsFileName
Geometry.LineWidth
Display width of lines (in pixels)
Default value: 2
Saved in: General.OptionsFileName
Geometry.MatchGeomAndMesh
Matches geometries and meshes
Default value: 0
Saved in: General.OptionsFileName
Geometry.MatchMeshScaleFactor
Rescaling factor for the mesh to correspond to size of the geometry
Default value: 1
Saved in: General.OptionsFileName
Geometry.MatchMeshTolerance
Tolerance for matching mesh and geometry
Default value: 1e-06
Saved in: General.OptionsFileName
Geometry.Normals
Display size of normal vectors (in pixels)
Default value: 0
Saved in: General.OptionsFileName
Geometry.NumSubEdges
Number of edge subdivisions between control points when displaying curves
Default value: 40
Saved in: General.OptionsFileName
Geometry.OCCAutoFix
Automatically fix orientation of wires, faces, shells and volumes when creating
new entities
Default value: 1
Saved in: General.OptionsFileName
Geometry.OCCDisableSTL
Disable STL computation
Default value: 0
Saved in: General.OptionsFileName
Appendix B: Options 187
Geometry.OCCFixDegenerated
Fix degenerated edges/faces in STEP, IGES and BRep models
Default value: 0
Saved in: General.OptionsFileName
Geometry.OCCFixSmallEdges
Fix small edges in STEP, IGES and BRep models
Default value: 0
Saved in: General.OptionsFileName
Geometry.OCCFixSmallFaces
Fix small faces in STEP, IGES and BRep models
Default value: 0
Saved in: General.OptionsFileName
Geometry.OCCSewFaces
Sew faces in STEP, IGES and BRep models
Default value: 0
Saved in: General.OptionsFileName
Geometry.OCCParallel
Use multi-threaded OCC boolean operators
Default value: 0
Saved in: General.OptionsFileName
Geometry.OCCBooleanPreserveNumbering
Try to preserve numbering of entities through OCC boolean operations
Default value: 1
Saved in: General.OptionsFileName
Geometry.OCCScaling
Scale STEP, IGES and BRep model by given factor
Default value: 1
Saved in: General.OptionsFileName
Geometry.OffsetX
Model display offset along X-axis (in model coordinates)
Default value: 0
Saved in: -
Geometry.OffsetY
Model display offset along Y-axis (in model coordinates)
Default value: 0
Saved in: -
Geometry.OffsetZ
Model display offset along Z-axis (in model coordinates)
Default value: 0
Saved in: -
188 Gmsh 4.0
Geometry.OldCircle
Use old circle description (compatibility option for old Gmsh geometries)
Default value: 0
Saved in: General.OptionsFileName
Geometry.OldRuledSurface
Use old 3-sided ruled surface interpolation (compatibility option for old Gmsh
geometries)
Default value: 0
Saved in: General.OptionsFileName
Geometry.OldNewReg
Use old newreg definition for geometrical transformations (compatibility option
for old Gmsh geometries)
Default value: 1
Saved in: General.OptionsFileName
Geometry.Points
Display geometry points?
Default value: 1
Saved in: General.OptionsFileName
Geometry.PointNumbers
Display points numbers?
Default value: 0
Saved in: General.OptionsFileName
Geometry.PointSelectSize
Display size of selected points (in pixels)
Default value: 6
Saved in: General.OptionsFileName
Geometry.PointSize
Display size of points (in pixels)
Default value: 4
Saved in: General.OptionsFileName
Geometry.PointType
Display points as solid color dots (0) or 3D spheres (1)
Default value: 0
Saved in: General.OptionsFileName
Geometry.ReparamOnFaceRobust
Use projection for reparametrization of a point classified on GEdge on a GFace
Default value: 0
Saved in: General.OptionsFileName
Geometry.ScalingFactor
Global geometry scaling factor
Default value: 1
Saved in: General.OptionsFileName
Appendix B: Options 189
Geometry.OrientedPhysicals
Use sign of elementary entity in physical definition as orientation indicator
Default value: 1
Saved in: General.OptionsFileName
Geometry.SnapX
Snapping grid spacing along the X-axis
Default value: 0.1
Saved in: General.OptionsFileName
Geometry.SnapY
Snapping grid spacing along the Y-axis
Default value: 0.1
Saved in: General.OptionsFileName
Geometry.SnapZ
Snapping grid spacing along the Z-axis
Default value: 0.1
Saved in: General.OptionsFileName
Geometry.Surfaces
Display geometry surfaces?
Default value: 0
Saved in: General.OptionsFileName
Geometry.SurfaceNumbers
Display surface numbers?
Default value: 0
Saved in: General.OptionsFileName
Geometry.SurfaceType
Surface display type (0=cross, 1=wireframe, 2=solid)
Default value: 0
Saved in: General.OptionsFileName
Geometry.Tangents
Display size of tangent vectors (in pixels)
Default value: 0
Saved in: General.OptionsFileName
Geometry.Tolerance
Geometrical tolerance
Default value: 1e-08
Saved in: General.OptionsFileName
Geometry.ToleranceBoolean
Geometrical tolerance for boolean operations
Default value: 0
Saved in: General.OptionsFileName
190 Gmsh 4.0
Geometry.Transform
Transform model display coordinates (0=no, 1=scale)
Default value: 0
Saved in: -
Geometry.TransformXX
Element (1,1) of the 3x3 model display transformation matrix
Default value: 1
Saved in: -
Geometry.TransformXY
Element (1,2) of the 3x3 model display transformation matrix
Default value: 0
Saved in: -
Geometry.TransformXZ
Element (1,3) of the 3x3 model display transformation matrix
Default value: 0
Saved in: -
Geometry.TransformYX
Element (2,1) of the 3x3 model display transformation matrix
Default value: 0
Saved in: -
Geometry.TransformYY
Element (2,2) of the 3x3 model display transformation matrix
Default value: 1
Saved in: -
Geometry.TransformYZ
Element (2,3) of the 3x3 model display transformation matrix
Default value: 0
Saved in: -
Geometry.TransformZX
Element (3,1) of the 3x3 model display transformation matrix
Default value: 0
Saved in: -
Geometry.TransformZY
Element (3,2) of the 3x3 model display transformation matrix
Default value: 0
Saved in: -
Geometry.TransformZZ
Element (3,3) of the 3x3 model display transformation matrix
Default value: 1
Saved in: -
Appendix B: Options 191
Geometry.Volumes
Display geometry volumes? (not implemented yet)
Default value: 0
Saved in: General.OptionsFileName
Geometry.VolumeNumbers
Display volume numbers? (not implemented yet)
Default value: 0
Saved in: General.OptionsFileName
Geometry.Color.Points
Normal geometry point color
Default value: {90,90,90}
Saved in: General.OptionsFileName
Geometry.Color.Lines
Normal geometry curve color
Default value: {0,0,255}
Saved in: General.OptionsFileName
Geometry.Color.Surfaces
Normal geometry surface color
Default value: {128,128,128}
Saved in: General.OptionsFileName
Geometry.Color.Volumes
Normal geometry volume color
Default value: {255,255,0}
Saved in: General.OptionsFileName
Geometry.Color.Selection
Selected geometry color
Default value: {255,0,0}
Saved in: General.OptionsFileName
Geometry.Color.HighlightZero
Highlight 0 color
Default value: {255,0,0}
Saved in: General.OptionsFileName
Geometry.Color.HighlightOne
Highlight 1 color
Default value: {255,150,0}
Saved in: General.OptionsFileName
Geometry.Color.HighlightTwo
Highlight 2 color
Default value: {255,255,0}
Saved in: General.OptionsFileName
192 Gmsh 4.0
Geometry.Color.Tangents
Tangent geometry vectors color
Default value: {255,255,0}
Saved in: General.OptionsFileName
Geometry.Color.Normals
Normal geometry vectors color
Default value: {255,0,0}
Saved in: General.OptionsFileName
Geometry.Color.Projection
Projection surface color
Default value: {0,255,0}
Saved in: General.OptionsFileName
Mesh.BdfFieldFormat
Field format for Nastran BDF files (0=free, 1=small, 2=large)
Default value: 1
Saved in: General.OptionsFileName
Mesh.Binary
Write mesh files in binary format (if possible)
Default value: 0
Saved in: General.OptionsFileName
Mesh.BoundaryLayerFanPoints
Number of points (per Pi rad) for 2D boundary layer fans
Default value: 5
Saved in: General.OptionsFileName
Mesh.CgnsImportOrder
Enable the creation of high-order mesh from CGNS structured meshes(1, 2, 4,
8, ...)
Default value: 1
Saved in: General.OptionsFileName
Mesh.CgnsConstructTopology
Reconstruct the model topology (BREP) after reading a CGNS file
Default value: 0
Saved in: General.OptionsFileName
Mesh.CharacteristicLengthExtendFromBoundary
Extend computation of mesh element sizes from the boundaries into the sur-
faces/volumes
Default value: 1
Saved in: General.OptionsFileName
Mesh.CharacteristicLengthFactor
Factor applied to all mesh element sizes
Default value: 1
Saved in: General.OptionsFileName
Mesh.CharacteristicLengthMin
Minimum mesh element size
Default value: 0
Saved in: General.OptionsFileName
Mesh.CharacteristicLengthMax
Maximum mesh element size
Default value: 1e+22
Saved in: General.OptionsFileName
Mesh.CharacteristicLengthFromCurvature
Automatically compute mesh element sizes from curvature (experimental)
Default value: 0
Saved in: General.OptionsFileName
194 Gmsh 4.0
Mesh.CharacteristicLengthFromPoints
Compute mesh element sizes from values given at geometry points
Default value: 1
Saved in: General.OptionsFileName
Mesh.Clip
Enable clipping planes? (Plane[i]=2^i, i=0,...,5)
Default value: 0
Saved in: -
Mesh.ColorCarousel
Mesh coloring (0=by element type, 1=by elementary entity, 2=by physical en-
tity, 3=by partition)
Default value: 1
Saved in: General.OptionsFileName
Mesh.CpuTime
CPU time (in seconds) for the generation of the current mesh (read-only)
Default value: 0
Saved in: -
Mesh.DrawSkinOnly
Draw only the skin of 3D meshes?
Default value: 0
Saved in: General.OptionsFileName
Mesh.Dual
Display the dual mesh obtained by barycentric subdivision
Default value: 0
Saved in: General.OptionsFileName
Mesh.ElementOrder
Element order (1=linear elements, N (<6) = elements of higher order)
Default value: 1
Saved in: General.OptionsFileName
Mesh.Explode
Element shrinking factor (between 0 and 1)
Default value: 1
Saved in: General.OptionsFileName
Mesh.FlexibleTransfinite
Allow transfinite constraints to be modified for Blossom or by global mesh size
factor
Default value: 0
Saved in: General.OptionsFileName
Mesh.NewtonConvergenceTestXYZ
Force inverse surface mapping algorithm (Newton-Raphson) to converge in real
coordinates (experimental)
Default value: 0
Saved in: General.OptionsFileName
Appendix B: Options 195
Mesh.Format
Mesh output format (1=msh, 2=unv, 10=auto, 16=vtk, 19=vrml, 21=mail,
26=pos stat, 27=stl, 28=p3d, 30=mesh, 31=bdf, 32=cgns, 33=med, 34=diff,
38=ir3, 39=inp, 40=ply2, 41=celum, 42=su2, 47=tochnog, 49=neu, 50=mat-
lab)
Default value: 10
Saved in: General.OptionsFileName
Mesh.Hexahedra
Display mesh hexahedra?
Default value: 1
Saved in: General.OptionsFileName
Mesh.HighOrderNumLayers
Number of high order mesh elements to consider for optimization
Default value: 6
Saved in: -
Mesh.HighOrderOptimize
Optimize high order meshes?
Default value: 0
Saved in: General.OptionsFileName
Mesh.HighOrderPoissonRatio
Poisson ratio of the material used in the elastic smoother for high order mesh-
esMust be between -1.0 and 0.5, excluded
Default value: 0.33
Saved in: -
Mesh.HighOrderThresholdMin
Minimum threshold for high order element optimization
Default value: 0.1
Saved in: General.OptionsFileName
Mesh.HighOrderThresholdMax
Maximum threshold for high order element optimization
Default value: 2
Saved in: General.OptionsFileName
Mesh.HighOrderOptPrimSurfMesh
Try to fix flipped surface mesh elements in high-order optimizer
Default value: 0
Saved in: General.OptionsFileName
Mesh.LabelSampling
Label sampling rate (display one label every ‘LabelSampling’ elements)
Default value: 1
Saved in: General.OptionsFileName
Mesh.LabelType
Type of element label (0=element number, 1=elementary entity number,
2=physical entity number, 3=partition number, 4=coordinates)
196 Gmsh 4.0
Default value: 0
Saved in: General.OptionsFileName
Mesh.LcIntegrationPrecision
Accuracy of evaluation of the LC field for 1D mesh generation
Default value: 1e-09
Saved in: General.OptionsFileName
Mesh.Light
Enable lighting for the mesh
Default value: 1
Saved in: General.OptionsFileName
Mesh.LightLines
Enable lighting for mesh edges (0=no, 1=surfaces, 2=surfaces+volumes
Default value: 2
Saved in: General.OptionsFileName
Mesh.LightTwoSide
Light both sides of surfaces (leads to slower rendering)
Default value: 1
Saved in: General.OptionsFileName
Mesh.Lines
Display mesh lines (1D elements)?
Default value: 0
Saved in: General.OptionsFileName
Mesh.LineNumbers
Display mesh line numbers?
Default value: 0
Saved in: General.OptionsFileName
Mesh.LineWidth
Display width of mesh lines (in pixels)
Default value: 1
Saved in: General.OptionsFileName
Mesh.MaxNumThreads1D
Maximum number of threads for 1D meshing (0: use default number of threads)
Default value: 0
Saved in: General.OptionsFileName
Mesh.MaxNumThreads2D
Maximum number of threads for 2D meshing (0: use default number of threads)
Default value: 0
Saved in: General.OptionsFileName
Mesh.MaxNumThreads3D
Maximum number of threads for 3D meshing (0: use default number of threads)
Default value: 0
Saved in: General.OptionsFileName
Appendix B: Options 197
Mesh.MeshOnlyVisible
Mesh only visible entities (experimental: use with caution!)
Default value: 0
Saved in: General.OptionsFileName
Mesh.MetisAlgorithm
METIS partitioning algorithm (1=Recursive, 2=K-way)
Default value: 1
Saved in: General.OptionsFileName
Mesh.MetisEdgeMatching
METIS edge matching type (1=Random, 2=Sorted Heavy-Edge)
Default value: 2
Saved in: General.OptionsFileName
Mesh.MetisRefinementAlgorithm
METIS algorithm for k-way refinement (1=FM-based cut, 2=Greedy, 3=Two-
sided node FM, 4=One-sided node FM)
Default value: 2
Saved in: General.OptionsFileName
Mesh.MinimumCirclePoints
Minimum number of points used to mesh a circle
Default value: 7
Saved in: General.OptionsFileName
Mesh.MinimumCurvePoints
Minimum number of points used to mesh a (non-straight) curve
Default value: 3
Saved in: General.OptionsFileName
Mesh.MshFileVersion
Version of the MSH file format to use
Default value: 2.2
Saved in: General.OptionsFileName
Mesh.PartitionHexWeight
Weight of hexahedral element for METIS load balancing
Default value: 1
Saved in: General.OptionsFileName
Mesh.PartitionPrismWeight
Weight of prismatic element (wedge) for METIS load balancing
Default value: 1
Saved in: General.OptionsFileName
Mesh.PartitionPyramidWeight
Weight of pyramidal element for METIS load balancing
Default value: 1
Saved in: General.OptionsFileName
198 Gmsh 4.0
Mesh.PartitionTrihedronWeight
Weight of trihedron element for METIS load balancing
Default value: 0
Saved in: General.OptionsFileName
Mesh.PartitionQuadWeight
Weight of quadrangle for METIS load balancing
Default value: 1
Saved in: General.OptionsFileName
Mesh.PartitionTetWeight
Weight of tetrahedral element for METIS load balancing
Default value: 1
Saved in: General.OptionsFileName
Mesh.PartitionTriWeight
Weight of triangle element for METIS load balancing
Default value: 1
Saved in: General.OptionsFileName
Mesh.PartitionCreateTopology
Create boundary representation of partitions
Default value: 1
Saved in: General.OptionsFileName
Mesh.PartitionCreatePhysicals
Create physical groups for partitions, based on existing physical groups
Default value: 1
Saved in: General.OptionsFileName
Mesh.PartitionCreateGhostCells
Create partition ghost cells
Default value: 0
Saved in: General.OptionsFileName
Mesh.PartitionSplitMeshFiles
Write one file for each mesh partition
Default value: 0
Saved in: General.OptionsFileName
Mesh.PartitionTopologyFile
Write a .pro file with the partition topology
Default value: 0
Saved in: General.OptionsFileName
Mesh.NbHexahedra
Number of hexahedra in the current mesh (read-only)
Default value: 0
Saved in: -
Appendix B: Options 199
Mesh.NbNodes
Number of nodes in the current mesh (read-only)
Default value: 0
Saved in: -
Mesh.NbPartitions
Number of partitions
Default value: 0
Saved in: General.OptionsFileName
Mesh.NbPrisms
Number of prisms in the current mesh (read-only)
Default value: 0
Saved in: -
Mesh.NbPyramids
Number of pyramids in the current mesh (read-only)
Default value: 0
Saved in: -
Mesh.NbTrihedra
Number of trihedra in the current mesh (read-only)
Default value: 0
Saved in: -
Mesh.NbQuadrangles
Number of quadrangles in the current mesh (read-only)
Default value: 0
Saved in: -
Mesh.NbTetrahedra
Number of tetrahedra in the current mesh (read-only)
Default value: 0
Saved in: -
Mesh.NbTriangles
Number of triangles in the current mesh (read-only)
Default value: 0
Saved in: -
Mesh.Normals
Display size of normal vectors (in pixels)
Default value: 0
Saved in: General.OptionsFileName
Mesh.NumSubEdges
Number of edge subdivisions when displaying high order elements
Default value: 2
Saved in: General.OptionsFileName
200 Gmsh 4.0
Mesh.OldRefinement
Use old 3D point insertion algorithm
Default value: 1
Saved in: General.OptionsFileName
Mesh.Optimize
Optimize the mesh to improve the quality of tetrahedral elements
Default value: 1
Saved in: General.OptionsFileName
Mesh.OptimizeThreshold
Optimize tetrahedra that have a quality below ...
Default value: 0.3
Saved in: General.OptionsFileName
Mesh.OptimizeNetgen
Optimize the mesh using Netgen to improve the quality of tetrahedral elements
Default value: 0
Saved in: General.OptionsFileName
Mesh.Points
Display mesh nodes (vertices)?
Default value: 0
Saved in: General.OptionsFileName
Mesh.PointNumbers
Display mesh node numbers?
Default value: 0
Saved in: General.OptionsFileName
Mesh.PointSize
Display size of mesh nodes (in pixels)
Default value: 4
Saved in: General.OptionsFileName
Mesh.PointType
Display mesh nodes as solid color dots (0) or 3D spheres (1)
Default value: 0
Saved in: General.OptionsFileName
Mesh.Prisms
Display mesh prisms?
Default value: 1
Saved in: General.OptionsFileName
Mesh.Pyramids
Display mesh pyramids?
Default value: 1
Saved in: General.OptionsFileName
Appendix B: Options 201
Mesh.Trihedra
Display mesh trihedra?
Default value: 1
Saved in: General.OptionsFileName
Mesh.Quadrangles
Display mesh quadrangles?
Default value: 1
Saved in: General.OptionsFileName
Mesh.QualityInf
Only display elements whose quality measure is greater than QualityInf
Default value: 0
Saved in: General.OptionsFileName
Mesh.QualitySup
Only display elements whose quality measure is smaller than QualitySup
Default value: 0
Saved in: General.OptionsFileName
Mesh.QualityType
Type of quality measure (0=SICN~signed inverse condition number,
1=SIGE~signed inverse gradient error, 2=gamma~vol/sum face/max edge,
3=Disto~minJ/maxJ
Default value: 2
Saved in: General.OptionsFileName
Mesh.RadiusInf
Only display elements whose longest edge is greater than RadiusInf
Default value: 0
Saved in: General.OptionsFileName
Mesh.RadiusSup
Only display elements whose longest edge is smaller than RadiusSup
Default value: 0
Saved in: General.OptionsFileName
Mesh.RandomFactor
Random factor used in the 2D meshing algorithm (should be increased if Ran-
domFactor * size(triangle)/size(model) approaches machine accuracy)
Default value: 1e-09
Saved in: General.OptionsFileName
Mesh.RandomFactor3D
Random factor used in the 3D meshing algorithm
Default value: 1e-12
Saved in: General.OptionsFileName
Mesh.PreserveNumberingMsh2
Preserve element numbering in MSH2 format (will break meshes with multiple
physical groups for a single elementary entity)
Default value: 0
Saved in: General.OptionsFileName
202 Gmsh 4.0
Mesh.IgnorePeriodicity
Ignore alignment of periodic boundaries when reading the mesh (used by Par-
aView plugin)
Default value: 0
Saved in: General.OptionsFileName
Mesh.RecombinationAlgorithm
Mesh recombination algorithm (0=standard, 1=blossom)
Default value: 1
Saved in: General.OptionsFileName
Mesh.RecombineAll
Apply recombination algorithm to all surfaces, ignoring per-surface spec
Default value: 0
Saved in: General.OptionsFileName
Mesh.Recombine3DAll
Apply recombination3D algorithm to all volumes, ignoring per-volume spec
Default value: 0
Saved in: General.OptionsFileName
Mesh.Recombine3DLevel
3d recombination level (0: hex, 1: hex+prisms, 2: hex+prism+pyramids)
Default value: 0
Saved in: General.OptionsFileName
Mesh.Recombine3DConformity
3d recombination conformity type (0: nonconforming, 1: trihedra, 2: pyra-
mids+trihedra, 3:pyramids+hexSplit+trihedra, 4:hexSplit+trihedra)
Default value: 0
Saved in: General.OptionsFileName
Mesh.DoRecombinationTest
Apply recombination algorithm for test
Default value: 0
Saved in: General.OptionsFileName
Mesh.RecombinationTestHorizStart
Depth start
Default value: 1
Saved in: General.OptionsFileName
Mesh.RecombinationTestNoGreedyStrat
No greedy (global) strategies
Default value: 0
Saved in: General.OptionsFileName
Mesh.RemeshAlgorithm
Remeshing algorithm (0=no split, 1=automatic, 2=automatic only with metis)
Default value: 0
Saved in: General.OptionsFileName
Appendix B: Options 203
Mesh.RemeshParametrization
Remeshing using discrete parametrization (0=harmonic circle, 1=confor-
mal spectral, 2=rbf, 3=harmonic plane, 4=convex circle, 5=convex plane,
6=harmonic square, 7=conformal fe
Default value: 4
Saved in: General.OptionsFileName
Mesh.RefineSteps
Number of refinement steps in the MeshAdapt-based 2D algorithms
Default value: 10
Saved in: General.OptionsFileName
Mesh.SaveAll
Ignore Physical definitions and save all elements
Default value: 0
Saved in: -
Mesh.SaveElementTagType
Type of the element tag saved in mesh formats that don’t support saving phys-
ical or partition ids (1=elementary, 2=physical, 3=partition)
Default value: 1
Saved in: General.OptionsFileName
Mesh.SaveTopology
Save model topology in MSH2 output files (this is always saved in MSH3)
Default value: 0
Saved in: General.OptionsFileName
Mesh.SaveParametric
Save parametric coordinates of nodes
Default value: 0
Saved in: General.OptionsFileName
Mesh.SaveGroupsOfNodes
Save groups of nodes for each physical line and surface (for UNV, INP and
Tochnog mesh formats)
Default value: 0
Saved in: General.OptionsFileName
Mesh.ScalingFactor
Global scaling factor applied to the saved mesh
Default value: 1
Saved in: General.OptionsFileName
Mesh.SecondOrderExperimental
Use experimental code to generate second order mesh
Default value: 0
Saved in: General.OptionsFileName
Mesh.SecondOrderIncomplete
Create incomplete second order elements? (8-node quads, 20-node hexas, etc.)
Default value: 0
Saved in: General.OptionsFileName
204 Gmsh 4.0
Mesh.SecondOrderLinear
Should second order nodes simply be created by linear interpolation?
Default value: 0
Saved in: General.OptionsFileName
Mesh.Smoothing
Number of smoothing steps applied to the final mesh
Default value: 1
Saved in: General.OptionsFileName
Mesh.SmoothCrossField
Apply n barycentric smoothing passes to the cross field
Default value: 0
Saved in: General.OptionsFileName
Mesh.SmoothNormals
Smooth the mesh normals?
Default value: 0
Saved in: General.OptionsFileName
Mesh.SmoothRatio
Ratio between mesh sizes at nodes of a same edge (used in BAMG)
Default value: 1.8
Saved in: General.OptionsFileName
Mesh.SubdivisionAlgorithm
Mesh subdivision algorithm (0=none, 1=all quadrangles, 2=all hexahedra)
Default value: 0
Saved in: General.OptionsFileName
Mesh.SurfaceEdges
Display edges of surface mesh?
Default value: 1
Saved in: General.OptionsFileName
Mesh.SurfaceFaces
Display faces of surface mesh?
Default value: 0
Saved in: General.OptionsFileName
Mesh.SurfaceNumbers
Display surface mesh element numbers?
Default value: 0
Saved in: General.OptionsFileName
Mesh.SwitchElementTags
Invert elementary and physical tags when reading the mesh
Default value: 0
Saved in: General.OptionsFileName
Appendix B: Options 205
Mesh.Tangents
Display size of tangent vectors (in pixels)
Default value: 0
Saved in: General.OptionsFileName
Mesh.Tetrahedra
Display mesh tetrahedra?
Default value: 1
Saved in: General.OptionsFileName
Mesh.ToleranceEdgeLength
Skip a model edge in mesh generation if its length is less than user’s defined
tolerance
Default value: 0
Saved in: General.OptionsFileName
Mesh.ToleranceInitialDelaunay
Tolerance for initial 3D Delaunay mesher
Default value: 1e-08
Saved in: General.OptionsFileName
Mesh.Triangles
Display mesh triangles?
Default value: 1
Saved in: General.OptionsFileName
Mesh.VolumeEdges
Display edges of volume mesh?
Default value: 1
Saved in: General.OptionsFileName
Mesh.VolumeFaces
Display faces of volume mesh?
Default value: 0
Saved in: General.OptionsFileName
Mesh.VolumeNumbers
Display volume mesh element numbers?
Default value: 0
Saved in: General.OptionsFileName
Mesh.Voronoi
Display the voronoi diagram
Default value: 0
Saved in: General.OptionsFileName
Mesh.ZoneDefinition
Method for defining a zone (0=single zone, 1=by partition, 2=by physical)
Default value: 0
Saved in: General.OptionsFileName
206 Gmsh 4.0
Mesh.Color.Points
Mesh node color
Default value: {0,0,255}
Saved in: General.OptionsFileName
Mesh.Color.PointsSup
Second order mesh node color
Default value: {255,0,255}
Saved in: General.OptionsFileName
Mesh.Color.Lines
Mesh line color
Default value: {0,0,0}
Saved in: General.OptionsFileName
Mesh.Color.Triangles
Mesh triangle color (if Mesh.ColorCarousel=0)
Default value: {160,150,255}
Saved in: General.OptionsFileName
Mesh.Color.Quadrangles
Mesh quadrangle color (if Mesh.ColorCarousel=0)
Default value: {130,120,225}
Saved in: General.OptionsFileName
Mesh.Color.Tetrahedra
Mesh tetrahedron color (if Mesh.ColorCarousel=0)
Default value: {160,150,255}
Saved in: General.OptionsFileName
Mesh.Color.Hexahedra
Mesh hexahedron color (if Mesh.ColorCarousel=0)
Default value: {130,120,225}
Saved in: General.OptionsFileName
Mesh.Color.Prisms
Mesh prism color (if Mesh.ColorCarousel=0)
Default value: {232,210,23}
Saved in: General.OptionsFileName
Mesh.Color.Pyramids
Mesh pyramid color (if Mesh.ColorCarousel=0)
Default value: {217,113,38}
Saved in: General.OptionsFileName
Mesh.Color.Trihedra
Mesh trihedron color (if Mesh.ColorCarousel=0)
Default value: {20,255,0}
Saved in: General.OptionsFileName
Appendix B: Options 207
Mesh.Color.Tangents
Tangent mesh vector color
Default value: {255,255,0}
Saved in: General.OptionsFileName
Mesh.Color.Normals
Normal mesh vector color
Default value: {255,0,0}
Saved in: General.OptionsFileName
Mesh.Color.Zero
Color 0 in color carousel
Default value: {255,120,0}
Saved in: General.OptionsFileName
Mesh.Color.One
Color 1 in color carousel
Default value: {0,255,132}
Saved in: General.OptionsFileName
Mesh.Color.Two
Color 2 in color carousel
Default value: {255,160,0}
Saved in: General.OptionsFileName
Mesh.Color.Three
Color 3 in color carousel
Default value: {0,255,192}
Saved in: General.OptionsFileName
Mesh.Color.Four
Color 4 in color carousel
Default value: {255,200,0}
Saved in: General.OptionsFileName
Mesh.Color.Five
Color 5 in color carousel
Default value: {0,216,255}
Saved in: General.OptionsFileName
Mesh.Color.Six
Color 6 in color carousel
Default value: {255,240,0}
Saved in: General.OptionsFileName
Mesh.Color.Seven
Color 7 in color carousel
Default value: {0,176,255}
Saved in: General.OptionsFileName
208 Gmsh 4.0
Mesh.Color.Eight
Color 8 in color carousel
Default value: {228,255,0}
Saved in: General.OptionsFileName
Mesh.Color.Nine
Color 9 in color carousel
Default value: {0,116,255}
Saved in: General.OptionsFileName
Mesh.Color.Ten
Color 10 in color carousel
Default value: {188,255,0}
Saved in: General.OptionsFileName
Mesh.Color.Eleven
Color 11 in color carousel
Default value: {0,76,255}
Saved in: General.OptionsFileName
Mesh.Color.Twelve
Color 12 in color carousel
Default value: {148,255,0}
Saved in: General.OptionsFileName
Mesh.Color.Thirteen
Color 13 in color carousel
Default value: {24,0,255}
Saved in: General.OptionsFileName
Mesh.Color.Fourteen
Color 14 in color carousel
Default value: {108,255,0}
Saved in: General.OptionsFileName
Mesh.Color.Fifteen
Color 15 in color carousel
Default value: {84,0,255}
Saved in: General.OptionsFileName
Mesh.Color.Sixteen
Color 16 in color carousel
Default value: {68,255,0}
Saved in: General.OptionsFileName
Mesh.Color.Seventeen
Color 17 in color carousel
Default value: {104,0,255}
Saved in: General.OptionsFileName
Appendix B: Options 209
Mesh.Color.Eighteen
Color 18 in color carousel
Default value: {0,255,52}
Saved in: General.OptionsFileName
Mesh.Color.Nineteen
Color 19 in color carousel
Default value: {184,0,255}
Saved in: General.OptionsFileName
Solver.Executable8
System command to launch solver 8
Default value: ""
Saved in: General.SessionFileName
Solver.Executable9
System command to launch solver 9
Default value: ""
Saved in: General.SessionFileName
Solver.Name0
Name of solver 0
Default value: "GetDP"
Saved in: General.SessionFileName
Solver.Name1
Name of solver 1
Default value: ""
Saved in: General.SessionFileName
Solver.Name2
Name of solver 2
Default value: ""
Saved in: General.SessionFileName
Solver.Name3
Name of solver 3
Default value: ""
Saved in: General.SessionFileName
Solver.Name4
Name of solver 4
Default value: ""
Saved in: General.SessionFileName
Solver.Name5
Name of solver 5
Default value: ""
Saved in: General.SessionFileName
Solver.Name6
Name of solver 6
Default value: ""
Saved in: General.SessionFileName
Solver.Name7
Name of solver 7
Default value: ""
Saved in: General.SessionFileName
Appendix B: Options 211
Solver.Name8
Name of solver 8
Default value: ""
Saved in: General.SessionFileName
Solver.Name9
Name of solver 9
Default value: ""
Saved in: General.SessionFileName
Solver.Extension0
File extension for solver 0
Default value: ".pro"
Saved in: General.SessionFileName
Solver.Extension1
File extension for solver 1
Default value: ""
Saved in: General.SessionFileName
Solver.Extension2
File extension for solver 2
Default value: ""
Saved in: General.SessionFileName
Solver.Extension3
File extension for solver 3
Default value: ""
Saved in: General.SessionFileName
Solver.Extension4
File extension for solver 4
Default value: ""
Saved in: General.SessionFileName
Solver.Extension5
File extension for solver 5
Default value: ""
Saved in: General.SessionFileName
Solver.Extension6
File extension for solver 6
Default value: ""
Saved in: General.SessionFileName
Solver.Extension7
File extension for solver 7
Default value: ""
Saved in: General.SessionFileName
212 Gmsh 4.0
Solver.Extension8
File extension for solver 8
Default value: ""
Saved in: General.SessionFileName
Solver.Extension9
File extension for solver 9
Default value: ""
Saved in: General.SessionFileName
Solver.OctaveInterpreter
Name of the Octave interpreter (used to run .m files)
Default value: "octave"
Saved in: General.SessionFileName
Solver.PythonInterpreter
Name of the Python interpreter (used to run .py files if they are not executable)
Default value: "python"
Saved in: General.SessionFileName
Solver.RemoteLogin0
Command to login to a remote host to launch solver 0
Default value: ""
Saved in: General.SessionFileName
Solver.RemoteLogin1
Command to login to a remote host to launch solver 1
Default value: ""
Saved in: General.SessionFileName
Solver.RemoteLogin2
Command to login to a remote host to launch solver 2
Default value: ""
Saved in: General.SessionFileName
Solver.RemoteLogin3
Command to login to a remote host to launch solver 3
Default value: ""
Saved in: General.SessionFileName
Solver.RemoteLogin4
Command to login to a remote host to launch solver 4
Default value: ""
Saved in: General.SessionFileName
Solver.RemoteLogin5
Command to login to a remote host to launch solver 5
Default value: ""
Saved in: General.SessionFileName
Appendix B: Options 213
Solver.RemoteLogin6
Command to login to a remote host to launch solver 6
Default value: ""
Saved in: General.SessionFileName
Solver.RemoteLogin7
Command to login to a remote host to launch solver 7
Default value: ""
Saved in: General.SessionFileName
Solver.RemoteLogin8
Command to login to a remote host to launch solver 8
Default value: ""
Saved in: General.SessionFileName
Solver.RemoteLogin9
Command to login to a remote host to launch solver 9
Default value: ""
Saved in: General.SessionFileName
Solver.SocketName
Base name of socket (UNIX socket if the name does not contain a colon, TCP/IP
otherwise, in the form ’host:baseport’; the actual name/port is constructed by
appending the unique client id. If baseport is 0 or is not provided, the port is
chosen automatically (recommended))
Default value: ".gmshsock"
Saved in: General.OptionsFileName
Solver.AlwaysListen
Always listen to incoming connection requests?
Default value: 0
Saved in: General.OptionsFileName
Solver.AutoArchiveOutputFiles
Automatically archive output files after each computation
Default value: 0
Saved in: General.OptionsFileName
Solver.AutoCheck
Automatically check model every time a parameter is changed
Default value: 1
Saved in: General.OptionsFileName
Solver.AutoLoadDatabase
Automatically load the ONELAB database when launching a solver
Default value: 0
Saved in: General.OptionsFileName
Solver.AutoSaveDatabase
Automatically save the ONELAB database after each computation
Default value: 1
Saved in: General.OptionsFileName
214 Gmsh 4.0
Solver.AutoMesh
Automatically mesh (0: never; 1: if geometry changed, but use existing mesh
on disk if available; 2: if geometry changed; -1: the geometry script creates the
mesh)
Default value: 2
Saved in: General.OptionsFileName
Solver.AutoMergeFile
Automatically merge result files
Default value: 1
Saved in: General.OptionsFileName
Solver.AutoShowViews
Automcatically show newly merged results (0: none; 1: all; 2: last one)
Default value: 2
Saved in: General.OptionsFileName
Solver.AutoShowLastStep
Automatically show the last step in newly merged results, if there are more
than 2 steps
Default value: 1
Saved in: General.OptionsFileName
Solver.Plugins
Enable default solver plugins?
Default value: 0
Saved in: General.OptionsFileName
Solver.ShowInvisibleParameters
Show all parameters, even those marked invisible
Default value: 0
Saved in: General.OptionsFileName
Solver.Timeout
Time (in seconds) before closing the socket if no connection is happening
Default value: 5
Saved in: General.OptionsFileName
PostProcessing.AnimationDelay
Delay (in seconds) between frames in automatic animation mode
Default value: 0.1
Saved in: General.OptionsFileName
PostProcessing.AnimationCycle
Cycle through time steps (0) or views (1) for animations
Default value: 0
Saved in: General.OptionsFileName
PostProcessing.AnimationStep
Step increment for animations
Default value: 1
Saved in: General.OptionsFileName
PostProcessing.CombineRemoveOriginal
Remove original views after a Combine operation
Default value: 1
Saved in: General.OptionsFileName
PostProcessing.DoubleClickedGraphPointX
Abscissa of last double-clicked graph point
Default value: 0
Saved in: -
PostProcessing.DoubleClickedGraphPointY
Ordinate of last double-clicked graph point
Default value: 0
Saved in: -
PostProcessing.DoubleClickedView
Index of last double-clicked view
Default value: 0
Saved in: -
PostProcessing.ForceElementData
Try to force saving datasets as ElementData
Default value: 0
Saved in: General.OptionsFileName
PostProcessing.ForceNodeData
Try to force saving datasets as NodeData
Default value: 0
Saved in: General.OptionsFileName
PostProcessing.Format
Default file format for post-processing views (0=ASCII view, 1=binary view,
2=parsed view, 3=STL triangulation, 4=raw text, 5=Gmsh mesh, 6=MED file,
10=automatic)
Default value: 10
Saved in: General.OptionsFileName
216 Gmsh 4.0
PostProcessing.GraphPointX
Synonym for ‘DoubleClickedGraphPointX’
Default value: 0
Saved in: -
PostProcessing.GraphPointY
Synonym for ‘DoubleClickedGraphPointY’
Default value: 0
Saved in: -
PostProcessing.HorizontalScales
Display value scales horizontally
Default value: 1
Saved in: General.OptionsFileName
PostProcessing.Link
Post-processing view links (0=apply next option changes to selected views,
1=force same options for all selected views)
Default value: 0
Saved in: General.OptionsFileName
PostProcessing.NbViews
Current number of views merged (read-only)
Default value: 0
Saved in: -
PostProcessing.Plugins
Enable default post-processing plugins?
Default value: 1
Saved in: General.OptionsFileName
PostProcessing.SaveInterpolationMatrices
Save the interpolation matrices when exporting model-based data
Default value: 1
Saved in: General.OptionsFileName
PostProcessing.SaveMesh
Save the mesh when exporting model-based data
Default value: 1
Saved in: General.OptionsFileName
PostProcessing.Smoothing
Apply (non-reversible) smoothing to post-processing view when merged
Default value: 0
Saved in: General.OptionsFileName
View.Attributes
Optional string attributes
Default value: ""
Saved in: General.OptionsFileName
Appendix B: Options 217
View.AxesFormatX
Number format for X-axis (in standard C form)
Default value: "%.3g"
Saved in: General.OptionsFileName
View.AxesFormatY
Number format for Y-axis (in standard C form)
Default value: "%.3g"
Saved in: General.OptionsFileName
View.AxesFormatZ
Number format for Z-axis (in standard C form)
Default value: "%.3g"
Saved in: General.OptionsFileName
View.AxesLabelX
X-axis label
Default value: ""
Saved in: General.OptionsFileName
View.AxesLabelY
Y-axis label
Default value: ""
Saved in: General.OptionsFileName
View.AxesLabelZ
Z-axis label
Default value: ""
Saved in: General.OptionsFileName
View.DoubleClickedCommand
Command parsed when double-clicking on the view
Default value: ""
Saved in: General.OptionsFileName
View.FileName
Default post-processing view file name
Default value: ""
Saved in: -
View.Format
Number format (in standard C form)
Default value: "%.3g"
Saved in: General.OptionsFileName
View.GeneralizedRaiseX
Generalized elevation of the view along X-axis (in model coordinates, using
formula possibly containing x, y, z, s[tep], t[ime], v0, ... v8)
Default value: "v0"
Saved in: General.OptionsFileName
218 Gmsh 4.0
View.GeneralizedRaiseY
Generalized elevation of the view along Y-axis (in model coordinates, using
formula possibly containing x, y, z, s[tep], t[ime], v0, ... v8)
Default value: "v1"
Saved in: General.OptionsFileName
View.GeneralizedRaiseZ
Generalized elevation of the view along Z-axis (in model coordinates, using
formula possibly containing x, y, z, s[tep], t[ime], v0, ... v8)
Default value: "v2"
Saved in: General.OptionsFileName
View.Group
Group to which this view belongs
Default value: ""
Saved in: General.OptionsFileName
View.Name
Default post-processing view name
Default value: ""
Saved in: -
View.Stipple0
First stippling pattern
Default value: "1*0x1F1F"
Saved in: General.OptionsFileName
View.Stipple1
Second stippling pattern
Default value: "1*0x3333"
Saved in: General.OptionsFileName
View.Stipple2
Third stippling pattern
Default value: "1*0x087F"
Saved in: General.OptionsFileName
View.Stipple3
Fourth stippling pattern
Default value: "1*0xCCCF"
Saved in: General.OptionsFileName
View.Stipple4
Fifth stippling pattern
Default value: "2*0x1111"
Saved in: General.OptionsFileName
View.Stipple5
Sixth stippling pattern
Default value: "2*0x0F0F"
Saved in: General.OptionsFileName
Appendix B: Options 219
View.Stipple6
Seventh stippling pattern
Default value: "1*0xCFFF"
Saved in: General.OptionsFileName
View.Stipple7
Eighth stippling pattern
Default value: "2*0x0202"
Saved in: General.OptionsFileName
View.Stipple8
Ninth stippling pattern
Default value: "2*0x087F"
Saved in: General.OptionsFileName
View.Stipple9
Tenth stippling pattern
Default value: "1*0xFFFF"
Saved in: General.OptionsFileName
View.AbscissaRangeType
Ascissa scale range type (1=default, 2=custom)
Default value: 1
Saved in: General.OptionsFileName
View.AdaptVisualizationGrid
Use adaptive visualization grid (for high-order elements)?
Default value: 0
Saved in: General.OptionsFileName
View.AngleSmoothNormals
Threshold angle below which normals are not smoothed
Default value: 30
Saved in: General.OptionsFileName
View.ArrowSizeMax
Maximum display size of arrows (in pixels)
Default value: 60
Saved in: General.OptionsFileName
View.ArrowSizeMin
Minimum display size of arrows (in pixels)
Default value: 0
Saved in: General.OptionsFileName
View.AutoPosition
Position the scale or 2D plot automatically (0: manual, 1: automatic, 2: top
left, 3: top right, 4: bottom left, 5: bottom right, 6: top, 7: bottom, 8: left, 9:
right, 10: full, 11: top third, 12: in model coordinates)
Default value: 1
Saved in: General.OptionsFileName
220 Gmsh 4.0
View.Axes
Axes (0=none, 1=simple axes, 2=box, 3=full grid, 4=open grid, 5=ruler)
Default value: 0
Saved in: General.OptionsFileName
View.AxesMikado
Mikado axes style
Default value: 0
Saved in: General.OptionsFileName
View.AxesAutoPosition
Position the axes automatically
Default value: 1
Saved in: General.OptionsFileName
View.AxesMaxX
Maximum X-axis coordinate
Default value: 1
Saved in: General.OptionsFileName
View.AxesMaxY
Maximum Y-axis coordinate
Default value: 1
Saved in: General.OptionsFileName
View.AxesMaxZ
Maximum Z-axis coordinate
Default value: 1
Saved in: General.OptionsFileName
View.AxesMinX
Minimum X-axis coordinate
Default value: 0
Saved in: General.OptionsFileName
View.AxesMinY
Minimum Y-axis coordinate
Default value: 0
Saved in: General.OptionsFileName
View.AxesMinZ
Minimum Z-axis coordinate
Default value: 0
Saved in: General.OptionsFileName
View.AxesTicsX
Number of tics on the X-axis
Default value: 5
Saved in: General.OptionsFileName
Appendix B: Options 221
View.AxesTicsY
Number of tics on the Y-axis
Default value: 5
Saved in: General.OptionsFileName
View.AxesTicsZ
Number of tics on the Z-axis
Default value: 5
Saved in: General.OptionsFileName
View.Boundary
Draw the ‘N minus b’-dimensional boundary of the element (N=element dimen-
sion, b=option value)
Default value: 0
Saved in: General.OptionsFileName
View.CenterGlyphs
Center glyphs (arrows, numbers, etc.)? (0=left, 1=centered, 2=right)
Default value: 0
Saved in: General.OptionsFileName
View.Clip
Enable clipping planes? (Plane[i]=2^i, i=0,...,5)
Default value: 0
Saved in: -
View.Closed
Close the subtree containing this view
Default value: 0
Saved in: General.OptionsFileName
View.ColormapAlpha
Colormap alpha channel value (used only if != 1)
Default value: 1
Saved in: General.OptionsFileName
View.ColormapAlphaPower
Colormap alpha channel power
Default value: 0
Saved in: General.OptionsFileName
View.ColormapBeta
Colormap beta parameter (gamma = 1-beta)
Default value: 0
Saved in: General.OptionsFileName
View.ColormapBias
Colormap bias
Default value: 0
Saved in: General.OptionsFileName
222 Gmsh 4.0
View.ColormapCurvature
Colormap curvature or slope coefficient
Default value: 0
Saved in: General.OptionsFileName
View.ColormapInvert
Invert the color values, i.e., replace x with (255-x) in the colormap?
Default value: 0
Saved in: General.OptionsFileName
View.ColormapNumber
Default colormap number (0: black, 1: vis5d, 2: jet, 3: lucie, 4: rainbow, 5:
emc2000, 6: incadescent, 7: hot, 8: pink, 9: grayscale, 10: french, 11: hsv, 12:
spectrum, 13: bone, 14: spring, 15: summer, 16: autumm, 17: winter, 18: cool,
19: copper, 20: magma, 21: inferno, 22: plasma, 23: viridis)
Default value: 2
Saved in: General.OptionsFileName
View.ColormapRotation
Incremental colormap rotation
Default value: 0
Saved in: General.OptionsFileName
View.ColormapSwap
Swap the min/max values in the colormap?
Default value: 0
Saved in: General.OptionsFileName
View.ComponentMap0
Forced component 0 (if View.ForceComponents > 0)
Default value: 0
Saved in: General.OptionsFileName
View.ComponentMap1
Forced component 1 (if View.ForceComponents > 0)
Default value: 1
Saved in: General.OptionsFileName
View.ComponentMap2
Forced component 2 (if View.ForceComponents > 0)
Default value: 2
Saved in: General.OptionsFileName
View.ComponentMap3
Forced component 3 (if View.ForceComponents > 0)
Default value: 3
Saved in: General.OptionsFileName
View.ComponentMap4
Forced component 4 (if View.ForceComponents > 0)
Default value: 4
Saved in: General.OptionsFileName
Appendix B: Options 223
View.ComponentMap5
Forced component 5 (if View.ForceComponents > 0)
Default value: 5
Saved in: General.OptionsFileName
View.ComponentMap6
Forced component 6 (if View.ForceComponents > 0)
Default value: 6
Saved in: General.OptionsFileName
View.ComponentMap7
Forced component 7 (if View.ForceComponents > 0)
Default value: 7
Saved in: General.OptionsFileName
View.ComponentMap8
Forced component 8 (if View.ForceComponents > 0)
Default value: 8
Saved in: General.OptionsFileName
View.CustomAbscissaMax
User-defined maximum abscissa value
Default value: 0
Saved in: -
View.CustomAbscissaMin
User-defined minimum abscissa value
Default value: 0
Saved in: -
View.CustomMax
User-defined maximum value to be displayed
Default value: 0
Saved in: -
View.CustomMin
User-defined minimum value to be displayed
Default value: 0
Saved in: -
View.DisplacementFactor
Displacement amplification
Default value: 1
Saved in: General.OptionsFileName
View.DrawHexahedra
Display post-processing hexahedra?
Default value: 1
Saved in: General.OptionsFileName
224 Gmsh 4.0
View.DrawLines
Display post-processing lines?
Default value: 1
Saved in: General.OptionsFileName
View.DrawPoints
Display post-processing points?
Default value: 1
Saved in: General.OptionsFileName
View.DrawPrisms
Display post-processing prisms?
Default value: 1
Saved in: General.OptionsFileName
View.DrawPyramids
Display post-processing pyramids?
Default value: 1
Saved in: General.OptionsFileName
View.DrawTrihedra
Display post-processing trihedra?
Default value: 1
Saved in: General.OptionsFileName
View.DrawQuadrangles
Display post-processing quadrangles?
Default value: 1
Saved in: General.OptionsFileName
View.DrawScalars
Display scalar values?
Default value: 1
Saved in: General.OptionsFileName
View.DrawSkinOnly
Draw only the skin of 3D scalar views?
Default value: 0
Saved in: General.OptionsFileName
View.DrawStrings
Display post-processing annotation strings?
Default value: 1
Saved in: General.OptionsFileName
View.DrawTensors
Display tensor values?
Default value: 1
Saved in: General.OptionsFileName
Appendix B: Options 225
View.DrawTetrahedra
Display post-processing tetrahedra?
Default value: 1
Saved in: General.OptionsFileName
View.DrawTriangles
Display post-processing triangles?
Default value: 1
Saved in: General.OptionsFileName
View.DrawVectors
Display vector values?
Default value: 1
Saved in: General.OptionsFileName
View.Explode
Element shrinking factor (between 0 and 1)
Default value: 1
Saved in: General.OptionsFileName
View.ExternalView
Index of the view used to color vector fields (-1=self)
Default value: -1
Saved in: General.OptionsFileName
View.FakeTransparency
Use fake transparency (cheaper than the real thing, but incorrect)
Default value: 0
Saved in: General.OptionsFileName
View.ForceNumComponents
Force number of components to display (see View.ComponentMapN for map-
ping)
Default value: 0
Saved in: General.OptionsFileName
View.GeneralizedRaiseFactor
Generalized raise amplification factor
Default value: 1
Saved in: General.OptionsFileName
View.GeneralizedRaiseView
Index of the view used for generalized raise (-1=self)
Default value: -1
Saved in: General.OptionsFileName
View.GlyphLocation
Glyph (arrow, number, etc.) location (1=center of gravity, 2=node)
Default value: 1
Saved in: General.OptionsFileName
226 Gmsh 4.0
View.Height
Height (in pixels) of the scale or 2D plot
Default value: 200
Saved in: General.OptionsFileName
View.IntervalsType
Type of interval display (1=iso, 2=continuous, 3=discrete, 4=numeric)
Default value: 2
Saved in: General.OptionsFileName
View.Light
Enable lighting for the view
Default value: 1
Saved in: General.OptionsFileName
View.LightLines
Light element edges
Default value: 1
Saved in: General.OptionsFileName
View.LightTwoSide
Light both sides of surfaces (leads to slower rendering)
Default value: 1
Saved in: General.OptionsFileName
View.LineType
Display lines as solid color segments (0) or 3D cylinders (1)
Default value: 0
Saved in: General.OptionsFileName
View.LineWidth
Display width of lines (in pixels)
Default value: 1
Saved in: General.OptionsFileName
View.MaxRecursionLevel
Maximum recursion level for adaptive views
Default value: 0
Saved in: General.OptionsFileName
View.Max Maximum value in the view (read-only)
Default value: 0
Saved in: -
View.MaxVisible
Maximum value in the visible parts of the view (read-only)
Default value: 0
Saved in: -
View.MaxX
Maximum view coordinate along the X-axis (read-only)
Default value: 0
Saved in: -
Appendix B: Options 227
View.MaxY
Maximum view coordinate along the Y-axis (read-only)
Default value: 0
Saved in: -
View.MaxZ
Maximum view coordinate along the Z-axis (read-only)
Default value: 0
Saved in: -
View.Min Minimum value in the view (read-only)
Default value: 0
Saved in: -
View.MinVisible
Minimum value in the visible parts of the view (read-only)
Default value: 0
Saved in: -
View.MinX
Minimum view coordinate along the X-axis (read-only)
Default value: 0
Saved in: -
View.MinY
Minimum view coordinate along the Y-axis (read-only)
Default value: 0
Saved in: -
View.MinZ
Minimum view coordinate along the Z-axis (read-only)
Default value: 0
Saved in: -
View.NbIso
Number of intervals
Default value: 10
Saved in: General.OptionsFileName
View.NbTimeStep
Number of time steps in the view (do not change this!)
Default value: 1
Saved in: -
View.NormalRaise
Elevation of the view along the normal (in model coordinates)
Default value: 0
Saved in: -
View.Normals
Display size of normal vectors (in pixels)
Default value: 0
Saved in: General.OptionsFileName
228 Gmsh 4.0
View.OffsetX
Translation of the view along X-axis (in model coordinates)
Default value: 0
Saved in: -
View.OffsetY
Translation of the view along Y-axis (in model coordinates)
Default value: 0
Saved in: -
View.OffsetZ
Translation of the view along Z-axis (in model coordinates)
Default value: 0
Saved in: -
View.PointSize
Display size of points (in pixels)
Default value: 3
Saved in: General.OptionsFileName
View.PointType
Display points as solid color dots (0), 3D spheres (1), scaled dots (2) or scaled
spheres (3)
Default value: 0
Saved in: General.OptionsFileName
View.PositionX
X position (in pixels) of the scale or 2D plot (< 0: measure from right edge; >=
1e5: centered)
Default value: 100
Saved in: General.OptionsFileName
View.PositionY
Y position (in pixels) of the scale or 2D plot (< 0: measure from bottom edge;
>= 1e5: centered)
Default value: 50
Saved in: General.OptionsFileName
View.RaiseX
Elevation of the view along X-axis (in model coordinates)
Default value: 0
Saved in: -
View.RaiseY
Elevation of the view along Y-axis (in model coordinates)
Default value: 0
Saved in: -
View.RaiseZ
Elevation of the view along Z-axis (in model coordinates)
Default value: 0
Saved in: -
Appendix B: Options 229
View.RangeType
Value scale range type (1=default, 2=custom, 3=per time step)
Default value: 1
Saved in: General.OptionsFileName
View.Sampling
Element sampling rate (draw one out every ‘Sampling’ elements)
Default value: 1
Saved in: General.OptionsFileName
View.SaturateValues
Saturate the view values to custom min and max (1=true, 0=false)
Default value: 0
Saved in: General.OptionsFileName
View.ScaleType
Value scale type (1=linear, 2=logarithmic, 3=double logarithmic)
Default value: 1
Saved in: General.OptionsFileName
View.ShowElement
Show element boundaries?
Default value: 0
Saved in: General.OptionsFileName
View.ShowScale
Show value scale?
Default value: 1
Saved in: General.OptionsFileName
View.ShowTime
Time display mode (0=none, 1=time series, 2=harmonic data, 3=automatic,
4=step data, 5=multi-step data, 6=real eigenvalues, 7=complex eigenvalues)
Default value: 3
Saved in: General.OptionsFileName
View.SmoothNormals
Smooth the normals?
Default value: 0
Saved in: General.OptionsFileName
View.Stipple
Stipple curves in 2D plots?
Default value: 0
Saved in: General.OptionsFileName
View.Tangents
Display size of tangent vectors (in pixels)
Default value: 0
Saved in: General.OptionsFileName
230 Gmsh 4.0
View.TargetError
Target representation error for adaptive views
Default value: 0.01
Saved in: General.OptionsFileName
View.TensorType
Tensor Visualization Type
Default value: 1
Saved in: General.OptionsFileName
View.TimeStep
Current time step displayed
Default value: 0
Saved in: -
View.Time
Current time displayed (if positive, sets the time step corresponding the given
time value)
Default value: 0
Saved in: -
View.TransformXX
Element (1,1) of the 3x3 coordinate transformation matrix
Default value: 1
Saved in: -
View.TransformXY
Element (1,2) of the 3x3 coordinate transformation matrix
Default value: 0
Saved in: -
View.TransformXZ
Element (1,3) of the 3x3 coordinate transformation matrix
Default value: 0
Saved in: -
View.TransformYX
Element (2,1) of the 3x3 coordinate transformation matrix
Default value: 0
Saved in: -
View.TransformYY
Element (2,2) of the 3x3 coordinate transformation matrix
Default value: 1
Saved in: -
View.TransformYZ
Element (2,3) of the 3x3 coordinate transformation matrix
Default value: 0
Saved in: -
Appendix B: Options 231
View.TransformZX
Element (3,1) of the 3x3 coordinate transformation matrix
Default value: 0
Saved in: -
View.TransformZY
Element (3,2) of the 3x3 coordinate transformation matrix
Default value: 0
Saved in: -
View.TransformZZ
Element (3,3) of the 3x3 coordinate transformation matrix
Default value: 1
Saved in: -
View.Type
Type of plot (1=3D, 2=2D space, 3=2D time, 4=2D)
Default value: 1
Saved in: -
View.UseGeneralizedRaise
Use generalized raise?
Default value: 0
Saved in: General.OptionsFileName
View.VectorType
Vector display type (1=segment, 2=arrow, 3=pyramid, 4=3D arrow, 5=dis-
placement, 6=comet)
Default value: 4
Saved in: General.OptionsFileName
View.Visible
Is the view visible?
Default value: 1
Saved in: -
View.Width
Width (in pixels) of the scale or 2D plot
Default value: 300
Saved in: General.OptionsFileName
View.Color.Points
Point color
Default value: {0,0,0}
Saved in: General.OptionsFileName
View.Color.Lines
Line color
Default value: {0,0,0}
Saved in: General.OptionsFileName
232 Gmsh 4.0
View.Color.Triangles
Triangle color
Default value: {0,0,0}
Saved in: General.OptionsFileName
View.Color.Quadrangles
Quadrangle color
Default value: {0,0,0}
Saved in: General.OptionsFileName
View.Color.Tetrahedra
Tetrahedron color
Default value: {0,0,0}
Saved in: General.OptionsFileName
View.Color.Hexahedra
Hexahedron color
Default value: {0,0,0}
Saved in: General.OptionsFileName
View.Color.Prisms
Prism color
Default value: {0,0,0}
Saved in: General.OptionsFileName
View.Color.Pyramids
Pyramid color
Default value: {0,0,0}
Saved in: General.OptionsFileName
View.Color.Trihedra
Trihedron color
Default value: {0,0,0}
Saved in: General.OptionsFileName
View.Color.Tangents
Tangent vector color
Default value: {255,255,0}
Saved in: General.OptionsFileName
View.Color.Normals
Normal vector color
Default value: {255,0,0}
Saved in: General.OptionsFileName
View.Color.Text2D
2D text color
Default value: {0,0,0}
Saved in: General.OptionsFileName
Appendix B: Options 233
View.Color.Text3D
3D text color
Default value: {0,0,0}
Saved in: General.OptionsFileName
View.Color.Axes
Axes color
Default value: {0,0,0}
Saved in: General.OptionsFileName
View.Color.Background2D
Bacground color for 2D plots
Default value: {255,255,255}
Saved in: General.OptionsFileName
View.ColorTable
Color table used to draw the view
Saved in: General.OptionsFileName
Appendix C: Compiling the source code 235
ENABLE_CAIRO
Enable Cairo to render fonts (experimental) (default: ON)
ENABLE_CXX11
Enable C++11 (default: ON)
ENABLE_C99
Enable C99 (default: ON)
ENABLE_PROFILE
Enable profiling compiler flags (default: OFF)
ENABLE_DINTEGRATION
Enable discrete integration (needed for levelsets) (default: ON)
ENABLE_FLTK
Enable FLTK graphical user interface (requires mesh/post) (default: ON)
ENABLE_FOURIER_MODEL
Enable Fourier geometrical models (experimental) (default: OFF)
ENABLE_GETDP
Enable GetDP solver (as a directly linked library) (default: ON)
ENABLE_GMM
Enable GMM linear solvers (simple alternative to PETSc) (default: ON)
ENABLE_GMP
Enable GMP for Kbipack (advanced) (default: ON)
ENABLE_GRAPHICS
Enable building graphics lib even without GUI (advanced) (default: OFF)
ENABLE_HXT
Enable HXT library (default: ON)
ENABLE_KBIPACK
Enable Kbipack (neeeded by homology solver) (default: ON)
ENABLE_MATHEX
Enable math expression parser (used by plugins and options) (default: ON)
ENABLE_MED
Enable MED mesh and post file formats (default: ON)
ENABLE_MESH
Enable mesh module (required by GUI) (default: ON)
ENABLE_METIS
Enable Metis mesh partitioner (default: ON)
ENABLE_MMG3D
Enable MMG3D 3D anisotropic mesh refinement (default: ON)
ENABLE_MPEG_ENCODE
Enable built-in MPEG movie encoder (default: ON)
Appendix C: Compiling the source code 237
ENABLE_MPI
Enable MPI (mostly for parser and solver - mesh generation is sequential) (de-
fault: OFF)
ENABLE_MSVC_STATIC_RUNTIME
Enable static Visual C++ runtime (default: OFF)
ENABLE_MUMPS
Enable MUMPS sparse direct linear solver (default: OFF)
ENABLE_NATIVE_FILE_CHOOSER
Enable native file chooser in GUI (default: ON)
ENABLE_NETGEN
Enable Netgen 3D frontal mesh generator (default: ON)
ENABLE_NUMPY
Enable fullMatrix and numpy array conversion for internal developer API (de-
fault: OFF)
ENABLE_PETSC4PY
Enable petsc4py wrappers for petsc matrices in internal developer API (default:
ON)
ENABLE_OCC
Enable OpenCASCADE geometrical models (default: ON)
ENABLE_OCC_CAF
Enable OpenCASCADE CAF module (default: OFF)
ENABLE_ONELAB
Enable ONELAB solver interface (default: ON)
ENABLE_ONELAB_METAMODEL
Enable ONELAB metamodels (experimental) (default: ON)
ENABLE_OPENMP
Enable OpenMP (experimental) (default: OFF)
ENABLE_OPTHOM
Enable high-order mesh optimization tools (default: ON)
ENABLE_OS_SPECIFIC_INSTALL
Enable OS-specific (e.g. app bundle) installation (default: OFF)
ENABLE_OSMESA
Enable OSMesa for offscreen rendering (experimental) (default: OFF)
ENABLE_PARSER
Enable GEO file parser (required for .geo/.pos files) (default: ON)
ENABLE_PETSC
Enable PETSc linear solvers (required for SLEPc) (default: ON)
ENABLE_PLUGINS
Enable post-processing plugins (default: ON)
238 Gmsh 4.0
ENABLE_POST
Enable post-processing module (required by GUI) (default: ON)
ENABLE_POPPLER
Enable Poppler for displaying PDF documents (experimental) (default: OFF)
ENABLE_PRIVATE_API
Enable private API (default: OFF)
ENABLE_REVOROPT
Enable Revoropt (used for CVT remeshing) (default: OFF)
ENABLE_SLEPC
Enable SLEPc eigensolvers (required for conformal compounds) (default: ON)
ENABLE_SOLVER
Enable built-in finite element solvers (required for compounds) (default: ON)
ENABLE_SYSTEM_CONTRIB
Use system versions of contrib libraries, when possible (default: OFF)
ENABLE_TCMALLOC
Enable libtcmalloc, a fast malloc implementation but that does not release
memory (default: OFF)
ENABLE_VISUDEV
Enable additional visualization capabilities for development purpose (default:
OFF)
ENABLE_VOROPP
Enable voro++ (for hex meshing, experimental) (default: ON)
ENABLE_WRAP_JAVA
Enable generation of Java wrappers for private API (default: OFF)
ENABLE_WRAP_PYTHON
Enable generation of Python wrappers for private API (default: OFF)
ENABLE_ZIPPER
Enable Zip file compression/decompression (default: OFF)
Appendix D: Gmsh API 239
Module /gmsh
initialize
Initialize Gmsh. This must be called before any call to the other functions in
the API. If argc and argv (or just argv in Python or Julia) are provided, they
will be handled in the same way as the command line arguments in the Gmsh
app. If readConfigFiles is set, read system Gmsh configuration files (gmshrc
and gmsh-options).
Input: argv, readConfigFiles
Output: -
Return: -
finalize Finalize Gmsh. This must be called when you are done using the Gmsh API.
Input: -
Output: -
1
In C++ /gmsh/model/geo/addPoint will lead to a namespaced function gmsh::model::geo::addPoint, while
in Python and Julia it will lead to gmsh.model.geo.addPoint, and in C to gmshModelGeoAddPoint. Output
values are passed by reference in C++, as pointers in C and directly returned (after the return value, if any)
in Python and Julia.
240 Gmsh 4.0
Return: -
open Open a file. Equivalent to the File->Open menu in the Gmsh app. Handling
of the file depends on its extension and/or its contents.
Input: fileName
Output: -
Return: -
merge Merge a file. Equivalent to the File->Merge menu in the Gmsh app. Handling
of the file depends on its extension and/or its contents.
Input: fileName
Output: -
Return: -
write Write a file. The export format is determined by the file extension.
Input: fileName
Output: -
Return: -
clear Clear all loaded models and post-processing data, and add a new empty model.
Input: -
Output: -
Return: -
Module /gmsh/option
setNumber
Set a numerical option to value. name is of the form "category.option" or "cat-
egory[num].option". Available categories and options are listed in the Gmsh
reference manual.
Input: name, value
Output: -
Return: -
getNumber
Get the value of a numerical option.
Input: name
Output: value
Return: -
setString
Set a string option to value.
Appendix D: Gmsh API 241
Module /gmsh/model
add Add a new model, with name name, and set it as the current model.
Input: name
Output: -
Return: -
remove Remove the current model.
Input: -
Output: -
Return: -
list List the names of all models.
Input: -
Output: names
Return: -
setCurrent
Set the current model to the model with name name. If several models have the
same name, select the one that was added first.
Input: name
Output: -
Return: -
getEntities
Get all the (elementary) geometrical entities in the current model. If dim is >=
0, return only the entities of the specified dimension (e.g. points if dim == 0).
The entities are returned as a vector of (dim, tag) integer pairs.
Input: dim
Output: dimTags
Return: -
242 Gmsh 4.0
getPhysicalGroups
Get all the physical groups in the current model. If dim is >= 0, return only
the entities of the specified dimension (e.g. physical points if dim == 0). The
entities are returned as a vector of (dim, tag) integer pairs.
Input: dim
Output: dimTags
Return: -
getEntitiesForPhysicalGroup
Get the tags of the geometrical entities making up the physical group of dimen-
sion dim and tag tag.
Input: dim, tag
Output: tags
Return: -
getPhysicalGroupsForEntity
Get the tags of the physical groups (if any) to which the geometrical entity of
dimension dim and tag tag belongs.
Input: dim, tag
Output: physicalTags
Return: -
addPhysicalGroup
Add a physical group of dimension dim, grouping the elementary entities with
tags tags. Return the tag of the physical group, equal to tag if tag is positive,
or a new tag if tag < 0.
Input: dim, tags, tag
Output: -
Return: integer
setPhysicalName
Set the name of the physical group of dimension dim and tag tag.
Input: dim, tag, name
Output: -
Return: -
getPhysicalName
Get the name of the physical group of dimension dim and tag tag.
Input: dim, tag
Output: name
Return: -
Appendix D: Gmsh API 243
getBoundary
Get the boundary of the geometrical entities dimTags. Return in outDimTags
the boundary of the individual entities (if combined is false) or the boundary
of the combined geometrical shape formed by all input entities (if combined is
true). Return tags multiplied by the sign of the boundary entity if oriented
is true. Apply the boundary operator recursively down to dimension 0 (i.e. to
points) if recursive is true.
Input: dimTags, combined, oriented, recursive
Output: outDimTags
Return: -
getEntitiesInBoundingBox
Get the (elementary) geometrical entities in the bounding box defined by the
two points (xmin, ymin, zmin) and (xmax, ymax, zmax). If dim is >= 0, return
only the entities of the specified dimension (e.g. points if dim == 0).
Input: xmin, ymin, zmin, xmax, ymax, zmax, dim
Output: tags
Return: -
getBoundingBox
Get the bounding box (xmin, ymin, zmin), (xmax, ymax, zmax) of the geometrical
entity of dimension dim and tag tag.
Input: dim, tag
Output: xmin, ymin, zmin, xmax, ymax, zmax
Return: -
getDimension
Get the geometrical dimension of the current model.
Input: -
Output: -
Return: integer
addDiscreteEntity
Add a discrete geometrical entity (defined by a mesh) of dimension dim in the
current model. Return the tag of the new discrete entity, equal to tag if tag is
positive, or a new tag if tag < 0. boundary specifies the tags of the entities on
the boundary of the discrete entity, if any. Specyfing boundary allows Gmsh to
construct the topology of the overall model.
Input: dim, tag, boundary
Output: -
Return: integer
244 Gmsh 4.0
removeEntities
Remove the entities dimTags of the current model. If recursive is true, remove
all the entities on their boundaries, down to dimension 0.
Input: dimTags, recursive
Output: -
Return: -
getType Get the type of the entity of dimension dim and tag tag.
Input: dim, tag
Output: entityType
Return: -
getParent
In a partitioned model, get the parent of the entity of dimension dim and tag
tag, i.e. from which the entity is a part of, if any. parentDim and parentTag
are set to -1 if the entity has no parent.
Input: dim, tag
Output: parentDim, parentTag
Return: -
getValue Evaluate the parametrization of the entity of dimension dim and tag tag at
the parametric coordinates parametricCoord and return triplets of x, y, z co-
ordinates in points. Only valid for dim equal to 0, 1 (with parametricCoord
containing parametric coordinates on the curve) or 2 (with parametricCoord
containing pairs of u, v parametric coordinates on the surface, concatenated),
Input: dim, tag, parametricCoord
Output: points
Return: -
getDerivative
Evaluate the derivative of the parametrization of the entity of dimension dim
and tag tag at the parametric coordinates parametricCoord. Only valid for
dim equal to 1 (with parametricCoord containing parametric coordinates on
the curve) or 2 (with parametricCoord containing pairs of u, v parametric
coordinates on the surface, concatenated).
Input: dim, tag, parametricCoord
Output: derivatives
Return: -
getCurvature
Evaluate the (maximum) curvature of the entity of dimension dim and tag tag
at the parametric coordinates parametricCoord. Only valid for dim equal to 1
(with parametricCoord containing parametric coordinates on the curve) or 2
(with parametricCoord containing pairs of u, v parametric coordinates on the
surface, concatenated).
Appendix D: Gmsh API 245
Module /gmsh/model/mesh
generate Generate a mesh of the current model, up to dimension dim (0, 1, 2 or 3).
Input: dim
Output: -
Return: -
partition
Partition the mesh of the current model into numPart partitions.
Input: numPart
Output: -
Return: -
refine Refine the mesh of the current model by uniformly splitting the elements.
Input: -
Output: -
Return: -
setOrder Set the order of the elements in the mesh of the current model to order.
Input: order
Output: -
246 Gmsh 4.0
Return: -
getLastEntityError
Get the last entities (if any) where a meshing error occurred. Currently only
populated by the new 3D meshing algorithms.
Input: -
Output: dimTags
Return: -
getLastNodeError
Get the last nodes (if any) where a meshing error occurred. Currently only
populated by the new 3D meshing algorithms.
Input: -
Output: nodeTags
Return: -
getNodes Get the nodes classified on the entity of dimension dim and tag tag. If tag <
0, get the nodes for all entities of dimension dim. If dim and tag are negative,
get all the nodes in the mesh. nodeTags contains the node tags (their unique,
strictly positive identification numbers). coord is a vector of length 3 times the
length of nodeTags that contains the (x, y, z) coordinates of the nodes, con-
catenated. If dim >= 0, parametricCoord contains the parametric coordinates
u or (u, v) the nodes, if available. The length of parametricCoord can be 0 or
dim times the length of nodeTags. If includeBoundary is set, also return the
nodes classified on the boundary of the entity (wich will be reparametrized on
the entity if dim >= 0 in order to compute their parametric coordinates).
Input: dim, tag, includeBoundary
Output: nodeTags, coord, parametricCoord
Return: -
getNode Get the coordinates and the parametric coordinates (if any) of the node with
tag tag. This is a sometimes useful but inefficient way of accessing nodes, as
it relies on a cache stored in the model. For large meshes all the nodes in the
model should be numbered in a continuous sequence of tags from 1 to N to
maintain reasonnable performance (in this case the internal cache is based on
a vector; otherwise it uses a map).
Input: nodeTag
Output: coord, parametricCoord
Return: -
rebuildNodeCache
Rebuild the node cache.
Input: onlyIfNecessary
Output: -
Appendix D: Gmsh API 247
Return: -
getNodesForPhysicalGroup
Get the nodes from all the elements belonging to the physical group of dimension
dim and tag tag. nodeTags contains the node tags; coord is a vector of length
3 times the length of nodeTags that contains the (x, y, z) coordinates of the
nodes, concatenated.
Input: dim, tag
Output: nodeTags, coord
Return: -
setNodes Set the nodes classified on the geometrical entity of dimension dim and tag tag.
nodeTags contains the node tags (their unique, strictly positive identification
numbers). coord is a vector of length 3 times the length of nodeTags that
contains the (x, y, z) coordinates of the nodes, concatenated. The optional
parametricCoord vector contains the parametric coordinates of the nodes, if
any. The length of parametricCoord can be 0 or dim times the length of
nodeTags.
Input: dim, tag, nodeTags, coord, parametricCoord
Output: -
Return: -
reclassifyNodes
Reclassify all nodes on their associated geometrical entity, based on the ele-
ments. Can be used when importing nodes in bulk (e.g. by associating them
all to a single volume), to reclassify them correctly on model surfaces, curves,
etc. after the elements have been set.
Input: -
Output: -
Return: -
getElements
Get the elements classified on the entity of dimension dim and tag tag. If tag
< 0, get the elements for all entities of dimension dim. If dim and tag are
negative, get all the elements in the mesh. elementTypes contains the MSH
types of the elements (e.g. 2 for 3-node triangles: see getElementProperties
to obtain the properties for a given element type). elementTags is a vector of
the same length as elementTypes; each entry is a vector containing the tags
(unique, strictly positive identifiers) of the elements of the corresponding type.
nodeTags is also a vector of the same length as elementTypes; each entry is a
vector of length equal to the number of elements of the given type times the
number of nodes for this type of element, that contains the node tags of all the
elements of the given type, concatenated.
Input: dim, tag
248 Gmsh 4.0
Input: elementType
Output: elementName, dim, order, numNodes, parametricCoord
Return: -
getElementsByType
Get the elements of type elementType classified on the entity of of tag tag. If
tag < 0, get the elements for all entities. elementTags is a vector containing the
tags (unique, strictly positive identifiers) of the elements of the corresponding
type. nodeTags is a vector of length equal to the number of elements of the
given type times the number of nodes for this type of element, that contains
the node tags of all the elements of the given type, concatenated. If numTasks
> 1, only compute and return the part of the data indexed by task.
Input: elementType, tag, task, numTasks
Output: elementTags, nodeTags
Return: -
preallocateElementsByType
Preallocate the data for getElementsByType. This is necessary only if
getElementsByType is called with numTasks > 1.
Input: elementType, elementTag, nodeTag, tag
Output: elementTags, nodeTags
Return: -
getJacobians
Get the Jacobians of all the elements of type elementType classified on the
entity of dimension dim and tag tag, at the integration points required by
the integrationType integration rule (e.g. "Gauss4"). Data is returned
by element, with elements in the same order as in getElements and
getElementsByType. jacobians contains for each element the 9 entries of
a 3x3 Jacobian matrix (by row), for each integration point. determinants
contains for each element the determinant of the Jacobian matrix for each
integration point. points contains for each element the (x, y, z) coordinates
of the integration points. If tag < 0, get the Jacobian data for all entities. If
numTasks > 1, only compute and return the part of the data indexed by task.
Input: elementType, integrationType, tag, task, numTasks
Output: jacobians, determinants, points
Return: -
preallocateJacobians
Preallocate the data required by getJacobians. This is necessary only if
getJacobians is called with numTasks > 1.
Input: elementType, integrationType, jacobian, determinant, point,
tag
Output: jacobians, determinants, points
250 Gmsh 4.0
Return: -
getBasisFunctions
Get the basis functions of the element of type elementType for the given
integrationType integration rule (e.g. "Gauss4") and functionSpaceType
function space (e.g. "IsoParametric"). integrationPoints contains the para-
metric coordinates (u, v, w) and the weight for each integeration point, concate-
nated. numComponents returns the number of components of a basis function.
basisFunctions contains the evaluation of the basis functions at the integra-
tion points.
Input: elementType, integrationType, functionSpaceType
Output: integrationPoints, numComponents, basisFunctions
Return: -
precomputeBasisFunctions
Precomputes the basis functions corresponding to elementType.
Input: elementType
Output: -
Return: -
getBarycenters
Get the barycenters of all elements of type elementType classified on the entity
of tag tag. If primary is set, only the primary nodes of the elements are taken
into account for the barycenter calculation. If fast is set, the function returns
the sum of the primary node coordinates (without normalizing by the number of
nodes). If numTasks > 1, only compute and return the part of the data indexed
by task.
Input: elementType, tag, fast, primary, task, numTasks
Output: barycenters
Return: -
preallocateBarycenters
Preallocate the data required by getBarycenters. This is necessary only if
getBarycenters is called with numTasks > 1.
Input: elementType, tag
Output: barycenters
Return: -
setSize Set a mesh size constraint on the geometrical entities dimTags. Currently only
entities of dimension 0 (points) are handled.
Input: dimTags, size
Output: -
Return: -
Appendix D: Gmsh API 251
setTransfiniteCurve
Set a transfinite meshing constraint on the curve tag, with numNodes nodes
distributed according to meshType and coef. Currently supported types are
"Progression" (geometrical progression with power coef) and "Bump" (refine-
ment toward both extremities of the curve).
Input: tag, numNodes, meshType, coef
Output: -
Return: -
setTransfiniteSurface
Set a transfinite meshing constraint on the surface tag. arrangement describes
the arrangement of the triangles when the surface is not flagged as recombined:
currently supported values are "Left", "Right", "AlternateLeft" and "Alter-
nateRight". cornerTags can be used to specify the (3 or 4) corners of the
transfinite interpolation explicitly; specifying the corners explicitly is manda-
tory if the surface has more that 3 or 4 points on its boundary.
Input: tag, arrangement, cornerTags
Output: -
Return: -
setTransfiniteVolume
Set a transfinite meshing constraint on the surface tag. cornerTags can be
used to specify the (6 or 8) corners of the transfinite interpolation explicitly.
Input: tag, cornerTags
Output: -
Return: -
setRecombine
Set a recombination meshing constraint on the geometrical entity of dimension
dim and tag tag. Currently only entities of dimension 2 (to recombine triangles
into quadrangles) are supported.
Input: dim, tag
Output: -
Return: -
setSmoothing
Set a smoothing meshing constraint on the geometrical entity of dimension dim
and tag tag. val iterations of a Laplace smoother are applied.
Input: dim, tag, val
Output: -
Return: -
252 Gmsh 4.0
setReverse
Set a reverse meshing constraint on the geometrical entity of dimension dim and
tag tag. If val is true, the mesh orientation will be reversed with respect to the
natural mesh orientation (i.e. the orientation consistent with the orientation of
the geometrical entity). If val is false, the mesh is left as-is.
Input: dim, tag, val
Output: -
Return: -
setOutwardOrientation
Set meshing constraints on the bounding surfaces of the volume of tag tag so
that all surfaces are oriented with outward pointing normals. Currently only
available with the OpenCASCADE kernel, as it relies on the STL triangulation.
Input: tag
Output: -
Return: -
embed Embed the geometrical entities of dimension dim and tags tags in the (inDim,
inTag) geometrical entity. inDim must be strictly greater than dim.
Input: dim, tags, inDim, inTag
Output: -
Return: -
reorderElements
Reorder the elements of type elementType classified on the entity of tag tag
according to ordering.
Input: elementType, tag, ordering
Output: -
Return: -
renumberNodes
Renumber the nodes tags in a contiunous sequence.
Input: -
Output: -
Return: -
renumberElements
Renumber the elements tags in a contiunous sequence.
Input: -
Output: -
Return: -
Appendix D: Gmsh API 253
setPeriodic
Set the meshes of the entities of dimension dim and tag tags as periodic copies
of the meshes of entities tagsSource, using the affine transformation specified
in affineTransformation (16 entries of a 4x4 matrix, by row). Currently only
available for dim == 1 and dim == 2.
Input: dim, tags, tagsSource, affineTransformation
Output: -
Return: -
getPeriodicNodes
Get the master entity, periodic node pairs and affine transform for the entity
of dimension dim and tag tag.
Input: dim, tag
Output: tagMaster, nodes, affineTransform
Return: -
removeDuplicateNodes
Remove duplicate nodes in the mesh of the current model.
Input: -
Output: -
Return: -
createTopology
Create a boundary representation from the mesh if the model does not have
one (e.g. when imported from mesh file formats with no BRep representation
of the underlying model). Warning: this is an experimental feature.
Input: -
Output: -
Return: -
createGeometry
Create a parametrization for curves and surfaces that do not have one (i.e.
discrete curves and surfaces represented solely by meshes, without an underlying
CAD description). Warning: this is an experimental feature.
Input: -
Output: -
Return: -
computeHomology
Compute a basis representation for homology spaces after a mesh has been
generated. The computation domain is given in a list of physical group tags
domainTags; if empty, the whole mesh is the domain. The computation subdo-
main for relative homology computation is given in a list of physical group tags
254 Gmsh 4.0
Module /gmsh/model/mesh/field
add Add a new mesh size field of type fieldType. If tag is positive, assign the tag
explcitly; otherwise a new tag is assigned automatically. Return the field tag.
Input: fieldType, tag
Output: -
Return: integer
remove Remove the field with tag tag.
Input: tag
Output: -
Return: -
setNumber
Set the numerical option option to value value for field tag.
Input: tag, option, value
Output: -
Return: -
setString
Set the string option option to value value for field tag.
Appendix D: Gmsh API 255
Module /gmsh/model/geo
addPoint Add a geometrical point in the internal GEO CAD representation, at coordi-
nates (x, y, z). If meshSize is > 0, add a meshing constraint at that point. If
tag is positive, set the tag explicitly; otherwise a new tag is selected automat-
ically. Return the tag of the point. (Note that the point will be added in the
current model only after synchronize is called. This behavior holds for all the
entities added in the geo module.)
Input: x, y, z, meshSize, tag
Output: -
Return: integer
addLine Add a straight line segment between the two points with tags startTag and
endTag. If tag is positive, set the tag explicitly; otherwise a new tag is selected
automatically. Return the tag of the line.
Input: startTag, endTag, tag
Output: -
Return: integer
256 Gmsh 4.0
addCircleArc
Add a circle arc (stricly smaller than Pi) between the two points with tags
startTag and endTag, with center centertag. If tag is positive, set the tag
explicitly; otherwise a new tag is selected automatically. If (nx, ny, nz) !=
(0,0,0), explicitely set the plane of the circle arc. Return the tag of the circle
arc.
Input: startTag, centerTag, endTag, tag, nx, ny, nz
Output: -
Return: integer
addEllipseArc
Add an ellipse arc (stricly smaller than Pi) between the two points startTag
and endTag, with center centertag and major axis point majorTag. If tag is
positive, set the tag explicitly; otherwise a new tag is selected automatically. If
(nx, ny, nz) != (0,0,0), explicitely set the plane of the circle arc. Return the
tag of the ellipse arc.
Input: startTag, centerTag, majorTag, endTag, tag, nx, ny, nz
Output: -
Return: integer
addSpline
Add a spline (Catmull-Rom) curve going through the points pointTags. If tag
is positive, set the tag explicitly; otherwise a new tag is selected automatically.
Create a periodic curve if the first and last points are the same. Return the tag
of the spline curve.
Input: pointTags, tag
Output: -
Return: integer
addBSpline
Add a cubic b-spline curve with pointTags control points. If tag is positive,
set the tag explicitly; otherwise a new tag is selected automatically. Creates a
periodic curve if the first and last points are the same. Return the tag of the
b-spline curve.
Input: pointTags, tag
Output: -
Return: integer
addBezier
Add a Bezier curve with pointTags control points. If tag is positive, set the
tag explicitly; otherwise a new tag is selected automatically. Return the tag of
the Bezier curve.
Input: pointTags, tag
Appendix D: Gmsh API 257
Output: -
Return: integer
addCurveLoop
Add a curve loop (a closed wire) formed by the curves curveTags. curveTags
should contain (signed) tags of geometrical enties of dimension 1 forming a
closed loop: a negative tag signifies that the underlying curve is considered
with reversed orientation. If tag is positive, set the tag explicitly; otherwise a
new tag is selected automatically. Return the tag of the curve loop.
Input: curveTags, tag
Output: -
Return: integer
addPlaneSurface
Add a plane surface defined by one or more curve loops wireTags. The first
curve loop defines the exterior contour; additional curve loop define holes. If tag
is positive, set the tag explicitly; otherwise a new tag is selected automatically.
Return the tag of the surface.
Input: wireTags, tag
Output: -
Return: integer
addSurfaceFilling
Add a surface filling the curve loops in wireTags. Currently only a single
curve loop is supported; this curve loop should be composed by 3 or 4 curves
only. If tag is positive, set the tag explicitly; otherwise a new tag is selected
automatically. Return the tag of the surface.
Input: wireTags, tag, sphereCenterTag
Output: -
Return: integer
addSurfaceLoop
Add a surface loop (a closed shell) formed by surfaceTags. If tag is positive,
set the tag explicitly; otherwise a new tag is selected automatically. Return the
tag of the shell.
Input: surfaceTags, tag
Output: -
Return: integer
addVolume
Add a volume (a region) defined by one or more shells shellTags. The first
surface loop defines the exterior boundary; additional surface loop define holes.
If tag is positive, set the tag explicitly; otherwise a new tag is selected auto-
matically. Return the tag of the volume.
258 Gmsh 4.0
Module /gmsh/model/geo/mesh
setSize Set a mesh size constraint on the geometrical entities dimTags. Currently only
entities of dimension 0 (points) are handled.
Input: dimTags, size
Output: -
Return: -
setTransfiniteCurve
Set a transfinite meshing constraint on the curve tag, with numNodes nodes
distributed according to meshType and coef. Currently supported types are
"Progression" (geometrical progression with power coef) and "Bump" (refine-
ment toward both extreminties of the curve).
Input: tag, nPoints, meshType, coef
Output: -
Return: -
setTransfiniteSurface
Set a transfinite meshing constraint on the surface tag. arrangement describes
the arrangement of the triangles when the surface is not flagged as recombined:
currently supported values are "Left", "Right", "AlternateLeft" and "Alter-
nateRight". cornerTags can be used to specify the (3 or 4) corners of the
transfinite interpolation explicitly; specifying the corners explicitly is manda-
tory if the surface has more that 3 or 4 points on its boundary.
Input: tag, arrangement, cornerTags
Output: -
Return: -
setTransfiniteVolume
Set a transfinite meshing constraint on the surface tag. cornerTags can be
used to specify the (6 or 8) corners of the transfinite interpolation explicitly.
Input: tag, cornerTags
Output: -
Return: -
setRecombine
Set a recombination meshing constraint on the geometrical entity of dimension
dim and tag tag. Currently only entities of dimension 2 (to recombine triangles
into quadrangles) are supported.
Input: dim, tag, angle
Output: -
Return: -
Appendix D: Gmsh API 261
setSmoothing
Set a smoothing meshing constraint on the geometrical entity of dimension dim
and tag tag. val iterations of a Laplace smoother are applied.
Input: dim, tag, val
Output: -
Return: -
setReverse
Set a reverse meshing constraint on the geometrical entity of dimension dim and
tag tag. If val is true, the mesh orientation will be reversed with respect to the
natural mesh orientation (i.e. the orientation consistent with the orientation of
the geometrical entity). If val is false, the mesh is left as-is.
Input: dim, tag, val
Output: -
Return: -
Module /gmsh/model/occ
addPoint Add a geometrical point in the internal OpenCASCADE CAD representation,
at coordinates (x, y, z). If meshSize is > 0, add a meshing constraint at that
point. If tag is positive, set the tag explicitly; otherwise a new tag is selected
automatically. Return the tag of the point. (Note that the point will be added
in the current model only after synchronize is called. This behavior holds for
all the entities added in the occ module.)
Input: x, y, z, meshSize, tag
Output: -
Return: integer
addLine Add a straight line segment between the two points with tags startTag and
endTag. If tag is positive, set the tag explicitly; otherwise a new tag is selected
automatically. Return the tag of the line.
Input: startTag, endTag, tag
Output: -
Return: integer
addCircleArc
Add a circle arc between the two points with tags startTag and endTag, with
center centerTag. If tag is positive, set the tag explicitly; otherwise a new tag
is selected automatically. Return the tag of the circle arc.
Input: startTag, centerTag, endTag, tag
Output: -
Return: integer
262 Gmsh 4.0
addCircle
Add a circle of center (x, y, z) and radius r. If tag is positive, set the tag
explicitly; otherwise a new tag is selected automatically. If angle1 and angle2
are specified, create a circle arc between the two angles. Return the tag of the
circle.
Input: x, y, z, r, tag, angle1, angle2
Output: -
Return: integer
addEllipseArc
Add an ellipse arc between the two points with tags startTag and endTag,
with center centerTag. If tag is positive, set the tag explicitly; otherwise a
new tag is selected automatically. Return the tag of the ellipse arc.
Input: startTag, centerTag, endTag, tag
Output: -
Return: integer
addEllipse
Add an ellipse of center (x, y, z) and radii r1 and r2 along the x- and y-axes
respectively. If tag is positive, set the tag explicitly; otherwise a new tag is
selected automatically. If angle1 and angle2 are specified, create an ellipse
arc between the two angles. Return the tag of the ellipse.
Input: x, y, z, r1, r2, tag, angle1, angle2
Output: -
Return: integer
addSpline
Add a spline (C2 b-spline) curve going through the points pointTags. If tag
is positive, set the tag explicitly; otherwise a new tag is selected automatically.
Create a periodic curve if the first and last points are the same. Return the tag
of the spline curve.
Input: pointTags, tag
Output: -
Return: integer
addBSpline
Add a b-spline curve of degree degree with pointTags control points. If
weights, knots or multiplicities are not provided, default parameters are
computed automatically. If tag is positive, set the tag explicitly; otherwise a
new tag is selected automatically. Create a periodic curve if the first and last
points are the same. Return the tag of the b-spline curve.
Input: pointTags, tag, degree, weights, knots, multiplicities
Output: -
Appendix D: Gmsh API 263
Return: integer
addBezier
Add a Bezier curve with pointTags control points. If tag is positive, set the
tag explicitly; otherwise a new tag is selected automatically. Return the tag of
the Bezier curve.
Input: pointTags, tag
Output: -
Return: integer
addWire Add a wire (open or closed) formed by the curves curveTags. curveTags
should contain (signed) tags: a negative tag signifies that the underlying curve
is considered with reversed orientation. If tag is positive, set the tag explicitly;
otherwise a new tag is selected automatically. Return the tag of the wire.
Input: curveTags, tag, checkClosed
Output: -
Return: integer
addCurveLoop
Add a curve loop (a closed wire) formed by the curves curveTags. curveTags
should contain tags of curves forming a closed loop. If tag is positive, set the
tag explicitly; otherwise a new tag is selected automatically. Return the tag of
the curve loop.
Input: curveTags, tag
Output: -
Return: integer
addRectangle
Add a rectangle with lower left corner at (x, y, z) and upper right corner at
(x + dx, y + dy, z). If tag is positive, set the tag explicitly; otherwise a new
tag is selected automatically. Round the corners if roundedRadius is nonzero.
Return the tag of the rectangle.
Input: x, y, z, dx, dy, tag, roundedRadius
Output: -
Return: integer
addDisk Add a disk with center (xc, yc, zc) and radius rx along the x-axis and ry
along the y-axis. If tag is positive, set the tag explicitly; otherwise a new tag
is selected automatically. Return the tag of the disk.
Input: xc, yc, zc, rx, ry, tag
Output: -
Return: integer
264 Gmsh 4.0
addPlaneSurface
Add a plane surface defined by one or more curve loops (or closed wires)
wireTags. The first curve loop defines the exterior contour; additional curve
loop define holes. If tag is positive, set the tag explicitly; otherwise a new tag
is selected automatically. Return the tag of the surface.
Input: wireTags, tag
Output: -
Return: integer
addSurfaceFilling
Add a surface filling the curve loops in wireTags. If tag is positive, set the tag
explicitly; otherwise a new tag is selected automatically. Return the tag of the
surface.
Input: wireTag, tag
Output: -
Return: integer
addSurfaceLoop
Add a surface loop (a closed shell) formed by surfaceTags. If tag is positive,
set the tag explicitly; otherwise a new tag is selected automatically. Return the
tag of the surface loop.
Input: surfaceTags, tag
Output: -
Return: integer
addVolume
Add a volume (a region) defined by one or more surface loops shellTags. The
first surface loop defines the exterior boundary; additional surface loop define
holes. If tag is positive, set the tag explicitly; otherwise a new tag is selected
automatically. Return the tag of the volume.
Input: shellTags, tag
Output: -
Return: integer
addSphere
Add a sphere of center (xc, yc, zc) and radius r. The optional angle1 and
angle2 arguments define the polar angle opening (from -Pi/2 to Pi/2). The op-
tional angle3 argument defines the azimuthal opening (from 0 to 2*Pi). If tag
is positive, set the tag explicitly; otherwise a new tag is selected automatically.
Return the tag of the sphere.
Input: xc, yc, zc, radius, tag, angle1, angle2, angle3
Output: -
Return: integer
Appendix D: Gmsh API 265
addBox Add a parallelepipedic box defined by a point (x, y, z) and the extents along
the x-, y- and z-axes. If tag is positive, set the tag explicitly; otherwise a new
tag is selected automatically. Return the tag of the box.
Input: x, y, z, dx, dy, dz, tag
Output: -
Return: integer
addCylinder
Add a cylinder, defined by the center (x, y, z) of its first circular face, the 3
components (dx, dy, dz) of the vector defining its axis and its radius r. The
optional angle argument defines the angular opening (from 0 to 2*Pi). If tag
is positive, set the tag explicitly; otherwise a new tag is selected automatically.
Return the tag of the cylinder.
Input: x, y, z, dx, dy, dz, r, tag, angle
Output: -
Return: integer
addCone Add a cone, defined by the center (x, y, z) of its first circular face, the 3
components of the vector (dx, dy, dz) defining its axis and the two radii r1
and r2 of the faces (these radii can be zero). If tag is positive, set the tag
explicitly; otherwise a new tag is selected automatically. angle defines the
optional angular opening (from 0 to 2*Pi). Return the tag of the cone.
Input: x, y, z, dx, dy, dz, r1, r2, tag, angle
Output: -
Return: integer
addWedge Add a right angular wedge, defined by the right-angle point (x, y, z) and the 3
extends along the x-, y- and z-axes (dx, dy, dz). If tag is positive, set the tag
explicitly; otherwise a new tag is selected automatically. The optional argument
ltx defines the top extent along the x-axis. Return the tag of the wedge.
Input: x, y, z, dx, dy, dz, tag, ltx
Output: -
Return: integer
addTorus Add a torus, defined by its center (x, y, z) and its 2 radii r and r2. If tag is
positive, set the tag explicitly; otherwise a new tag is selected automatically.
The optional argument angle defines the angular opening (from 0 to 2*Pi).
Return the tag of the wedge.
Input: x, y, z, r1, r2, tag, angle
Output: -
Return: integer
266 Gmsh 4.0
addThruSections
Add a volume (if the optional argument makeSolid is set) or surfaces defined
through the open or closed wires wireTags. If tag is positive, set the tag
explicitly; otherwise a new tag is selected automatically. The new entities are
returned in outDimTags. If the optional argument makeRuled is set, the surfaces
created on the boundary are forced to be ruled surfaces.
Input: wireTags, tag, makeSolid, makeRuled
Output: outDimTags
Return: -
addThickSolid
Add a hollowed volume built from an initial volume volumeTag and a set of
faces from this volume excludeSurfaceTags, which are to be removed. The
remaining faces of the volume become the walls of the hollowed solid, with
thickness offset. If tag is positive, set the tag explicitly; otherwise a new tag
is selected automatically.
Input: volumeTag, excludeSurfaceTags, offset, tag
Output: outDimTags
Return: -
extrude Extrude the geometrical entities dimTags by translation along (dx, dy, dz).
Return extruded entities in outDimTags. If numElements is not empty, also
extrude the mesh: the entries in numElements give the number of elements in
each layer. If height is not empty, it provides the (cummulative) height of the
different layers, normalized to 1.
Input: dimTags, dx, dy, dz, numElements, heights, recombine
Output: outDimTags
Return: -
revolve Extrude the geometrical entities dimTags by rotation of angle radians around
the axis of revolution defined by the point (x, y, z) and the direction (ax, ay,
az). Return extruded entities in outDimTags. If numElements is not empty,
also extrude the mesh: the entries in numElements give the number of elements
in each layer. If height is not empty, it provides the (cummulative) height of
the different layers, normalized to 1.
Input: dimTags, x, y, z, ax, ay, az, angle, numElements, heights,
recombine
Output: outDimTags
Return: -
addPipe Add a pipe by extruding the entities dimTags along the wire wireTag. Return
the pipe in outDimTags.
Input: dimTags, wireTag
Appendix D: Gmsh API 267
Output: outDimTags
Return: -
fillet Fillet the volumes volumeTags on the curves curveTags with radii radii. The
radii vector can either contain a single radius, as many radii as curveTags, or
twice as many as curveTags (in which case different radii are provided for the
begin and end points of the curves). Return the filleted entities in outDimTags.
Remove the original volume if removeVolume is set.
Input: volumeTags, curveTags, radii, removeVolume
Output: outDimTags
Return: -
chamfer Chamfer the volumes volumeTags on the curves curveTags with distances
distances measured on surfaces surfaceTags. The distances vector
can either contain a single distance, as many distances as curveTags and
surfaceTags, or twice as many as curveTags and surfaceTags (in which case
the first in each pair is measured on the corresponding surface in surfaceTags,
the other on the other adjacent surface). Return the chamfered entities in
outDimTags. Remove the original volume if removeVolume is set.
Input: volumeTags, curveTags, surfaceTags, distances, removeVolume
Output: outDimTags
Return: -
fuse Compute the boolean union (the fusion) of the entities objectDimTags and
toolDimTags. Return the resulting entities in outDimTags. If tag is positive,
try to set the tag explicitly (ony valid if the boolean operation results in a
single entity). Remove the object if removeObject is set. Remove the tool if
removeTool is set.
Input: objectDimTags, toolDimTags, tag, removeObject, removeTool
Output: outDimTags, outDimTagsMap
Return: -
intersect
Compute the boolean intersection (the common parts) of the entities
objectDimTags and toolDimTags. Return the resulting entities in
outDimTags. If tag is positive, try to set the tag explicitly (ony valid if
the boolean operation results in a single entity). Remove the object if
removeObject is set. Remove the tool if removeTool is set.
Input: objectDimTags, toolDimTags, tag, removeObject, removeTool
Output: outDimTags, outDimTagsMap
Return: -
cut Compute the boolean difference between the entities objectDimTags and
toolDimTags. Return the resulting entities in outDimTags. If tag is positive,
268 Gmsh 4.0
try to set the tag explicitly (ony valid if the boolean operation results in a
single entity). Remove the object if removeObject is set. Remove the tool if
removeTool is set.
Input: objectDimTags, toolDimTags, tag, removeObject, removeTool
Output: outDimTags, outDimTagsMap
Return: -
fragment Compute the boolean fragments (general fuse) of the entities objectDimTags
and toolDimTags. Return the resulting entities in outDimTags. If tag is posi-
tive, try to set the tag explicitly (ony valid if the boolean operation results in
a single entity). Remove the object if removeObject is set. Remove the tool if
removeTool is set.
Input: objectDimTags, toolDimTags, tag, removeObject, removeTool
Output: outDimTags, outDimTagsMap
Return: -
translate
Translate the geometrical entities dimTags along (dx, dy, dz).
Input: dimTags, dx, dy, dz
Output: -
Return: -
rotate Rotate the geometrical entities dimTags of angle radians around the axis of
revolution defined by the point (x, y, z) and the direction (ax, ay, az).
Input: dimTags, x, y, z, ax, ay, az, angle
Output: -
Return: -
dilate Scale the geometrical entities dimTag by factors a, b and c along the three
coordinate axes; use (x, y, z) as the center of the homothetic transformation.
Input: dimTags, x, y, z, a, b, c
Output: -
Return: -
symmetrize
Apply a symmetry transformation to the geometrical entities dimTag, with
respect to the plane of equation a * x + b * y + c * z + d = 0.
Input: dimTags, a, b, c, d
Output: -
Return: -
copy Copy the entities dimTags; the new entities are returned in outDimTags.
Appendix D: Gmsh API 269
Input: dimTags
Output: outDimTags
Return: -
remove Remove the entities dimTags. If recursive is true, remove all the entities on
their boundaries, down to dimension 0.
Input: dimTags, recursive
Output: -
Return: -
removeAllDuplicates
Remove all duplicate entities (different entities at the same geometrical location)
after intersecting (using boolean fragments) all highest dimensional entities.
Input: -
Output: -
Return: -
importShapes
Import BREP, STEP or IGES shapes from the file fileName. The imported
entities are returned in outDimTags. If the optional argument highestDimOnly
is set, only import the highest dimensional entities in the file. The optional
argument format can be used to force the format of the file (currently "brep",
"step" or "iges").
Input: fileName, highestDimOnly, format
Output: outDimTags
Return: -
importShapesNativePointer
Imports an OpenCASCADE shape by providing a pointer to a native Open-
CASCADE TopoDS_Shape object (passed as a pointer to void). The imported
entities are returned in outDimTags. If the optional argument highestDimOnly
is set, only import the highest dimensional entities in shape. Warning: this
function is unsafe, as providing an invalid pointer will lead to undefined behav-
ior.
Input: shape, highestDimOnly
Output: outDimTags
Return: -
setMeshSize
Set a mesh size constraint on the geometrical entities dimTags. Currently only
entities of dimension 0 (points) are handled.
Input: dimTags, size
Output: -
270 Gmsh 4.0
Return: -
synchronize
Synchronize the internal OpenCASCADE CAD representation with the current
Gmsh model. This can be called at any time, but since it involves a non trivial
amount of processing, the number of synchronization points should normally
be minimized.
Input: -
Output: -
Return: -
Module /gmsh/view
add Add a new post-processing view, with name name. If tag is positive use it (and
remove the view with that tag if it already exists), otherwise associate a new
tag. Return the view tag.
Input: name, tag
Output: -
Return: integer
remove Remove the view with tag tag.
Input: tag
Output: -
Return: -
getIndex Get the index of the view with tag tag in the list of currently loaded views.
This dynamic index (it can change when views are removed) is used to access
view options.
Input: tag
Output: -
Return: integer
getTags Get the tags of all views.
Input: -
Output: tags
Return: -
addModelData
Add model-based post-processing data to the view with tag tag. modelName
identifies the model the data is attached to. dataType specifies the type of
data, currently either "NodeData", "ElementData" or "ElementNodeData".
step specifies the identifier (>= 0) of the data in a sequence. tags gives the
tags of the nodes or elements in the mesh to which the data is associated. data is
Appendix D: Gmsh API 271
a vector of the same length as tags: each entry is the vector of double precision
numbers representing the data associated with the corresponding tag. The
optional time argument associate a time value with the data. numComponents
gives the number of data components (1 for scalar data, 3 for vector data, etc.)
per entity; if negative, it is automatically inferred (when possible) from the
input data. partition allows to specify data in several sub-sets.
Input: tag, step, modelName, dataType, tags, data, time,
numComponents, partition
Output: -
Return: -
getModelData
Get model-based post-processing data from the view with tag tag at step step.
Return the data associated to the nodes or the elements with tags tags, as well
as the dataType and the number of components numComponents.
Input: tag, step
Output: dataType, tags, data, time, numComponents
Return: -
addListData
Add list-based post-processing data to the view with tag tag. dataType identi-
fies the data: "SP" for scalar points, "VP", for vector points, etc. numEle gives
the number of elements in the data. data contains the data for the numEle
elements.
Input: tag, dataType, numEle, data
Output: -
Return: -
getListData
Get list-based post-processing data from the view with tag tag. Return the
types dataTypes, the number of elements numElements for each data type and
the data for each data type.
Input: tag
Output: dataType, numElements, data
Return: -
probe Probe the view tag for its value at point (x, y, z). Return only the value at
step step is step is positive. Return only values with numComp if numComp is
positive. Return the gradient of the value if gradient is set. Probes with a
geometrical tolerance (in the reference unit cube) of tolerance if tolerance
is not zero. Return the result from the element described by its coordinates if
xElementCoord, yElementCoord and zElementCoord are provided.
Input: tag, x, y, z, step, numComp, gradient, tolerance, xElemCoord,
yElemCoord, zElemCoord
272 Gmsh 4.0
Output: value
Return: -
write Write the view to a file fileName. The export format is determined by the file
extension. Append to the file if append is set.
Input: tag, fileName, append
Output: -
Return: -
Module /gmsh/plugin
setNumber
Set the numerical option option to the value value for plugin name.
Input: name, option, value
Output: -
Return: -
setString
Set the string option option to the value value for plugin name.
Input: name, option, value
Output: -
Return: -
run Run the plugin name.
Input: name
Output: -
Return: -
Module /gmsh/graphics
draw Draw all the OpenGL scenes.
Input: -
Output: -
Return: -
Module /gmsh/fltk
initialize
Create the Fltk graphical user interface.
Input: -
Output: -
Appendix D: Gmsh API 273
Return: -
wait Wait at most time seconds for user interface events and return. If time < 0,
wait indefinitely. First automatically create the user interface if it has not yet
been initialized.
Input: time
Output: -
Return: -
run Run the event loop of the Fltk graphical user interface, i.e. repeatedly calls
wait. First automatically create the user interface if it has not yet been initial-
ized.
Input: -
Output: -
Return: -
Module /gmsh/onelab
get Get data from the ONELAB server.
Input: format
Output: data
Return: -
set Set data in the ONELAB server.
Input: data, format
Output: -
Return: -
run Run a ONELAB client. If name is provided, create a new ONELAB client with
name name and executes command. If not, try to run a client that might be
linked to the processed input files.
Input: name, command
Output: -
Return: -
Module /gmsh/logger
start Start logging messages in log.
Input: -
Output: log
Return: -
274 Gmsh 4.0
2. Gmsh is very slow when I use many transformations (Translate, Rotate, Symmetry,
Extrude, etc. ). What’s wrong?
The default behavior of Gmsh is to check and suppress all duplicate entities (points,
curves and surfaces) each time a transformation command is issued. This can slow
down things a lot if many transformations are performed. There are two solutions to
this problem:
• you may save the unrolled geometry in another file (e.g. with gmsh file.geo -0),
and use this new file for subsequent computations;
• or you may set the Geometry.AutoCoherence option to 0. This will prevent any
automatic duplicate check/replacement. If you still need to remove the duplicates
entities, simply add Coherence; at strategic locations in your geo files (e.g. before
the creation of curve loops, etc.).
3. How can I display only selected parts of my model?
Use ‘Tools->Visibility’. This allows you to select elementary entities and physical
groups, as well as mesh elements, in a variety of ways (in a list or tree browser, by
tag, interactively, or per window).
4. Can I edit STEP/IGES/BRep models?
Yes. With the OpenCASCADE kernel (SetFactory("OpenCASCADE");), load the file
(Merge "file.step"; or ShapeFromFile("file.step")) and add the relevant script-
ing commands after that to delete parts, create new parts or appy boolean operators.
5. How can I build modular geometries?
Define common geometrical objects and options in separate files or using Macro,
reusable in all your problem definition structures.
14. How can I “explore” a mesh (for example, to see inside a complex structure)?
You can use ‘Tools->Clipping Planes’ to clip the region of interest. You can define up
to 6 clipping planes in Gmsh (i.e., enough to define a “cube” inside your model) and
each plane can clip either the geometry, the mesh, the post-processing views, or any
combination of the above. The clipping planes are defined using the four coefficients
A,B,C,D of the equation A*x+B*y+C*y+D=0, which can be adjusted interactively by
dragging the mouse in the input fields.
15. What is the signification of SICN, Gamma and SIGE in Tools->Statistics?
They measure the quality of the tetrahedra in a mesh:
SICN ~signed inverse condition number
Gamma ~ inscribed radius / circumscribed radius
SIGE~signed inverse error on the gradient of FE solution
For the exact definitions, see Geo/MElement.cpp. The graphs plot the the number of
elements vs. the quality measure.
16. Why don’t the node and/or elememt numbers on the screen match the numbers in the
mesh file?
This was a feature of the legacy version 1 and version 2 MSH file formats. The MSH
format version 4 does not renumber nodes and elements by default.
3.0.4 (July 28, 2017): moved vorometal code to plugin; openmp improvements; bug
fixes.
3.0.3 (June 27, 2017): new element quality measures; Block->Box; minor fixes.
3.0.2 (May 13, 2017): improved handling of meshing constraints and entity
numbering after boolean operations; improved handling of fast coarseness
transitions in MeshAdapt; new TIKZ export; small bug fixes.
3.0.1 (April 14, 2017): fixed OpenCASCADE plane surfaces with holes.
3.0.0 (April 13, 2017): new constructive solid geometry features and boolean
operations using OpenCASCADE; improved graphical user interface for interactive,
parametric geometry construction; new or modified commands in .geo files:
SetFactory, Circle, Ellipse, Wire, Surface, Sphere, Block, Torus, Rectangle,
Disk, Cylinder, Cone, Wedge, ThickSolid, ThruSections, Ruled ThruSections,
Fillet, Extrude, BooleanUnion, BooleanIntersection, BooleanDifference,
BooleanFragments, ShapeFromFile, Recursive Delete, Unique; "Surface" replaces
the deprecated "Ruled Surface" command; faster 3D tetrahedral mesh optimization
enabled by default; major code refactoring and numerous bug fixes.
2.16.0 (January 3, 2017): small improvements (list functions, second order hexes
for MED, GUI) and bug fixes.
2.14.1 (October 30, 2016): fixed regression in periodic meshes; small bug fixes
and code cleanups.
2.14.0 (October 9, 2016): new Tochnog file format export; added ability to
remove last command in scripts generated interactively; ONELAB 1.3 with
usability and performance improvements; faster "Coherence Mesh".
2.13.2 (August 18, 2016)): small improvements (scale labels, periodic and
high-order meshes) and bug fixes.
2.13.0 (July 11, 2016): new ONELAB 1.2 protocol with native support for lists;
new experimental 3D boundary recovery code and 3D refinement algorithm; better
adaptive visualization of quads and hexahedra; fixed several regressions
introduced in 2.12.
2.10.0 (July 21, 2015): improved periodic meshing constraints; new Physical
specification with both label and numeric id; images can now be used as glyphs
in post-processing views, using text annotations with the ‘file://’ prefix;
Views can be grouped and organized in subtrees; improved visibility browser
navigation; geometrical entities and post-processing views can now react to
double-clicks, via new generic DoubleClicked options; new Get/SetNumber and
Get/SetString for direct access to ONELAB variables; small bug fixes and code
cleanups.
2.9.2 (March 31, 2015): added support for extrusion of embedded points/curves;
improved hex-dominant algorithm; fixed crashes in quad algorithm; fix regression
Appendix G: Version history 287
2.9.0 (March 12, 2015): improved robustness of spatial searches (extruded meshes,
geometry coherence); improved reproductibility of 2D and 3D meshes; added
support for high resolution ("retina") graphics; interactive graph point
commands; on-the-fly creation of onelab clients in scripts; general periodic
meshes using afine transforms; scripted selection of entities in bounding boxes;
extended string and list handling functions; many small improvements and bug
fixes.
2.8.5 (Jul 9, 2014): improved stability and error handling, better Coherence
function, updated onelab API version and inline parameter definitions, new
background image modes, more robust Triangulate/Tetrahedralize plugins, new PGF
output, improved support for string~index variable names in parser, small
improvements and bug fixes all over the place.
2.8.3 (Sep 27, 2013): new quick access menu and multiple view selection in GUI;
enhanced animation creation; many small enhancements and bug fixes.
2.8.2 (Jul 16, 2013): improved high order tools interface; minor bug fixes.
2.8.1 (Jul 11, 2013): improved compound surfaces and transfinite arrangements.
2.8.0 (Jul 8, 2013): improved Delaunay point insertion; fixed mesh orientation
of plane surfaces; fixed mesh size prescribed at embedded points; improved
display of vectors at COG; new experimental text string display engines;
improved fullscreen mode; access time/step in transformations; new experimental
features: AdaptMesh and Surface In Volume; accept unicode file paths on Windows;
compilation and bug fixes.
2.7.1 (May 11, 2013): improved Delaunay point insertion; updated onelab; better
Abaqus and UNV export; small bug and compilation fixes.
2.6.0 (Jun 19, 2012): new quadrilateral meshing algorithms (Blossom and
DelQuad); new solver module based on ONELAB project (requires FLTK 1.3); new
288 Gmsh 4.0
2.5.0 (Oct 15, 2010): new compound geometrical entities (for remeshing and/or
trans-patch meshing); improved mesh reclassification tool; new client/server
visualization mode; new ability to watch a pattern of files to merge; new
integrated MPEG export; new option to force the type of views dynamically;
bumped mesh version format to 2.2 (small change in the meaning of the partition
tags; this only affects partitioned (i.e. parallel) meshes); renamed several
post-processing plugins (as well as plugin options) to make them easier to
understand; many bug fixes and usability improvements all over the place.
2.4.2 (Sep 21, 2009): solver code refactoring + better IDE integration.
2.4.1 (Sep 1, 2009): fixed surface mesh orientation bug introduced in 2.4.0;
mesh and graphics code refactoring, small usability enhancements and bug fixes.
2.4.0 (Aug 22, 2009): switched build system to CMake; optionally copy
transfinite mesh constraints during geometry transformations; bumped mesh
version format to 2.1 (small change in the $PhysicalNames section, where the
group dimension is now required); ported most plugins to the new
post-processing API; switched from MathEval to MathEx and Flu_Tree_Browser to
Fl_Tree; small bug fixes and improvements all over the place.
2.3.1 (Mar 18, 2009): removed GSL dependency (Gmsh now simply uses Blas and
Lapack); new per-window visibility; added support for composite window printing
and background images; fixed string option affectation in parser; fixed surface
mesh orientation for OpenCASCADE models; fixed random triangle orientations in
Delaunay and Frontal algorithms.
2.3.0 (Jan 23, 2009): major graphics and GUI code refactoring; new
full-quad/hexa subdivision algorithm; improved automatic transfinite corner
selection (now also for volumes); improved visibility browser; new automatic
adaptive visualization for high-order simplices; modified arrow size, clipping
planes and transform options; many improvements and bug fixes all over the
place.
2.2.6 (Nov 21, 2008): better transfinite smoothing and automatic corner
selection; fixed high order meshing crashes on Windows and Linux; new uniform
mesh refinement (thanks Brian!); fixed various other small bugs.
Appendix G: Version history 289
2.2.5 (Oct 25, 2008): Gmsh now requires FLTK 1.1.7 or above; various small
improvements (STL and VTK mesh IO, Netgen upgrade, Visual C++ support, Fields,
Mesh.{Msh,Stl,...}Binary changed to Mesh.Bindary) and bug fixes (pyramid
interpolation, Chaco crashes).
2.2.4 (Aug 14, 2008): integrated Metis and Chaco mesh partitioners; variables
can now be deleted in geo files; added support for point datasets in model-based
postprocessing views; small bug fixes.
2.2.3 (Jul 14, 2008): enhanced clipping interface; API cleanup; fixed various
bugs (Plugin(Integrate), high order meshes, surface info crash).
2.2.2 (Jun 20, 2008): added geometrical transformations on volumes; fixed bug in
high order mesh generation.
2.2.1 (Jun 15, 2008): various small improvements (adaptive views, GUI, code
cleanup) and bug fixes (high order meshes, Netgen interface).
2.2.0 (Apr 19, 2008): new model-based post-processing backend; added MED I/O for
mesh and post-processing; fixed BDF vertex ordering for 2nd order elements;
replaced Mesh.ConstrainedBackgroundMesh with
Mesh.CharacteristicLength{FromPoints,ExtendFromBoundary}; new Fields interface;
control windows are now non-modal by default; new experimental 2D frontal
algorithm; fixed various bugs.
2.1.1 (Mar 1, 2008): small bug fixes (second order meshes, combine views, divide
and conquer crash, ...).
2.0.8 (Jul 13, 2007): unused vertices are not saved in mesh files anymore; new
plugin GUI; automatic GUI font size selection; renamed
Plugin(DecomposeInSimplex) into Plugin(MakeSimplex); reintroduced enhanced
Plugin(SphericalRaise); clarified meshing algo names; new option to save groups
of nodes in UNV meshes; new background mesh infrastructure; many small
improvements and small bug fixes.
2.0.7 (Apr 3, 2007): volumes can now be defined from external CAD surfaces;
Delaunay/Tetgen algorithm is now used by default when available; re-added
support for Plot3D structured mesh format; added ability to export external CAD
models as GEO files (this only works for the limited set of geometrical
primitives available in the GEO language, of course--so trying to convert e.g. a
290 Gmsh 4.0
trimmed NURBS from a STEP file into a GEO file will fail); "lateral" entities
are now added at the end of the list returned by extrusion commands; fixed
various bugs.
2.0.0 (Feb 5, 2007): new geometry and mesh databases, with support for STEP and
IGES import via OpenCASCADE; complete rewrite of geometry and mesh drawing
code; complete rewrite of mesh I/O layer (with new native binary MSH format and
support for import/export of I-deas UNV, Nastran BDF, STL, Medit MESH and VRML
1.0 files); added support for incomplete second order elements; new 2D and 3D
meshing algorithms; improved integration of Netgen and TetGen algorithms;
removed anisotropic meshing algorithm (as well as attractors); removed explicit
region number specification in extrusions; option changes in the graphical
interface are now applied instantaneously; added support for offscreen rendering
using OSMesa; added support for SVG output; added string labels for Physical
entities; lots of other improvements all over the place.
1.65 (May 15, 2006): new Plugin(ExtractEdges); fixed compilation errors with
gcc4.1; replaced Plugin(DisplacementRaise) and Plugin(SphericalRaise) with the
more flexible Plugin(Warp); better handling of discrete curves; new Status
command in parser; added option to renumber nodes in .msh files (to avoid holes
in the numbering sequence); fixed 2 special cases in quad->prism extrusion;
fixed saving of 2nd order hexas with negative volume; small bug fixes and
cleanups.
1.64 (Mar 18, 2006): Windows versions do no depend on Cygwin anymore; various
bug fixes and cleanups.
1.63 (Feb 01, 2006): post-processing views can now be exported as meshes;
improved background mesh handling (a lot faster, and more accurate); improved
support for input images; new Plugin(ExtractElements); small bug fixes and
enhancements.
1.62 (Jan 15, 2006): new option to draw color gradients in the background;
enhanced perspective projection mode; new "lasso" selection mode (same as
"lasso" zoom, but in selection mode); new "invert selection" button in the
visibility browser; new snapping grid when adding points in the GUI; nicer
normal smoothing; new extrude syntax (old syntax still available, but
deprecated); various small bug fixes and enhancements.
1.61 (Nov 29, 2005): added support for second order (curved) elements in
post-processor; new version (1.4) of post-processing file formats; new stippling
options for 2D plots; removed limit on allowed number of files on command line;
all "Combine" operations are now available in the parser; changed
View.ArrowLocation into View.GlyphLocation; optimized memory usage when loading
many (>1000) views; optimized loading and drawing of line meshes and 2D iso
views; optimized handling of meshes with large number of physical entities;
optimized vertex array creation for large post-processing views on
Appendix G: Version history 291
Windows/Cygwin; removed Discrete Line and Discrete Surface commands (the same
functionality can now be obtained by simply loading a mesh in .msh format);
fixed coloring by mesh partition; added option to light wireframe meshes and
views; new "mesh statistics" export format; new full-quad recombine option; new
Plugin(ModulusPhase); hexas and prisms are now always saved with positive
volume; improved interactive entity selection; new experimental Tetgen
integration; new experimental STL remeshing algorithm; various small bug fixes
and improvements.
1.60 (Mar 15, 2005): added support for discrete curves; new Window menu on Mac
OS X; generalized all octree-based plugins (CutGrid, StreamLines, Probe, etc.)
to handle all element types (and not only scalar and vector
triangles+tetrahedra); generalized Plugin(Evaluate), Plugin(Extract) and
Plugin(Annotate); enhanced clipping plane interface; new grid/axes/rulers for 3D
post-processing views (renamed the AbscissaName, NbAbscissa and AbscissaFormat
options to more general names in the process); better automatic positioning of
2D graphs; new manipulator dialog to specify rotations, translations and
scalings "by hand"; various small enhancements and bug fixes.
1.59 (Feb 06, 2005): added support for discrete (triangulated) surfaces, either
in STL format or with the new "Discrete Surface" command; added STL and Text
output format for post-processing views and STL output format for surface
meshes; all levelset-based plugins can now also compute isovolumes; generalized
Plugin(Evaluate) to handle external view data (based on the same or on a
different mesh); generalized Plugin(CutGrid); new plugins (Eigenvalues,
Gradient, Curl, Divergence); changed default colormap to match Matlab’s "Jet"
colormap; new transformation matrix option for views (for non-destructive
rotations, symmetries, etc.); improved solver interface to keep the GUI
responsive during solver calls; new C++ and Python solver examples; simplified
Tools->Visibility GUI; transfinite lines with "Progression" now allow negative
line numbers to reverse the progression; added ability to retrieve Gmsh’s
version number in the parser (to help write backward compatible scripts); fixed
white space in unv mesh output; fixed various small bugs.
1.58 (Jan 01, 2005): fixed UNIX socket interface on Windows (broken by the TCP
solver patch in 1.57); bumped version number of default post-processing file
formats to 1.3 (the only small modification is the handling of the end-of-string
character for text2d and text3d objects in the ASCII format); new File->Rename
menu; new colormaps+improved colormap handling; new color+min/max options in
views; new GetValue() function to ask for values interactively in scripts;
generalized For/EndFor loops in parser; new plugins (Annotate, Remove, Probe);
new text attributes in views; renamed some shortcuts; fixed TeX output for large
scenes; new option dialogs for various output formats; fixed many small memory
leaks in parser; many small enhancements to polish the graphics and the user
interface.
1.57 (Dec 23, 2004): generalized displacement maps to display arbitrary view
292 Gmsh 4.0
types; the arrows representing a vector field can now also be colored by the
values from other scalar, vector or tensor fields; new adaptive high order
visualization mode; new options (Solver.SocketCommand, Solver.NameCommand,
View.ArrowSizeProportional, View.Normals, View.Tangents and General.ClipFactor);
fixed display of undesired solver plugin popups; enhanced interactive plugin
behavior; new plugins (HarmonicToTime, Integrate, Eigenvectors); tetrahedral
mesh file reading speedup (50% faster on large meshes); large memory footprint
reduction (up to 50%) for the visualization of triangular/tetrahedral meshes;
the solver interface now supports TCP/IP connections; new generalized raise mode
(allows to use complex expressions to offset post-processing maps); upgraded
Netgen kernel to version 4.4; new optional TIME list in parsed views to specify
the values of the time steps; several bug fixes in the Elliptic mesh algorithm;
various other small bug fixes and enhancements.
1.56 (Oct 17, 2004): new post-processing option to draw a scalar view raised by
a displacement view without using Plugin(DisplacementRaise) (makes drawing
arbitrary scalar fields on deformed meshes much easier); better post-processing
menu (arbitrary number of views+scrollable+show view number); improved
view->combine; new horizontal post-processing scales; new option to draw the
mesh nodes per element; views can now also be saved in "parsed" format; fixed
various path problems on Windows; small bug fixes.
1.55 (Aug 21, 2004): added background mesh support for Triangle; meshes can now
be displayed using "smoothed" normals (like post-processing views); added GUI
for clipping planes; new interactive clipping/cutting plane definition;
reorganized the Options GUI; enhanced 3D iso computation; enhanced lighting;
many small bug fixes.
1.54 (Jul 03, 2004): integrated Netgen (3D mesh quality optimization +
alternative 3D algorithm); Extrude Surface now always automatically creates a
new volume (in the same way Extrude Point or Extrude Line create new lines and
surfaces, respectively); fixed UNV output; made the "Layers" region numbering
consistent between lines, surfaces and volumes; fixed home directory problem on
Win98; new Plugin(CutParametric); the default project file is now created in the
home directory if no current directory is defined (e.g., when double-clicking on
the icon on Windows/Mac); fixed the discrepancy between the orientation of
geometrical surfaces and the associated surface meshes; added automatic
orientation of surfaces in surface loops; generalized Plugin(Triangulate) to
handle vector and tensor views; much nicer display of discrete iso-surfaces and
custom ranges using smooth normals; small bug fixes and cleanups.
1.53 (Jun 04, 2004): completed support for second order elements in the mesh
module (line, triangles, quadrangles, tetrahedra, hexahedra, prisms and
pyramids); various background mesh fixes and enhancements; major performance
improvements in mesh and post-processing drawing routines (OpenGL vertex arrays
for tri/quads); new Plugin(Evaluate) to evaluate arbitrary expressions on
post-processing views; generalized Plugin(Extract) to handle any combination of
Appendix G: Version history 293
1.52 (May 06, 2004): new raster ("bitmap") PostScript/EPS/PDF output formats;
new Plugin(Extract) to extract a given component from a post-processing view;
new Plugin(CutGrid) and Plugin(StreamLines); improved mesh projection on
non-planar surfaces; added support for second order tetrahedral elements; added
interactive control of element order; refined mesh entity drawing selection (and
renamed most of the corresponding options); enhanced log scale in
post-processing; better font selection; simplified View.Raise{X,Y,Z} by removing
the scaling; various bug fixes (default postscript printing mode, drawing of 3D
arrows/cylinders on Linux, default home directory on Windows, default initial
file browser directory, extrusion of points with non-normalized axes of
rotation, computation of the scene bounding box in scripts, + the usual
documentation updates).
1.51 (Feb 29, 2004): initial support for visualizing mesh partitions; integrated
version 2.0 of the MSH mesh file format; new option to compute post-processing
ranges (min/max) per time step; Multiple views can now be combined into multi
time step ones (e.g. for programs that generate data one time step at a time);
new syntax: #var[] returns the size of the list var[]; enhanced "gmsh -convert";
temporary and error files are now created in the home directory to avoid file
permission issues; new 3D arrows; better lighting support; STL facets can now be
converted into individual geometrical surfaces; many other small improvements
and bug fixes (multi timestep tensors, color by physical entity, parser cleanup,
etc.).
1.50 (Dec 06, 2003): small changes to the visibility browser + made visibility
scriptable (new Show/Hide commands); fixed (rare) crash when deleting views;
split File->Open into File->Open and File->New to behave like most other
programs; Mac versions now use the system menu bar by default (if possible);
fixed bug leading to degenerate and/or duplicate tetrahedra in extruded meshes;
fixed crash when reloading sms meshes.
1.49 (Nov 30, 2003): made Merge, Save and Print behave like Include (i.e., open
files in the same directory as the main project file if the path is relative);
new Plugin(DecomposeInSimplex); new option View.AlphaChannel to set the
transparency factor globally for a post-processing view; new "Combine Views"
command; various bug fixes and cleanups.
294 Gmsh 4.0
1.48 (Nov 23, 2003): new DisplacementRaise plugin to plot arbitrary fields on
deformed meshes; generalized CutMap, CutPlane, CutSphere and Skin plugins to
handle all kinds of elements and fields; new "Save View[n]" command to save
views from a script; many small bug fixes (configure tests for libpng, handling
of erroneous options, multi time step scalar prism drawings, copy of surface
mesh attributes, etc.).
1.47 (Nov 12, 2003): fixed extrusion of surfaces defined by only two curves; new
syntax to retrieve point coordinates and indices of entities created through
geometrical transformations; new PDF and compressed PostScript output formats;
fixed numbering of elements created with "Extrude Point/Line"; use $GMSH_HOME as
home directory if defined.
1.46 (Aug 23, 2003): fixed crash for very long command lines; new options for
setting the displacement factor and Triangle’s parameters + renamed a couple of
options to more sensible names (View.VectorType, View.ArrowSize); various small
bug fixes; documentation update.
1.45 (Jun 14, 2003): small bug fixes (min/max computation for tensor views,
missing physical points in read mesh, "jumping" geometry during interactive
manipulation of large models, etc.); variable definition speedup; restored
support for second order elements in one- and two-dimensional meshes;
documentation updates.
1.44 (Apr 21, 2003): new reference manual; added support for PNG output; fixed
small configure script bugs.
1.43 (Mar 28, 2003): fixed solver interface problem on Mac OS X; new option to
specify the interactive rotation center (default is now the pseudo "center of
gravity" of the object, instead of (0,0,0)).
1.42 (Mar 19, 2003): suppressed the automatic addition of a ".geo" extension if
the file given on the command line is not recognized; added missing Layer option
for Extrude Point; fixed various small bugs.
1.41 (Mar 04, 2003): Gmsh is now licensed under the GNU General Public License;
general code cleanup (indent).
1.40 (Feb 26, 2003): various small bug fixes (mainly GSL-related).
1.39 (Feb 23, 2003): removed all non-free routines; more build system work;
implemented Von-Mises tensor display for all element types; fixed small GUI
bugs.
1.38 (Feb 17, 2003): fixed custom range selection for 3D iso graphs; new build
system based on autoconf; new image reading code to import bitmaps as
Appendix G: Version history 295
post-processing views.
1.37 (Jan 25, 2003): generalized smoothing and cuts of post-processing views;
better Windows integration (solvers, external editors, etc.); small bug fixes.
1.36 (Nov 20, 2002): enhanced view duplication (one can now use "Duplicata
View[num]" in the input file); merged all option dialogs in a new general option
window; enhanced discoverability of the view option menus; new 3D point and line
display; many small bug fixes and enhancements ("Print" format in parser,
post-processing statistics, smooth normals, save window positions, restore
default options, etc.).
1.35 (Sep 11, 2002): graphical user interface upgraded to FLTK 1.1 (tooltips,
new file chooser with multiple selection, full keyboard navigation, cut/paste of
messages, etc.); colors can be now be directly assigned to mesh entities;
initial tensor visualization; new keyboard animation (right/left arrow for time
steps; up/down arrow for view cycling); new VRML output format for surface
meshes; new plugin for spherical elevation plots; new post-processing file
format (version 1.2) supporting quadrangles, hexahedra, prisms and pyramids;
transparency is now enabled by default for post-processing plots; many small bug
fixes (read mesh, ...).
1.34 (Feb 18, 2002): improved surface mesh of non-plane surfaces; fixed
orientation of elements in 2D anisotropic algorithm; minor user interface polish
and additions (mostly in post-processing options); various small bug fixes.
1.32 (Oct 04, 2001): new visibility browser; better floating point exception
checks; fixed infinite looping when merging meshes in project files; various
small clean ups (degenerate 2D extrusion, view->reload, ...).
1.31 (Nov 30, 2001): corrected ellipses; PostScript output update (better
shading, new combined PS/LaTeX output format); more interface polish; fixed
extra memory allocation in 2D meshes; Physical Volume handling in unv format;
various small fixes.
1.30 (Nov 16, 2001): interface polish; fix crash when extruding quadrangles.
1.29 (Nov 12, 2001): translations and rotations can now be combined in
extrusions; fixed coherence bug in Extrude Line; various small bug fixes and
additions.
1.28 (Oct 30, 2001): corrected the ’Using Progression’ attribute for tranfinite
meshes to actually match a real geometric progression; new Triangulate plugin;
new 2D graphs (space+time charts); better performance of geometrical
296 Gmsh 4.0
1.27 (Oct 05, 2001): added ability to extrude curves with Layers/Recombine
attributes; new PointSize/LineWidth options; fixed For/EndFor loops in included
files; fixed error messages (line numbers+file names) in loops and functions;
made the automatic removal of duplicate geometrical entities optional
(Geometry.AutoCoherence=0); various other small bug fixes and clean-ups.
1.25 (Sep 01, 2001): fixed bug with mixed recombined/non-recombined extruded
meshes; Linux versions are now build with no optimization, due to bugs in gcc
2.95.X.
1.24 (Aug 30, 2001): fixed characteristic length interpolation for Splines;
fixed edge swapping bug in 3D initial mesh; fixed degenerated case in
geometrical extrusion (ruled surface with 3 borders); fixed generation of
degenerated hexahedra and prisms for recombined+extruded meshes; added BSplines
creation in the GUI; integrated Jonathan Shewchuk’s Triangle as an alternative
isotropic 2D mesh generator; added AngleSmoothNormals to control sharp edge
display with smoothed normals; fixed random crash for lighted 3D iso surfaces.
1.22 (Aug 03, 2001): fixed (yet another) bug for 2D mesh in the mean plane;
fixed surface coherence bug in extruded meshes; new double logarithmic scale,
saturate value and smoothed normals option for post-processing views; plugins
are now enabled by default; three new experimental statically linked plugins:
CutMap (extracts a given iso surface from a 3D scalar map), CutPlane (cuts a 3D
scalar map with a plane section), CutSphere (cuts a 3D scalar map with a
sphere); various other bug fixes, additions and clean-ups.
1.21 (Jul 25, 2001): fixed more memory leaks; added -opt command line option to
parse definitions directly from the command line; fixed missing screen refreshes
Appendix G: Version history 297
1.20 (Jun 14, 2001): fixed various bugs (memory leaks, functions in included
files, solver command selection, ColorTable option, duplicate nodes in extruded
meshes (not finished yet), infinite loop on empty views, orientation of
recombined quadrangles, ...); reorganized the interface menus; added constrained
background mesh and mesh visibility options; added mesh quality histograms;
changed default mesh colors; reintegrated the old command-line extrusion mesh
generator.
1.19 (May 07, 2001): fixed seg. fault for scalar simplex post-processing; new
Solver menu; interface for GetDP solver through sockets; fixed multiple scale
alignment; added some options + full option descriptions.
1.18 (Apr 26, 2001): fixed many small bugs and incoherences in post-processing;
fixed broken background mesh in 1D mesh generation.
1.17 (Apr 17, 2001): corrected physical points saving; fixed parsing of DOS
files (carriage return problems); easier geometrical selections (cursor change);
plugin manager; enhanced variable arrays (sublist selection and affectation);
line loop check; New arrow display; reduced number of ’fatal’ errors + better
handling in interactive mode; fixed bug when opening meshes; enhanced File->Open
behavior for meshes and post-processing views.
1.16 (Feb 26, 2001): added single/double buffer selection (only useful for Unix
versions of Gmsh run from remote hosts without GLX); fixed a bug for recent
versions of the opengl32.dll on Windows, which caused OpenGL fonts not to show
up.
1.15 (Feb 23, 2001): added automatic visibility setting during entity selection;
corrected geometrical extrusion bug.
1.14 (Feb 17, 2001): corrected a few bugs in the GUI (most of them were
introduced in 1.13); added interactive color selection; made the option database
bidirectional (i.e. scripts now correctly update the GUI); default options can
now be saved and automatically reloaded at startup; made some changes to the
scripting syntax (PostProcessing.View[n] becomes View[n]; Offset0 becomes
OffsetX, etc.); corrected the handling of simple triangular surfaces with large
characteristic lengths in the 2D isotropic algorithm; added an ASCII to binary
post-processing view converter.
1.13 (Feb 09, 2001): added support for JPEG output on Windows.
1.10 (Feb 04, 2001): switched from Motif to FLTK for the GUI. Many small tweaks.
1.00 (Jan 15, 2001): added PPM and YUV output; corrected nested If/Endif;
Corrected several bugs for pixel output and enhanced GIF output (dithering,
transparency); slightly changed the post-processing file format to allow both
single and double precision numbers.
0.999 (Dec 20, 2000): added JPEG output and easy MPEG generation (see t8.geo in
the tutorial); clean up of export functions; small fixes; Linux versions are now
compiled with gcc 2.95.2, which should fix the problems encountered with
Mandrake 7.2.
0.998 (Dec 19, 2000): corrected bug introduced in 0.997 in the generation of the
initial 3D mesh.
0.995 (Dec 11, 2000): totally rewritten geometrical database (performance has
been drastically improved for all geometrical transformations, and most notably
for extrusion). As a consequence, the internal numbering of geometrical entities
has changed: this will cause incompatibilities with old .geo files, and will
require a partial rewrite of your old .geo files if these files made use of
geometrical transformations. The syntax of the .geo file has also been
clarified. Many additions for scripting purposes. New extrusion mesh
generator. Preliminary version of the coupling between extruded and Delaunay
meshes. New option and procedural database. All interactive operations can be
scripted in the input files. See the last example in the tutorial for an
example. Many stability enhancements in the 2D and 3D mesh
algorithms. Performance boost of the 3D algorithm. Gmsh is still slow, but the
performance becomes acceptable. An average 1000 tetrahedra/second is obtained on
a 600Mhz computer for a mesh of one million tetrahedra. New anisotropic 2D mesh
algorithm. New (ASCII and binary) post-processing file format and clarified mesh
file format. New handling for interactive rotations (trackball mode). New
didactic interactive mesh construction (watch the Delaunay algorithm in real
time on complex geometries: that’s exciting ;-). And many, many bug fixes and
cleanups.
0.992 (Nov 13, 2000): corrected recombined extrusion; corrected ellipses; added
Appendix G: Version history 299
0.991 (Oct 24, 2000): fixed a serious allocation bug in 2D algorithm, which
caused random crashes. All users should upgrade to 0.991.
0.989 (Sep 01, 2000): added ability to reload previously saved meshes; some new
command line options; reorganization of the scale menu; GIF output.
0.987: fixed bug with smoothing (leading to the possible generation of erroneous
3d meshes); corrected bug for mixed 3D meshes; moved the ’toggle view link’
option to Opt->Postprocessing_Options.
0.986: fixed overlay problems; SGI version should now also run on 32 bits
machines; fixed small 3d mesh bug.
0.985: corrected colormap bug on HP, SUN, SGI and IBM versions; corrected small
initialization bug in postscript output.
0.982: lighting for mesh and post-processing; corrected 2nd order mesh on non
plane surfaces; added example 13.
Appendix H: Copyright and credits 301
Christophe Geuzaine
<cgeuzaine at uliege.be>
and
Jean-Francois Remacle
<jean-francois.remacle at uclouvain.be>
Thanks to the following folks who have contributed by providing fresh ideas on
theoretical or programming topics, who have sent patches, requests for changes
or improvements, or who gave us access to exotic machines for testing Gmsh: Juan
Abanto, Olivier Adam, Guillaume Alleon, Laurent Champaney, Pascal Dupuis,
Patrick Dular, Philippe Geuzaine, Johan Gyselinck, Francois Henrotte, Benoit
Meys, Nicolas Moes, Osamu Nakamura, Chad Schmutzer, Jean-Luc Fl’ejou, Xavier
Dardenne, Christophe Prud’homme, Sebastien Clerc, Jose Miguel Pasini, Philippe
Lussou, Jacques Kools, Bayram Yenikaya, Peter Hornby, Krishna Mohan Gundu,
Christopher Stott, Timmy Schumacher, Carl Osterwisch, Bruno Frackowiak, Philip
Kelleners, Romuald Conty, Renaud Sizaire, Michel Benhamou, Tom De Vuyst, Kris
Van den Abeele, Simon Vun, Simon Corbin, Thomas De-Soza, Marcus Drosson, Antoine
Dechaume, Jose Paulo Moitinho de Almeida, Thomas Pinchard, Corrado Chisari, Axel
302 Gmsh 4.0
Special thanks to Bill Spitzak, Michael Sweet, Matthias Melcher, Greg Ercolano
and others for the Fast Light Tool Kit on which Gmsh’s GUI is based. See
http://www.fltk.org for more info on this excellent object-oriented,
cross-platform toolkit. Special thanks also to EDF for funding the original
OpenCASCADE and MED integration in 2006-2007.
The AVL tree code (Common/avl.{cpp,h}) and the YUV image code
(Graphics/gl2yuv.{cpp,h}) are copyright (C) 1988-1993, 1995 The Regents of the
University of California. Permission to use, copy, modify, and distribute this
software and its documentation for any purpose and without fee is hereby
granted, provided that the above copyright notice appear in all copies and that
both that copyright notice and this permission notice appear in supporting
documentation, and that the name of the University of California not be used in
advertising or publicity pertaining to distribution of the software without
specific, written prior permission. The University of California makes no
representations about the suitability of this software for any purpose. It is
provided "as is" without express or implied warranty.
The GIF and PPM routines (Graphics/gl2gif.cpp) are based on code copyright (C)
1989, 1991, Jef Poskanzer. Permission to use, copy, modify, and distribute this
software and its documentation for any purpose and without fee is hereby
granted, provided that the above copyright notice appear in all copies and that
both that copyright notice and this permission notice appear in supporting
documentation. This software is provided "as is" without express or implied
warranty.
In addition, this this version of Gmsh may contain the following contributed
codes in the contrib/ directory, each governed by their own license:
* contrib/ANN copyright (C) 1997-2005 University of Maryland and Sunil Arya and
David Mount;
304 Gmsh 4.0
* contrib/MathEx based in part on the work of the SSCILIB Library, copyright (C)
2000-2003 Sadao Massago;
* contrib/mmg3d from MMG3D Version 4.0 (C) 2004-2011 Cecile Dobrzynski and
Pascal Frey (IPB - UPMC - INRIA);
* contrib/voro++ from Voro++ Copyright (c) 2008, The Regents of the University
of California, through Lawrence Berkeley National Laboratory (subject to
receipt of any required approvals from the U.S. Dept. of Energy). All rights
reserved;
Check the configuration options to see which has been enabled and see each
directory for detailed licensing information.
Appendix I: License 305
Appendix I License
Gmsh is provided under the terms of the GNU General Public License
(GPL), Version 2 or later, with the following exception:
Note that people who make modified versions of Gmsh are not
obligated to grant this special exception for their modified
versions; it is their choice whether to do so. The GNU General
Public License gives permission to release a modified version
without this exception; this exception also makes it possible to
release a modified version which carries forward this exception.
End of exception.
Preamble
The licenses for most software are designed to take away your
freedom to share and change it. By contrast, the GNU General Public
License is intended to guarantee your freedom to share and change free
software--to make sure the software is free for all its users. This
General Public License applies to most of the Free Software
Foundation’s software and to any other program whose authors commit to
using it. (Some other Free Software Foundation software is covered by
the GNU Library General Public License instead.) You can apply it to
your programs, too.
this service if you wish), that you receive source code or can get it
if you want it, that you can change the software or use pieces of it
in new free programs; and that you know you can do these things.
We protect your rights with two steps: (1) copyright the software, and
(2) offer you this license which gives you legal permission to copy,
distribute and/or modify the software.
Also, for each author’s protection and ours, we want to make certain
that everyone understands that there is no warranty for this free
software. If the software is modified by someone else and passed on, we
want its recipients to know that what they have is not the original, so
that any problems introduced by others will not reflect on the original
authors’ reputations.
You may charge a fee for the physical act of transferring a copy, and
you may at your option offer warranty protection in exchange for a fee.
2. You may modify your copy or copies of the Program or any portion
of it, thus forming a work based on the Program, and copy and
distribute such modifications or work under the terms of Section 1
above, provided that you also meet all of these conditions:
b) You must cause any work that you distribute or publish, that in
whole or in part contains or is derived from the Program or any
part thereof, to be licensed as a whole at no charge to all third
parties under the terms of this License.
sections when you distribute them as separate works. But when you
distribute the same sections as part of a whole which is a work based
on the Program, the distribution of the whole must be on the terms of
this License, whose permissions for other licensees extend to the
entire whole, and thus to each and every part regardless of who wrote it.
3. You may copy and distribute the Program (or a work based on it,
under Section 2) in object code or executable form under the terms of
Sections 1 and 2 above provided that you also do one of the following:
The source code for a work means the preferred form of the work for
making modifications to it. For an executable work, complete source
code means all the source code for all modules it contains, plus any
associated interface definition files, plus the scripts used to
control compilation and installation of the executable. However, as a
special exception, the source code distributed need not include
anything that is normally distributed (in either source or binary
form) with the major components (compiler, kernel, and so on) of the
operating system on which the executable runs, unless that component
itself accompanies the executable.
Appendix I: License 309
5. You are not required to accept this License, since you have not
signed it. However, nothing else grants you permission to modify or
distribute the Program or its derivative works. These actions are
prohibited by law if you do not accept this License. Therefore, by
modifying or distributing the Program (or any work based on the
Program), you indicate your acceptance of this License to do so, and
all its terms and conditions for copying, distributing or modifying
the Program or works based on it.
6. Each time you redistribute the Program (or any work based on the
Program), the recipient automatically receives a license from the
original licensor to copy, distribute or modify the Program subject to
these terms and conditions. You may not impose any further
restrictions on the recipients’ exercise of the rights granted herein.
You are not responsible for enforcing compliance by third parties to
this License.
9. The Free Software Foundation may publish revised and/or new versions
of the General Public License from time to time. Such new versions will
be similar in spirit to the present version, but may differ in detail to
address new problems or concerns.
10. If you wish to incorporate parts of the Program into other free
programs whose distribution conditions are different, write to the author
to ask for permission. For software which is copyrighted by the Free
Software Foundation, write to the Free Software Foundation; we sometimes
make exceptions for this. Our decision will be guided by the two goals
of preserving the free status of all derivatives of our free software and
of promoting the sharing and reuse of software generally.
NO WARRANTY
Appendix I: License 311
<one line to give the program’s name and a brief idea of what it does.>
Copyright (C) <year> <name of author>
You should have received a copy of the GNU General Public License
along with this program; if not, write to the Free Software
Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
Also add information on how to contact you by electronic and paper mail.
The hypothetical commands ‘show w’ and ‘show c’ should show the appropriate
parts of the General Public License. Of course, the commands you use may
be called something other than ‘show w’ and ‘show c’; they could even be
mouse-clicks or menu items--whatever suits your program.
You should also get your employer (if you work as a programmer) or your
school, if any, to sign a "copyright disclaimer" for the program, if
necessary. Here is a sample; alter the names:
This General Public License does not permit incorporating your program into
proprietary programs. If your program is a subroutine library, you may
consider it more useful to permit linking proprietary applications with the
library. If this is what you want to do, use the GNU Library General
Public License instead of this License.
Concept index 313
Concept index
2 Elementary points . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
2D plots . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 73 Elementary surfaces . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
Elementary volumes . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
Evaluation order . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
3 Examples . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 127
3D plots . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 73 Expressions, affectation . . . . . . . . . . . . . . . . . . . . . . . . 29
Expressions, character . . . . . . . . . . . . . . . . . . . . . . . . . 24
Expressions, color . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
A Expressions, definition . . . . . . . . . . . . . . . . . . . . . . . . . 21
Expressions, floating point . . . . . . . . . . . . . . . . . . . . . 21
Acknowledgments . . . . . . . . . . . . . . . . . . . . . . . . . . . . 301
Expressions, identifiers . . . . . . . . . . . . . . . . . . . . . . . . . 29
API . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 239
Expressions, lists . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 22
Authors, e-mail . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8
Extrusion, geometry . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
Extrusion, mesh . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64
B
Background mesh. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47 F
Binary operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
Bindings, keyboard . . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 FAQ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 277
Bindings, mouse . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 File format, mesh . . . . . . . . . . . . . . . . . . . . . . . . . . . . 107
Boolean operations, geometry . . . . . . . . . . . . . . . . . . 41 File formats . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 107
Bugs, reporting . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8 File, comments . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
Floating point numbers . . . . . . . . . . . . . . . . . . . . . . . . 21
Frequently asked questions . . . . . . . . . . . . . . . . . . . 277
C Functions, built-in . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
Changelog . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 285
Characteristic lengths. . . . . . . . . . . . . . . . . . . . . . . . . . 47
Colors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25 G
Command-line options . . . . . . . . . . . . . . . . . . . . . . . . . 12 General commands . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
Commands, general . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29 Geometry commands . . . . . . . . . . . . . . . . . . . . . . . . . . 35
Commands, geometry . . . . . . . . . . . . . . . . . . . . . . . . . . 35 Geometry, boolean operations . . . . . . . . . . . . . . . . . . 41
Commands, mesh . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47 Geometry, difference . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
Commands, post-processing . . . . . . . . . . . . . . . . . . . . 74 Geometry, extrusion . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
Comments . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21 Geometry, fragments. . . . . . . . . . . . . . . . . . . . . . . . . . . 41
Concepts, index . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 313 Geometry, intersection . . . . . . . . . . . . . . . . . . . . . . . . . 41
Conditionals . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28 Geometry, module . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
Constants . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21 Geometry, options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 44
Contact information . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8 Geometry, transformations . . . . . . . . . . . . . . . . . . . . . 42
Contributors, list . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 301 Geometry, union . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
Copyright . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3, 301 Graphs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 73
Credits . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 301
Curves, elementary . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
Curves, physical . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36 H
History, versions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 285
D
Developer, information . . . . . . . . . . . . . . . . . . . . . . . 275
Document syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
I
Download . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1 Index, concepts . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 313
Index, syntax . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 315
Interactive mode . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
E Internet address . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1
E-mail, authors . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8 Introduction . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5
Elementary curves . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
314 Gmsh 4.0
K Post-processing commands . . . . . . . . . . . . . . . . . . . . . 74
Keyboard, shortcuts . . . . . . . . . . . . . . . . . . . . . . . . . . . 17 Post-processing plugins . . . . . . . . . . . . . . . . . . . . . . . . 78
Keywords, index . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 315 Post-processing, module . . . . . . . . . . . . . . . . . . . . . . . 73
Post-processing, options . . . . . . . . . . . . . . . . . . . . . . 105
Precedence, operators. . . . . . . . . . . . . . . . . . . . . . . . . . 26
L Programming, API . . . . . . . . . . . . . . . . . . . . . . . . . . . 239
Programming, notes . . . . . . . . . . . . . . . . . . . . . . . . . . 275
License . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 3, 305
Lines . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
Loops . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
Q
Questions, frequently asked . . . . . . . . . . . . . . . . . . . 277
M
Macros, user-defined . . . . . . . . . . . . . . . . . . . . . . . . . . . 28
Mailing list . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8
R
Mesh commands . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47 Real numbers. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
Mesh, background . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47 Reporting bugs . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 8
Mesh, element size . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47 Rotation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42
Mesh, extrusion . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 Rules, syntactic . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
Mesh, file format . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 107 Running Gmsh . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11
Mesh, module . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45
Mesh, options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69
Mesh, transfinite . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 S
Module, geometry . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35 Scale . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42
Module, Mesh . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 45 Shortcuts, keyboard . . . . . . . . . . . . . . . . . . . . . . . . . . . 17
Module, Post-processing . . . . . . . . . . . . . . . . . . . . . . . 73 Size, elements . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 47
Module, Solver . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71 Solver commands . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71
Mouse, actions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 Solver, module . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 71
MSH4 file . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 107 Strings . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24
Surfaces, elementary . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
Surfaces, physical . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
N Symmetry . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42
Nodes, ordering . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 112 Syntax, index . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 315
Non-interactive mode . . . . . . . . . . . . . . . . . . . . . . . . . . 12 Syntax, rules . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
Numbers, real . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 21
O T
Ternary operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
Operating system . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 11 Transfinite, mesh . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64
Operator precedence . . . . . . . . . . . . . . . . . . . . . . . . . . . 26 Transformations, geometry . . . . . . . . . . . . . . . . . . . . . 42
Operators, definition . . . . . . . . . . . . . . . . . . . . . . . . . . . 25 Translation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 42
Options, command-line . . . . . . . . . . . . . . . . . . . . . . . . 12 Tutorial . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 127
Options, geometry . . . . . . . . . . . . . . . . . . . . . . . . . 44, 71
Options, mesh . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 69
Options, post-processing . . . . . . . . . . . . . . . . . . . . . . 105 U
Order, evaluation . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
Unary operators . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
Overview . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5
P V
Physical curves . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36 Versions . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 285
Physical points . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35 Views . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 73
Physical surfaces . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37 Volumes, elementary . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
Physical volumes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38 Volumes, physical. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
Plots . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 73
Plugins, post-processing . . . . . . . . . . . . . . . . . . . . . . . 78
Points, elementary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35 W
Points, physical . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35 Web site . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 1
Syntax index 315
Syntax index
! -format string . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
! . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25 -gamepad . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
!= . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26 -help . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16
-help_options . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16
-ho_[min,max,nlayers] . . . . . . . . . . . . . . . . . . . . . . . 14
% -ignore_periocity. . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
% . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26 -info . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16
-link int . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
-listen . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
& -match . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
&& . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26 -merge . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
-minterpreter string . . . . . . . . . . . . . . . . . . . . . . . . 14
-n . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
( -new . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
-nodb . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
() . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
-nopopup . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
-nt int . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16
* -numsubedges . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
-o file . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
* . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
-open . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
*= . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
-optimize[_netgen] . . . . . . . . . . . . . . . . . . . . . . . . . . 14
-optimize_ho . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
+ -optimize_threshold . . . . . . . . . . . . . . . . . . . . . . . . . 14
-option file . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16
+ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26
-order int . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
++ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25
-part int . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
+= . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
-part_[no_]ghosts. . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
-part_[no_]physicals . . . . . . . . . . . . . . . . . . . . . . . . 13
- -part_[no_]topo . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
- . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25, 26 -part_split . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
-, -parse_and_exit . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 -part_topo_pro . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
-- . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26 -part_weight tri|quad|tet|hex|pri|pyr|trih
-= . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29 int . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
-0 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 -pid . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
-1, -2, -3 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 -preserve_numbering_msh2 . . . . . . . . . . . . . . . . . . . 13
-a, -g, -m, -s, -p . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 -pyinterpreter string . . . . . . . . . . . . . . . . . . . . . . . 14
-algo string . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 -rand float . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
-aniso_max float . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 -reclassify . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
-barycentric_refine . . . . . . . . . . . . . . . . . . . . . . . . . 13 -refine . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
-bg file . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 -run . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
-bgm file . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 -save . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
-bin . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13 -save_all . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
-camera . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 -save_parametric . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
-check . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 -save_topology . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
-clcurv . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 -setnumber name value . . . . . . . . . . . . . . . . . . . . . . . . 15
-clmax float . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 -setstring name value . . . . . . . . . . . . . . . . . . . . . . . . 15
-clmin float . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 -smooth int . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
-clscale float . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 -smooth_ratio float . . . . . . . . . . . . . . . . . . . . . . . . . . 14
-combine . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 -stereo . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
-convert files . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 -string "string" . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
-cpu . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 -swapangle. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
-display string . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 -theme string. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
-epslc1d . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14 -tol float . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
-fontsize int. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 -v int. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15
316 Gmsh 4.0
? B
? . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26 Background Field = expression ;. . . . . . . . . . . . . . 48
Background Mesh View[expression ]; . . . . . . . . . . 75
Ball . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 50
^ Bezier ( expression ) = { expression-list };
^ . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36
boolean . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
BooleanDifference { boolean-list } {
| boolean-list } . . . . . . . . . . . . . . . . . . . . . . . 41, 42
|| . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 26 BooleanFragments { boolean-list } {
boolean-list } . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
BooleanIntersection ( expression ) = {
A boolean-list } { boolean-list }; . . . . . . . 42
Abort; . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32 BooleanIntersection { boolean-list } {
Acos ( expression ) . . . . . . . . . . . . . . . . . . . . . . . . . . 27 boolean-list } . . . . . . . . . . . . . . . . . . . . . . . . . . . 41
Syntax index 317
NewModel; . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34 Plugin(Crack) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80
newp . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 Plugin(Curl) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80
newreg . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 Plugin(CurvedBndDist) . . . . . . . . . . . . . . . . . . . . . . . 81
news . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 Plugin(CutBox) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 81
newsl . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 Plugin(CutGrid) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82
newv . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30 Plugin(CutMesh) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 82
NonBlockingSystemCall char-expression ;. . . . 34 Plugin(CutParametric) . . . . . . . . . . . . . . . . . . . . . . . 83
Plugin(CutPlane) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 83
Plugin(CutSphere). . . . . . . . . . . . . . . . . . . . . . . . . . . . 84
O Plugin(DiscretizationError) . . . . . . . . . . . . . . . . 85
Octree . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60 Plugin(Distance) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 85
OnelabRun ( char-expression <, Plugin(Divergence) . . . . . . . . . . . . . . . . . . . . . . . . . . 85
char-expression > ) . . . . . . . . . . . . . . . . . . . . . 34 Plugin(Eigenvalues) . . . . . . . . . . . . . . . . . . . . . . . . . 86
open . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 240 Plugin(Eigenvectors) . . . . . . . . . . . . . . . . . . . . . . . . 86
operator-binary . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 25 Plugin(ExtractEdges) . . . . . . . . . . . . . . . . . . . . . . . . 86
operator-ternary-left . . . . . . . . . . . . . . . . . . . . . . . 25 Plugin(ExtractElements) . . . . . . . . . . . . . . . . . . . . . 86
operator-ternary-right . . . . . . . . . . . . . . . . . . . . . . 25 Plugin(FaultZone). . . . . . . . . . . . . . . . . . . . . . . . . . . . 87
operator-unary-left . . . . . . . . . . . . . . . . . . . . . . . . . 25 Plugin(FieldFromAmplitudePhase) . . . . . . . . . . . 87
operator-unary-right . . . . . . . . . . . . . . . . . . . . . . . . 25 Plugin(GaussPoints) . . . . . . . . . . . . . . . . . . . . . . . . . 88
OptimizeMesh char-expression ; . . . . . . . . . . . . . . 66 Plugin(Gradient) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 88
Plugin(HarmonicToTime) . . . . . . . . . . . . . . . . . . . . . . 88
Plugin(HomologyComputation) . . . . . . . . . . . . . . . . 89
P Plugin(HomologyPostProcessing) . . . . . . . . . . . . . 90
Param . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 61 Plugin(Integrate). . . . . . . . . . . . . . . . . . . . . . . . . . . . 91
partition . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 245 Plugin(Isosurface) . . . . . . . . . . . . . . . . . . . . . . . . . . 91
PartitionMesh expression ; . . . . . . . . . . . . . . . . . . 67 Plugin(Lambda2) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 92
Periodic Curve { expression-list } = { Plugin(LongitudeLatitude) . . . . . . . . . . . . . . . . . . 92
expression-list } ; . . . . . . . . . . . . . . . . . . . . . 67 Plugin(MakeSimplex) . . . . . . . . . . . . . . . . . . . . . . . . . 92
Periodic Curve | Surface { expression-list } = Plugin(MathEval) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 92
{ expression-list } Affine | Translate { Plugin(MeshSubEntities) . . . . . . . . . . . . . . . . . . . . . 94
expression-list } ; . . . . . . . . . . . . . . . . . . . . . 67 Plugin(MinMax) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 94
Periodic Curve | Surface { expression-list } = Plugin(ModifyComponents) . . . . . . . . . . . . . . . . . . . 94
{ expression-list } Rotate { Plugin(ModulusPhase) . . . . . . . . . . . . . . . . . . . . . . . . 96
expression-list }, { expression-list }, Plugin(NearestNeighbor) . . . . . . . . . . . . . . . . . . . . . 97
expression } ; . . . . . . . . . . . . . . . . . . . . . . . . . . . 67 Plugin(NearToFarField) . . . . . . . . . . . . . . . . . . . . . . 96
Periodic Surface expression { expression-list
Plugin(NewView) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 97
} = expression { expression-list } ; . . . 67
Plugin(Particles). . . . . . . . . . . . . . . . . . . . . . . . . . . . 97
Physical Curve ( expression | char-expression
Plugin(Probe) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99
<, expression > ) <+|->= { expression-list
Plugin(Remove) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99
}; . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
Plugin(Scal2Tens). . . . . . . . . . . . . . . . . . . . . . . . . . . . 99
Physical Point ( expression | char-expression
<, expression > ) <+|->= { expression-list Plugin(Scal2Vec). . . . . . . . . . . . . . . . . . . . . . . . . . . . 100
}; . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 36 Plugin(ShowNeighborElements) . . . . . . . . . . . . . . 100
Physical Surface ( expression | Plugin(SimplePartition) . . . . . . . . . . . . . . . . . . . 101
char-expression <, expression > ) <+|->= { Plugin(Skin) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101
expression-list }; . . . . . . . . . . . . . . . . . . . . . . 38 Plugin(Smooth) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 101
Physical Volume ( expression | Plugin(SphericalRaise) . . . . . . . . . . . . . . . . . . . . . 101
char-expression <, expression > ) <+|->= { Plugin(StreamLines) . . . . . . . . . . . . . . . . . . . . . . . . 102
expression-list }; . . . . . . . . . . . . . . . . . . . . . . 39 Plugin(Summation) . . . . . . . . . . . . . . . . . . . . . . . . . . 103
Pi . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29 Plugin(Tetrahedralize) . . . . . . . . . . . . . . . . . . . . . 103
Plane Surface ( expression ) = { Plugin(ThinLayerFixMesh) . . . . . . . . . . . . . . . . . . 104
expression-list }; . . . . . . . . . . . . . . . . . . . . . . 37 Plugin(Transform) . . . . . . . . . . . . . . . . . . . . . . . . . . 104
Plugin (string ) . Run; . . . . . . . . . . . . . . . . . . . . . . . 75 Plugin(Triangulate) . . . . . . . . . . . . . . . . . . . . . . . . 104
Plugin (string ) . string = expression | Plugin(VoroMetal) . . . . . . . . . . . . . . . . . . . . . . . . . . 105
char-expression ; . . . . . . . . . . . . . . . . . . . . . . . . 75 Plugin(Warp) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 105
Plugin(AnalyseCurvedMesh) . . . . . . . . . . . . . . . . . . 78 Point ( expression ) = { expression,
Plugin(Annotate) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 79 expression, expression <, expression > };
Plugin(Bubbles) . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 80 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 35
Syntax index 325
View.Visible . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 231 W
View.Width . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 231 wait . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 273
Volume ( expression ) = { expression-list }; Wedge ( expression ) = { expression-list };
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 39
Wire ( expression ) = { expression-list };
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 37
write . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 240, 272