Open
Graph Drawing
Framework

 v. 2023.09 (Elderberry)
 

Loading...
Searching...
No Matches
ogdf::ClusterGraphCopy Class Reference

#include <ogdf/layered/ExtendedNestingGraph.h>

+ Inheritance diagram for ogdf::ClusterGraphCopy:

Public Member Functions

 ClusterGraphCopy ()
 
 ClusterGraphCopy (const ExtendedNestingGraph &H, const ClusterGraph &CG)
 
cluster copy (cluster cOrig) const
 
const ClusterGraphgetOriginalClusterGraph () const
 
void init (const ExtendedNestingGraph &H, const ClusterGraph &CG)
 
cluster original (cluster cCopy) const
 
void setParent (node v, cluster c)
 
- Public Member Functions inherited from ogdf::ClusterGraph
 ClusterGraph ()
 Creates a cluster graph associated with no graph.
 
 ClusterGraph (const ClusterGraph &C)
 Copy constructor.
 
 ClusterGraph (const ClusterGraph &C, Graph &G)
 Copies the underlying graph of C into G and constructs a copy of C associated with G.
 
 ClusterGraph (const ClusterGraph &C, Graph &G, ClusterArray< cluster > &originalClusterTable, NodeArray< node > &originalNodeTable)
 Copies the underlying graph of C into G and constructs a copy of C associated with G.
 
 ClusterGraph (const ClusterGraph &C, Graph &G, ClusterArray< cluster > &originalClusterTable, NodeArray< node > &originalNodeTable, EdgeArray< edge > &edgeCopy)
 Copies the underlying graph of C into G and constructs a copy of C associated with G.
 
 ClusterGraph (const Graph &G)
 Creates a cluster graph associated with graph G.
 
virtual ~ClusterGraph ()
 Destructor.
 
cluster rootCluster () const
 Returns the root cluster.
 
int numberOfClusters () const
 Returns the number of clusters.
 
int maxClusterIndex () const
 Returns the maximal used cluster index.
 
int clusterArrayTableSize () const
 Returns the table size of cluster arrays associated with this graph.
 
cluster clusterOf (node v) const
 Returns the cluster to which a node belongs.
 
intclusterDepth (cluster c) const
 Returns depth of cluster c in cluster tree, starting with root depth 1.
 
cluster firstCluster () const
 Returns the first cluster in the list of all clusters.
 
cluster lastCluster () const
 Returns the last cluster in the list of all cluster.
 
cluster firstPostOrderCluster () const
 Returns the first cluster in the list of post ordered clusters.
 
template<class CLUSTERLIST >
void allClusters (CLUSTERLIST &clusterList) const
 Returns the list of all clusters in clusterList.
 
void clear ()
 Removes all clusters except for the root cluster.
 
void init (const Graph &G)
 Clears all cluster data and then reinitializes the instance with underlying graph G.
 
void clearClusterTree (cluster C)
 Removes all clusters from the cluster subtree rooted at cluster C except for cluster C itself.
 
cluster newCluster (cluster parent, int id=-1)
 Inserts a new cluster; makes it a child of the cluster parent.
 
cluster createEmptyCluster (const cluster parent=nullptr, int clusterId=-1)
 Creates an empty cluster with index clusterId and parent parent.
 
cluster createCluster (SList< node > &nodes, const cluster parent=nullptr)
 Creates a new cluster containing the nodes given by nodes; makes it a child of the cluster parent.
 
void delCluster (cluster c)
 Deletes cluster c.
 
void moveCluster (cluster c, cluster newParent)
 Moves cluster c to a new parent newParent.
 
void reassignNode (node v, cluster c)
 Reassigns node v to cluster c.
 
void reInit (Graph &G)
 Clear cluster info structure, reinitializes with underlying graph G.
 
template<class NODELIST >
void collapse (NODELIST &nodes, Graph &G)
 Collapses all nodes in the list nodes to the first node; multi-edges are removed.
 
void setUpdateDepth (bool b) const
 Turns automatic update of node depth values on or off.
 
void pullUpSubTree (cluster c)
 Updates depth information in subtree after delCluster.
 
int treeDepth () const
 Computes depth of cluster tree, running time O(C).
 
