MintaYLu / DDN

Differential Dependency Network

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

This repository will not be updated later.

DDN 3.0

We developed an efficient and accurate differential network analysis tool – Differential Dependency Networks (DDN). DDN is capable of jointly learning sparse common and rewired network structures, which is especially useful for genomics, proteomics, and other biomedical studies. DDN 3.0 significantly improves the speed of previous versions of DDN, and is available as a Python package. This repository provides the source code and examples of using DDN.

Installation

Option 1: install into a new Conda environment using pip

One way is to install DDN into a new Conda environment. To create and activate an environment named ddn, run this:

conda create -n ddn python=3.11
conda activate ddn

Python 3.12 may have some issue with Numba in Windows.

DDN 3.0 can then be installed with the followin command.

pip install ddn3

Option 2: install into an existing Conda environment

If you want to install DDN into an existing Conda environment, it is suggested to install dependencies from Conda first.

First we need to install some common dependencies.

$ conda install -c conda-forge numpy scipy numba networkx matplotlib jupyter scipy pandas scikit-learn

Then run

pip install ddn3

Alternatively, you can clone the repository, or just download or unzip it. Then we can install DDN 3.0.

$ pip install ./

Or you may want to install it in development mode.

$ pip install -e ./

Usage

This toy example generates two random datasets, and use estimate to estimate two networks, one for each dataset.

import numpy as np
from ddn import ddn
dat1 = np.random.randn(1000, 10)
dat2 = np.random.randn(1000, 10)
networks = ddn.ddn(dat1, dat2, lambda1=0.3, lambda2=0.1)

For more details and examples, check the documentation, which includes three tutorials and the API reference. The tutorials can also be found in the docs/notebooks folder.

Tests

To run tests, go to the folder of DDN3 source code, then run pytest.

pytest tests

It will compare output of DDN with reference values. It tests DDN with various acceleration strategies.

Contributing

Please report bugs in the issues. You may also email us directly: Yizhi Wang (yzwang@vt.edu), Yingzhou Lu (lyz66@vt.edu), or Yue Wang (yuewang@vt.edu). If you are interested in adding features or fixing bug, feel free to contact us.

License

The ddn3 package is licensed under the terms of the MIT license.

Citations

[1] DDN3.0: Determining significant rewiring of biological network structure with differential dependency networks.

About

Differential Dependency Network

License:MIT License


Languages

Language:Python 100.0%