mirror of
https://github.com/NGSolve/netgen.git
synced 2025-01-12 22:20:35 +05:00
43 lines
1.1 KiB
C++
43 lines
1.1 KiB
C++
|
#ifndef CLUSTERS
|
||
|
#define CLUSTERS
|
||
|
|
||
|
/**************************************************************************/
|
||
|
/* File: clusers.hh */
|
||
|
/* Author: Joachim Schoeberl */
|
||
|
/* Date: 28. Apr. 01 */
|
||
|
/**************************************************************************/
|
||
|
|
||
|
/*
|
||
|
Anisotropic clusters
|
||
|
|
||
|
nodes, edges, faces, elements
|
||
|
*/
|
||
|
|
||
|
|
||
|
class AnisotropicClusters
|
||
|
{
|
||
|
const Mesh & mesh;
|
||
|
|
||
|
int nv, ned, nfa, ne;
|
||
|
|
||
|
// connected nodes, nodes = vertices, edges, faces, elements
|
||
|
ARRAY<int> cluster_reps;
|
||
|
|
||
|
public:
|
||
|
AnisotropicClusters (const Mesh & amesh);
|
||
|
~AnisotropicClusters();
|
||
|
|
||
|
void Update();
|
||
|
|
||
|
int GetVertexRepresentant (int vnr) const
|
||
|
{ return cluster_reps.Get(vnr); }
|
||
|
int GetEdgeRepresentant (int ednr) const
|
||
|
{ return cluster_reps.Get(nv+ednr); }
|
||
|
int GetFaceRepresentant (int fnr) const
|
||
|
{ return cluster_reps.Get(nv+ned+fnr); }
|
||
|
int GetElementRepresentant (int enr) const
|
||
|
{ return cluster_reps.Get(nv+ned+nfa+enr); }
|
||
|
};
|
||
|
|
||
|
#endif
|