Title: | Analyzing Partial Rankings in Networks |
---|---|
Description: | Implements methods for centrality related analyses of networks. While the package includes the possibility to build more than 20 indices, its main focus lies on index-free assessment of centrality via partial rankings obtained by neighborhood-inclusion or positional dominance. These partial rankings can be analyzed with different methods, including probabilistic methods like computing expected node ranks and relative rank probabilities (how likely is it that a node is more central than another?). The methodology is described in depth in the vignettes and in Schoch (2018) <doi:10.1016/j.socnet.2017.12.003>. |
Authors: | David Schoch [aut, cre] , Julian Müller [ctb] |
Maintainer: | David Schoch <[email protected]> |
License: | MIT + file LICENSE |
Version: | 1.2.3 |
Built: | 2025-01-01 06:23:53 UTC |
Source: | https://github.com/schochastics/netrankr |
Function to aggregate positions defined via indirect relations to construct centrality scores.
aggregate_positions(tau_x, type = "sum")
aggregate_positions(tau_x, type = "sum")
tau_x |
Numeric matrix containing indirect relations calculated with indirect_relations. |
type |
String indicating the type of aggregation to be used. See Details for options. |
The predefined functions are mainly wrappers around base R functions.
type='sum', for instance, is equivalent to rowSums()
. A non-base functions is
type='invsum' which calculates the inverse of type='sum'.
type='self' is mostly useful for walk based relations, e.g. to count closed walks.
Other self explanatory options are type='mean', type='min', type='max' and type='prod'.
Scores for the index defined by the indirect relation tau_x
and the
used aggregation type.
David Schoch
indirect_relations, transform_relations
library(igraph) library(magrittr) data("dbces11") # degree dbces11 %>% indirect_relations(type = "adjacency") %>% aggregate_positions(type = "sum") # closeness centrality dbces11 %>% indirect_relations(type = "dist_sp") %>% aggregate_positions(type = "invsum") # betweenness centrality dbces11 %>% indirect_relations(type = "depend_sp") %>% aggregate_positions(type = "sum") # eigenvector centrality dbces11 %>% indirect_relations(type = "walks", FUN = walks_limit_prop) %>% aggregate_positions(type = "sum") # subgraph centrality dbces11 %>% indirect_relations(type = "walks", FUN = walks_exp) %>% aggregate_positions(type = "self")
library(igraph) library(magrittr) data("dbces11") # degree dbces11 %>% indirect_relations(type = "adjacency") %>% aggregate_positions(type = "sum") # closeness centrality dbces11 %>% indirect_relations(type = "dist_sp") %>% aggregate_positions(type = "invsum") # betweenness centrality dbces11 %>% indirect_relations(type = "depend_sp") %>% aggregate_positions(type = "sum") # eigenvector centrality dbces11 %>% indirect_relations(type = "walks", FUN = walks_limit_prop) %>% aggregate_positions(type = "sum") # subgraph centrality dbces11 %>% indirect_relations(type = "walks", FUN = walks_exp) %>% aggregate_positions(type = "self")
Implements a variety of functions to approximate expected ranks for partial rankings.
approx_rank_expected(P, method = "lpom")
approx_rank_expected(P, method = "lpom")
P |
A partial ranking as matrix object calculated with neighborhood_inclusion or positional_dominance. |
method |
String indicating which method to be used. see Details. |
The method parameter can be set to
local partial order model
extension of the local partial order model.
based on a connection with relative rank probabilities.
extension of the previous method.
Which of the above methods performs best depends on the structure and size of the partial
ranking. See vignette("benchmarks",package="netrankr")
for more details.
A vector containing approximated expected ranks.
David Schoch
Brüggemann R., Simon, U., and Mey,S, 2005. Estimation of averaged ranks by extended local partial order models. MATCH Commun. Math. Comput. Chem., 54:489-518.
Brüggemann, R. and Carlsen, L., 2011. An improved estimation of averaged ranks of partial orders. MATCH Commun. Math. Comput. Chem., 65(2):383-414.
De Loof, L., De Baets, B., and De Meyer, H., 2011. Approximation of Average Ranks in Posets. MATCH Commun. Math. Comput. Chem., 66:219-229.
approx_rank_relative, exact_rank_prob, mcmc_rank_prob
P <- matrix(c(0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, rep(0, 10)), 5, 5, byrow = TRUE) # Exact result exact_rank_prob(P)$expected.rank approx_rank_expected(P, method = "lpom") approx_rank_expected(P, method = "glpom")
P <- matrix(c(0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, rep(0, 10)), 5, 5, byrow = TRUE) # Exact result exact_rank_prob(P)$expected.rank approx_rank_expected(P, method = "lpom") approx_rank_expected(P, method = "glpom")
Approximate relative rank probabilities .
In a network context,
is the probability that u is
less central than v, given the partial ranking P.
approx_rank_relative(P, iterative = TRUE, num.iter = 10)
approx_rank_relative(P, iterative = TRUE, num.iter = 10)
P |
A partial ranking as matrix object calculated with neighborhood_inclusion or positional_dominance. |
iterative |
Logical scalar if iterative approximation should be used. |
num.iter |
Number of iterations to be used. defaults to 10 (see Details). |
The iterative approach generally gives better approximations
than the non iterative, if only slightly. The default number of iterations
is based on the observation, that the approximation does not improve
significantly beyond this value. This observation, however, is based on
very small networks such that increasing it for large network may yield
better results. See vignette("benchmarks",package="netrankr")
for more details.
a matrix containing approximation of relative rank probabilities.
relative.rank[i,j]
is the probability that i is ranked lower than j
David Schoch
De Loof, K. and De Baets, B and De Meyer, H., 2008. Properties of mutual rank probabilities in partially ordered sets. In Multicriteria Ordering and Ranking: Partial Orders, Ambiguities and Applied Issues, 145-165.
approx_rank_expected, exact_rank_prob, mcmc_rank_prob
P <- matrix(c(0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, rep(0, 10)), 5, 5, byrow = TRUE) P approx_rank_relative(P, iterative = FALSE) approx_rank_relative(P, iterative = TRUE)
P <- matrix(c(0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, rep(0, 10)), 5, 5, byrow = TRUE) P approx_rank_relative(P, iterative = FALSE) approx_rank_relative(P, iterative = TRUE)
extract probabilities as matrices from the result of an object obtained from exact_rank_prob
## S3 method for class 'netrankr_full' as.matrix(x, type = "rank", ...)
## S3 method for class 'netrankr_full' as.matrix(x, type = "rank", ...)
x |
A netrankr_full object |
type |
which probabilities to return. "rank" for rank probabilities, "relative" for relative rank probabilities and "expected" for expected rank probabilities and their variants |
... |
additional parameters for as.matrix |
David Schoch
Calculates the fraction of comparable pairs in a partial order.
comparable_pairs(P)
comparable_pairs(P)
P |
A partial order as matrix object, e.g. calculated with neighborhood_inclusion or positional_dominance. |
Fraction of comparable pairs in P
.
David Schoch
library(igraph) g <- sample_gnp(100, 0.1) P <- neighborhood_inclusion(g) comparable_pairs(P) # All pairs of vertices are comparable in a threshold graph tg <- threshold_graph(100, 0.3) P <- neighborhood_inclusion(g) comparable_pairs(P)
library(igraph) g <- sample_gnp(100, 0.1) P <- neighborhood_inclusion(g) comparable_pairs(P) # All pairs of vertices are comparable in a threshold graph tg <- threshold_graph(100, 0.3) P <- neighborhood_inclusion(g) comparable_pairs(P)
Counts the number of concordant, discordant and (left/right) ties between two rankings.
compare_ranks(x, y)
compare_ranks(x, y)
x |
A numeric vector. |
y |
A numeric vector with the same length as |
Explicitly calculating the number of occurring cases is more robust
than using correlation indices as given in the cor
function. Especially
left and right ties can significantly alter correlations.
A list containing
concordant |
number of concordant pairs: |
discordant |
number of discordant pairs: |
ties |
number of tied pairs: |
left |
number of left ties: |
right |
number of right ties: |
David Schoch
library(igraph) tg <- threshold_graph(100, 0.2) compare_ranks(degree(tg), closeness(tg)) # only concordant pairs compare_ranks(degree(tg), betweenness(tg)) # no discordant pairs ## Rank Correlation cor(degree(tg), closeness(tg), method = "kendall") # 1 cor(degree(tg), betweenness(tg), method = "kendall") # not 1, although no discordant pairs
library(igraph) tg <- threshold_graph(100, 0.2) compare_ranks(degree(tg), closeness(tg)) # only concordant pairs compare_ranks(degree(tg), betweenness(tg)) # no discordant pairs ## Rank Correlation cor(degree(tg), closeness(tg), method = "kendall") # 1 cor(degree(tg), betweenness(tg), method = "kendall") # not 1, although no discordant pairs
Smallest graph (11 nodes and 17 edges) where the centers according to (d)egree, (b)etweenness, (c)loseness, (e)igenvector centrality, and (s)ubgraph centrality are all different.
dbces11
dbces11
igraph object
Turns a partial ranking into a directed graph. An edge (u,v) is
present if P[u,v]=1
, meaning that u is dominated by v.
dominance_graph(P)
dominance_graph(P)
P |
A partial ranking as matrix object calculated with neighborhood_inclusion or positional_dominance. |
Directed graph as an igraph object.
David Schoch
library(igraph) g <- threshold_graph(20, 0.1) P <- neighborhood_inclusion(g) d <- dominance_graph(P) ## Not run: plot(d) ## End(Not run) # to reduce overplotting use transitive reduction P <- transitive_reduction(P) d <- dominance_graph(P) ## Not run: plot(d) ## End(Not run)
library(igraph) g <- threshold_graph(20, 0.1) P <- neighborhood_inclusion(g) d <- dominance_graph(P) ## Not run: plot(d) ## End(Not run) # to reduce overplotting use transitive reduction P <- transitive_reduction(P) d <- dominance_graph(P) ## Not run: plot(d) ## End(Not run)
Performs a complete and exact rank analysis of a given partial ranking. This includes rank probabilities, relative rank probabilities and expected ranks.
exact_rank_prob(P, only.results = TRUE, verbose = FALSE, force = FALSE)
exact_rank_prob(P, only.results = TRUE, verbose = FALSE, force = FALSE)
P |
A partial ranking as matrix object calculated with neighborhood_inclusion or positional_dominance. |
only.results |
Logical. return only results (default) or additionally
the ideal tree and lattice if |
verbose |
Logical. should diagnostics be printed. Defaults to |
force |
Logical. If |
The function derives rank probabilities from a given partial ranking
(for instance returned by neighborhood_inclusion or positional_dominance). This includes the
calculation of expected ranks, (relative) rank probabilities and the number of possible rankings.
Note that the set of rankings grows exponentially in the number of elements and the exact
calculation becomes infeasible quite quickly and approximations need to be used.
See vignette("benchmarks")
for guidelines and approx_rank_relative,
approx_rank_expected, and mcmc_rank_prob for approximative methods.
lin.ext |
Number of possible rankings that extend |
mse |
Array giving the equivalence classes of |
rank.prob |
Matrix containing rank probabilities: |
relative.rank |
Matrix containing relative rank probabilities: |
expected.rank |
Expected ranks of nodes in any centrality ranking. |
rank.spread |
Standard deviation of the ranking probabilities. |
topo.order |
Random ranking used to build the lattice of ideals (if |
tree |
Adjacency list (incoming) of the tree of ideals (if |
lattice |
Adjacency list (incoming) of the lattice of ideals (if |
ideals |
List of order ideals (if |
In all cases, higher numerical ranks imply a higher position in the ranking. That is, the lowest ranked node has rank 1.
David Schoch, Julian Müller
De Loof, K. 2009. Efficient computation of rank probabilities in posets. Phd thesis, Ghent University.
De Loof, K., De Meyer, H. and De Baets, B., 2006. Exploiting the lattice of ideals representation of a poset. Fundamenta Informaticae, 71(2,3):309-321.
approx_rank_relative, approx_rank_expected, mcmc_rank_prob
P <- matrix(c(0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, rep(0, 10)), 5, 5, byrow = TRUE) P res <- exact_rank_prob(P) # a warning is displayed if only one ranking is possible tg <- threshold_graph(20, 0.2) P <- neighborhood_inclusion(tg) res <- exact_rank_prob(P)
P <- matrix(c(0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, rep(0, 10)), 5, 5, byrow = TRUE) P res <- exact_rank_prob(P) # a warning is displayed if only one ranking is possible tg <- threshold_graph(20, 0.2) P <- neighborhood_inclusion(tg) res <- exact_rank_prob(P)
Florentine family marriage network
florentine_m
florentine_m
An igraph object containing marriage links of florentine families
Padgett, J.F. and Ansell, C.K., 1993. Robust Action and the Rise of the Medici, 1400-1434. American Journal of Sociology, 98(6), 1259-1319.
Returns all possible rankings that extend a partial ranking.
get_rankings(data, force = FALSE)
get_rankings(data, force = FALSE)
data |
List as returned by exact_rank_prob when run with |
force |
Logical scalar. Stops function if the number of rankings is too large. Only change to TRUE if you know what you are doing |
The i
th row of the matrix contains the rank of node i
in all possible rankings
that are in accordance with the partial ranking P
. The lowest rank possible is
associated with 1
.
A matrix containing ranks of nodes in all possible rankings.
David Schoch
P <- matrix(c(0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, rep(0, 10)), 5, 5, byrow = TRUE) P res <- exact_rank_prob(P, only.results = FALSE) get_rankings(res)
P <- matrix(c(0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, rep(0, 10)), 5, 5, byrow = TRUE) P res <- exact_rank_prob(P, only.results = FALSE) get_rankings(res)
The hyperbolic index is an index that considers all closed walks of even or odd length on induced neighborhoods of a vertex.
hyperbolic_index(g, type = "odd")
hyperbolic_index(g, type = "odd")
g |
igraph object. |
type |
string. 'even' if only even length walks should be considered. 'odd' (Default) if only odd length walks should be used. |
The hyperbolic index is an illustrative index that should not be used for any serious analysis. Its purpose is to show that with enough mathematical trickery, any desired result can be obtained when centrality indices are used.
A vector containing centrality scores.
David Schoch
library(igraph) data("dbces11") hyperbolic_index(dbces11, type = "odd") hyperbolic_index(dbces11, type = "even")
library(igraph) data("dbces11") hyperbolic_index(dbces11, type = "odd") hyperbolic_index(dbces11, type = "even")
Calculates the fraction of incomparable pairs in a partial order.
incomparable_pairs(P)
incomparable_pairs(P)
P |
A partial order as matrix object, e.g. calculated with neighborhood_inclusion or positional_dominance. |
Fraction of incomparable pairs in P
.
David Schoch
library(igraph) g <- sample_gnp(100, 0.1) P <- neighborhood_inclusion(g) comparable_pairs(P) # All pairs of vertices are comparable in a threshold graph tg <- threshold_graph(100, 0.3) P <- neighborhood_inclusion(g) comparable_pairs(P)
library(igraph) g <- sample_gnp(100, 0.1) P <- neighborhood_inclusion(g) comparable_pairs(P) # All pairs of vertices are comparable in a threshold graph tg <- threshold_graph(100, 0.3) P <- neighborhood_inclusion(g) comparable_pairs(P)
This shiny gadget can be used to build centrality indices based on specific indirect relations, transformations and aggregation functions. use the dropdown menus to select components that make up the index. Depending on your choices, some options are not available at later stages. At the end, code is being inserted into the current script to use the index
index_builder()
index_builder()
code to calculate the specified index.
Derive indirect relations for a given network. Observed relations, like presents or absence of a relation, are commonly not the center of analysis, but are transformed in a new set of indirect relation like shortest path distances among nodes. These transformations are usually an implicit step when centrality indices are used. Making this step explicit gives more possibilities, for example calculating partial centrality rankings with positional_dominance.
indirect_relations( g, type = "dist_sp", lfparam = NULL, dwparam = NULL, netflowmode = "", rspxparam = NULL, FUN = identity, ... )
indirect_relations( g, type = "dist_sp", lfparam = NULL, dwparam = NULL, netflowmode = "", rspxparam = NULL, FUN = identity, ... )
g |
igraph object. The network for which relations should be derived. |
type |
String giving the relation to be calculated. See Details for options. |
lfparam |
Numeric parameter. Only used if type = "dist_lf". |
dwparam |
Numeric parameter. Only used if type = "dist_walk". |
netflowmode |
String, one of raw, frac, or norm. Only used if type = "depend_netflow". |
rspxparam |
Numeric parameter. Only used if type = "depend_rsps" or type = "depend_rspn". |
FUN |
A function that allows the transformation of relations. See Details. |
... |
Additional arguments passed to FUN. |
The type
parameter has the following options.
'adjacency' returns the adjacency matrix of the network.
'weights' returns the weighted adjacency matrix of the network if an edge attribute 'weight' is present.
'dist_sp' returns shortest path distances between all pairs of nodes.
'depend_sp' returns dyadic dependencies
where is the number of shortest paths from s to t that include u and
is the total number of shortest (s,t)-paths. This relation is used
for betweenness-like centrality indices.
'walks' returns walk counts between pairs of nodes, usually they are
weighted decreasingly in their lengths or other properties which can be done by adding
a function in FUN
. See transform_relations for options.
'dist_resist' returns the resistance distance between all pairs of nodes.
'dist_lf' returns a logarithmic forest distance . The logarithmic forest
distances form a one-parametric family of distances, converging to shortest path distances as
and to the resistance distance as
. See (Chebotarev, 2011) for more details.
The parameter
lfparam
can be used to tune .
'dist_walk' returns the walk distance between nodes. The walk distances form a one-parametric
family of distances, converging to shortest path distances as
and to longest
walk distances for
. Walk distances contain the logarithmic forest
distances as a special case. See (Chebotarev, 2012) for more details.
'dist_rwalk' returns the expected length of a random walk between two nodes. For more details see (Noh and Rieger, 2004)
'depend_netflow' returns dependencies based on network flow (See Freeman et al.,1991).
If netflowmode="raw"
, the function returns
where f(s,t,G) is the maximum flow from s to t in G and f(s,t,G-v) in G without the node v.
For netflowmode="frac"
it returns dependencies in the form, similar to shortest path dependencies:
'depend_curflow' returns pairwise dependencies based on current flow. The relation is based on the same idea as 'depend_sp' and 'depend_netflow'. However, instead of considering shortest paths or network flow, the current flow (or equivalent: random walks) between nodes are of interest. See (Newman, 2005) for details.
'depend_exp' returns pairwise dependencies based on 'communicability':
where E(u) has nonzeros only in row and column u, and in this row and column has -1 if A has +1. See (Estrada et al., 2009) for additional details.
'depend_rsps'. Simple randomized shortest path dependencies.
The simple RSP dependency of a node u with respect to absorbing paths from s to t,
is defined as the expected number of visits through u over all s-t-walks. The
parameter rspxparam
is the "inverse temperature parameter".
If it converges to infinity, only shortest paths are considered and the expected
number of visits to a node on a shortest path approaches the probability of
following that particular path. When the parameter converges to zero, then the
dependencies converge to the expected number of visits to a node over all absorbing
walks with respect to the unbiased random walk probabilities. This means for undirected networks,
that the relations converge to adjacency. See (Kivimäki et al., 2016) for details.
'depend_rspn' Net randomized shortest path dependencies.
The parameter rspxparam
is the "inverse temperature parameter". The asymptotic
for the infinity case are the same as for 'depend_rsps'. If the parameter approaches zero, then
it converges to 'depend_curflow'. The net randomized shortest path dependencies
are closely related to the random walk interpretation of current flows.
See (Kivimäki et al., 2016) for technical details.
The function FUN
is used to transform the indirect
relation. See transform_relations for predefined functions and additional help.
A matrix containing indirect relations in a network.
David Schoch
Chebotarev, P., 2012. The walk distances in graphs. Discrete Applied Mathematics, 160(10), pp.1484-1500.
Chebotarev, P., 2011. A class of graph-geodetic distances generalizing the shortest-path and the resistance distances. Discrete Applied Mathematics 159,295-302.
Noh, J.D. and Rieger, H., 2004. Random walks on complex networks. Physical Review Letters, 92(11), p.118701.
Freeman, L.C., Borgatti, S.P., and White, D.R., 1991. Centrality in Valued Graphs: A Measure of Betweenness Based on Network Flow. Social Networks 13(2), 141-154.
Newman, M.E., 2005. A measure of betweenness centrality based on random walks. Social Networks, 27(1), pp.39-54.
Estrada, E., Higham, D.J., and Hatano, N., 2009. Communicability betweenness in complex networks. Physica A 388,764-774.
Kivimäki, I., Lebichot, B., Saramäki, J., and Saerens, M., 2016. Two betweenness centrality measures based on Randomized Shortest Paths Scientific Reports 6: 19668
aggregate_positions to build centrality indices, positional_dominance to derive dominance relations
library(igraph) data("dbces11") # shortest path distances D <- indirect_relations(dbces11, type = "dist_sp") # inverted shortest path distances D <- indirect_relations(dbces11, type = "dist_sp", FUN = dist_inv) # shortes path dependencies (used for betweenness) D <- indirect_relations(dbces11, type = "depend_sp") # walks attenuated exponentially by their length W <- indirect_relations(dbces11, type = "walks", FUN = walks_exp)
library(igraph) data("dbces11") # shortest path distances D <- indirect_relations(dbces11, type = "dist_sp") # inverted shortest path distances D <- indirect_relations(dbces11, type = "dist_sp", FUN = dist_inv) # shortes path dependencies (used for betweenness) D <- indirect_relations(dbces11, type = "depend_sp") # walks attenuated exponentially by their length W <- indirect_relations(dbces11, type = "walks", FUN = walks_exp)
Checks if a partial ranking is preserved in the ranking induced by scores
.
is_preserved(P, scores)
is_preserved(P, scores)
P |
A partial ranking as matrix object calculated with neighborhood_inclusion or positional_dominance. |
scores |
Numeric vector containing the scores of a centrality index. |
In order for a score vector to preserve a partial ranking, the following
condition must be fulfilled:
P[u,v]==1 & scores[i]<=scores[j]
.
Logical scaler whether scores
preserves the relations in P
.
David Schoch
library(igraph) # standard measures of centrality preserve the neighborhood inclusion preorder data("dbces11") P <- neighborhood_inclusion(dbces11) is_preserved(P, degree(dbces11)) is_preserved(P, betweenness(dbces11)) is_preserved(P, closeness(dbces11))
library(igraph) # standard measures of centrality preserve the neighborhood inclusion preorder data("dbces11") P <- neighborhood_inclusion(dbces11) is_preserved(P, degree(dbces11)) is_preserved(P, betweenness(dbces11)) is_preserved(P, closeness(dbces11))
Calculates the (normalized) majorization gap of an undirected graph. The majorization gap indicates how far the degree sequence of a graph is from a degree sequence of a threshold_graph.
majorization_gap(g, norm = TRUE)
majorization_gap(g, norm = TRUE)
g |
An igraph object |
norm |
|
The distance is measured by the number of reverse unit transformations necessary to turn the degree sequence into a threshold sequence. First, the corrected conjugated degree sequence d' is calculated from the degree sequence d as follows:
the majorization gap is then defined as
The higher the value, the further away is a graph to be a threshold graph.
Majorization gap of an undirected graph.
David Schoch
Schoch, D., Valente, T. W. and Brandes, U., 2017. Correlations among centrality indices and a class of uniquely ranked graphs. Social Networks 50, 46–54.
Arikati, S.R. and Peled, U.N., 1994. Degree sequences and majorization. Linear Algebra and its Applications, 199, 179-211.
library(igraph) g <- graph.star(5, "undirected") majorization_gap(g) # 0 since star graphs are threshold graphs g <- sample_gnp(100, 0.15) majorization_gap(g, norm = TRUE) # fraction of reverse unit transformation majorization_gap(g, norm = FALSE) # number of reverse unit transformation
library(igraph) g <- graph.star(5, "undirected") majorization_gap(g) # 0 since star graphs are threshold graphs g <- sample_gnp(100, 0.15) majorization_gap(g, norm = TRUE) # fraction of reverse unit transformation majorization_gap(g, norm = FALSE) # number of reverse unit transformation
Performs a probabilistic rank analysis based on an almost uniform sample of possible rankings that preserve a partial ranking.
mcmc_rank_prob(P, rp = nrow(P)^3)
mcmc_rank_prob(P, rp = nrow(P)^3)
P |
P A partial ranking as matrix object calculated with neighborhood_inclusion or positional_dominance. |
rp |
Integer indicating the number of samples to be drawn. |
This function can be used instead of exact_rank_prob
if the number of elements in P
is too large for an exact computation. As a rule of thumb,
the number of samples should be at least cubic in the number of elements in P
.
See vignette("benchmarks",package="netrankr")
for guidelines and benchmark results.
expected.rank |
Estimated expected ranks of nodes |
relative.rank |
Matrix containing estimated relative rank probabilities:
|
David Schoch
Bubley, R. and Dyer, M., 1999. Faster random generation of linear extensions. Discrete Mathematics, 201(1):81-88
exact_rank_prob, approx_rank_relative, approx_rank_expected
## Not run: data("florentine_m") P <- neighborhood_inclusion(florentine_m) res <- exact_rank_prob(P) mcmc <- mcmc_rank_prob(P, rp = vcount(g)^3) # mean absolute error (expected ranks) mean(abs(res$expected.rank - mcmc$expected.rank)) ## End(Not run)
## Not run: data("florentine_m") P <- neighborhood_inclusion(florentine_m) res <- exact_rank_prob(P) mcmc <- mcmc_rank_prob(P, rp = vcount(g)^3) # mean absolute error (expected ranks) mean(abs(res$expected.rank - mcmc$expected.rank)) ## End(Not run)
Calculates the neighborhood-inclusion preorder of an undirected graph.
neighborhood_inclusion(g, sparse = FALSE)
neighborhood_inclusion(g, sparse = FALSE)
g |
An igraph object |
sparse |
Logical scalar, whether to create a sparse matrix |
Neighborhood-inclusion is defined as
where is the neighborhood of
and
is the closed neighborhood of
.
implies that
,
where
is a centrality index based on a specific path algebra. Indices
falling into this category are closeness (and variants), betweenness
(and variants) as well as many walk-based indices (eigenvector and subgraph
centrality, total communicability,...).
The neighborhood-inclusion preorder of g
as matrix object. P[u,v]=1
if
David Schoch
Schoch, D. and Brandes, U., 2016. Re-conceptualizing centrality in social networks. European Journal of Applied Mathematics 27(6), 971-985.
Brandes, U. Heine, M., Müller, J. and Ortmann, M., 2017. Positional Dominance: Concepts and Algorithms. Conference on Algorithms and Discrete Applied Mathematics, 60-71.
positional_dominance, exact_rank_prob
library(igraph) # the neighborhood inclusion preorder of a star graph is complete g <- graph.star(5, "undirected") P <- neighborhood_inclusion(g) comparable_pairs(P) # the same holds for threshold graphs tg <- threshold_graph(50, 0.1) P <- neighborhood_inclusion(tg) comparable_pairs(P) # standard centrality indices preserve neighborhood-inclusion data("dbces11") P <- neighborhood_inclusion(dbces11) is_preserved(P, degree(dbces11)) is_preserved(P, closeness(dbces11)) is_preserved(P, betweenness(dbces11))
library(igraph) # the neighborhood inclusion preorder of a star graph is complete g <- graph.star(5, "undirected") P <- neighborhood_inclusion(g) comparable_pairs(P) # the same holds for threshold graphs tg <- threshold_graph(50, 0.1) P <- neighborhood_inclusion(tg) comparable_pairs(P) # standard centrality indices preserve neighborhood-inclusion data("dbces11") P <- neighborhood_inclusion(dbces11) is_preserved(P, degree(dbces11)) is_preserved(P, closeness(dbces11)) is_preserved(P, betweenness(dbces11))
This function is deprecated. Use plot(rank_intervals(P))
instead
plot_rank_intervals(P, cent.df = NULL, ties.method = "min")
plot_rank_intervals(P, cent.df = NULL, ties.method = "min")
P |
A partial ranking as matrix object calculated with neighborhood_inclusion or positional_dominance. |
cent.df |
A data frame containing centrality scores of indices (optional). See Details. |
ties.method |
String specifying how ties are treated in the base |
David Schoch
library(igraph) data("dbces11") P <- neighborhood_inclusion(dbces11) ## Not run: plot_rank_intervals(P) ## End(Not run) # adding index based rankings cent_scores <- data.frame( degree = degree(dbces11), betweenness = round(betweenness(dbces11), 4), closeness = round(closeness(dbces11), 4), eigenvector = round(eigen_centrality(dbces11)$vector, 4) ) ## Not run: plot_rank_intervals(P, cent.df = cent_scores) ## End(Not run)
library(igraph) data("dbces11") P <- neighborhood_inclusion(dbces11) ## Not run: plot_rank_intervals(P) ## End(Not run) # adding index based rankings cent_scores <- data.frame( degree = degree(dbces11), betweenness = round(betweenness(dbces11), 4), closeness = round(closeness(dbces11), 4), eigenvector = round(eigen_centrality(dbces11)$vector, 4) ) ## Not run: plot_rank_intervals(P, cent.df = cent_scores) ## End(Not run)
Plots the result of an object obtained from exact_rank_prob
## S3 method for class 'netrankr_full' plot(x, icols = NULL, bcol = "grey66", ecol = "black", ...)
## S3 method for class 'netrankr_full' plot(x, icols = NULL, bcol = "grey66", ecol = "black", ...)
x |
A netrankr_full object |
icols |
a list of colors (an internal palette is used if missing) |
bcol |
color used for the barcharts |
ecol |
color used for errorbars |
... |
additional plot parameters |
David Schoch
Plots results from rank_intervals
## S3 method for class 'netrankr_interval' plot(x, cent_scores = NULL, cent_cols = NULL, ties.method = "min", ...)
## S3 method for class 'netrankr_interval' plot(x, cent_scores = NULL, cent_cols = NULL, ties.method = "min", ...)
x |
A netrank object |
cent_scores |
A data frame containing centrality scores of indices (optional) |
cent_cols |
colors for centrality indices. If NULL a default palette is used. Length must be equal to columns in cent_scores. |
ties.method |
how to treat ties in the rankings. see rank for details |
... |
additional arguments to plot |
David Schoch
Plots the result of an object obtained from mcmc_rank_prob
## S3 method for class 'netrankr_mcmc' plot(x, icols = NULL, bcol = "grey66", ...)
## S3 method for class 'netrankr_mcmc' plot(x, icols = NULL, bcol = "grey66", ...)
x |
A netrankr_mcmc object |
icols |
a list of colors (an internal) |
bcol |
color used for the barcharts |
... |
additional plot parameters |
David Schoch
generalized dominance relations that can be computed on one and two mode networks.
positional_dominance(A, type = "one-mode", map = FALSE, benefit = TRUE)
positional_dominance(A, type = "one-mode", map = FALSE, benefit = TRUE)
A |
Matrix containing attributes or relations, for instance calculated by indirect_relations. |
type |
A string which is either 'one-mode' (Default) if |
map |
Logical scalar, whether rows can be sorted or not (Default). See Details. |
benefit |
Logical scalar, whether the attributes or relations are benefit or cost variables. |
Positional dominance is a generalization of neighborhood-inclusion for
arbitrary network data. In the default case, it checks for all pairs if
holds for all
if
benefit = TRUE
or
holds for all
if
benefit = FALSE
.
This form of dominance is referred to as dominance under total heterogeneity.
If map=TRUE
, the rows of are sorted decreasingly (
benefit = TRUE
)
or increasingly (benefit = FALSE
) and then the dominance condition is checked. This second
form of dominance is referred to as dominance under total homogeneity, while the
first is called dominance under total heterogeneity.
Dominance relations as matrix object. An entry [u,v]
is 1
if u is dominated by v.
David Schoch
Brandes, U., 2016. Network positions. Methodological Innovations 9, 2059799116630650.
Schoch, D. and Brandes, U., 2016. Re-conceptualizing centrality in social networks. European Journal of Applied Mathematics 27(6), 971-985.
neighborhood_inclusion, indirect_relations, exact_rank_prob
library(igraph) data("dbces11") P <- neighborhood_inclusion(dbces11) comparable_pairs(P) # positional dominance under total heterogeneity dist <- indirect_relations(dbces11, type = "dist_sp") D <- positional_dominance(dist, map = FALSE, benefit = FALSE) comparable_pairs(D) # positional dominance under total homogeneity D_map <- positional_dominance(dist, map = TRUE, benefit = FALSE) comparable_pairs(D_map)
library(igraph) data("dbces11") P <- neighborhood_inclusion(dbces11) comparable_pairs(P) # positional dominance under total heterogeneity dist <- indirect_relations(dbces11, type = "dist_sp") D <- positional_dominance(dist, map = FALSE, benefit = FALSE) comparable_pairs(D) # positional dominance under total homogeneity D_map <- positional_dominance(dist, map = TRUE, benefit = FALSE) comparable_pairs(D_map)
Prints the result of an object obtained from exact_rank_prob to terminal
## S3 method for class 'netrankr_full' print(x, ...)
## S3 method for class 'netrankr_full' print(x, ...)
x |
A netrankr_full object |
... |
additional arguments to print |
David Schoch
Prints the result of an object obtained from rank_intervals to terminal
## S3 method for class 'netrankr_interval' print(x, ...)
## S3 method for class 'netrankr_interval' print(x, ...)
x |
A netrankr_interval object |
... |
additional arguments to print |
David Schoch
Prints the result of an object obtained from mcmc_rank_prob to terminal
## S3 method for class 'netrankr_mcmc' print(x, ...)
## S3 method for class 'netrankr_mcmc' print(x, ...)
x |
A netrank object |
... |
additional arguments to print |
David Schoch
Calculate the maximal and minimal rank possible for each node
in any ranking that is in accordance with the partial ranking P
.
rank_intervals(P)
rank_intervals(P)
P |
A partial ranking as matrix object calculated with neighborhood_inclusion or positional_dominance. |
Note that the returned mid_point
is not the same as the expected
rank, for instance computed with exact_rank_prob.
It is simply the average of min_rank
and max_rank
. For exact rank probabilities
use exact_rank_prob.
An object of type netrankr_interval
David Schoch
P <- matrix(c(0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, rep(0, 10)), 5, 5, byrow = TRUE) rank_intervals(P)
P <- matrix(c(0, 0, 1, 1, 1, 0, 0, 0, 1, 0, 0, 0, 0, 0, 1, rep(0, 10)), 5, 5, byrow = TRUE) rank_intervals(P)
The spectral (or eigen) gap of a graph is the absolute difference between the biggest and second biggest eigenvalue of the adjacency matrix. To compare spectral gaps across networks, the fraction can be used.
spectral_gap(g, method = "frac")
spectral_gap(g, method = "frac")
g |
igraph object |
method |
A string, either "frac" or "abs" |
The spectral gap is bounded between 0 and 1 if method="frac"
. The closer
the value to one, the bigger the gap.
Numeric value
David Schoch
# The fractional spectral gap of a threshold graph is usually close to 1 g <- threshold_graph(50, 0.3) spectral_gap(g, method = "frac")
# The fractional spectral gap of a threshold graph is usually close to 1 g <- threshold_graph(50, 0.3) spectral_gap(g, method = "frac")
Summarizes the result of an object obtained from exact_rank_prob to terminal
## S3 method for class 'netrankr_full' summary(object, ...)
## S3 method for class 'netrankr_full' summary(object, ...)
object |
A netrankr_full object |
... |
additional arguments to summary |
David Schoch
Constructs a random threshold graph. A threshold graph is a graph where the neighborhood inclusion preorder is complete.
threshold_graph(n, p, bseq)
threshold_graph(n, p, bseq)
n |
The number of vertices in the graph. |
p |
The probability of inserting dominating vertices. Equates approximately to the density of the graph. See Details. |
bseq |
(0,1)-vector a binary sequence that produces a threshold grah. See details |
Either n
and p
, or bseq
must be specified.
Threshold graphs can be constructed with a binary sequence. For each 0, an isolated
vertex is inserted and for each 1, a vertex is inserted that connects to all previously inserted
vertices. The probability of inserting a dominating vertices is controlled with parameter p
.
If bseq
is given instead, a threshold graph is constructed from that sequence.
An important property of threshold graphs is, that all centrality indices induce the same ranking.
A threshold graph as igraph object
David Schoch
Mahadev, N. and Peled, U. N. , 1995. Threshold graphs and related topics.
Schoch, D., Valente, T. W. and Brandes, U., 2017. Correlations among centrality indices and a class of uniquely ranked graphs. Social Networks 50, 46–54.
neighborhood_inclusion, positional_dominance
library(igraph) g <- threshold_graph(10, 0.3) ## Not run: plot(g) # star graphs and complete graphs are threshold graphs complete <- threshold_graph(10, 1) # complete graph plot(complete) star <- threshold_graph(10, 0) # star graph plot(star) ## End(Not run) # centrality scores are perfectly rank correlated cor(degree(g), closeness(g), method = "kendall")
library(igraph) g <- threshold_graph(10, 0.3) ## Not run: plot(g) # star graphs and complete graphs are threshold graphs complete <- threshold_graph(10, 1) # complete graph plot(complete) star <- threshold_graph(10, 0) # star graph plot(star) ## End(Not run) # centrality scores are perfectly rank correlated cor(degree(g), closeness(g), method = "kendall")
Mostly wrapper functions that can be used in conjunction with indirect_relations to fine tune indirect relations.
dist_2pow(x) dist_inv(x) dist_dpow(x, alpha = 1) dist_powd(x, alpha = 0.5) walks_limit_prop(x) walks_exp(x, alpha = 1) walks_exp_even(x, alpha = 1) walks_exp_odd(x, alpha = 1) walks_attenuated(x, alpha = 1/max(x) * 0.99) walks_uptok(x, alpha = 1, k = 3)
dist_2pow(x) dist_inv(x) dist_dpow(x, alpha = 1) dist_powd(x, alpha = 0.5) walks_limit_prop(x) walks_exp(x, alpha = 1) walks_exp_even(x, alpha = 1) walks_exp_odd(x, alpha = 1) walks_attenuated(x, alpha = 1/max(x) * 0.99) walks_uptok(x, alpha = 1, k = 3)
x |
Matrix of relations. |
alpha |
Potential weighting factor. |
k |
For walk counts up to a certain length. |
The predefined functions follow the naming scheme relation_transformation
.
Predefined functions walks_*
are thus best used with type="walks" in
indirect_relations. Theoretically, however, any transformation can be used with any relation.
The results might, however, not be interpretable.
The following functions are implemented so far:
dist_2pow
returns
dist_inv
returns
dist_dpow
returns where
should be chosen greater than 0.
dist_powd
returns where
should be chosen between 0 and 1.
walks_limit_prop
returns the limit proportion of walks between pairs of nodes. Calculating
rowSums of this relation will result in the principle eigenvector of the network.
walks_exp
returns
walks_exp_even
returns
walks_exp_odd
returns
walks_attenuated
returns
walks_uptok
returns
Walk based transformation are defined on the eigen decomposition of the adjacency matrix using the fact that
Care has to be taken when using user defined functions.
Transformed relations as matrix
David Schoch
Calculates the transitive reduction of a partial ranking.
transitive_reduction(P)
transitive_reduction(P)
P |
A partial ranking as matrix object calculated with neighborhood_inclusion or positional_dominance. |
transitive reduction of P
David Schoch
library(igraph) g <- threshold_graph(100, 0.1) P <- neighborhood_inclusion(g) sum(P) R <- transitive_reduction(P) sum(R)
library(igraph) g <- threshold_graph(100, 0.1) P <- neighborhood_inclusion(g) sum(P) R <- transitive_reduction(P) sum(R)