# FUNCTION
# - arguments: dataframe taken from explore or analyze functions
# - returns: correlation network with colored nodes and thick/thin edges
# NOTES
# - edge width has been adjust to represent absolute correlation x10
# (the multiplication is done in order for the edges to
# have visibly different width)
# - edge color is either blue (positive correlation)
# or red (negative correlation). The amount of correlation is
# represented by edge width
utils::globalVariables(c("igraph", "layout_in_circle","make_graph","V","V<-",
"tkplot","E","<-E",
"pathCor_pathprint_v1.2.3_unadjusted_dframe",
"pathCor_CPv5.1_unadjusted_dframe"))
#' Create a network of a pcxn object
#'
#' @param object pcxn object created by explore or analyze functions
#'
#' @return draws a tkplot object and saves a graph object
#' representing the network
#' @export
#'
#' @examples
#' # Create a network of a pcxn object
#' object <- pcxn_explore("pathprint","Alzheimer's disease (KEGG)",
#' 10, 0.05, 0.05)
#'
#' # network <- pcxn_network(object)
#'
pcxn_network <- function(object) {
edges <- c()
edge_thickness <- c()
edge_color <- c()
for (i in 1:nrow(object@data)) {
edges <- c(edges, object@data[i,1])
edges <- c(edges, object@data[i,2])
edge_thickness <- c(edge_thickness,
abs(as.numeric(object@data[i,3]) * 10))
if(as.numeric(object@data[i,3]) < 0) edge_color <- c(edge_color, "blue")
else edge_color <- c(edge_color, "red")
}
graph <- igraph::make_graph(edges, directed = FALSE)
# setting node colours
if (object@type == "explore") {
V(graph)$color <- "#ffaf1a"
V(graph)[object@geneset_groups$query_geneset]$color[1] <- "#66b2ff"
}
if (object@type == "analyze") {
V(graph)$color <- "white"
for(i in 1:length(object@geneset_groups$top_correlated_genesets)) {
tryCatch({
cgs <- object@geneset_groups$top_correlated_genesets[i]
V(graph)[cgs]$color <- "#ffaf1a"
}, error = function(e) {
print(paste("No edges containing ", cgs,
" pass the correlation and p-value filters therefore
the node is not included in the network",sep = ""))
})
}
for(j in 1:length(object@geneset_groups$phenotype_0_genesets)) {
tryCatch({
cgs1 <- object@geneset_groups$phenotype_0_genesets[j]
V(graph)[cgs1]$color <- "#66b2ff"
}, error = function(e) {
print(paste("No edges containing ", cgs1,
" pass the correlation and p-value filters therefore
the node is not included in the network",sep = ""))
})
}
for(h in 1:length(object@geneset_groups$phenotype_1_genesets)) {
tryCatch({
cgs2 <- object@geneset_groups$phenotype_1_genesets[h]
V(graph)[cgs2]$color <- "#19c67e"
}, error = function(e) {
print(paste("No edges containing ", cgs2,
" pass the correlation and p-value filters therefore
the node is not included in the network",sep = ""))
})
}
}
# drawing the plot
plot <- igraph::tkplot(graph, layout= igraph::layout_in_circle,
width = NULL,
height = NULL,
edge.width = edge_thickness, edge.color = edge_color)
igraph::E(graph)$colour=edge_color
igraph::E(graph)$width=edge_thickness
return(graph)
}
Add the following code to your website.
For more information on customizing the embed code, read Embedding Snippets.