File: meshfunc2d.cpp

package info (click to toggle)
netgen 6.2.2601%2Bdfsg1-2
  • links: PTS, VCS
  • area: main
  • in suites:
  • size: 13,076 kB
  • sloc: cpp: 166,627; tcl: 6,310; python: 2,868; sh: 522; makefile: 90
file content (107 lines) | stat: -rw-r--r-- 2,628 bytes parent folder | download | duplicates (4)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
#include <mystdlib.h>
#include "meshing.hpp"

namespace netgen
{

  DLL_HEADER void Optimize2d (Mesh & mesh, MeshingParameters & mp, int faceindex)
  {
    static Timer timer("optimize2d"); RegionTimer reg(timer);

    mesh.CalcSurfacesOfNode();

    bool secondorder = mesh.GetNP() > mesh.GetNV();


    if (secondorder)
      {
      for (SurfaceElementIndex ei = 0; ei < mesh.GetNSE(); ei++)
        mesh[ei].SetType(TRIG);
      }
    mesh.Compress();

    bool optimize_swap_separate_faces = false;
    if(!mp.quad)
    {
      bool mixed = false;
      ParallelFor( Range(mesh.GetNSE()), [&] (auto i) NETGEN_LAMBDA_INLINE
          {
            if (mesh[SurfaceElementIndex(i)].GetNP() != 3)
                mixed = true;
          });
      if(mixed)
        optimize_swap_separate_faces = true;
    }

    if(faceindex)
      optimize_swap_separate_faces = false;

    const char * optstr = mp.optimize2d.c_str();
    int optsteps = mp.optsteps2d;

    // reset topology
    mesh.GetTopology() = MeshTopology(mesh);
    for (int i = 1; i <= optsteps; i++)
      for (size_t j = 1; j <= strlen(optstr); j++)
	{
	  if (multithread.terminate) break;
          MeshOptimize2d meshopt(mesh);
          meshopt.SetMetricWeight (mp.elsizeweight);
          meshopt.SetFaceIndex(faceindex);
	  switch (optstr[j-1])
	    {
	    case 's': 
	      {  // topological swap

                if(optimize_swap_separate_faces)
                {
                  for(auto i : Range(1, mesh.GetNFD()+1))
                  {
                    meshopt.SetFaceIndex(i);
                    meshopt.EdgeSwapping (0);
                  }
                }
                else
                {
                  meshopt.EdgeSwapping (0);
                }
		break;
	      }
	    case 'S': 
	      {  // metric swap
                if(optimize_swap_separate_faces)
                {
                  for(auto i : Range(1, mesh.GetNFD()+1))
                  {
                    meshopt.SetFaceIndex(i);
                    meshopt.EdgeSwapping (1);
                  }
                }
                else
                {
                  meshopt.EdgeSwapping (1);
                }
		break;
	      }
	    case 'm': 
	      {
		meshopt.ImproveMesh(mp);
		break;
	      }
	    case 'c': 
	      {
		meshopt.CombineImprove();
		break;
	      }
	    default:
	      cerr << "Optimization code " << optstr[j-1] << " not defined" << endl;
	    }  
	}
    mesh.Compress(); // better: compress in individual steps, if necessary
    if (secondorder)
      {
        mesh.GetGeometry()->GetRefinement().MakeSecondOrder(mesh);
      }
  }

}