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.1.1.9.dev202506161749662709-cp310-abi3-win_amd64.whl (2.9 MB view details)

Uploaded CPython 3.10+Windows x86-64

pyagrum_nightly-2.1.1.9.dev202506161749662709-cp310-abi3-macosx_11_0_arm64.whl (4.3 MB view details)

Uploaded CPython 3.10+macOS 11.0+ ARM64

pyagrum_nightly-2.1.1.9.dev202506161749662709-cp310-abi3-macosx_10_13_x86_64.whl (4.8 MB view details)

Uploaded CPython 3.10+macOS 10.13+ x86-64

File details

Details for the file pyagrum_nightly-2.1.1.9.dev202506161749662709-cp310-abi3-win_amd64.whl.

File metadata

File hashes

Hashes for pyagrum_nightly-2.1.1.9.dev202506161749662709-cp310-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 1dbb19f6eec2ee9c61247a51ecffc99492480b5d62a619dd1658a1e31535edf8
MD5 6923212a573970eec83180c4a9247d7d
BLAKE2b-256 111b5414189b0b1cb74fca0fc2223b84a79ac01544c25deb66cd20861aa848e4

See more details on using hashes here.

File details

Details for the file pyagrum_nightly-2.1.1.9.dev202506161749662709-cp310-abi3-manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for pyagrum_nightly-2.1.1.9.dev202506161749662709-cp310-abi3-manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 b27c7b62bae56fe509147b44087f2f859f7c2f6cb08539618d6d644618e2f853
MD5 d8e2550e8871656d545a71fe57882675
BLAKE2b-256 dea7cab963803528c0cb9923c040f7f1701cf349a3ce13573cc35cd10d0c4a95

See more details on using hashes here.

File details

Details for the file pyagrum_nightly-2.1.1.9.dev202506161749662709-cp310-abi3-manylinux2014_aarch64.whl.

File metadata

File hashes

Hashes for pyagrum_nightly-2.1.1.9.dev202506161749662709-cp310-abi3-manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 404b9f9867ae61f92657c0dfce920d1a747931144f340df122921e57e5527fe0
MD5 f9653057a6d28c2bde96920ada0c612f
BLAKE2b-256 102890c5509cccd3212ac87c32355cf12871f8ae82e6eb9fc34c7ff59af835bf

See more details on using hashes here.

File details

Details for the file pyagrum_nightly-2.1.1.9.dev202506161749662709-cp310-abi3-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for pyagrum_nightly-2.1.1.9.dev202506161749662709-cp310-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 724494dad35bbee30a11fc24f06756f0aea557ab01fd55c157135312a36e3b4d
MD5 83d74a8be98e5945bbf9eaaa5ad0638d
BLAKE2b-256 7212e6647ab61065a9a149e023591e9c3347f48e42e7bfac14c4916c9ff02625

See more details on using hashes here.

File details

Details for the file pyagrum_nightly-2.1.1.9.dev202506161749662709-cp310-abi3-macosx_10_13_x86_64.whl.

File metadata

File hashes

Hashes for pyagrum_nightly-2.1.1.9.dev202506161749662709-cp310-abi3-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 f3e0b5e33ec0e2874f09140c2a35d1ee49e873ca24ba3f220764e7625e4a64d2
MD5 a783ea05432700922b2a8585a1eaf6ee
BLAKE2b-256 57da7a0f98f55a39baaf3b2c63f3d00f8816149ea731259c81d4017ed529cf4a

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