SPQR-trees of planar graphs. More...
#include <ogdf/decomposition/DynamicPlanarSPQRTree.h>
Public Member Functions | |
DynamicPlanarSPQRTree (Graph &G, bool isEmbedded=false) | |
Creates an SPQR tree for planar graph G rooted at the first edge of G . More... | |
DynamicPlanarSPQRTree (Graph &G, edge e, bool isEmbedded=false) | |
Creates an SPQR tree for planar graph G rooted at edge e . More... | |
Public Member Functions inherited from ogdf::DynamicSPQRTree | |
DynamicSPQRTree (Graph &G) | |
Creates an SPQR tree T for graph G rooted at the first edge of G . More... | |
DynamicSPQRTree (Graph &G, edge e) | |
Creates an SPQR tree T for graph G rooted at the edge e . More... | |
~DynamicSPQRTree () | |
edge | copyOfReal (edge e) const override |
Returns the skeleton edge that corresponds to the real edge e . More... | |
SList< node > & | findPath (node s, node t) |
Finds the shortest path between the two sets of vertices of T which s and t of G belong to. More... | |
List< node > | nodesOfType (NodeType t) const override |
Returns the list of all nodes with type t . More... | |
int | numberOfPNodes () const override |
Returns the number of P-nodes in T. More... | |
int | numberOfRNodes () const override |
Returns the number of R-nodes in T. More... | |
int | numberOfSNodes () const override |
Returns the number of S-nodes in T. More... | |
const Graph & | originalGraph () const override |
Returns a reference to the original graph G. More... | |
edge | rootEdge () const override |
Returns the edge of G at which T is rooted. More... | |
node | rootNode () const override |
Returns the root node of T. More... | |
node | rootTreeAt (edge e) override |
Roots T at edge e and returns the new root node of T. More... | |
node | rootTreeAt (node v) override |
Roots T at node v and returns v . More... | |
Skeleton & | skeleton (node v) const override |
Returns the skeleton of node v . More... | |
edge | skeletonEdge (node v, node w) const |
Returns the virtual edge in the skeleton of w that corresponds to the tree edge between v and w . More... | |
const Skeleton & | skeletonOfReal (edge e) const override |
Returns the skeleton that contains the real edge e . More... | |
const Graph & | tree () const override |
Returns a reference to the tree T. More... | |
NodeType | typeOf (node v) const override |
Returns the type of node v . More... | |
edge | updateInsertedEdge (edge e) override |
Updates the whole data structure after a new edge e has been inserted into G. More... | |
node | updateInsertedNode (edge e, edge f) override |
Updates the whole data structure after a new vertex has been inserted into G by splitting an edge into e and f . More... | |
Public Member Functions inherited from ogdf::SPQRTree | |
SPQRTree () | |
SPQRTree (const SPQRTree ©)=delete | |
SPQRTree (SPQRTree &&move)=delete | |
virtual | ~SPQRTree () |
SPQRTree & | operator= (const SPQRTree ©)=delete |
SPQRTree & | operator= (SPQRTree &&move)=delete |
void | pertinentGraph (node v, PertinentGraph &Gp) const |
Returns the pertinent graph of tree node v in Gp . More... | |
void | directSkEdge (node vT, edge e, node src) |
void | replaceSkEdgeByPeak (node vT, edge e) |
Public Member Functions inherited from ogdf::DynamicSPQRForest | |
DynamicSPQRForest (Graph &G, bool not_connected=false) | |
A constructor. More... | |
DynamicSPQRForest (Graph &G, node vG, bool not_connected=false) | |
A constructor. More... | |
~DynamicSPQRForest () | |
node | spqrproper (edge eH) const |
void | createSPQR (node vB) const |
Creates the SPQR-tree for a given B-component of the BC-tree. More... | |
node | spqrroot (node vB) const |
Returns the root of the SPQR-tree for a given B-component of the BC-tree. More... | |
int | numberOfSNodes (node vB) const |
Returns the number of S-nodes in the SPQR-tree for a given B-component of the BC-tree. More... | |
int | numberOfPNodes (node vB) const |
Returns the number of P-nodes in the SPQR-tree for a given B-component of the BC-tree. More... | |
int | numberOfRNodes (node vB) const |
Returns the number of R-nodes in the SPQR-tree for a given B-component of the BC-tree. More... | |
const Graph & | spqrTree () const |
Returns the SPQR-tree graph. More... | |
node | spqrParent (node vT) const |
Returns the parent node of a node of the SPQR-tree Graph, or nullptr if vT is a root. More... | |
edge | spqrParentEdge (node vT) const |
Returns the virtual edge leading to the parents of a SPQR-tree vertex, or nullptr if vT is a root. More... | |
node | spqrNodeOf (edge eH) const |
The SPQR-tree-vertex which a real or virtual edge eH belongs to, if the SPQR-tree has been created using createSPQR. More... | |
edge | twinEdge (edge eH) const |
Returns the twin edge of a given edge of m_H, if it is virtual, or nullptr, if it is real. More... | |
TNodeType | typeOfTNode (node vT) const |
const List< edge > & | hEdgesSPQR (node vT) const |
Returns a linear list of the edges in m_H belonging to the triconnected component represented by a given SPQR-tree-vertex. More... | |
SList< node > & | findPathSPQR (node sH, node tH) const |
Finds the shortest path between the two sets of SPQR-tree-vertices which sH and tH are belonging to. More... | |
edge | virtualEdge (node vT, node wT) const |
Returns the virtual edge which leads from one vertex of an SPQR-tree to another one. More... | |
Public Member Functions inherited from ogdf::DynamicBCTree | |
DynamicBCTree (Graph &G, bool not_connected=false) | |
DynamicBCTree (Graph &G, node vG, bool not_connected=false) | |
A constructor. More... | |
node | bccomp (node vH) const override |
node | bccomp (edge eH) const override |
Returns the BC-tree-vertex representing the biconnected component which a given edge of the auxiliary graph is belonging to. More... | |
node | repVertex (node uG, node vB) const override |
node | cutVertex (node uB, node vB) const override |
Returns the copy of a cut-vertex in the biconnected components graph which belongs to a certain B-component and leads to another B-component. More... | |
edge | insertEdge (node sG, node tG) |
Inserts a new edge into the original graph and updates the BC-tree. More... | |
node | insertNode (edge eG) |
Inserts a new vertex into the original graph and updates the BC-tree. More... | |
node | bComponent (node uG, node vG) const |
Public Member Functions inherited from ogdf::BCTree | |
BCTree (BCTree &&move)=delete | |
BCTree (const BCTree ©)=delete | |
BCTree (Graph &G, bool not_connected=false) | |
A constructor. More... | |
BCTree (Graph &G, List< node > &vG) | |
Constructor for not connected graphs. More... | |
BCTree (Graph &G, node vG, bool not_connected=false) | |
A constructor. More... | |
virtual | ~BCTree () |
Virtual destructor. More... | |
void | consistencyCheck () const |
Asserts that this BCTree is consistent. More... | |
BCTree & | operator= (BCTree &&move)=delete |
BCTree & | operator= (const BCTree ©)=delete |
const Graph & | originalGraph () const |
Returns the original graph. More... | |
const Graph & | bcTree () const |
Returns the BC-tree graph. More... | |
const Graph & | auxiliaryGraph () const |
Returns the biconnected components graph. More... | |
int | numberOfBComps () const |
Returns the number of B-components. More... | |
int | numberOfCComps () const |
Returns the number of C-components. More... | |
GNodeType | typeOfGNode (node vG) const |
node | bcproper (node vG) const |
Returns a BC-tree-vertex representing a biconnected component which a given vertex of the original graph is belonging to. More... | |
node | bcproper (edge eG) const |
Returns the BC-tree-vertex representing the biconnected component which a given edge of the original graph is belonging to. More... | |
node | rep (node vG) const |
Returns a vertex of the biconnected components graph corresponding to a given vertex of the original graph. More... | |
edge | rep (edge eG) const |
Returns the edge of the biconnected components graph corresponding to a given edge of the original graph. More... | |
node | original (node vH) const |
edge | original (edge eH) const |
Returns the edge of the original graph which a given edge of the biconnected components graph is corresponding to. More... | |
BNodeType | typeOfBNode (node vB) const |
const SList< edge > & | hEdges (node vB) const |
Returns a linear list of the edges of the biconnected components graph belonging to the biconnected component represented by a given BC-tree-vertex. More... | |
int | numberOfEdges (node vB) const |
Returns the number of edges belonging to the biconnected component represented by a given BC-tree-vertex. More... | |
int | numberOfNodes (node vB) const |
Returns the number of vertices belonging to the biconnected component represented by a given BC-tree-vertex. More... | |
node | bComponent (node uG, node vG) const |
SList< node > & | findPath (node sG, node tG) const |
Calculates a path in the BC-tree. More... | |
SList< node > * | findPathBCTree (node sB, node tB) const |
Calculates a path in the BC-tree. More... | |
Public Member Functions inherited from ogdf::PlanarSPQRTree | |
void | embed (Graph &G) |
Embeds G according to the current embeddings of the skeletons of T. More... | |
void | embed (node &vT, long long x) |
Embeds the skeleton of the node vT with the specific embedding numbered by x. More... | |
void | firstEmbedding (Graph &G) |
Embeds the original graph G canonically by the indices of their adjEntries. More... | |
bool | nextEmbedding (Graph &G) |
Embeds the original graph G with the next embedding. More... | |
double | numberOfEmbeddings () const |
Returns the number of possible embeddings of G. More... | |
double | numberOfEmbeddings (node v) const |
Returns the number of possible embeddings of the pertinent graph of node v . More... | |
long long | numberOfNodeEmbeddings (node vT) const |
Returns the number of possible embeddings of the skeleton of node vT . More... | |
void | randomEmbed () |
Embeds all skeleton graphs randomly. More... | |
void | randomEmbed (Graph &G) |
Embeds all skeleton graphs randomly and embeds G according to the embeddings of the skeletons. More... | |
void | reverse (node vT) |
Flips the skeleton S of vT around its poles. More... | |
void | swap (node vT, adjEntry adj1, adjEntry adj2) |
Exchanges the positions of the two edges corresponding to adj1 and adj2 in skeleton of vT . More... | |
void | swap (node vT, edge e1, edge e2) |
Exchanges the positions of edges e1 and e2 in skeleton of vT. More... | |
Additional Inherited Members | |
Public Types inherited from ogdf::SPQRTree | |
enum | NodeType { NodeType::SNode, NodeType::PNode, NodeType::RNode } |
The type of a tree node in T. More... | |
Public Types inherited from ogdf::DynamicSPQRForest | |
enum | TNodeType { TNodeType::SComp, TNodeType::PComp, TNodeType::RComp } |
Enumeration type for characterizing the SPQR-tree-vertices. More... | |
Public Types inherited from ogdf::BCTree | |
enum | BNodeType { BNodeType::BComp, BNodeType::CComp } |
Enumeration type for characterizing the BC-tree-vertices. More... | |
enum | GNodeType { GNodeType::Normal, GNodeType::CutVertex } |
Enumeration type for characterizing the vertices of the original graph. More... | |
Protected Member Functions inherited from ogdf::DynamicSPQRTree | |
void | cpRec (node v, PertinentGraph &Gp) const override |
Recursively performs the task of adding edges (and nodes) to the pertinent graph Gp for each involved skeleton graph. More... | |
DynamicSkeleton & | createSkeleton (node vT) const |
Creates the skeleton graph belonging to a given vertex vT of T. More... | |
void | init (edge e) |
Initialization (called by constructors). More... | |
Protected Member Functions inherited from ogdf::SPQRTree | |
edge | cpAddEdge (edge eOrig, PertinentGraph &Gp) const |
Add an edge to Gp corresponding to eOrig . More... | |
node | cpAddNode (node vOrig, PertinentGraph &Gp) const |
Add a node to Gp corresponding to vOrig if required. More... | |
Protected Member Functions inherited from ogdf::DynamicSPQRForest | |
void | addHEdge (edge eH, node vT) const |
Adds edge eH to a vertex vT of the SPQRForest. More... | |
void | delHEdge (edge eH, node vT) const |
Deletes edge eH from m_H and removes its connection to a vertex vT of the SPQRForest. More... | |
void | init () |
Initialization. More... | |
node | newSPQRNode (node vB, const TNodeType spqrNodeType) const |
Creates a new node in the SPQR-tree for a given B-component of the BC-tree. More... | |
edge | newTwinEdge (edge eH, node vT) const |
Creates a twin edge for eH , adds it to vT and returns it. More... | |
node | uniteSPQR (node vB, node sT, node tT) |
node | findSPQR (node vT) const |
Finds the proper representative of an SPQR-tree-vertex (FIND part of UNION/FIND). More... | |
node | findNCASPQR (node sT, node tT) const |
SList< node > & | findPathSPQR (node sH, node tH, node &rT) const |
Finds the shortest path between the two sets of SPQR-tree-vertices which sH and tH are belonging to. More... | |
edge | updateInsertedEdgeSPQR (node vB, edge eG) |
node | updateInsertedNodeSPQR (node vB, edge eG, edge fG) |
Updates an SPQR-tree after a new vertex has been inserted into the original graph by splitting an edge into eG and fG . More... | |
Protected Member Functions inherited from ogdf::DynamicBCTree | |
void | init () |
node | unite (node uB, node vB, node wB) |
node | find (node vB) const |
The FIND function of the UNION/FIND structure. More... | |
node | parent (node vB) const override |
node | condensePath (node sG, node tG) |
Performs path condensation. More... | |
Protected Member Functions inherited from ogdf::BCTree | |
void | biComp (adjEntry adjuG, node vG) |
Generates the BC-tree and the biconnected components graph recursively. More... | |
void | initNotConnected (List< node > &vG) |
Initialization for not connected graphs. More... | |
void | initNotConnected (node vG) |
Initialization for not connected graphs. More... | |
node | findNCA (node uB, node vB) const |
Calculates the nearest common ancestor of two vertices of the BC-tree. More... | |
void | init (node vG) |
Protected Member Functions inherited from ogdf::PlanarSPQRTree | |
void | adoptEmbedding () |
void | createInnerVerticesEmbed (Graph &G, node vT) |
void | expandVirtualEmbed (node vT, adjEntry adjVirt, SListPure< adjEntry > &adjEdges) |
void | firstEmbedding (node &vT) |
void | init (bool isEmbedded) |
Initialization (adaption of embeding). More... | |
bool | nextEmbedding (ListIterator< node > it) |
bool | nextEmbedding (node &vT) |
void | reverse (node &nP, adjEntry &first, adjEntry &last) |
void | setPosInEmbedding (NodeArray< SListPure< adjEntry >> &adjEdges, NodeArray< node > ¤tCopy, NodeArray< adjEntry > &lastAdj, SListPure< node > ¤t, const Skeleton &S, adjEntry adj) |
Protected Attributes inherited from ogdf::DynamicSPQRTree | |
NodeArray< node > | m_mapV |
temporary array used by createSkeleton() More... | |
edge | m_rootEdge |
edge of G at which T is rooted More... | |
NodeArray< DynamicSkeleton * > | m_sk |
pointer to skeleton of a node in T More... | |
EdgeArray< edge > | m_skelEdge |
copies of real and virtual edges in their skeleton graphs (invalid, if the skeleton does not actually exist) More... | |
Protected Attributes inherited from ogdf::SPQRTree | |
NodeArray< node > * | m_cpV |
node in pertinent graph corresponding to an original node (auxiliary member) More... | |
SList< node > | m_cpVAdded |
list of added nodes (auxiliary member) More... | |
Protected Attributes inherited from ogdf::DynamicSPQRForest | |
Graph | m_T |
A Graph structure containing all SPQR-trees. More... | |
NodeArray< node > | m_bNode_SPQR |
NodeArray< int > | m_bNode_numS |
The numbers of S-components. More... | |
NodeArray< int > | m_bNode_numP |
The numbers of P-components. More... | |
NodeArray< int > | m_bNode_numR |
The numbers of R-components. More... | |
NodeArray< TNodeType > | m_tNode_type |
The types of the SPQR-tree-vertices. More... | |
NodeArray< node > | m_tNode_owner |
The owners of the SPQR-tree-vertices in the UNION/FIND structure. More... | |
NodeArray< edge > | m_tNode_hRefEdge |
The virtual edges leading to the parents of the SPQR-tree vertices. More... | |
NodeArray< List< edge > * > | m_tNode_hEdges |
Lists of real and virtual edges belonging to SPQR-tree vertices. More... | |
EdgeArray< ListIterator< edge > > | m_hEdge_position |
The positions of real and virtual edges in their m_tNode_hEdges lists. More... | |
EdgeArray< node > | m_hEdge_tNode |
The SPQR-tree-vertices which the real and virtual edges are belonging to. More... | |
EdgeArray< edge > | m_hEdge_twinEdge |
The partners of virtual edges (nullptr if real). More... | |
NodeArray< node > | m_htogc |
Auxiliary array used by createSPQR(). More... | |
NodeArray< bool > | m_tNode_isMarked |
Auxiliary array used by findNCASPQR() More... | |
Protected Attributes inherited from ogdf::DynamicBCTree | |
NodeArray< int > | m_bNode_degree |
Array that contains for each proper BC-tree-vertex its degree. More... | |
NodeArray< node > | m_bNode_owner |
Array that contains for each BC-tree-vertex its parent in its UNION/FIND-tree structure. More... | |
Protected Attributes inherited from ogdf::BCTree | |
Graph | m_B |
The BC-tree. More... | |
Graph & | m_G |
The original graph. More... | |
Graph | m_H |
The biconnected components graph. More... | |
int | m_numB |
The number of B-components. More... | |
int | m_numC |
The number of C-components. More... | |
NodeArray< bool > | m_gNode_isMarked |
NodeArray< node > | m_gNode_hNode |
An injective mapping vertices(G) -> vertices(H). More... | |
EdgeArray< edge > | m_gEdge_hEdge |
A bijective mapping edges(G) -> edges(H). More... | |
NodeArray< BNodeType > | m_bNode_type |
Array that contains the type of each BC-tree-vertex. More... | |
NodeArray< bool > | m_bNode_isMarked |
Array of marks for the BC-tree-vertices. More... | |
NodeArray< node > | m_bNode_hRefNode |
Array that contains for each BC-tree-vertex the representantive of its parent within the subgraph in the biconnected components graph belonging to the biconnected component represented by the respective BC-tree-vertex. More... | |
NodeArray< node > | m_bNode_hParNode |
Array that contains for each BC-tree-vertex the representant of itself within the subgraph in the biconnected components graph belonging to the biconnected component represented by the parent of the respective BC-tree-vertex. More... | |
NodeArray< SList< edge > > | m_bNode_hEdges |
Array that contains for each BC-tree-vertex a linear list of the edges of the biconnected components graph belonging to the biconnected component represented by the respective BC-tree-vertex. More... | |
NodeArray< int > | m_bNode_numNodes |
Array that contains for each BC-tree-vertex the number of vertices belonging to the biconnected component represented by the respective BC-tree-vertex. More... | |
NodeArray< node > | m_hNode_bNode |
EdgeArray< node > | m_hEdge_bNode |
A surjective mapping edges(H) -> vertices(B). More... | |
NodeArray< node > | m_hNode_gNode |
A surjective mapping vertices(H) -> vertices(G). More... | |
EdgeArray< edge > | m_hEdge_gEdge |
A bijective mapping edges(H) -> edges(G). More... | |
int | m_count |
NodeArray< int > | m_number |
Temporary array. More... | |
NodeArray< int > | m_lowpt |
Temporary array. More... | |
ArrayBuffer< adjEntry > | m_eStack |
Temporary stack. More... | |
NodeArray< node > | m_gtoh |
Temporary array. More... | |
SList< node > | m_nodes |
Temporary list. More... | |
Protected Attributes inherited from ogdf::PlanarSPQRTree | |
bool | m_finished |
SPQR-trees of planar graphs.
The class DynamicPlanarSPQRTree maintains the triconnected components of a planar biconnected graph G and represents all possible embeddings of G. Each skeleton graph is embedded.
The current embeddings of the skeletons define an embedding of G. There are two basic operations for obtaining another embedding of G: reverse(v), which flips the skeleton of an R-node v around its poles, and swap(v,e_1,e_2), which exchanges the positions of the edges e_1 and e_2 in the skeleton of a P-node v.
Definition at line 55 of file DynamicPlanarSPQRTree.h.
|
inlineexplicit |
Creates an SPQR tree for planar graph G
rooted at the first edge of G
.
If isEmbedded
is set to true, G
must represent a combinatorial embedding, i.e., the counter-clockwise order of the adjacency entries around each vertex defines an embedding.
G
is planar and biconnected and contains at least 3 nodes, or G
has exactly 2 nodes and at least 3 edges. Definition at line 67 of file DynamicPlanarSPQRTree.h.
|
inline |
Creates an SPQR tree for planar graph G
rooted at edge e
.
If isEmbedded
is set to true, G
must represent a combinatorial embedding, i.e., the counter-clockwise order of the adjacency entries around each vertex defines an embedding.
e
is an edge in G
, and G
is planar and biconnected and contains at least 3 nodes, or G
has exactly 2 nodes and at least 3 edges. Definition at line 80 of file DynamicPlanarSPQRTree.h.