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

Uploaded CPython 3.10+Windows x86-64

pyagrum_nightly-2.2.1.9.dev202510051759295983-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.dev202510051759295983-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.dev202510051759295983-cp310-abi3-win_amd64.whl.

File metadata

File hashes

Hashes for pyagrum_nightly-2.2.1.9.dev202510051759295983-cp310-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 53176326244df0bab1910d87dfb3dde9438550b8327cce65f15954f7565c2377
MD5 0a364cd5184faa3f2abc2e53b3138cb3
BLAKE2b-256 5fe2834a08b6484332f37df1e41b136362628c9c636c3f5508788ade5b869490

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyagrum_nightly-2.2.1.9.dev202510051759295983-cp310-abi3-manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 274b61762b97cbd06049a730188f51c5e90c9fc4cbd0cd21cecd140b2e782132
MD5 de177c2800fcc3def2dce2b0dc7fb2b4
BLAKE2b-256 b34e203fbcb4d4fe50e2d8b60040d2591bcc6d73137d1aa1b6693090a6c54077

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyagrum_nightly-2.2.1.9.dev202510051759295983-cp310-abi3-manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 9531e67bcad205988cd736b2014f319e3f4e0429d42e08621eeffa0dbdf8070d
MD5 cee2d5dff85802f95c6b7ef288384fab
BLAKE2b-256 ba13f143df1a03367a7b9eef6cfe212e3a859a2abf3c419ba00f28bf1f6dbcc4

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyagrum_nightly-2.2.1.9.dev202510051759295983-cp310-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 1623d139ec06172e546de9f8a77f1c325e64227aaf585dc4e8f1ac4607d7c324
MD5 6e1a089d22c7f40cb3204a255d7a283b
BLAKE2b-256 bc8b3993f070ed720f05cc908afba8cae9687c0f41cdff44e1f432e89ea948d0

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyagrum_nightly-2.2.1.9.dev202510051759295983-cp310-abi3-macosx_10_15_x86_64.whl
Algorithm Hash digest
SHA256 0c277abf54ad5552d44e008529c8ca1aaeb6d7cf519dec95926ff32c3ff101d7
MD5 a4a4415be45dd6182570248ec38a2fef
BLAKE2b-256 17b7bf2180e172d9fb2122ac415405c0ca59264db8cd61a3121a30147aec7029

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