#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
  NgArray<int> cluster_reps;

public:
  AnisotropicClusters (const Mesh & amesh);
  ~AnisotropicClusters();

  void Update(TaskManager tm = &DummyTaskManager, Tracer trace = &DummyTracer);

  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