igraph (version 0.7.0)

graph.difference: Difference of graphs

Description

The difference of two graphs are created.

Usage

graph.difference(big, small, byname = "auto")

Arguments

big
The left hand side argument of the minus operator. A directed or undirected graph.
small
The right hand side argument of the minus operator. A directed ot undirected graph.
byname
A logical scalar, or the character scalar auto. Whether to perform the operation based on symbolic vertex names. If it is auto, that means TRUE if both graphs are named and FALSE otherwise. A

Value

  • A new graph object.

concept

Graph operators

Details

graph.difference creates the difference of two graphs. Only edges present in the first graph but not in the second will be be included in the new graph. The corresponding operator is %m%.

If the byname argument is TRUE (or auto and the graphs are all named), then the operation is performed based on symbolic vertex names. Otherwise numeric vertex ids are used. graph.difference keeps all attributes (graph, vertex and edge) of the first graph.

Note that big and small must both be directed or both be undirected, otherwise an error message is given.

Examples

Run this code
## Create a wheel graph
wheel <- graph.union(graph.ring(10),
                     graph.star(11, center=11, mode="undirected"))
V(wheel)$name <- letters[seq_len(vcount(wheel))]

## Subtract a star graph from it
sstar <- graph.star(6, center=6, mode="undirected")
V(sstar)$name <- letters[c(1,3,5,7,9,11)]
G <- wheel %m% sstar
str(G)
plot(G, layout=layout.auto(wheel))

Run the code above in your browser using DataCamp Workspace