Class Avogadro::Core::Graph#
-
class Graph#
The Graph class represents a graph data structure.
A graph consists of vertices and edges, wherein every edge connects two vertices. Each vertex is assigned an index, starting from 0 up to size() - 1. Each edge is also assigned an index, from 0 to edgeCount() - 1.
Public Functions
-
Graph()#
Creates a new, empty graph.
-
explicit Graph(size_t n)#
Creates a new graph containing size
n
vertices.
-
~Graph()#
Destroys the graph.
-
void setSize(size_t n)#
Sets the number of vertices in the graph to size
n
.If
n
is smaller thansize()
, this removes all vertices with indexn
or higher, as well as any edges connected to them, while preserving all other vertices and edges. These vertices keep their existing indices, while no guarantee is made regarding preserved edge indices.If
n
is larger thansize()
, a number of unconnected vertices are added, up to the requested size. All existing vertices and edges are preserved in their current form.
-
size_t size() const#
- Returns:
the number of vertices in the graph.
-
void clear()#
Removes all vertices and edges from the graph.
-
size_t addVertex()#
Adds a vertex to the graph and returns its index. The new vertex is initially not connected. All existing vertices and edges are preserved and their indices unchanged.
-
void removeVertex(size_t index)#
Removes the vertex at
index
from the graph, as well as all edges to it. Ifindex
is not the highest vertex index in the graph, the vertex with highest index will be assigned the index of the removed vertex. All other vertices will keep their indices. No guarantees are made regarding edge indices.
-
void swapVertexIndices(size_t a, size_t b)#
Swaps two vertices’ indices, without affecting connectivity. All other vertices and all edges keep their existing indices.
-
size_t vertexCount() const#
- Returns:
the number of vertices in the graph.
-
size_t addEdge(size_t a, size_t b)#
Adds an edge between vertices
a
andb
and returns its index. All existing vertices and edges are preserved unchanged.
-
void removeEdge(size_t a, size_t b)#
Removes the edge between vertices
a
andb
. All vertices keep their indices. If the removed edge has an index lower than the highest edge index in the graph, the edge with the highest index is given the index of the removed edge. All other edges remain unchanged.
-
void removeEdge(size_t edgeIndex)#
Removes edge with index
edgeIndex
. All vertices keep their indices. IfedgeIndex
is lower than the highest edge index in the graph, the edge with the highest index is given the index of the removed edge. All other edges remain unchanged.
-
void removeEdges()#
Removes all of the edges from the graph, without affecting vertices.
-
void removeEdges(size_t index)#
Removes all of the edges that contain the vertex at
index
from the graph.
-
void editEdgeInPlace(size_t edgeIndex, size_t a, size_t b)#
Removes the edge at
edgeIndex
, and creates a new one between verticesa
andb
, with the same index as the removed edge. All other edges and vertices keep their current indices.
-
void swapEdgeIndices(size_t edgeIndex1, size_t edgeIndex2)#
Swaps two edges’ indices, without affecting connectivity. All other edges and all vertices keep their current indices.
-
size_t edgeCount() const#
- Returns:
the number of edges in the graph.
-
std::vector<size_t> neighbors(size_t index) const#
- Returns:
a vector containing the indices of each vertex that the vertex at index shares an edge with.
-
std::vector<size_t> edges(size_t index) const#
- Returns:
a vector containing the indices of each edge that the vertex at
index
is an endpoint of; that is, the edges incident at it.
-
std::pair<size_t, size_t> endpoints(size_t edgeIndex) const#
- Returns:
the indices of the two vertices that the edge at
index
connects; that is, its endpoints.
-
size_t degree(size_t index) const#
- Returns:
the degree of the vertex at
index
.
-
bool containsEdge(size_t a, size_t b) const#
- Returns:
true
if the graph contains an edge between verticesa
andb
.
-
const Array<std::pair<size_t, size_t>> &edgePairs() const#
- Returns:
an array with all edges, where every element contains the indices of both endpoints of the edge with index equal to the element’s array index.
-
std::vector<std::set<size_t>> connectedComponents() const#
- Returns:
a vector of vector containing the indices of each vertex in each connected component in the graph.
-
std::set<size_t> connectedComponent(size_t index) const#
- Returns:
a set containing the indices of each vertex connected with
index
.
-
size_t subgraphsCount() const#
- Returns:
the number of connected subgraphs.
-
size_t subgraph(size_t index) const#
- Returns:
the subgraph ID of the connected subgraph
index
lies in.
-
size_t subgraphCount(size_t index) const#
- Returns:
the size of the connected subgraph that includes
index
, that is, the number of connected vertices in it.
-
size_t getConnectedID(size_t index) const#
- Returns:
the subgraph ID of the connected subgraph
index
lies in.
-
Graph()#