- Thank you received: 0
Obtaining meshes that are continuous across a circular boundary
7 years 4 months ago #150
by Gregory
I am using the Python interface to netgen to create surface meshes for circular discs using geo = CSGeometry etc. I am finding it to be very useful.
I now need to mesh what could be visualised as two circular coins of different sizes put together concentrically. The larger coin has an annular structure on one face with no mesh in the central area where it touches the smaller coin. The smaller coin is fully meshed. There is a special requirement that the mesh points on the edges give continuity of the surface mesh (triangles) if the two coins are put together. I need to create a separate .vol mesh file for each coin.
Could anyone provide me with a code snippet to do this? I downloaded and compiled the latest NGsolve (6.1-experimental).
Andrew.
I now need to mesh what could be visualised as two circular coins of different sizes put together concentrically. The larger coin has an annular structure on one face with no mesh in the central area where it touches the smaller coin. The smaller coin is fully meshed. There is a special requirement that the mesh points on the edges give continuity of the surface mesh (triangles) if the two coins are put together. I need to create a separate .vol mesh file for each coin.
Could anyone provide me with a code snippet to do this? I downloaded and compiled the latest NGsolve (6.1-experimental).
Andrew.
7 years 4 months ago #155
by Gregory
Replied by Gregory on topic Obtaining meshes that are continuous across a circular boundary
I found out how to mesh the contact planes of the coins after seeing this tutorial (code below):
web.pdx.edu/~gjay/teaching/mth610_2015.2/TutorialNGSpy.html
How to I extend the mesh over the Cylindrical sides and backs of the coins to form 3D meshes?
from netgen.geom2d import SplineGeometry
def Circle(geom,r, bc, left, right, maxh):
disc_pnts = [ ( r, 0), ( r, r), ( 0, r), (-r, r), (-r, 0), (-r, -r), ( 0, -r), ( r, -r) ]
disc_pnums = [geom.AppendPoint(*p) for p in disc_pnts]
curves = [ (disc_pnums[0], disc_pnums[1], disc_pnums[2]),
(disc_pnums[2], disc_pnums[3], disc_pnums[4]),
(disc_pnums[4], disc_pnums[5], disc_pnums[6]),
(disc_pnums[6], disc_pnums[7], disc_pnums[0]) ]
for p0,p1,p2 in curves:
geom.Append( ["spline3", p0,p1,p2],
bc=bc, leftdomain=left, rightdomain=right, maxh=maxh)
return geom
geo = SplineGeometry()
geo = Circle(geo, 4.0, 1, 0, 1, 0.1)
geo = Circle(geo, 5.0, 2, 1, 0, 1.0)
ngmesh = geo.GenerateMesh()
ngmesh.Save("large_coin_face.vol")
geo2 = SplineGeometry()
geo2 = Circle(geo2, 4.0, 3, 1, 0, 0.1)
ngmesh = geo2.GenerateMesh()
ngmesh.Save("small_coin_face.vol")
web.pdx.edu/~gjay/teaching/mth610_2015.2/TutorialNGSpy.html
How to I extend the mesh over the Cylindrical sides and backs of the coins to form 3D meshes?
from netgen.geom2d import SplineGeometry
def Circle(geom,r, bc, left, right, maxh):
disc_pnts = [ ( r, 0), ( r, r), ( 0, r), (-r, r), (-r, 0), (-r, -r), ( 0, -r), ( r, -r) ]
disc_pnums = [geom.AppendPoint(*p) for p in disc_pnts]
curves = [ (disc_pnums[0], disc_pnums[1], disc_pnums[2]),
(disc_pnums[2], disc_pnums[3], disc_pnums[4]),
(disc_pnums[4], disc_pnums[5], disc_pnums[6]),
(disc_pnums[6], disc_pnums[7], disc_pnums[0]) ]
for p0,p1,p2 in curves:
geom.Append( ["spline3", p0,p1,p2],
bc=bc, leftdomain=left, rightdomain=right, maxh=maxh)
return geom
geo = SplineGeometry()
geo = Circle(geo, 4.0, 1, 0, 1, 0.1)
geo = Circle(geo, 5.0, 2, 1, 0, 1.0)
ngmesh = geo.GenerateMesh()
ngmesh.Save("large_coin_face.vol")
geo2 = SplineGeometry()
geo2 = Circle(geo2, 4.0, 3, 1, 0, 0.1)
ngmesh = geo2.GenerateMesh()
ngmesh.Save("small_coin_face.vol")
Time to create page: 0.130 seconds