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_nightly-2.3.2.9.dev202605031770834561-cp310-abi3-win_amd64.whl (3.1 MB view details)

Uploaded CPython 3.10+Windows x86-64

pyagrum_nightly-2.3.2.9.dev202605031770834561-cp310-abi3-macosx_11_0_arm64.whl (4.3 MB view details)

Uploaded CPython 3.10+macOS 11.0+ ARM64

pyagrum_nightly-2.3.2.9.dev202605031770834561-cp310-abi3-macosx_10_15_x86_64.whl (4.9 MB view details)

Uploaded CPython 3.10+macOS 10.15+ x86-64

File details

Details for the file pyagrum_nightly-2.3.2.9.dev202605031770834561-cp310-abi3-win_amd64.whl.

File metadata

File hashes

Hashes for pyagrum_nightly-2.3.2.9.dev202605031770834561-cp310-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 dc8c81f8af9975a8c32cfc20c17dc751656471a6296ae8136e2819045c8346f9
MD5 efffcfdb5369db39ecf5d64d68a239ab
BLAKE2b-256 32479cf5c74cd6be99e9195202688c01f62e94641839174cff0ab857e99a8bc6

See more details on using hashes here.

File details

Details for the file pyagrum_nightly-2.3.2.9.dev202605031770834561-cp310-abi3-manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for pyagrum_nightly-2.3.2.9.dev202605031770834561-cp310-abi3-manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 8544b0c1d2cb9807f48d9e28a2b2d9b9b991c611dad7389e1469fa8eabbdc512
MD5 0ced946c2140bc22b8133b99994541ac
BLAKE2b-256 29fb1100f926396ce7deb2571bdc28e38b8c68c46c06cbf9599159a74089c0e7

See more details on using hashes here.

File details

Details for the file pyagrum_nightly-2.3.2.9.dev202605031770834561-cp310-abi3-manylinux2014_aarch64.whl.

File metadata

File hashes

Hashes for pyagrum_nightly-2.3.2.9.dev202605031770834561-cp310-abi3-manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 3d097f1890f5e626a52a7ceac4d165ca2adfe1cee15b81ce8bfb12ee364ad3ca
MD5 8dedb7523f97011f7b8cf7c1b82dab4f
BLAKE2b-256 dbbd769bafac4e3d1f13512b15c67cacf9b3306916ddc56ea6bbfb7fa85932a0

See more details on using hashes here.

File details

Details for the file pyagrum_nightly-2.3.2.9.dev202605031770834561-cp310-abi3-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for pyagrum_nightly-2.3.2.9.dev202605031770834561-cp310-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 22da832feaefbd94b5e45e743396b36e2a714bd6be2187bc2ce14bb14100cb81
MD5 c1cf35aaea300c8cd9621c1daab11e3b
BLAKE2b-256 2e40e7447692035ce00ce6c5b35381f470d022001033cb7990f24a62b48d213e

See more details on using hashes here.

File details

Details for the file pyagrum_nightly-2.3.2.9.dev202605031770834561-cp310-abi3-macosx_10_15_x86_64.whl.

File metadata

File hashes

Hashes for pyagrum_nightly-2.3.2.9.dev202605031770834561-cp310-abi3-macosx_10_15_x86_64.whl
Algorithm Hash digest
SHA256 1bf1f19020b84d131ca3472b03e62af54ec042da4e50b7d4d527c2a6c9831325
MD5 ad613c782f19cb022a7cf5de3d5ebf8c
BLAKE2b-256 20c255c807daf5d7d4b2e090a7988d046194334c996fbdb44ca65824b3ec0586

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