This page was generated from unit-4.1.1-geom2d/geom2d.ipynb.
4.1.1 Geometries in 2D¶
We have to import the SplineGeometry
class from the geom2d
module to be able to generate two-dimensional geometries. After importing the module we can create a new SplineGeometry
.
[1]:
import netgen.gui
from netgen.geom2d import SplineGeometry
geo = SplineGeometry()
Now we can use one the predefined objects (Rectangle,Circle) or generate our own geometry with lines or rational splines of 2nd order.
Predefined geometries¶
First we use the predefined ones and add a rectangle and a circle to our geometry with the boundary conditions rectangle
and circle
.
[2]:
geo.AddRectangle((-1,-1),(1,1),bc="rectangle")
geo.AddCircle((0,0),0.5,bc="circle")
[3]:
ngmesh = geo.GenerateMesh()
Generate Mesh from spline geometry
Boundary mesh done, np = 28
CalcLocalH: 28 Points 0 Elements 0 Surface Elements
Meshing domain 1 / 1
load internal triangle rules
give up with qualclass 212
number of frontlines = 8
Surface meshing done
---------------------------------------------------------------------------
NgException Traceback (most recent call last)
/tmp/ipykernel_665/383390664.py in <module>
----> 1 ngmesh = geo.GenerateMesh()
NgException: meshing failed
To get a proper geometry we have to set domain numbers for the domain on the left side of the curve and for the one in its right side. In this case the curves are parametrized in a mathematical positive sense. Additionally we can use SetMaterial
to identify the domains with names.
[4]:
geo = SplineGeometry()
geo.AddRectangle(p1=(-1,-1),
p2=(1,1),
bc="rectangle",
leftdomain=1,
rightdomain=0)
geo.AddCircle(c=(0,0),
r=0.5,
bc="circle",
leftdomain=2,
rightdomain=1)
geo.SetMaterial (1, "outer")
geo.SetMaterial (2, "inner")
[5]:
geo.SetDomainMaxH(2, 0.02)
ngmesh = geo.GenerateMesh(maxh=0.1)
Generate Mesh from spline geometry
Boundary mesh done, np = 236
CalcLocalH: 236 Points 0 Elements 0 Surface Elements
Meshing domain 1 / 2
Surface meshing done
Meshing domain 2 / 2
Surface meshing done
Edgeswapping, topological
Smoothing
Split improve
Combine improve
Smoothing
Edgeswapping, metric
Smoothing
Split improve
Combine improve
Smoothing
Edgeswapping, metric
Smoothing
Split improve
Combine improve
Smoothing
Using lines and splines¶
We define a new geometry and write a list of points we want to use for out geometry and add them to geo geometry.
[6]:
geo = SplineGeometry()
pnts =[(0,0),
#(0,0,0.05), # define a local mesh refinement for one point
(1,0),
(1,0.5),
(1,1),
(0.5,1),
(0,1)]
p1,p2,p3,p4,p5,p6 = [geo.AppendPoint(*pnt) for pnt in pnts]
Then we define the curves which define our geometry and add them to the geometry using Append
.
[7]:
curves = [[["line",p1,p2],"bottom"],
[["line",p2,p3],"right"],
[["spline3",p3,p4,p5],"curve"],
[["line",p5,p6],"top"],
[["line",p6,p1],"left"]]
[geo.Append(c,bc=bc) for c,bc in curves]
[7]:
[0, 1, 2, 3, 4]
[8]:
ngmesh = geo.GenerateMesh(maxh=0.2)
Generate Mesh from spline geometry
Boundary mesh done, np = 20
CalcLocalH: 20 Points 0 Elements 0 Surface Elements
Meshing domain 1 / 1
Surface meshing done
Edgeswapping, topological
Smoothing
Split improve
Combine improve
Smoothing
Edgeswapping, metric
Smoothing
Split improve
Combine improve
Smoothing
Edgeswapping, metric
Smoothing
Split improve
Combine improve
Smoothing
[9]:
# from ngsolve import *
# mesh = Mesh(ngmesh)
# mesh.Curve(3)
Additonally to the boundary condition one can set a maximal mesh size for a whole curve with an optional argument maxh
.
[10]:
geo = SplineGeometry()
p1,p2,p3,p4,p5,p6 = [geo.AppendPoint(*pnt) for pnt in pnts]
geo.Append(["line",p1,p2],maxh=0.02)
geo.Append(["line",p2,p4])
geo.Append(["line",p4,p6])
geo.Append(["line",p6,p1])
ngmesh = geo.GenerateMesh(maxh=0.2)#,quad_dominated=True)
Generate Mesh from spline geometry
Boundary mesh done, np = 69
CalcLocalH: 69 Points 0 Elements 0 Surface Elements
Meshing domain 1 / 1
Surface meshing done
Edgeswapping, topological
Smoothing
Split improve
Combine improve
Smoothing
Edgeswapping, metric
Smoothing
Split improve
Combine improve
Smoothing
Edgeswapping, metric
Smoothing
Split improve
Combine improve
Smoothing
Periodic geometries¶
The following example shows how construct a geometry for a periodic \(L_2\) finite element space.
Again we start with adding the points to the geometry. In this case the points of a hexagon. For the first three segments we save the return value (the line number) of geo.Append
. Now we can use those line numbers to identify each of the last three segments with the opposite, already added one. This identification is done with the optional argument copy
. The meshing algorithm then just copies the boundary mesh to the opposite segment. Thus the segments have to have the same orientation.
[11]:
from math import pi, cos, sin
geo = SplineGeometry()
pnums = [ geo.AddPoint(cos(phi),sin(phi)) for phi in [x*pi/3 for x in range(6)] ]
l1 = geo.Append(["line", 0, 1], leftdomain=1, rightdomain=0, bc="upperRight")
l2 = geo.Append(["line", 1, 2], leftdomain=1, rightdomain=0, bc="upperCenter")
l3 = geo.Append(["line", 2, 3], leftdomain=1, rightdomain=0, bc="upperLeft")
geo.Append(["line", 0, 5], leftdomain=0, rightdomain=1, bc="lowerRight", copy = l3)
geo.Append(["line", 5, 4], leftdomain=0, rightdomain=1, bc="lowerCenter", copy = l2)
geo.Append(["line", 4, 3], leftdomain=0, rightdomain=1, bc="lowerLeft", copy = l1)
ngmesh = geo.GenerateMesh(maxh=0.1)
Generate Mesh from spline geometry
Copy edge, from 3 to 4
Copy edge, from 2 to 5
Copy edge, from 1 to 6
Boundary mesh done, np = 60
CalcLocalH: 60 Points 0 Elements 0 Surface Elements
Meshing domain 1 / 1
Surface meshing done
Edgeswapping, topological
Smoothing
Split improve
Combine improve
Smoothing
Edgeswapping, metric
Smoothing
Split improve
Combine improve
Smoothing
Edgeswapping, metric
Smoothing
Split improve
Combine improve
Smoothing
[ ]: