mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-26 12:50:34 +05:00
Merge remote-tracking branch 'origin/master' into ngcore
This commit is contained in:
commit
69363e7ff2
@ -469,6 +469,17 @@ However, when r = 0, the top part becomes a point(tip) and meshing fails!
|
|||||||
self.AddSplineSurface(surf);
|
self.AddSplineSurface(surf);
|
||||||
}),
|
}),
|
||||||
py::arg("SplineSurface"))
|
py::arg("SplineSurface"))
|
||||||
|
.def("SingularFace", [] (CSGeometry & self, shared_ptr<SPSolid> sol, shared_ptr<SPSolid> surfaces, double factor)
|
||||||
|
{
|
||||||
|
int tlonum = -1;
|
||||||
|
for (int i = 0; i < self.GetNTopLevelObjects(); i++)
|
||||||
|
if (self.GetTopLevelObject(i)->GetSolid() == sol->GetSolid())
|
||||||
|
tlonum = i;
|
||||||
|
if (tlonum == -1) throw NgException("not a top-level-object");
|
||||||
|
if (!surfaces) surfaces = sol;
|
||||||
|
auto singface = new SingularFace(tlonum, surfaces->GetSolid(), factor);
|
||||||
|
self.singfaces.Append(singface);
|
||||||
|
}, py::arg("solid"), py::arg("surfaces")=nullptr, py::arg("factor")=0.25)
|
||||||
.def("SingularEdge", [] (CSGeometry & self, shared_ptr<SPSolid> s1,shared_ptr<SPSolid> s2, double factor)
|
.def("SingularEdge", [] (CSGeometry & self, shared_ptr<SPSolid> s1,shared_ptr<SPSolid> s2, double factor)
|
||||||
{
|
{
|
||||||
auto singedge = new SingularEdge(1, -1, self, s1->GetSolid(), s2->GetSolid(), factor);
|
auto singedge = new SingularEdge(1, -1, self, s1->GetSolid(), s2->GetSolid(), factor);
|
||||||
|
@ -45,6 +45,19 @@ namespace netgen
|
|||||||
T * Release() { T * hd = data; data = nullptr; return hd; }
|
T * Release() { T * hd = data; data = nullptr; return hd; }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
template <typename T, int S>
|
||||||
|
class Ng_BufferMS
|
||||||
|
{
|
||||||
|
size_t s;
|
||||||
|
T data[S];
|
||||||
|
public:
|
||||||
|
Ng_BufferMS (size_t as) : s(as) { ; }
|
||||||
|
size_t Size() const { return s; }
|
||||||
|
T & operator[] (size_t i) { return data[i]; }
|
||||||
|
T operator[] (size_t i) const { return data[i]; }
|
||||||
|
};
|
||||||
|
|
||||||
|
|
||||||
class Ng_Element
|
class Ng_Element
|
||||||
{
|
{
|
||||||
|
|
||||||
@ -185,6 +198,7 @@ namespace netgen
|
|||||||
int operator[] (size_t i) const { return ptr[i]-POINTINDEX_BASE; }
|
int operator[] (size_t i) const { return ptr[i]-POINTINDEX_BASE; }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
/*
|
||||||
class Ng_Edges
|
class Ng_Edges
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
@ -194,11 +208,11 @@ namespace netgen
|
|||||||
size_t Size() const { return ned; }
|
size_t Size() const { return ned; }
|
||||||
int operator[] (size_t i) const { return ptr[i]-1; }
|
int operator[] (size_t i) const { return ptr[i]-1; }
|
||||||
};
|
};
|
||||||
|
*/
|
||||||
|
|
||||||
public:
|
public:
|
||||||
Ng_Vertices vertices;
|
Ng_Vertices vertices;
|
||||||
Ng_Edges edges;
|
// Ng_Edges edges;
|
||||||
int surface_el; // -1 if face not on surface
|
int surface_el; // -1 if face not on surface
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -283,6 +297,7 @@ namespace netgen
|
|||||||
template <int DIM>
|
template <int DIM>
|
||||||
const Ng_Node<DIM> GetNode (int nr) const;
|
const Ng_Node<DIM> GetNode (int nr) const;
|
||||||
|
|
||||||
|
Ng_BufferMS<int,4> GetFaceEdges (int fnr) const;
|
||||||
|
|
||||||
template <int DIM>
|
template <int DIM>
|
||||||
int GetNNodes ();
|
int GetNNodes ();
|
||||||
|
@ -717,6 +717,16 @@ namespace netgen
|
|||||||
return mesh->GetIdentifications().GetType(idnr+1);
|
return mesh->GetIdentifications().GetType(idnr+1);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Ng_BufferMS<int,4> Ngx_Mesh::GetFaceEdges (int fnr) const
|
||||||
|
{
|
||||||
|
const MeshTopology & topology = mesh->GetTopology();
|
||||||
|
ArrayMem<int,4> ia;
|
||||||
|
topology.GetFaceEdges (fnr+1, ia);
|
||||||
|
Ng_BufferMS<int,4> res(ia.Size());
|
||||||
|
for (size_t i = 0; i < ia.Size(); i++)
|
||||||
|
res[i] = ia[i]-1;
|
||||||
|
return res;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
@ -3398,6 +3398,7 @@ namespace netgen
|
|||||||
|
|
||||||
size_t nsel = mtris.Size();
|
size_t nsel = mtris.Size();
|
||||||
NgProfiler::StartTimer (timer_bisecttrig);
|
NgProfiler::StartTimer (timer_bisecttrig);
|
||||||
|
(*opt.tracer)("Bisect trigs", false);
|
||||||
for (size_t i = 0; i < nsel; i++)
|
for (size_t i = 0; i < nsel; i++)
|
||||||
if (mtris[i].marked)
|
if (mtris[i].marked)
|
||||||
{
|
{
|
||||||
@ -3440,7 +3441,7 @@ namespace netgen
|
|||||||
}
|
}
|
||||||
|
|
||||||
NgProfiler::StopTimer (timer_bisecttrig);
|
NgProfiler::StopTimer (timer_bisecttrig);
|
||||||
|
(*opt.tracer)("Bisect trigs", true);
|
||||||
|
|
||||||
int nquad = mquads.Size();
|
int nquad = mquads.Size();
|
||||||
for (int i = 1; i <= nquad; i++)
|
for (int i = 1; i <= nquad; i++)
|
||||||
|
Loading…
Reference in New Issue
Block a user