File: raw_tetrahedralization.cpp

package info (click to toggle)
gmsh 4.15.1%2Bds1-2
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 52,880 kB
  • sloc: cpp: 440,657; ansic: 114,930; f90: 15,611; python: 13,907; yacc: 7,438; java: 3,491; lisp: 3,206; lex: 633; perl: 571; makefile: 500; xml: 414; sh: 407; javascript: 113; modula3: 32
file content (36 lines) | stat: -rw-r--r-- 988 bytes parent folder | download | duplicates (2)
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
#include <gmsh.h>
#include <set>
#include <cstdlib> // for rand()

int main(int argc, char **argv)
{
  // number of points to tetrahedralize
  std::size_t N = 100;

  gmsh::initialize();

  gmsh::option::setNumber("Mesh.Algorithm3D", 10); // new Delaunay algo

  std::vector<double> points(3 * N), steiner;
  std::vector<std::size_t> tags(N);
  for(auto i = 0; i < N; ++i) {
    tags[i] = i + 1;
    points[3 * i] = (double)std::rand() / (double)RAND_MAX;
    points[3 * i + 1] = (double)std::rand() / (double)RAND_MAX;
    points[3 * i + 2] = (double)std::rand() / (double)RAND_MAX;
  }

  std::vector<std::size_t> tets;
  gmsh::algorithm::tetrahedralize(points, tets, steiner);

  std::set<std::string> args(argv, argv + argc);
  if(!args.count("-nopopup")) {
    int vol = gmsh::model::addDiscreteEntity(3);
    gmsh::model::mesh::addNodes(3, vol, tags, points);
    gmsh::model::mesh::addElementsByType(vol, 4, {}, tets);
    gmsh::fltk::run();
  }

  gmsh::finalize();
  return 0;
}