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

Uploaded CPython 3.10+Windows x86-64

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

Uploaded CPython 3.10+

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

Uploaded CPython 3.10+

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

Uploaded CPython 3.10+macOS 11.0+ ARM64

pyagrum-2.3.2-cp310-abi3-macosx_10_15_x86_64.whl (4.9 MB view details)

Uploaded CPython 3.10+macOS 10.15+ x86-64

File details

Details for the file pyagrum-2.3.2-cp310-abi3-win_amd64.whl.

File metadata

  • Download URL: pyagrum-2.3.2-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.2-cp310-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 e635f27f5b3fac7d0f32f5f4c7608e994b3be9a65ff3d5f87f38696323753e16
MD5 8a7cde64facfa160e4e2cbdf6ec1cf21
BLAKE2b-256 17bb23d4fe01eb86fcdd90475d888617d1d2c42de5138208c620a279ca197556

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyagrum-2.3.2-cp310-abi3-manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 83ea5aab643fbf4da0f03df4c897d9fb0e741f4cae686d34a71920a0e403f923
MD5 2103e36427162eb3efa889c59e57f2c4
BLAKE2b-256 20a6b6fcf4368c3f7d8a856ebc66a9bb3362e20c3edda7c7498b020cd4e64e78

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyagrum-2.3.2-cp310-abi3-manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 365735722f84c05a0d2b344ac560e2faa4e50ce157449c7af5633adf3775b112
MD5 a8846d29e2b57bd0d7b34f61c4767f06
BLAKE2b-256 0dbcf78ce8f7efd0c2b770c96f901ffb009832c651b118c7349031cdf937fd56

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyagrum-2.3.2-cp310-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 eb28aa11cb690a91ba1260774f9fc9432dc3afdf0502c62a05e7958dcc35ad9f
MD5 15eae946ff1fbee3b574762b3beaf9a0
BLAKE2b-256 13947c39c6eb7cf046d11bc626bbc6ef32f63ceb9fb44d7237b8e46c16d3cc76

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyagrum-2.3.2-cp310-abi3-macosx_10_15_x86_64.whl
Algorithm Hash digest
SHA256 4ff6f445c4a4ca4b044ef68d4eaa43e9cf8a96e9715c706404cbad880c5761b4
MD5 e30c681e05d497bd9456aa7aedea46ba
BLAKE2b-256 6d535bfb2aa457a9837f201e0bf7ac218e6ec00462ee7a968b02059179d524ee

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