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

Uploaded CPython 3.10+Windows x86-64

pyagrum-2.3.0-cp310-abi3-manylinux2014_x86_64.whl (6.6 MB view details)

Uploaded CPython 3.10+

pyagrum-2.3.0-cp310-abi3-manylinux2014_aarch64.whl (6.0 MB view details)

Uploaded CPython 3.10+

pyagrum-2.3.0-cp310-abi3-macosx_11_0_arm64.whl (4.2 MB view details)

Uploaded CPython 3.10+macOS 11.0+ ARM64

pyagrum-2.3.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.3.0-cp310-abi3-win_amd64.whl.

File metadata

  • Download URL: pyagrum-2.3.0-cp310-abi3-win_amd64.whl
  • Upload date:
  • Size: 3.1 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.3.0-cp310-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 4cb87ca82fdc7a7c0b4fd035c0b661a22cf00887d2a54758e277f1e8d88176a3
MD5 09b173289a179c6fffa48bc450636396
BLAKE2b-256 84c30bb820471098c0fbe74bd561899e0105f2d562676b37fc5e5e38a6d90510

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyagrum-2.3.0-cp310-abi3-manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 aba8f230a622c8f5137a89b3e4829e72a92cb20a9cf5fb663c960d46d0f79557
MD5 c0d7f05b9c43a3e5e5047cd879fd8630
BLAKE2b-256 83c5c444bfc77c0a3f6e186d77233c38bf0c9210214e30de8a8870251284a42b

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyagrum-2.3.0-cp310-abi3-manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 5f08489e1d5f3f47832573d48a4d155059879cffd84fc5df925f00b109fd080a
MD5 0cc6f1706cd93d319111ee391a645dde
BLAKE2b-256 99065b78c66465546aeb4df6f5c55b413b757926c00dceeb598f28fe3b36bb55

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyagrum-2.3.0-cp310-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 1f14791021d81e3cfd7c24eeb99b9f76df25aeec0861d7ab48f2c757e140339e
MD5 ad66da7eb2fc3278ffe19fa486a4c234
BLAKE2b-256 a9ca7d841a9018b68cd033e7d6d8baf8e85e1a90b04f2da714009dd4e56d595b

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyagrum-2.3.0-cp310-abi3-macosx_10_15_x86_64.whl
Algorithm Hash digest
SHA256 01a38dbca822719c54fae447cb654b51b9e1e9fbf2203ad97e8543a977d81dbe
MD5 41192ca180b27a2aed80926bf84b113d
BLAKE2b-256 8957245411a552b05f8b526c1283615fb5f94b0d86668d65a6e477e006bb9848

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