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.2.1.9.dev202510091759295983-cp310-abi3-win_amd64.whl (3.0 MB view details)

Uploaded CPython 3.10+Windows x86-64

pyagrum_nightly-2.2.1.9.dev202510091759295983-cp310-abi3-macosx_11_0_arm64.whl (4.1 MB view details)

Uploaded CPython 3.10+macOS 11.0+ ARM64

pyagrum_nightly-2.2.1.9.dev202510091759295983-cp310-abi3-macosx_10_15_x86_64.whl (4.7 MB view details)

Uploaded CPython 3.10+macOS 10.15+ x86-64

File details

Details for the file pyagrum_nightly-2.2.1.9.dev202510091759295983-cp310-abi3-win_amd64.whl.

File metadata

File hashes

Hashes for pyagrum_nightly-2.2.1.9.dev202510091759295983-cp310-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 ddad9d6dfcd5ca56804f323424616a9e763d490b3fad4fe8e9e29626a21e4afa
MD5 4ce6aec160d327304e15ceb9464638b3
BLAKE2b-256 89c8b059ce7604722c6d01a2d5e37f5e0ee965a5b4b0201836080ef9490683dd

See more details on using hashes here.

File details

Details for the file pyagrum_nightly-2.2.1.9.dev202510091759295983-cp310-abi3-manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for pyagrum_nightly-2.2.1.9.dev202510091759295983-cp310-abi3-manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 05fed7946a50c1e1a825fcb003abdf01d3d17ca9a34d9163b70dc1e1b62c9711
MD5 6bd260932a8cd00cf88362ae2623095a
BLAKE2b-256 935df2d112d16fc27c5d5fdffd8382519db6a5b33e8be0e377d4fd0d809759e1

See more details on using hashes here.

File details

Details for the file pyagrum_nightly-2.2.1.9.dev202510091759295983-cp310-abi3-manylinux2014_aarch64.whl.

File metadata

File hashes

Hashes for pyagrum_nightly-2.2.1.9.dev202510091759295983-cp310-abi3-manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 f0e7fb482adf9a121ba9d340a0b0d9650e243f63f356169ea4debd8b19abf0d1
MD5 93e19ea0c778122eba851632bc35add4
BLAKE2b-256 d95a5c27fae8a6b67a2b5b086e41e7a7de9ebbb4e487e39629648adeed77806e

See more details on using hashes here.

File details

Details for the file pyagrum_nightly-2.2.1.9.dev202510091759295983-cp310-abi3-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for pyagrum_nightly-2.2.1.9.dev202510091759295983-cp310-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 46aff1bf8432072255bd9a65d619a9fde70e2ecf09e3f5373702d703f4271063
MD5 cafe8a80bdba28b56dd6dc8c57b69a7b
BLAKE2b-256 cbc1a328d9f5dba6ff63cc77372d8b8c7721cd679303c9ad62d362f962061bbf

See more details on using hashes here.

File details

Details for the file pyagrum_nightly-2.2.1.9.dev202510091759295983-cp310-abi3-macosx_10_15_x86_64.whl.

File metadata

File hashes

Hashes for pyagrum_nightly-2.2.1.9.dev202510091759295983-cp310-abi3-macosx_10_15_x86_64.whl
Algorithm Hash digest
SHA256 399b1c3149210fcc54403b828c0aba9d5ab6e4577a05b0dca62880993480e966
MD5 e9baeaf77f6899c2416ec8df3227c084
BLAKE2b-256 493ea357e598762a7427020fd8dcc1114faac11bc61f600931a001583a5fb515

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