Link events stored in data frames that modify attributes of the nodeset or modify ties in a network.
link_events(x, ...)
# S3 method for class 'nodes.goldfish'
link_events(x, change_events, attribute, ...)
# S3 method for class 'network.goldfish'
link_events(x, change_events, nodes = NULL, nodes2 = NULL, ...)
# Default S3 method
link_events(x, ...)Either a nodeset (nodes.goldfish object) or a network
(network.goldfish object)
additional arguments to be passed to the method.
The name of a data frame that represents a valid events list.
a character vector indicating the names of the attributes that should be updated by the specified events (ONLY if the object is a nodeset).
a nodeset (data.frame or nodes.goldfish object)
related to the network (ONLY if x is a network)
an optional nodeset (data.frame or nodes.goldfish object)
related to the network (ONLY if x is a network)
an object with the same class as the object x.
For objects of class network.goldfish the attribute events with the name
of the event data frame passed through with the argument change_events.
For objects of class nodes.goldfish attibutes events and
dynamic_attribute are modified with name of the objects passed through with
the arguments change_events and attribute respectively.
The data frame that contains the events must contain variables with specific names depending if they refer to dynamic attributes or dynamic networks.
For dynamic networks stored in object of class network.goldfish the
change_events data frame must contain the following variables:
numeric or POSIXct (see base::as.Date()) variable
containing the time-stamps when the event happen.
character variable indicating the label of the sender
of the event.
character variable indicating the label of the receiver
of the event.
See the bilatchanges and contigchanges data frames in the
Fisheries_Treaties_6070 datasets for examples of event data frames that
relate with dynamic networks.
For dynamic attributes stored in object of class nodes.goldfish the
change_events data frame must contain the following variables:
numeric or POSIXct (see base::as.Date()) variable
containing the time-stamps when the event happen.
character variable indicating the label of the node
for which the attribute changes.
See sovchanges, regchanges and gdpchanges data frames in the
Fisheries_Treaties_6070 datasets for examples of event data frames that
relate with dynamic attributes
For both cases an additional variable indicates the change in value of either
the ties or attributes.
The class of this variable must be the same as the tie value or attribute
value that will be updated, i.e., when the present variable is dynamic the
updating values must be logical (see make_nodes() for a description
of this variable.
There are two possibilities on how to specify those
changes but only one can be used at a time:
with a numerical value that represent the increment
(when it's positive value) or the decrement (when it's a negative value)
of the dynamic element from their past value (with respect to the time
value).
In the Social_Evolution dataset the calls data frame contains
the calling events between students where the increment represent a new call.
With every new call the dyad (sender-receiver) increase the count of calls
that had happen in the past.
contains the value that would replace at point-time time
the attribute or tie value. It is usually the way to represent changes in
node attributes.
In the Fisheries_Treaties_6070 dataset the sovchanges,
regchanges and gdpchangesdata frames are examples where the replace
variable is used to specify attribute changes and their class match with the
variable in the node set.
Dynamic network attributes can be also defined using the replace variable.
The contigchanges data frame in the Fisheries_Treaties_6070 dataset, and
friendship data frame in the Social_Evolution are examples of this.
actors <- data.frame(
  actor = 1:5, label = paste("Actor", 1:5),
  present = TRUE, gender = sample.int(2, 5, replace = TRUE)
)
actors <- make_nodes(nodes = actors)
callNetwork <- make_network(nodes = actors)
# Link events to a nodeset
compositionChangeEvents <- data.frame(
  time = c(14, 60),
  node = "Actor 4",
  replace = c(FALSE, TRUE)
)
actorsnew <- link_events(
  x = actors, attribute = "present", change_events = compositionChangeEvents
)
# Link events to a Network
calls <- data.frame(
  time = c(12, 27, 45, 56, 66, 68, 87),
  sender = paste("Actor", c(1, 3, 5, 2, 3, 4, 2)),
  receiver = paste("Actor", c(4, 2, 3, 5, 1, 2, 5)),
  increment = rep(1, 7)
)
callNetwork <- link_events(
  x = callNetwork, change_events = calls, nodes = actors
)