Skip to main content

Bayesian networks and other Probabilistic Graphical Models.

Project description

pyAgrum

pyAgrum is a scientific C++ and Python library dedicated to Bayesian Networks and other Probabilistic Graphical Models. It provides a high-level interface to the part of aGrUM allowing to create, model, learn, use, calculate with and embed Bayesian Networks and other graphical models. Some specific (python and C++) codes are added in order to simplify and extend the aGrUM API.

Important

Since pyAgrum 2.0.0, the package name follows PEP8 rules and is now pyagrum (lowercase). Please use import pyagrum instead of import pyAgrum in your code.

See the CHANGELOG for more details.

Example

import pyagrum as gum

# Creating BayesNet with 4 variables
bn=gum.BayesNet('WaterSprinkler')
print(bn)

# Adding nodes the long way
c=bn.add(gum.LabelizedVariable('c','cloudy ?',["Yes","No"]))
print(c)

# Adding nodes the short way
s, r, w = [ bn.add(name, 2) for name in "srw" ]
print (s,r,w)
print (bn)

# Addings arcs c -> s, c -> r, s -> w, r -> w
bn.addArc(c,s)
for link in [(c,r),(s,w),(r,w)]:
bn.addArc(*link)
print(bn)

# or, equivalenlty, creating the BN with 4 variables, and the arcs in one line
bn=gum.fastBN("w<-r<-c{Yes|No}->s->w")

# Filling CPTs
bn.cpt("c").fillWith([0.5,0.5])
bn.cpt("s")[0,:]=0.5 # equivalent to [0.5,0.5]
bn.cpt("s")[{"c":1}]=[0.9,0.1]
bn.cpt("w")[0,0,:] = [1, 0] # r=0,s=0
bn.cpt("w")[0,1,:] = [0.1, 0.9] # r=0,s=1
bn.cpt("w")[{"r":1,"s":0}] = [0.1, 0.9] # r=1,s=0
bn.cpt("w")[1,1,:] = [0.01, 0.99] # r=1,s=1
bn.cpt("r")[{"c":0}]=[0.8,0.2]
bn.cpt("r")[{"c":1}]=[0.2,0.8]

# Saving BN as a BIF file
gum.saveBN(bn,"WaterSprinkler.bif")

# Loading BN from a BIF file
bn2=gum.loadBN("WaterSprinkler.bif")

# Inference
ie=gum.LazyPropagation(bn)
ie.makeInference()
print (ie.posterior("w"))

# Adding hard evidence
ie.setEvidence({"s": 1, "c": 0})
ie.makeInference()
print(ie.posterior("w"))

# Adding soft and hard evidence
ie.setEvidence({"s": [0.5, 1], "c": 0})
ie.makeInference()
print(ie.posterior("w"))

LICENSE

Copyright (C) 2005-2024 by Pierre-Henri WUILLEMIN et Christophe GONZALES {prenom.nom}_at_lip6.fr

The aGrUM/pyAgrum library and all its derivatives are distributed under the dual LGPLv3+MIT license, see LICENSE.LGPL and LICENSE.MIT.

You can therefore integrate this library into your software solution but it will remain covered by either the LGPL v.3 license or the MIT license or, as aGrUM itself, by the dual LGPLv3+MIT license at your convenience. If you wish to integrate the aGrUM library into your product without being affected by this license, please contact us (info@agrum.org).

This library depends on different third-party codes. See src/aGrUM/tools/externals for specific COPYING and explicit permission of the authors, if needed.

If you use aGrUM/pyAgrum as a dependency of your own project, you are not contaminated by the GPL license of some of these third-party codes as long as you use only their aGrUM/pyAgrum interfaces and not their native interfaces.

Authors

  • Pierre-Henri Wuillemin

  • Christophe Gonzales

Maintainers

  • Lionel Torti

  • Gaspard Ducamp

Release history Release notifications | RSS feed

Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

If you're not sure about the file name format, learn more about wheel file names.

pyagrum-2.2.0-cp310-abi3-win_amd64.whl (2.9 MB view details)

Uploaded CPython 3.10+Windows x86-64

pyagrum-2.2.0-cp310-abi3-manylinux2014_x86_64.whl (6.2 MB view details)

Uploaded CPython 3.10+

pyagrum-2.2.0-cp310-abi3-manylinux2014_aarch64.whl (5.7 MB view details)

Uploaded CPython 3.10+

pyagrum-2.2.0-cp310-abi3-macosx_11_0_arm64.whl (4.3 MB view details)

Uploaded CPython 3.10+macOS 11.0+ ARM64

pyagrum-2.2.0-cp310-abi3-macosx_10_15_x86_64.whl (4.8 MB view details)

Uploaded CPython 3.10+macOS 10.15+ x86-64

File details

Details for the file pyagrum-2.2.0-cp310-abi3-win_amd64.whl.

File metadata

  • Download URL: pyagrum-2.2.0-cp310-abi3-win_amd64.whl
  • Upload date:
  • Size: 2.9 MB
  • Tags: CPython 3.10+, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.8.10

File hashes

Hashes for pyagrum-2.2.0-cp310-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 4f3dc078191124d8feef3518990919ae9616e54075d3cfad4f95380b158df820
MD5 9dd35f97e6d19a316a3b14ada4ff35e0
BLAKE2b-256 f8c5bd30a8bcd2b405b9928d71b07c92bd2372b9530e2d6534694afc1cc154de

See more details on using hashes here.

File details

Details for the file pyagrum-2.2.0-cp310-abi3-manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for pyagrum-2.2.0-cp310-abi3-manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 b6211f87b5b47c4eb67f62f4e802f76ad75a936b20ef8375c41b852ef06514ce
MD5 d505e754c605481a386e8b849e93d574
BLAKE2b-256 9f743e6a6dbd63f5e722338bfb6f084e106c2f4a2da77af55b59cf87039f3e42

See more details on using hashes here.

File details

Details for the file pyagrum-2.2.0-cp310-abi3-manylinux2014_aarch64.whl.

File metadata

File hashes

Hashes for pyagrum-2.2.0-cp310-abi3-manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 e892d1a9359dc3787553c06594ec06e875c33eeeeafbe42400da88ba2d8cea14
MD5 f413d881664dbdf18a019c33de1a211a
BLAKE2b-256 1dc95c0831da99c60c15a21b72cee000f07db1732501bc09bb63091fcd6a1fcb

See more details on using hashes here.

File details

Details for the file pyagrum-2.2.0-cp310-abi3-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for pyagrum-2.2.0-cp310-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 8f7127e84c778cd380efe367cb1245561515f0146f3fe38befc468c61ea560da
MD5 90125d01a6d6ecff0b901e0c15df731d
BLAKE2b-256 5533e4da6e82a19aca457e6be326a707c35ed7e410b2668d95dfe53dd6791ddd

See more details on using hashes here.

File details

Details for the file pyagrum-2.2.0-cp310-abi3-macosx_10_15_x86_64.whl.

File metadata

File hashes

Hashes for pyagrum-2.2.0-cp310-abi3-macosx_10_15_x86_64.whl
Algorithm Hash digest
SHA256 1ac441bf538a639a4f67ccba4673b7dcc4578f767f69db806adbf0796df03d4a
MD5 5c94162c541c5c30cb75950fc611dad3
BLAKE2b-256 c8356863e7ced29d3e3789ce818a9fde999e058c4421f4e5038bef4e4e03bde7

See more details on using hashes here.

Supported by

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