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

Uploaded CPython 3.10+Windows x86-64

pyagrum_nightly-2.2.1.9.dev202509101756303741-cp310-abi3-macosx_11_0_arm64.whl (4.3 MB view details)

Uploaded CPython 3.10+macOS 11.0+ ARM64

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

File metadata

File hashes

Hashes for pyagrum_nightly-2.2.1.9.dev202509101756303741-cp310-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 e25495a7f26c40c7cff7328e1b72be674c88b521dae9ad97206280b4e6c767b4
MD5 98dc426c6b79cb867c4fce78a9b855f9
BLAKE2b-256 9dcbc00d327484259f9ed7554ca91dcc636254038d9cda2c5b12871807dcca0c

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyagrum_nightly-2.2.1.9.dev202509101756303741-cp310-abi3-manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 32aff8ac29b0ba17abdc7ff78a899c6b9b0c2046e703a3159f3bea5eb6ec6af7
MD5 7b6a11337cb62fb0313861e7f8fbcede
BLAKE2b-256 0bf85afedbdee1357932ffb58dc0f56b10c06f5c0e26c71a3c44a194b770bb78

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyagrum_nightly-2.2.1.9.dev202509101756303741-cp310-abi3-manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 5ca6404ac0e793a86cfaee8255cc370a0f341278714ba2d4d9b234d503fe0f46
MD5 bc46ab3e099c6266bcaa478aea0fd470
BLAKE2b-256 48485b2955f0518b7b347ac290dd75316abd1b5e930d0191a22f11bb290d35ca

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyagrum_nightly-2.2.1.9.dev202509101756303741-cp310-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 738f09e4d4f157e467f7df65046227bb32b3f2b01194059246e794b801e11f4e
MD5 7c7ea3615812740bcfaa654d1032de6c
BLAKE2b-256 800941f6e6cb5db4a0e81b0129e0311862cfdaf08bd401e2dffee6982d5f9eb0

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for pyagrum_nightly-2.2.1.9.dev202509101756303741-cp310-abi3-macosx_10_15_x86_64.whl
Algorithm Hash digest
SHA256 21ce8364e57636ade7124790b9c728bcc1fbdb43c1ad878933a53b3437ef2872
MD5 a6c01a2d8a3893c4999b3acfeb3b4291
BLAKE2b-256 b5643568aed13e438160551f65596a482a1b0e17c72b8b14c99308e3ac0c90b2

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