Skip to main content

No project description provided

Project description

pyvfg

This package declares and defines a class VFG that represents a Verses Factor Graph. It supports python versions 3.11, 3.12, and 3.13. The wide version support is necessary so that downstream clients, such as the SDK, can continue to support the python versions required by popular ML packages.

What is a VFG?

VFGs, or Verses Factor Graphs, are a data structure that represents a probabilistic model. They are used to represent the relationships between variables in a model, and can be used to perform inference and learning. This is a generic structure that can be used to represent a variety of models, including Bayesian networks, Markov random fields, and partially-observable Markov decision processes (POMDPs).

Versioning

VFG is versioned from 0.2.0 to 0.5.0. These are, in general, backwards-compatible -- calling pyvfg.vfg_upgrade() on a 0.2.0 VFG will produce a 0.5.0 VFG. However, one exception os <= 0.4.0 POMDPs to 0.5.0 POMDPs. Please see below for how to upgrade the POMDPs.

Upgrading POMDPs from 0.4.0 to 0.5.0

VFG 0.5.0 introduces numeric validation for factor values. This means that POMDPs that use "categorical" for their reward factor will fail validation. As such, the model will need to be updated.

To upgrade a POMDP from 0.4.0 to 0.5.0, you will need to change the reward factor from "categorical" to "logits".

Model Description

Currently supported model types are Bayesian Networks (BNs), Markov Random Fields (MRFs), and Partially-Observable Markov Decision Processes (POMDPs).

Version

Determines how the model will be parsed, for backwards compatability when using durable storage. Will be output as 0.5.0.

Variables

Variables are the nodes in the VFG. They represent the states, actions, and observations in the model.

Variable Role

Role Model Type Description
null BN, MRF, POMDP a "default" variable without a role.
control_state POMDP The state of the system. This is the variable that is being controlled.
latent BN, MRF A variable known to be present in the system, but cannot be observed.

Factors

Factors represent the relations between nodes.

Possible Distribution Types

Distribution Model type Description Example Field
categorical BN, MRF, POMDP A categorical distribution over a set of variables, for joint probability. Joint probability of a single variable is simply the probability of that variable. position with role initial_state_prior
categorical_conditional BN, MRF, POMDP A categorical distribution conditioned on a set of variables. ["A", "B", "C"] means P(A|B,C). observation|position
logits POMDP A distribution as the input to a softmax, usually for intermediate or reward states. position with role preference
potential MRF A non-normalized probability distribution. position with role potential

Counts

The counts are raw, observed counts for input variables, and are used to scale for continuous learning. This must be kept in sync with values (which can be done by setting the values field to the normalized counts).

Values

The values are scaled, probabilistic values, and are used for inference. This must be kept in sync with counts, if counts are present for the same factor.

Factor Role

Role Model Type Description
null BN, MRF, POMDP A "default" factor without a role.
transition MRF, POMDP The transition factor. This is a factor that represents the transition probabilities between states.
reward POMDP The reward factor. This is a factor that represents the reward probabilities.
initial_state_prior POMDP The initial state prior factor. This is a factor that represents the initial state probabilities.
preference POMDP The preference factor. This is a factor that represents the preference probabilities.
belief MRF The potential factor. This is a factor that represents the potential probabilities.
observation POMDP The observation factor. This is a factor that represents the observation probabilities.

Metadata

Stores information about the model, as distinct from the graph. These are user-defined and will be parroted, without affecting output.

Model Version

The version of the model, not the VFG. User-defined. No versioning scheme is imposed.

Model type

Informational only. One of "bayesian_network", "markov_random_field", "pomdp", or the generic "factor_graph". This is not used in any parsers; model type is used implicitly.

Description

Free-form text field describing information and the purpose of the model.

Visualization Metadata

Will be parroted, and never parsed. May be removed in the future.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

pyvfg-7.0.2.tar.gz (29.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pyvfg-7.0.2-py3-none-any.whl (19.7 kB view details)

Uploaded Python 3

File details

Details for the file pyvfg-7.0.2.tar.gz.

File metadata

  • Download URL: pyvfg-7.0.2.tar.gz
  • Upload date:
  • Size: 29.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.7.3

File hashes

Hashes for pyvfg-7.0.2.tar.gz
Algorithm Hash digest
SHA256 b612ad6a622c86468ba8c9617f9543c49ae3b5b3c51a6a6f95b6dbd2085b6c8a
MD5 96fc1624e751c25147c0d2677908f96f
BLAKE2b-256 d246e38118c5e0e4d49950f613f50a273be53cfef92541853b6c33742d3cc2fd

See more details on using hashes here.

File details

Details for the file pyvfg-7.0.2-py3-none-any.whl.

File metadata

  • Download URL: pyvfg-7.0.2-py3-none-any.whl
  • Upload date:
  • Size: 19.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.7.3

File hashes

Hashes for pyvfg-7.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 83a2c1b8f90558a98d7202171b3c132a747af5a717d6bf376b154deee23e5b3e
MD5 5f8c2c5981b8929f7aba45df5d2bedb4
BLAKE2b-256 a8c1c584bd09180f6c7159c18914548f74385f901bf629264bb99fafae1de4c0

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