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

Uploaded CPython 3.10+Windows x86-64

pyagrum_nightly-2.1.1.9.dev202506141749662709-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.dev202506141749662709-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.dev202506141749662709-cp310-abi3-win_amd64.whl.

File metadata

File hashes

Hashes for pyagrum_nightly-2.1.1.9.dev202506141749662709-cp310-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 d18330cdcc6df38784a366505e38018282e1ce4ac336f394da176c863da477c2
MD5 55cbec77499b5032c0aff31bfadacbc2
BLAKE2b-256 e6b5c591d687d63bf172f8f7be883bab638cae014f3e351c24b573af916fc06b

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyagrum_nightly-2.1.1.9.dev202506141749662709-cp310-abi3-manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 05ef9077b8c03f816ebd8913e50ca521a326c90e27cba041b74511a4a6080079
MD5 b53a9ce5f53b9427858b889b48de972b
BLAKE2b-256 29912594625f928e5fddb66637d3c9c524b6acffa453626d89d097274848d471

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyagrum_nightly-2.1.1.9.dev202506141749662709-cp310-abi3-manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 f1dfd8ca27b4bc16480035c5611f858d458d4357277a5b8d6ad2bb4092e11d5a
MD5 04793285159825586b111fe78d379f10
BLAKE2b-256 354231c71fe4da621155201b4a97e3cc5710cfa96ecd409264c4496b53f694a4

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyagrum_nightly-2.1.1.9.dev202506141749662709-cp310-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 e6841fadca7ba0093caadf9d98302d6a67d9d01a5d516b249782b209953f61e3
MD5 83c6436b003812106444d0965849561d
BLAKE2b-256 5ab78a3d3f266b44dd357cd1c10070e9bcc0a35135ed6ba6a70041370a78cdf5

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyagrum_nightly-2.1.1.9.dev202506141749662709-cp310-abi3-macosx_10_13_x86_64.whl
Algorithm Hash digest
SHA256 3011301f4985ad5ba7cee747e278681b0d312525dc580c26053ac908c9169fc3
MD5 b8d5b3d2c61e5c9a1f23138ed67735ac
BLAKE2b-256 8390a5f72624b3f02a32c5354422158cfc45710142be2445f8b7fe04bb3d5fc6

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