The R package to infer and plot Bayesian networks. The network are inferred from expression data based on clusterProfiler or ReactomePA results. It makes use of libraries including clusterProfiler, ReactomePA, bnlearn, graphite and depmap. In this vignette, the description of functions and several use cases are depicted using random data. The more detailed use cases including the analysis of the dataset GSE133624, which contains RNA-Seq data of bladder cancer, can be found on the book (https://noriakis.github.io/CBNplot/).
BiocManager::install("CBNplot")library(CBNplot)
library(bnlearn)
library(org.Hs.eg.db)
## Load data
data(gaussian.test)
## Draw genes in the KEGG pathway as DEG
kegg <- org.Hs.egPATH2EG
mapped <- mappedkeys(kegg)
genes <- as.list(kegg[mapped])[["00532"]]
## Random data
counts <- head(gaussian.test, length(genes))
row.names(counts) <- genes
## Perform enrichment analysis
pway <- clusterProfiler::enrichKEGG(gene = genes)
pway <- clusterProfiler::setReadable(pway, org.Hs.eg.db, keyType="ENTREZID")Then use CBNplot. Basically, you need to supply the enrichment analysis result, normalized expression value and samples to be included. For bngeneplot, the pathway number in the result slot of enrichment analysis results must be given.
bngeneplot(results = pway,exp = counts, pathNum = 1, expRow="ENTREZID")Data frame of raw values used in the inference, data frame containing strength and direction, averaged network, and plot can be obtained by specifying returnNet=TRUE
ret <- bngeneplot(results = pway,exp = counts, pathNum = 1, returnNet=TRUE, , expRow="ENTREZID")
head(ret$str)FALSE    from      to strength direction
FALSE 1 CHST3     UST     0.25 0.4000000
FALSE 2 CHST3 B4GALT7     0.00 0.0000000
FALSE 3 CHST3   CHSY1     0.15 0.0000000
FALSE 4 CHST3  B3GAT3     0.30 0.5833333
FALSE 5 CHST3     DSE     0.10 0.5000000
FALSE 6 CHST3  CHST11     0.10 0.5000000The resulting network can be converted to igraph object using bnlearn::as.igraph().
g <- bnlearn::as.igraph(ret$av)
igraph::evcent(g)$vector## Warning: `evcent()` was deprecated in igraph 2.0.0.
## ℹ Please use `eigen_centrality()` instead.
## This warning is displayed once every 8 hours.
## Call `lifecycle::last_lifecycle_warnings()` to see where this warning was
## generated.##        CHST3          UST      B4GALT7        CHSY1       B3GAT3          DSE 
## 1.442222e-16 0.000000e+00 1.634518e-15 8.660254e-01 8.660254e-01 0.000000e+00 
##       CHST11       CHST15        CHPF2   CSGALNACT2       CHST12   CSGALNACT1 
## 0.000000e+00 1.538370e-15 1.922963e-16 5.000000e-01 4.807407e-17 9.614813e-17 
##        CHST7        XYLT1        XYLT2         CHPF       CHST14      B3GALT6 
## 9.614813e-17 6.730369e-16 1.000000e+00 0.000000e+00 5.000000e-01 0.000000e+00 
##       CHST13        CHSY3 
## 4.807407e-17 6.730369e-16The relationship between pathways can be drawn by bnpathplot. The number to be included in the inference can be specified by nCategory.
bnpathplot(results = pway,exp = counts, nCategory=5, shadowText = TRUE, expRow="ENTREZID")bngeneplotCustom and bnpathplotCustom can be used to customize visualization with more flexibility, like highlighting the nodes and edges of interest by glowEdgeNum and hub.
bnpathplotCustom(results = pway, exp = counts, expRow="ENTREZID",
                 fontFamily="serif", glowEdgeNum=1, hub=1)bngeneplotCustom(results = pway, exp = counts, expRow="ENTREZID",
                 pathNum=1, fontFamily="sans", glowEdgeNum=NULL, hub=1)The detailed usage for the package, like including covariates to the plot and probabilistic reasoning is available in the package documentation (https://noriakis.github.io/CBNplot/).
sessionInfo()## R version 4.5.0 RC (2025-04-04 r88126 ucrt)
## Platform: x86_64-w64-mingw32/x64
## Running under: Windows Server 2022 x64 (build 20348)
## 
## Matrix products: default
##   LAPACK version 3.12.1
## 
## locale:
## [1] LC_COLLATE=C                          
## [2] LC_CTYPE=English_United States.utf8   
## [3] LC_MONETARY=English_United States.utf8
## [4] LC_NUMERIC=C                          
## [5] LC_TIME=English_United States.utf8    
## 
## time zone: America/New_York
## tzcode source: internal
## 
## attached base packages:
## [1] stats4    stats     graphics  grDevices utils     datasets  methods  
## [8] base     
## 
## other attached packages:
##  [1] org.Hs.eg.db_3.21.0  AnnotationDbi_1.70.0 IRanges_2.42.0      
##  [4] S4Vectors_0.46.0     Biobase_2.68.0       BiocGenerics_0.54.0 
##  [7] generics_0.1.3       bnlearn_5.0.2        CBNplot_1.8.0       
## [10] BiocStyle_2.36.0    
## 
## loaded via a namespace (and not attached):
##   [1] RColorBrewer_1.1-3      jsonlite_2.0.0          pvclust_2.2-0          
##   [4] magrittr_2.0.3          magick_2.8.6            ggtangle_0.0.6         
##   [7] farver_2.1.2            rmarkdown_2.29          fs_1.6.6               
##  [10] vctrs_0.6.5             memoise_2.0.1           ggtree_3.16.0          
##  [13] tinytex_0.57            htmltools_0.5.8.1       AnnotationHub_3.16.0   
##  [16] distributional_0.5.0    curl_6.2.2              gridGraphics_0.5-1     
##  [19] sass_0.4.10             bslib_0.9.0             plyr_1.8.9             
##  [22] cachem_1.1.0            igraph_2.1.4            lifecycle_1.0.4        
##  [25] pkgconfig_2.0.3         Matrix_1.7-3            R6_2.6.1               
##  [28] fastmap_1.2.0           gson_0.1.0              GenomeInfoDbData_1.2.14
##  [31] digest_0.6.37           aplot_0.2.5             enrichplot_1.28.0      
##  [34] colorspace_2.1-1        patchwork_1.3.0         ExperimentHub_2.16.0   
##  [37] RSQLite_2.3.9           labeling_0.4.3          filelock_1.0.3         
##  [40] httr_1.4.7              polyclip_1.10-7         compiler_4.5.0         
##  [43] bit64_4.6.0-1           withr_3.0.2             graphite_1.54.0        
##  [46] BiocParallel_1.42.0     viridis_0.6.5           DBI_1.2.3              
##  [49] ggforce_0.4.2           R.utils_2.13.0          MASS_7.3-65            
##  [52] rappdirs_0.3.3          tools_4.5.0             ape_5.8-1              
##  [55] R.oo_1.27.0             glue_1.8.0              nlme_3.1-168           
##  [58] GOSemSim_2.34.0         grid_4.5.0              reshape2_1.4.4         
##  [61] fgsea_1.34.0            gtable_0.3.6            R.methodsS3_1.8.2      
##  [64] tidyr_1.3.1             data.table_1.17.0       tidygraph_1.3.1        
##  [67] XVector_0.48.0          ggrepel_0.9.6           BiocVersion_3.21.1     
##  [70] pillar_1.10.2           ggdist_3.3.2            stringr_1.5.1          
##  [73] yulab.utils_0.2.0       splines_4.5.0           dplyr_1.1.4            
##  [76] tweenr_2.0.3            BiocFileCache_2.16.0    treeio_1.32.0          
##  [79] lattice_0.22-7          gmp_0.7-5               bit_4.6.0              
##  [82] tidyselect_1.2.1        GO.db_3.21.0            Biostrings_2.76.0      
##  [85] knitr_1.50              gridExtra_2.3           bookdown_0.43          
##  [88] xfun_0.52               graphlayouts_1.2.2      stringi_1.8.7          
##  [91] UCSC.utils_1.4.0        lazyeval_0.2.2          ggfun_0.1.8            
##  [94] yaml_2.3.10             evaluate_1.0.3          codetools_0.2-20       
##  [97] ggraph_2.2.1            tibble_3.2.1            qvalue_2.40.0          
## [100] graph_1.86.0            BiocManager_1.30.25     ggplotify_0.1.2        
## [103] cli_3.6.4               munsell_0.5.1           jquerylib_0.1.4        
## [106] Rcpp_1.0.14             GenomeInfoDb_1.44.0     dbplyr_2.5.0           
## [109] png_0.1-8               parallel_4.5.0          ggplot2_3.5.2          
## [112] blob_1.2.4              clusterProfiler_4.16.0  DOSE_4.2.0             
## [115] Rmpfr_1.0-0             viridisLite_0.4.2       tidytree_0.4.6         
## [118] scales_1.3.0            purrr_1.0.4             crayon_1.5.3           
## [121] rlang_1.1.6             cowplot_1.1.3           fastmatch_1.1-6        
## [124] KEGGREST_1.48.0