Crandore Hub

bnRep

A Repository of Bayesian Networks from the Academic Literature

A collection of Bayesian networks (discrete, Gaussian, and conditional linear Gaussian) collated from recent academic literature. The 'bnRep_summary' object provides an overview of the Bayesian networks in the repository and the package documentation includes details about the variables in each network. A Shiny app to explore the repository can be launched with 'bnRep_app()' and is available online at <https://manueleleonelli.shinyapps.io/bnRep>. Reference: 'M. Leonelli' (2025) <doi:10.1016/j.neucom.2025.129502>.

README

<!-- README.md is generated from README.Rmd. Please edit that file -->

# bnRep <img src="https://github.com/manueleleonelli/bnRep/blob/master/hex-bnRep.png" align="right" height="150px" width="150px"/>

<!-- badges: start -->

[![CRAN
status](https://www.r-pkg.org/badges/version/bnRep)](https://cran.r-project.org/package=bnRep)
[![Last-commit](https://img.shields.io/github/last-commit/manueleleonelli/bnRep)](https://github.com/manueleleonelli/bnRep/commits/main)
[![Lifecycle:
stable](https://img.shields.io/badge/lifecycle-stable-green.svg)](https://lifecycle.r-lib.org/articles/stages.html#stable)

<!-- badges: end -->

The R package `bnRep` includes the largest repository of Bayesian
networks, which were all collected from recent academic literature in a
variety of fields! If you are using any Bayesian network from `bnRep`
you should cite:

Leonelli, M. (2025). bnRep: A repository of Bayesian networks from the
academic literature. Neurocomputing, 624, 129502.

    @Article{,
        title = {bn{R}ep: A repository of {B}ayesian networks from the academic literature},
        author = {Manuele Leonelli},
        journal = {Neurocomputing},
        volume = {624},
        year = {2025},
        pages = {129502}
      }

Go to <https://manueleleonelli.shinyapps.io/bnRep/> to explore the
repository online!

## Contribution

If you are interested in having your Bayesian network included in
`bnRep` you must prepare three objects:

- the Bayesian network as a `bn.fit` object (if not created with
  `bnlearn` you can always use import functions, such as `read.bif()`);

- an R file with the same name of the `bn.fit` object reporting the
  documentation of the Bayesian network;

- a vector/excel file with the required details to include in the
  `bnRep_summary` object.

You can submit the required objects directly via github (e.g fork/pull),
or via email.

If you struggle with any of these steps, please get in touch and I will
try to help!

## Overview

`bnRep` includes over 200 Bayesian networks from more than 150 academic
publications. It includes discrete, Gaussian and conditional linear
Gaussian Bayesian networks, all stored as appropriate `bn.fit` objects
from `bnlearn`. They can be exported for use to other software
(e.g. Phython libraries) using functions from `bnlearn` such as
`write.bif()`. Recall that in order to plot the associated DAG, one must
first convert it to a graph object with `bn.net()` from the `bnlearn`
package.

### Installation

``` r
# Install stable version from CRAN:
install.packages("bnRep")

# Or the development version from GitHub:
remotes::install_github("manueleleonelli/bnRep")
```

### Usage

We will use the `lawschool` Bayesian network as an example. To load it
in the environment simply call `data(lawschool)` and to then plot it
(for instance using `graphviz.plot` from the `bnlearn` package)

``` r
library(bnRep)
library(bnlearn)
library(qgraph)
data("lawschool")
qgraph::qgraph(bn.net(lawschool))
```

<img src="man/figures/README-unnamed-chunk-3-1.png" width="50%" />

Notice that the function `bn.net` function must be used in order to plot
the network.

### Exploring bnRep

`bnRep` includes two features to explore the Bayesian networks in the
repository:

- `bnRep_summary`: a dataframe with important details about each network
  in the repository.

- `bnRep_app`: a Shiny app to interactively explore `bnRep_summary` and
  filter the networks according to various criteria. The app is also
  available online at <https://manueleleonelli.shinyapps.io/bnRep/>.

Here’s the columns of `bnRep_summary`:

    #>  [1] "Name"                   "Type"                   "Structure"             
    #>  [4] "Probabilities"          "Graph"                  "Area"                  
    #>  [7] "Nodes"                  "Arcs"                   "Parameters"            
    #> [10] "Avg. Parents"           "Max Parents"            "Avg. Levels"           
    #> [13] "Max Levels"             "Average Markov Blanket" "Year"                  
    #> [16] "Journal"                "Reference"

### An overview of the Bayesian networks in bnRep

The following plots show some summary statistics of the repository.

    #> Warning: package 'ggplot2' was built under R version 4.3.3

<img src="man/figures/README-unnamed-chunk-5-1.png" width="50%" />

<img src="man/figures/README-unnamed-chunk-6-1.png" width="50%" />
<img src="man/figures/README-unnamed-chunk-7-1.png" width="50%" />

<img src="man/figures/README-unnamed-chunk-8-1.png" width="50%" />

<img src="man/figures/README-unnamed-chunk-9-1.png" width="50%" />

<img src="man/figures/README-unnamed-chunk-10-1.png" width="50%" />

<img src="man/figures/README-unnamed-chunk-11-1.png" width="50%" />

<img src="man/figures/README-unnamed-chunk-12-1.png" width="50%" />

<img src="man/figures/README-unnamed-chunk-13-1.png" width="50%" />

<img src="man/figures/README-unnamed-chunk-14-1.png" width="50%" />

Versions across snapshots

VersionRepositoryFileSize
0.0.6 rolling linux/jammy R-4.5 bnRep_0.0.6.tar.gz 1.8 MiB
0.0.6 rolling linux/noble R-4.5 bnRep_0.0.6.tar.gz 1.8 MiB
0.0.6 rolling source/ R- bnRep_0.0.6.tar.gz 1.8 MiB
0.0.6 latest linux/jammy R-4.5 bnRep_0.0.6.tar.gz 1.8 MiB
0.0.6 latest linux/noble R-4.5 bnRep_0.0.6.tar.gz 1.8 MiB
0.0.6 latest source/ R- bnRep_0.0.6.tar.gz 1.8 MiB
0.0.6 2026-04-26 source/ R- bnRep_0.0.6.tar.gz 1.8 MiB
0.0.6 2026-04-23 source/ R- bnRep_0.0.6.tar.gz 1.8 MiB
0.0.3 2025-04-20 source/ R- bnRep_0.0.3.tar.gz 1.6 MiB

Dependencies (latest)

Imports

Suggests