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

Uploaded CPython 3.10+Windows x86-64

pyagrum_nightly-2.3.0.9.dev202510301761586496-cp310-abi3-macosx_11_0_arm64.whl (4.2 MB view details)

Uploaded CPython 3.10+macOS 11.0+ ARM64

pyagrum_nightly-2.3.0.9.dev202510301761586496-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.3.0.9.dev202510301761586496-cp310-abi3-win_amd64.whl.

File metadata

File hashes

Hashes for pyagrum_nightly-2.3.0.9.dev202510301761586496-cp310-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 968dd5985320853ffde3c13596d600625007638e2e708f3363cb94a21e478bf2
MD5 20f6f615fba14f0dc85144764ab3db75
BLAKE2b-256 4c4a99ec7111c7f27257ee80e1ebc3374a279268c2b370d16422b91be505d425

See more details on using hashes here.

File details

Details for the file pyagrum_nightly-2.3.0.9.dev202510301761586496-cp310-abi3-manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for pyagrum_nightly-2.3.0.9.dev202510301761586496-cp310-abi3-manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 c60d2c6bc3e12de0881b570ec4097fad49e545c9e1f414615e4f89b6775e4731
MD5 381067ad9e044b2fa87df0419a6b3b2d
BLAKE2b-256 a3cea6555b022801164ca8e256927862a8be40a040a5209b8160ad91c179004a

See more details on using hashes here.

File details

Details for the file pyagrum_nightly-2.3.0.9.dev202510301761586496-cp310-abi3-manylinux2014_aarch64.whl.

File metadata

File hashes

Hashes for pyagrum_nightly-2.3.0.9.dev202510301761586496-cp310-abi3-manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 e81e64617c6748fffcf3a1aa997395311d6b1fb558e3e353fb0c2d7f983f9344
MD5 f24cb07e2d39cf9355a2eb5bd90e1183
BLAKE2b-256 3e26876c70d5c836400aaa70c8a95b3f40224cc64c9836c2fcdeadc8b4cd18a8

See more details on using hashes here.

File details

Details for the file pyagrum_nightly-2.3.0.9.dev202510301761586496-cp310-abi3-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for pyagrum_nightly-2.3.0.9.dev202510301761586496-cp310-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 931abe4a331027814885dec4cf08ec8b818a7966c256d8052fc5b421e9501930
MD5 22c011dfd0a8d5d7800444f5ef0c1a1e
BLAKE2b-256 c871bb856714a829e693cb5b4bda3415fcfb7bbf283a45d07d62148758adefb5

See more details on using hashes here.

File details

Details for the file pyagrum_nightly-2.3.0.9.dev202510301761586496-cp310-abi3-macosx_10_15_x86_64.whl.

File metadata

File hashes

Hashes for pyagrum_nightly-2.3.0.9.dev202510301761586496-cp310-abi3-macosx_10_15_x86_64.whl
Algorithm Hash digest
SHA256 a0ac7ab4a78d80a22d4828261e054e2a170e14891e0cd94e02eba09bd79fa0a6
MD5 d035a9d3e95e0793de2b0df7ebe4c695
BLAKE2b-256 f6326d78954b10b570c4c0e1d3217c68e378f3272c947554a28e97b866c9d7d0

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