void computeSubTreeDepth (cluster c) const
 Computes depth of cluster tree hanging at c.
 
cluster commonCluster (SList< node > &nodes)
 Returns lowest common cluster of nodes in list nodes.
 
cluster commonCluster (node v, node w) const
 Returns the lowest common cluster of v and w in the cluster tree.
 
cluster commonClusterLastAncestors (node v, node w, cluster &c1, cluster &c2) const
 Returns the lowest common cluster lca and the highest ancestors on the path to lca.
 
cluster commonClusterPath (node v, node w, List< cluster > &eL) const
 Returns lca of v and w and stores corresponding path in eL.
 
cluster commonClusterAncestorsPath (node v, node w, cluster &c1, cluster &c2, List< cluster > &eL) const
 Returns lca of v and w, stores corresponding path in eL and ancestors in c1, c2.
 
void emptyClusters (SList< cluster > &emptyCluster, SList< cluster > *checkCluster=nullptr)
 Returns the list of clusters that are empty or only contain empty clusters.
 
bool emptyOnNodeDelete (cluster c)
 Returns true if cluster c has only one node and no children.
 
bool emptyOnClusterDelete (cluster c)
 Returns true if cluster c has only one child and no nodes.
 
template<class EDGELIST >
void adjEdges (cluster c, EDGELIST &edges) const
 Returns the list of all edges adjacent to cluster c in edges.
 
template<class ADJLIST >
void adjEntries (cluster c, ADJLIST &entries) const
 Returns the list of all adjacency entries adjacent to cluster c in entries.
 
template<class LISTITERATOR >
void makeAdjEntries (cluster c, LISTITERATOR start)
 Computes the adjacency entry list for cluster c.
 
void adjAvailable (bool val)
 Sets the availability status of the adjacency entries.
 
bool representsCombEmbedding () const
 Checks the combinatorial cluster planar embedding.
 
ListIterator< ClusterArrayBase * > registerArray (ClusterArrayBase *pClusterArray) const
 Registers a cluster array.
 
void unregisterArray (ListIterator< ClusterArrayBase * > it) const
 Unregisters a cluster array.
 
void moveRegisterArray (ListIterator< ClusterArrayBase * > it, ClusterArrayBase *pClusterArray) const
 Move the registration it of a cluster array to pClusterArray (used with move semantics for cluster arrays).
 
ListIterator< ClusterGraphObserver * > registerObserver (ClusterGraphObserver *pObserver) const
 Registers a cluster graph observer.
 
void unregisterObserver (ListIterator< ClusterGraphObserver * > it) const
 Unregisters a cluster graph observer.
 
 operator const Graph & () const
 Conversion to const Graph reference (to underlying graph).
 
const GraphconstGraph () const
 Returns a reference to the underlying graph.
 
ClusterGraphoperator= (const ClusterGraph &C)
 Assignment operator.
 
- Public Member Functions inherited from ogdf::GraphObserver
 GraphObserver ()
 Constructs instance of GraphObserver class.
 
 GraphObserver (const Graph *G)
 Constructs instance of GraphObserver class.
 
virtual ~GraphObserver ()
 Destroys the instance, unregisters it from watched graph.
 
const GraphgetGraph () const
 
void reregister (const Graph *pG)
 Associates observer instance with graph G.
 

Private Member Functions

void createClusterTree (cluster cOrig)
 

Private Attributes

ClusterArray< clusterm_copy
 
ClusterArray< clusterm_original
 
const ClusterGraphm_pCG
 
const ExtendedNestingGraphm_pH
 

Additional Inherited Members

- Public Types inherited from ogdf::ClusterGraph
using cluster_iterator = internal::GraphIterator< cluster >
 Provides a bidirectional iterator to a cluster in a clustered graph.
 
- Public Attributes inherited from ogdf::ClusterGraph
internal::GraphObjectContainer< ClusterElementclusters
 The container containing all cluster objects.
 
- Protected Member Functions inherited from ogdf::ClusterGraph
void copyLCA (const ClusterGraph &C)
 Copies lowest common ancestor info to copy of clustered graph.
 
void doClear ()
 Clears all cluster data.
 
