It is often needed to perform an operation on a subset of vertices of
edges in a graph. A vertex sequence is simply a vector containing vertex ids, but it has
a special class attribute which makes it possible to perform graph
specific operations on it, like selecting a subset of the vertices
based on some vertex attributes.
A vertex sequence is created by V(g)
this selects are vertices
in increasing vertex id order. A vertex sequence can be indexed by a
numberic vector, this way only a subset of all vertices can be
selected.
Vertex sequences provide powerful operations for dealing with vertex
attributes. A vertex sequence can be indexed with the
$
operator to select (or modify) the attributes of a
subset of vertices. A vertex sequence can be indexed by a logical
expression, and this expression may contain the names of the vertex
attributes and ordinary variables as well. The return value of such a
construct (ie. a vertex sequence indexed by a logical expression) is
another vertex sequence containing only vertices from the original
sequence for which the expression evaluates to TRUE.
Let us see an example to make everything clear. We assign random
numbers between 1 and 100 to the vertices, and select those vertices
for which the number is less than 50. We set the color of these
vertices to red.
g <- graph.ring(10)
V(g)$number <- sample(1:100, vcount(g), replace=TRUE)
V(g)$color <- "grey"
V(g)[ number < 50 ]$color <- "red"
plot(g, layout=layout.circle, vertex.color="a:color")
There is a similar notation for edges. E(g)
selects all edges
from the g
graph. Edge sequences can be also indexed
with logical expressions containing edge attributes:
g <- graph.ring(10)
E(g)$weight <- runif(ecount(g))
E(g)$width <- 1
E(g)[ weight >= 0.5 ]$width <- 2
plot(g, layout=layout.circle, edge.width="a:width", edge.color="black")
There are some special functions which are only defined in the
indexing expressions of vertex and edge sequences. For vertex
sequences these are: nei
, adj
, from
and
to
.
nei
has a mandatory and an optional argument, the first is
another vertex sequence, the second is a mode argument similar to that
of the neighbors
function. nei
returns a logical
vector of the same length as the indexed vertex sequence and evaluates
to TRUE
for those vertices only which have a neighbor vertex in
the vertex sequence supplied as a parameter. Thus for selecting all
neighbors of vertices 0 and 1 one can write:
V(g) [ nei( 0:1 ) ]
The mode argument (just like for neighbors
) gives the
type of the neighbors to be included, it is interpreted only in
directed graphs, and defaults to all types of neighbors. See the
example below.
adj
takes an edge sequence as an argument and returns
TRUE
for vertices which have at least one adjacent edge in it.
from
and to
are similar to adj
but only edges
originated at (from
) or pointing to (to
) are taken into
account.
For edge sequences the special functions are: adj
, from
,
to
, %--%
, %->%
and %<-%
.
adj
takes a vertex sequence as an argument and returns
NULL
for edges which have an adjacent vertex in it.
from
and to
are similar to adj
, but only vertices
at the source (from
) or target (to
) of the edge.
The %--%
operator selects edges connecting two vertex
sequences, the direction of the edges is ignored. The %->%
is
different only for directed graphs and only edges pointing from the
left hand side argument to the right hand side argument are selected.
%<-%
is exactly the opposite, it selects edges pointing from
the right hand side to the left hand side.
E
has two optional arguments: P
and path
. If
given P
can be used to select edges based on their end points,
eg. E(g, P=c(0,1))
selects edge 0->1
.
path
can be used to select all edges along a path. The path
should be given with the visited vertex ids in the appropriate order.
See also the examples below.