Skip to main content

causal-learn Python Package

Project description

causal-learn: Causal Discovery in Python

Causal-learn (documentation, paper) is a python package for causal discovery that implements both classical and state-of-the-art causal discovery algorithms, which is a Python translation and extension of Tetrad.

The package is actively being developed. Feedbacks (issues, suggestions, etc.) are highly encouraged.

Package Overview

Our causal-learn implements methods for causal discovery:

  • Constraint-based causal discovery methods.
  • Score-based causal discovery methods.
  • Causal discovery methods based on constrained functional causal models.
  • Hidden causal representation learning.
  • Permutation-based causal discovery methods.
  • Granger causality.
  • Multiple utilities for building your own method, such as independence tests, score functions, graph operations, and evaluations.

Install

Causal-learn needs the following packages to be installed beforehand:

  • python 3 (>=3.7)
  • numpy
  • networkx
  • pandas
  • scipy
  • scikit-learn
  • statsmodels
  • pydot

(For visualization)

  • matplotlib
  • graphviz

To use causal-learn, we could install it using pip:

pip install causal-learn

Documentation

Please kindly refer to causal-learn Doc for detailed tutorials and usages.

Running examples

For search methods in causal discovery, there are various running examples in the ‘tests’ directory, such as TestPC.py and TestGES.py.

For the implemented modules, such as (conditional) independent test methods, we provide unit tests for the convenience of developing your own methods.

Benchmarks

For the convenience of our community, CMU-CLeaR group maintains a list of benchmark datasets including real-world scenarios and various learning tasks. Please refer to the following links:

Please feel free to let us know if you have any recommendation regarding causal datasets with high-quality. We are grateful for any effort that benefits the development of causality community.

Contribution

Please feel free to open an issue if you find anything unexpected. And please create pull requests, perhaps after passing unittests in 'tests/', if you would like to contribute to causal-learn. We are always targeting to make our community better!

Running Tetrad in Python

Although causal-learn provides python implementations for some causal discovery algorithms, there are currently a lot more in the classical Java-based Tetrad program. For users who would like to incorporate arbitrary Java code in Tetrad as part of a Python workflow, we strongly recommend considering py-tetrad. Here is a list of reusable examples of how to painlessly benefit from the most comprehensive Tetrad Java codebase.

Citation

Please cite as:

@article{zheng2024causal,
  title={Causal-learn: Causal discovery in python},
  author={Zheng, Yujia and Huang, Biwei and Chen, Wei and Ramsey, Joseph and Gong, Mingming and Cai, Ruichu and Shimizu, Shohei and Spirtes, Peter and Zhang, Kun},
  journal={Journal of Machine Learning Research},
  volume={25},
  number={60},
  pages={1--8},
  year={2024}
}

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

causal_learn-0.1.4.1.tar.gz (152.9 kB view details)

Uploaded Source

Built Distribution

causal_learn-0.1.4.1-py3-none-any.whl (192.6 kB view details)

Uploaded Python 3

File details

Details for the file causal_learn-0.1.4.1.tar.gz.

File metadata

  • Download URL: causal_learn-0.1.4.1.tar.gz
  • Upload date:
  • Size: 152.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.11.7

File hashes

Hashes for causal_learn-0.1.4.1.tar.gz
Algorithm Hash digest
SHA256 134128f707fec11c698f732e89ad1d58154c8ebf8d8cc189f2a1c6dca4a68b31
MD5 bd0cc7166d53abcec53b25905711bb68
BLAKE2b-256 00566e0cbeaf2f9369eff9ad4f7a763104ebe40576b7ca3ff24497199dd5ba60

See more details on using hashes here.

File details

Details for the file causal_learn-0.1.4.1-py3-none-any.whl.

File metadata

File hashes

Hashes for causal_learn-0.1.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 c82afc0602f6385a48bd72535d75cabb581aa190e75bd0a42f6be5d001bc68cd
MD5 0dd1fee6d6d1839de43fc30df84534c1
BLAKE2b-256 62268aa83c1029bf1d84e29c07fe7b061fdc3460439674beed6653028c2fc33c

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page