Python library for modeling DFAs, Moore Machines, and Transition Systems in JAX.
Project description
DFAx
A JAX-compatible Python implementation of a Deterministic Finite Automaton (DFA).
Installation
Install using pip.
pip install dfax
Usage
Create DFAs by specifying a start state, transitions matrix, which is max number of states by number of alphabet symbols, and the associated labels for each state.
from dfax import DFAx
dfax = DFAx(
start=0, # State referred to as 0 is the initial state
transitions=jnp.array([
[1, 2, 0, 0, 0],
[1, 1, 1, 1, 1],
[2, 2, 2, 2, 2],
]), # Max number of states is 3 and number of tokens is 5
labels=jnp.array([False, True, False]) # State labels
) # Returns a DFA
Take transitions on the DFA using a given symbol.
dfax = dfax.advance(0) # Returns the resulting DFA after reading the symbol referred to as 0
Minimize DFAs.
dfax = dfax.minimize() # Returns a canonical minimal DFA
Canonicalize DFAs by relabeling states based on a BFS search.
dfax = dfax.canonicalize() # Returns a canonical DFA
Mutate DFAs by randomly toggling entries in the transition matrix.
import jax
key = jax.random.PRNGKey(0)
dfax = dfax.mutate(key) # Returns a mutated DFA
Perform syntactic equality check between DFAs.
dfax1 == dfax2
Perform semantic equality check between DFAs.
dfax1.minimize() == dfax2.minimize()
Use DFAs as reward functions. With ternary semantics, reward is (i) +1 if the start state has label True, (ii) -1 if the start state has label False and is a sink state, and (iii) 0 otherwise. With binary semantics, 0 is returned instead of -1.
dfax.reward() # Returns a ternary reward
dfax.reward(binary=True) # Returns a binary reward
Sample from different DFA distributions: Reach samples DFAs ordering alphabet symbols, ReachAvoid samples Reach DFAs but also includes Avoid constraints, and ReachAvoidDerived samples randomly mutated Reach and ReachAvoid DFAs.
import jax
from dfax.samplers import ReachSampler, ReachAvoidSampler, RADSampler
key = jax.random.PRNGKey(0)
sampler = ReachAvoidSampler()
dfax = sampler.sample(key)
Define your own DFA samplers by overloading DFASampler .
@struct.dataclass
class MySampler(DFASampler):
@partial(jax.jit, static_argnums=(0,))
def sample(self, key: chex.PRNGKey) -> DFAx:
# Write sampling code and return sampled DFA
Visualize DFAs.
from dfax.utils import visualize
visualize(dfax)
This project is a JAX extension of dfa. Therefore, we include helper methods for translating DFAx objects to and from DFA objects.
from dfax import dfa2dfax, dfax2dfa
dfa = dfax2dfa(dfax) # Create DFA from DFAx
dfax = dfa2dfax(dfa) # Create DFAx from DFA
In progress
Currently, we are working on implementing Boolean operations on DFAx objects, e.g., conjunction, disjunction, etc. If there are other functionalities you would like to have in this package, create pull request or contact us to work together!
Project details
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 Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file dfax-0.1.8.tar.gz.
File metadata
- Download URL: dfax-0.1.8.tar.gz
- Upload date:
- Size: 127.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.5.18
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7a7f2bee57e99575eace920fb881af3e62e0071f9199b483d81037559a83197c
|
|
| MD5 |
ebdd2461200186cf37d5e23b2e0b7c0b
|
|
| BLAKE2b-256 |
64b762b27cdfcab8cc51ea5046d6e4d3858b8e002d773c111a4399a430878912
|
File details
Details for the file dfax-0.1.8-py3-none-any.whl.
File metadata
- Download URL: dfax-0.1.8-py3-none-any.whl
- Upload date:
- Size: 10.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.5.18
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f8fc186a379c4c1ecdce8df5b046b06923d16fd267f5262f67d52098f97c99e1
|
|
| MD5 |
4f314f88729466d784467ae9cf2e970c
|
|
| BLAKE2b-256 |
dee5b76d852573b8fb7d015be78af161d910f766a9994bb0a770d06eff6d299b
|