https://github.com/cbg-ethz/bnpc
Bayesian non-parametric clustering (BnpC) of binary data with missing values and uneven error rates
Science Score: 26.0%
This score indicates how likely this project is to be science-related based on various indicators:
-
○CITATION.cff file
-
✓codemeta.json file
Found codemeta.json file -
○.zenodo.json file
-
✓DOI references
Found 2 DOI reference(s) in README -
○Academic publication links
-
○Committers with academic emails
-
○Institutional organization owner
-
○JOSS paper metadata
-
○Scientific vocabulary similarity
Low similarity (13.6%) to scientific vocabulary
Keywords
Keywords from Contributors
Repository
Bayesian non-parametric clustering (BnpC) of binary data with missing values and uneven error rates
Basic Info
Statistics
- Stars: 20
- Watchers: 3
- Forks: 4
- Open Issues: 8
- Releases: 1
Topics
Metadata Files
README.md
BnpC
Bayesian non-parametric clustering (BnpC) of binary data with missing values and uneven error rates.
BnpC is a novel non-parametric method to cluster individual cells into clones and infer their genotypes based on their noisy mutation profiles. BnpC employs a Chinese Restaurant Process prior to handle the unknown number of clonal populations. The model introduces a combination of Gibbs sampling, a modified non-conjugate split-merge move and Metropolis-Hastings updates to explore the joint posterior space of all parameters. Furthermore, it employs a novel estimator, which accounts for the shape of the posterior distribution, to predict the clones and genotypes.
The corresponsing paper can be found in Bioinformatics
Contents
Requirements
- Python 3.X
Installation
Clone repository
First, download BnpC from github and change to the directory:
bash
git clone https://github.com/cbg-ethz/BnpC
cd BnpC
Create conda environment (optional)
First, create a new environment named "BnpC":
bash
conda create --name BnpC python=3
Second, source it:
bash
conda activate BnpC
Install requirements
Use pip to install the requirements:
bash
python -m pip install -r requirements.txt
Now you are ready to run BnpC!
Usage
The BnpC wrapper script run_BnpC.py can be run with the following shell command:
bash
python run_BnpC.py <INPUT_DATA> [-t] [-FN] [-FP] [-FN_m] [-FN_sd] [-FP_m] [-FP_sd] [-dpa] [-pp] [-n] [-s] [-r] [-ls] [-b] [-smp] [-cup] [-e] [-sc] [--seed] [-o] [-v] [-np] [-tr] [-tc] [-td]]
Input
BnpC requires a binary matrix as input, where each row corresponds with a mutations and each columns with a cell. All matrix entries must be of the following: 0|1|3/" ", where 0 indicates the absence of a mutation, 1 the presence, and a 3 or empty element a missing value.
Note
If your data is arranged in the transposed way (cells = columns, rows = mutations), use the
-targument.
Arguments
Input Data Arguments
<str>, Path to the input data.-t <flag>, If set, the input matrix is transposed.
Optional input arguments (for simulated data)
-tr <str>, Path to the mutation tree file (in .gv format) used for data generation.-tc <str>, Path to the true clusters assignments to compare clustering methods.-td <str>, Path to the true/raw data/genotypes.
Model Arguments
-FN <float>, Replacewith the fixed error rate for false negatives. -FP <float>, Replacewith the fixed error rate for false positives. -FN_m <float>, Replacewith the mean for the prior for the false negative rate. -FN_sd <float>, Replacewith the standard deviation for the prior for the false negative rate. -FP_m <float>, Replacewith the mean for the prior for the false positive rate. -FP_sd <float>, Replacewith the standard deviation for the prior for the false positive rate. -ap <float>, Alpha value of the Beta function used as prior for the concentration parameter of the CRP.-pp <float> <float>, Beta function shape parameters used for the cluster parameter prior.
Note
If you run BnpC on panel data with few mutation only or on error free data, we recommend changing the
-ppargument to beta distribution closer to uniform, like-pp 0.75 0.75or even-pp 1 1. Otherwise, BnpC will incorrectly report many singleton clusters.
MCMC Arguments
-n <int>, Number of MCMC chains to run in parallel (1 chain per thread).-s <int>, Number of MCMC steps.-r <int>, Runtime in minutes. If set, steps argument is overwritten.-ls <float>, Lugsail batch means estimator as convergence diagnostics [Vats and Flegal, 2018].-b <float>, Ratio of MCMC steps discarded as burn-in.-cup <float>, Probability of updating the CRP concentration parameter.-eup <float>, Probability to do update the error rates in An MCMC step.-smp <float>, Probability to do a split/merge step instead of Gibbs sampling.-sms <int>, Number of intermediate, restricted Gibbs steps in the split-merge move.-smr <float, float>, Ratio of splits/merges in the split merge move.-e +<str>, Estimator(s) for inferrence. If more than one, seperate by space. Options = posterior|ML|MAP.-sc <flag>, If set, infer a result for each chain individually (instead of from all chains together).--seed <int>, Seed used for random number generation.
Output Arguments
-o <str>, Path to an output directory.-np <flag>, If set, no plots are generated.-v <int>, Stdout verbosity level. Options = 0|1|2.
Example data
Lets employ the toy dataset that one can find in the data folder (data.csv) to understand the functionality of the different arguments. First go to the folder and activate the environment:
cd /path/to/crp_clustering
conda activate environment_name
BnpC can run in three different settings: 1. Number of steps. Runs for the given number of MCMC steps. Arument: -s 2. Running time limit. Every MCMC the time is tracked and the method stops after the introduced time is achieved. Argument: -r 3. Lugsail for convergence diagnosis. The chain is terminated if the estimator undercuts a threshold defined by a significance level of 0.05 and a user defined float between [0,1], comparable to the half-width of the confidence interval in sample size calculation for a one sample t-test. Reasonal values = 0.1, 0.2, 0.3. Argument: -ls
The simplest way to run the BnpC is to leave every argument as default and hence only the path to the data needs to be given. In this case BnpC runs in the setting 1.
bash
python run_BnpC.py example_data/data.csv
If the error rates are known for a particular sequenced data (e.g FP = 0.0001 and FN = 0.3), one can run BnpC with fixed error rates by:
bash
python run_BnpC.py example_data/data.csv -FP 0.0001 -FN 0.3
On the other hand, if errors are not known one can leave it blank as in the first case or if there is some intuition add the mean and standard deviation priors for the method to learn them:
bash
python run_BnpC.py example_data/data.csv -FP_m 0.0001 -FN_m 0.3 -FP_sd 0.000001 -FN_sd 0.05
Additional MCMC arguments can be employed to allow faster convergence. Among other options:
- Reduce burnin to include more posterior samples in the estimation. Example: -b 0.2, discard 20 % of the total MCMC steps.
- Adapt split-merge probability to better explore the posterior landscape. Example: -smp 0.33, 1 out of every 3 steps will be a split-merge move on average.
- Adjust the Dirchlet Process alpha which accounts for the probability of starting a new cluster. Example: -dpa 10. Increasing the value, leads to a larger probability of starting a new cluster in the cell assignment step.
Owner
- Name: Computational Biology Group (CBG)
- Login: cbg-ethz
- Kind: organization
- Location: Basel, Switzerland
- Website: https://www.bsse.ethz.ch/cbg
- Twitter: cbg_ethz
- Repositories: 91
- Profile: https://github.com/cbg-ethz
Beerenwinkel Lab at ETH Zurich
GitHub Events
Total
- Watch event: 2
Last Year
- Watch event: 2
Committers
Last synced: 10 months ago
Top Committers
| Name | Commits | |
|---|---|---|
| NBMueller | n****r@w****e | 30 |
| dependabot[bot] | 4****] | 5 |
| josebonet | j****t@i****g | 2 |
| Nico Borgsmüller | n****r@b****e | 1 |
Committer Domains (Top 20 + Academic)
Issues and Pull Requests
Last synced: 10 months ago
All Time
- Total issues: 14
- Total pull requests: 18
- Average time to close issues: about 1 month
- Average time to close pull requests: 16 days
- Total issue authors: 5
- Total pull request authors: 3
- Average comments per issue: 1.93
- Average comments per pull request: 0.06
- Merged pull requests: 16
- Bot issues: 0
- Bot pull requests: 6
Past Year
- Issues: 1
- Pull requests: 1
- Average time to close issues: 10 days
- Average time to close pull requests: 23 days
- Issue authors: 1
- Pull request authors: 1
- Average comments per issue: 3.0
- Average comments per pull request: 0.0
- Merged pull requests: 1
- Bot issues: 0
- Bot pull requests: 1
Top Authors
Issue Authors
- monicaSudarsanam (6)
- jeffchen2000 (3)
- rituparna-13 (1)
- qmuuu (1)
- jpcartailler (1)
Pull Request Authors
- NBMueller (11)
- dependabot[bot] (9)
- pepebonet (1)
Top Labels
Issue Labels
Pull Request Labels
Dependencies
- Bottleneck ==1.3.1
- PyYAML ==5.4
- cycler ==0.10.0
- graphviz ==0.13.2
- joblib ==0.14.1
- kiwisolver ==1.1.0
- matplotlib ==3.1.2
- numpy ==1.22
- pandas ==0.25.3
- psutil ==5.6.7
- pycosat ==0.6.3
- pyparsing ==2.4.6
- python-dateutil ==2.8.1
- pytz ==2019.3
- ruamel-yaml ==0.15.46
- scikit-learn ==0.22.1
- scipy ==1.4.1
- seaborn ==0.9.0
- six ==1.13.0