mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-13 14:40:35 +05:00
52 lines
953 B
C++
52 lines
953 B
C++
|
#include <mystdlib.h>
|
||
|
#include "meshing.hpp"
|
||
|
|
||
|
namespace netgen
|
||
|
{
|
||
|
|
||
|
|
||
|
int NetgenGeometry :: GenerateMesh (Mesh*& mesh,
|
||
|
int perfstepsstart, int perfstepsend, char* optstring)
|
||
|
{
|
||
|
if (!mesh) return 1;
|
||
|
|
||
|
if (perfstepsstart <= MESHCONST_MESHVOLUME)
|
||
|
{
|
||
|
multithread.task = "Volume meshing";
|
||
|
|
||
|
MESHING3_RESULT res =
|
||
|
MeshVolume (mparam, *mesh);
|
||
|
|
||
|
if (res != MESHING3_OK) return 1;
|
||
|
|
||
|
if (multithread.terminate) return 0;
|
||
|
|
||
|
RemoveIllegalElements (*mesh);
|
||
|
if (multithread.terminate) return 0;
|
||
|
|
||
|
MeshQuality3d (*mesh);
|
||
|
}
|
||
|
|
||
|
|
||
|
if (multithread.terminate || perfstepsend <= MESHCONST_MESHVOLUME)
|
||
|
return 0;
|
||
|
|
||
|
|
||
|
if (perfstepsstart <= MESHCONST_OPTVOLUME)
|
||
|
{
|
||
|
multithread.task = "Volume optimization";
|
||
|
|
||
|
OptimizeVolume (mparam, *mesh);
|
||
|
if (multithread.terminate) return 0;
|
||
|
}
|
||
|
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
|
||
|
const Refinement & NetgenGeometry :: GetRefinement () const
|
||
|
{
|
||
|
return *new Refinement;;
|
||
|
}
|
||
|
}
|