From ff59017e114b10812dcfb1704a19e01fc1586a13 Mon Sep 17 00:00:00 2001 From: Leo Sendelbach Date: Tue, 9 Jan 2024 16:33:06 +0100 Subject: [PATCH] Fix get.expanded.adjacency to work if author list does not contain all authors from network and print a warning if that is the case Signed-off by: Leo Sendelbach --- util-networks-misc.R | 17 +++++++++++++---- 1 file changed, 13 insertions(+), 4 deletions(-) diff --git a/util-networks-misc.R b/util-networks-misc.R index 040c0d3a..0446c9ee 100644 --- a/util-networks-misc.R +++ b/util-networks-misc.R @@ -135,13 +135,22 @@ get.expanded.adjacency = function(network, authors, weighted = FALSE) { ## get the weighted adjacency matrix for the current network matrix.data = igraph::get.adjacency(network, attr = "weight") } else { - ## get the unweighted adjacency matrix for the current network + ## get the unweighted sparse adjacency matrix for the current network matrix.data = igraph::get.adjacency(network) } - - ## order the adjacency matrix + + network.authors.num = nrow(matrix.data) + ## order the adjacency matrix and filter out authors that were not in authors list if (nrow(matrix.data) > 1) { # for a 1x1 matrix ordering does not work - matrix.data = matrix.data[order(rownames(matrix.data)), order(colnames(matrix.data))] + matrix.data = matrix.data[order((rownames(matrix.data)[rownames(matrix.data) %in% authors])), + order((rownames(matrix.data)[rownames(matrix.data) %in% authors]))] + } + + if(network.authors.num > nrow(matrix.data)) { + # write a warning with the number of authors from the network that we ignore + warning.string = sprintf("The network had %d authors that will not be displayed in the matrix!", + network.authors.num - nrow(matrix.data)) + warning(warning.string) } ## save the activity data per author