1
0
mirror of https://github.com/NGSolve/netgen.git synced 2025-01-19 09:20:33 +05:00
netgen/py_tutorials/csg2d.py

38 lines
681 B
Python
Raw Normal View History

2020-08-19 19:58:54 +05:00
from random import random, seed
2020-09-15 18:48:49 +05:00
from ngsolve import Draw, Mesh
2020-08-19 19:58:54 +05:00
import netgen
from pyngcore import *
from netgen.geom2d import *
seed(4)
2020-09-15 18:48:49 +05:00
g = CSG2d()
outer = Rectangle((0, 0), (1, 1), "outer","outer")
inner = Solid2d()
2020-08-19 19:58:54 +05:00
2020-09-15 18:48:49 +05:00
for i in range(30):
cx = random()
cy = random()
r = 0.03+0.05*random()
print("Add Circle", i, cx, cy, r, flush = True)
circle = Circle((cx, cy), r, "circle"+str(i), "circle"+str(i))
inner += circle
outer -= circle
2020-08-19 19:58:54 +05:00
2020-09-15 18:48:49 +05:00
g.Add(inner)
g.Add(outer)
geo = g.GenerateSplineGeometry()
2020-08-19 19:58:54 +05:00
2020-09-15 18:48:49 +05:00
m = geo.GenerateMesh(maxh=0.1)
2020-08-19 19:58:54 +05:00
2020-09-15 18:48:49 +05:00
try:
from ngsolve import Draw, Mesh
Draw(geo)
2020-08-19 19:58:54 +05:00
mesh = Mesh(m)
mesh.Curve(3)
Draw(mesh)
2020-09-15 18:48:49 +05:00
except:
pass