1
0
mirror of https://github.com/NGSolve/netgen.git synced 2025-01-19 01:10:33 +05:00
netgen/libsrc/interface/writetecplot.cpp
2023-10-12 19:04:40 +02:00

132 lines
2.8 KiB
C++

//
//
// TECPLOT file by Jawor Georgiew
//
#include <mystdlib.h>
#include <myadt.hpp>
#include <linalg.hpp>
#include <csg.hpp>
#include <meshing.hpp>
#include "writeuser.hpp"
namespace netgen
{
void WriteTecPlotFormat (const Mesh & mesh,
const filesystem::path & filename)
{
auto geom = dynamic_pointer_cast<CSGeometry>(mesh.GetGeometry());
if(geom == nullptr)
throw Exception("TecPlot format requires a CSGeometry");
INDEX i;
int j, k, e, z;
Vec<3> n;
INDEX np = mesh.GetNP();
INDEX ne = mesh.GetNE();
INDEX nse = mesh.GetNSE();
NgArray<int> sn(np);
ofstream outfile(filename);
outfile << "TITLE=\" " << filename.string() << "\"" << endl;
// fill hashtable
INDEX_3_HASHTABLE<int> face2volelement(ne);
for (i = 1; i <= ne; i++)
{
const Element & el = mesh.VolumeElement(i);
INDEX_3 i3;
int l;
for (j = 1; j <= 4; j++) // loop over faces of tet
{
l = 0;
for (k = 1; k <= 4; k++)
if (k != j)
{
l++;
i3.I(l) = el.PNum(k);
}
i3.Sort();
face2volelement.Set (i3, i);
}
}
for (j = 1; j <= geom->GetNSurf(); j++) /* Flaeche Nummer j */
{
for (i = 1; i <= np; i++)
sn.Elem(i) = 0;
e = 0;
for (i = 1; i <= nse; i++)
{
const Element2d & el = mesh.SurfaceElement(i);
if (j == mesh.GetFaceDescriptor (el.GetIndex ()).SurfNr())
{
for (k = 1; k <= 3; k++)
sn.Elem(el.PNum(k)) = 1;
e++; /* e= Anzahl der neuen Elemente */
}
}
z = 0;
for (i = 1; i <= np; i++)
if (sn.Elem(i) == 1)
sn.Elem(i) = ++z;
outfile << "ZONE T=\" Surface " << j << " \", N=" << z
<< ", E=" << e << ", ET=TRIANGLE, F=FEPOINT" << endl;
for (i = 1; i <= np; i++)
if (sn.Elem(i) != 0)
{
n = geom->GetSurface(j) -> GetNormalVector ( mesh.Point(i) );
outfile << mesh.Point(i)(0) << " " /* Knoten Koordinaten */
<< mesh.Point(i)(1) << " "
<< mesh.Point(i)(2) << " "
<< n(0) << " "
<< n(1) << " "
<< n(2) << " "
<< i << endl;
}
for (i = 1; i <= nse; i++)
{
const Element2d & el = mesh.SurfaceElement(i);
if (j == mesh.GetFaceDescriptor(el.GetIndex ()).SurfNr())
/* FlaechenKnoten (3) */
outfile << sn.Get(el.PNum(1)) << " "
<< sn.Get(el.PNum(2)) << " "
<< sn.Get(el.PNum(3)) << endl;
/// Hier soll noch die Ausgabe der Nummer des angrenzenden
/// Vol.elements erfolgen !
for (k = 1; k <= nse; k++)
{
const Element2d & sel = mesh.SurfaceElement(k);
INDEX_3 i3;
for (j = 1; j <= 3; j++)
i3.I(j) = sel.PNum(j);
i3.Sort();
//int elind = face2volelement.Get(i3);
}
}
}
}
static RegisterUserFormat reg_tecplot ("TecPlot Format", {".mesh"}, nullopt, WriteTecPlotFormat);
}