cluster doCreateCluster (SList< node > &nodes, const cluster parent, int clusterId=-1)
 Creates new cluster containing nodes in parameter list with index clusterId.
 
cluster doCreateCluster (SList< node > &nodes, SList< cluster > &emptyCluster, const cluster parent, int clusterId=-1)
 Creates new cluster containing nodes in parameter list and stores resulting empty clusters in list, cluster has index clusterId.
 
cluster leftMostCluster (cluster c) const
 Leftmost cluster in subtree rooted at c, gets predecessor of subtree.
 
cluster postOrderPredecessor (cluster c) const
 Computes new predecessor for subtree at moved cluster c (nullptr if c is the root).
 
void updatePostOrder (cluster c, cluster oldParent, cluster newParent)
 Adjusts the post order structure for moved clusters.
 
virtual void nodeDeleted (node v) override
 Implementation of inherited method: Updates data if node deleted.
 
virtual void nodeAdded (node v) override
 Implementation of inherited method: Updates data if node added.
 
virtual void edgeDeleted (edge) override
 Implementation of inherited method: Updates data if edge deleted.
 
virtual void edgeAdded (edge) override
 Implementation of inherited method: Updates data if edge added.
 
virtual void cleared () override
 Clears cluster data without deleting root when underlying graphs' clear method is called.
 
- Protected Attributes inherited from ogdf::ClusterGraph
bool m_depthUpToDate
 Status of cluster depth information.
 
int m_lcaNumber
 Used to save last search run number for commoncluster.
 
ClusterArray< int > * m_lcaSearch
 Used to save last search run number for commoncluster.
 
bool m_updateDepth
 Depth of clusters is always updated if set to true.
 
ClusterArray< cluster > * m_vAncestor
 Used to save last search run number for commoncluster.
 
ClusterArray< cluster > * m_wAncestor
 Used to save last search run number for commoncluster.
 
- Protected Attributes inherited from ogdf::GraphObserver
ListIterator< GraphObserver * > m_itGList
 watched graph
 
const Graphm_pGraph
 

Detailed Description

Definition at line 270 of file ExtendedNestingGraph.h.

Constructor & Destructor Documentation

◆ ClusterGraphCopy() [1/2]

ogdf::ClusterGraphCopy::ClusterGraphCopy ( )

◆ ClusterGraphCopy() [2/2]

ogdf::ClusterGraphCopy::ClusterGraphCopy ( const ExtendedNestingGraph H,
const ClusterGraph CG 
)

Member Function Documentation

◆ copy()

cluster ogdf::ClusterGraphCopy::copy ( cluster  cOrig) const
inline

Definition at line 279 of file ExtendedNestingGraph.h.

◆ createClusterTree()

void ogdf::ClusterGraphCopy::createClusterTree ( cluster  cOrig)
private

◆ getOriginalClusterGraph()

const ClusterGraph & ogdf::ClusterGraphCopy::getOriginalClusterGraph ( ) const
inline

Definition at line 277 of file ExtendedNestingGraph.h.

◆ init()

void ogdf::ClusterGraphCopy::init ( const ExtendedNestingGraph H,
const ClusterGraph CG 
)

◆ original()

cluster ogdf::ClusterGraphCopy::original ( cluster  cCopy) const
inline

Definition at line 281 of file ExtendedNestingGraph.h.

◆ setParent()

void ogdf::ClusterGraphCopy::setParent ( node  v,
cluster  c 
)

Member Data Documentation

◆ m_copy

ClusterArray<cluster> ogdf::ClusterGraphCopy::m_copy
private

Definition at line 291 of file ExtendedNestingGraph.h.

◆ m_original

ClusterArray<cluster> ogdf::ClusterGraphCopy::m_original
private

Definition at line 292 of file ExtendedNestingGraph.h.

◆ m_pCG

const ClusterGraph* ogdf::ClusterGraphCopy::m_pCG
private

Definition at line 288 of file ExtendedNestingGraph.h.

◆ m_pH

const ExtendedNestingGraph* ogdf::ClusterGraphCopy::m_pH
private

Definition at line 289 of file ExtendedNestingGraph.h.


The documentation for this class was generated from the following file: