mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-12 06:00:33 +05:00
fix not working boundarylayer test
This commit is contained in:
parent
47632a06aa
commit
d40c05b1b1
@ -2,10 +2,14 @@
|
|||||||
import pytest
|
import pytest
|
||||||
from netgen.csg import *
|
from netgen.csg import *
|
||||||
|
|
||||||
def GetNSurfaceElements(mesh, boundaries):
|
def GetNSurfaceElements(mesh, boundaries, adjacent_domain=None):
|
||||||
nse_in_layer = 0
|
nse_in_layer = 0
|
||||||
for el in mesh.Elements2D():
|
for el in mesh.Elements2D():
|
||||||
if mesh.GetBCName(el.index-1) in boundaries:
|
if mesh.GetBCName(el.index-1) in boundaries:
|
||||||
|
if adjacent_domain is None:
|
||||||
|
nse_in_layer += 1
|
||||||
|
else:
|
||||||
|
if (mesh.FaceDescriptor(el.index).domin > 0 and mesh.GetMaterial(mesh.FaceDescriptor(el.index).domin) == adjacent_domain) or (mesh.FaceDescriptor(el.index).domout > 0 and mesh.GetMaterial(mesh.FaceDescriptor(el.index).domout) == adjacent_domain):
|
||||||
nse_in_layer += 1
|
nse_in_layer += 1
|
||||||
return nse_in_layer
|
return nse_in_layer
|
||||||
|
|
||||||
@ -29,7 +33,7 @@ def test_boundarylayer(outside, capfd):
|
|||||||
assert not "elements are not matching" in capture.out
|
assert not "elements are not matching" in capture.out
|
||||||
|
|
||||||
@pytest.mark.parametrize("outside", [True, False])
|
@pytest.mark.parametrize("outside", [True, False])
|
||||||
@pytest.mark.parametrize("version", [1]) # version 2 not working yet
|
@pytest.mark.parametrize("version", [1, 2]) # version 2 not working yet
|
||||||
def test_boundarylayer2(outside, version, capfd):
|
def test_boundarylayer2(outside, version, capfd):
|
||||||
geo = CSGeometry()
|
geo = CSGeometry()
|
||||||
top = Plane(Pnt(0,0,0.5), Vec(0,0,1))
|
top = Plane(Pnt(0,0,0.5), Vec(0,0,1))
|
||||||
@ -48,7 +52,7 @@ def test_boundarylayer2(outside, version, capfd):
|
|||||||
|
|
||||||
geo.CloseSurfaces(top, bot, [])
|
geo.CloseSurfaces(top, bot, [])
|
||||||
mesh = geo.GenerateMesh()
|
mesh = geo.GenerateMesh()
|
||||||
should_ne = mesh.ne + 2 * GetNSurfaceElements(mesh, ["default"])
|
should_ne = mesh.ne + 2 * GetNSurfaceElements(mesh, ["default"], "part")
|
||||||
layersize = 0.05
|
layersize = 0.05
|
||||||
mesh.BoundaryLayer("default", [0.5 * layersize, layersize], "layer", domains="part", outside=outside, grow_edges=True)
|
mesh.BoundaryLayer("default", [0.5 * layersize, layersize], "layer", domains="part", outside=outside, grow_edges=True)
|
||||||
assert mesh.ne == should_ne
|
assert mesh.ne == should_ne
|
||||||
|
Loading…
Reference in New Issue
Block a user