This page is about Graph class and graph generators. To see the list of generic graphs methods please visit this page.
The Graph class has several static methods to generate random and special graphs, like random(n, m) or complete(n). The source of randomness is rnd.
After calling a method you can add modifiers to allow or disallow loops, make graph connected etc. As you can see from the following example, chaining semantics is used. To support this semantics generation methods return not Graph itself but a special proxy class. To get a Graph itself, you may do one of the following:
- call .g() method after modifiers chain:
- cast the returned object to Graph;
- or directly print the proxy class to the stream, in this case the generated graph will be printed.
See the example for further clarifications.
auto g = Graph::random(10, 20).connected().allowMulti().g().shuffled();
Graph g2 = Graph::randomStretched(100, 200, 2, 5);
cout << Graph::complete(5).allowLoops() << endl;
All graph generators return graph with sorted edges to make tests more human-readable. If you want to have your graph shuffled, use .shuffle() method, as in the example.
- Returns: a random graph with n vertices and m edges.
- Available modifiers: connected, allowLoops, allowMulti, directed, allowAntiparallel, acyclic.
- Returns: a complete graph with n vertices. If directed is specified, the direction of each edge is selected randomly, taking into account allowAntiparallel and acyclic flags.
- Available modifiers: allowLoops, directed, allowAntiparallel, acyclic.
- Returns: a cycle with n vertices, connected in order.
- Available modifiers: directed.
- Returns: an empty graph with n vertices.
- Available modifiers: directed.
- Returns: a connected stretched graph with n vertices and m vertices.
- Available modifiers: allowLoops, allowMulti, directed, allowAntiparallel, acyclic.
- Description: first a random tree on n vertices with given elongation (see tree docs) is generated. Then remaining m-n+1 edges are added. One endpoint of an edge is selected at random. The second is a result of jumping to a tree parent of the first endoint a random number of times, from 0 to spread, inclusive.
- If the graph is directed, the direction of each edge is selected at random, unless it is acyclic: in this case the direction of all edges is down the tree.
- Returns: a random bipartite graph with n1 vertices in one part, n2 vertices in another part and m edges. Vertices from 1 to n1 belong to the first part.
- Available modifiers: connected, allowMulti.
- Returns: a complet bipartite graph with n1 vertices in one part and n2 vertices in another part. Vertices from 1 to n1 belong to the first part.
- Available modifiers: none.
All options are unset by default. If the generator contradicts some option (like randomStretched, which always produces a connected graph), it is ignored.
- Action: force the generated graph to be connected.
- Action: allow multiple edges in the generated graph (i.e. several edges with the same endpoints).
- Action: allow loops in the generated graph (i.e. edges from a vertex to itself).
- Action: create a directed graph.
- Action: allow antiparallel edges (that is, edges u-v and v-u) in a directed graph. Ignored if directed is unset.
- Action: make the directed graph acyclic (DAG). Ignored if directed is unset.
- Construct an empty graph with n vertices.
- Set the number of vertices of the graph to n.
- Note: this operation cannot lessen the number of vertices.
- Shuffle the graph. This means:
- relabel vertices in random order;
- shuffle edges;
- randomly swap egdes' endpoints (for undirected graphs only).
- Same as shuffle, but vertices from except do not change their numbers.
- Possible usecase: we may generate a graph where s-t path is supposed to be found. Then shuffle the graph in such a way that path endpoints are still 1 and n:
g = Graph::random(n, m)...;
g.shuffleAllBut({0, n-1});