0.2.0
This is a second "major" release of AEON.py. It adds some of the latest functionality from the internal biodivine libraries (although, still not everything is covered). It also improves significantly on several issues of the original 0.1.0
version, which unfortunately means a few breaking changes in the public API. However, we are getting closer to the stable 1.0.0
release, hopefully later this year, which will then have full ongoing backwards compatibility support and proper API documentation. It is almost certain that there will still be further breaking changes between 0.2.0
and 1.0.0
(e.g. we plan to subdivide AEON.py into proper modules), but many of the new APIs introduced in this version can be considered essentially final.
Key highlights:
- Added support for faster fixed point computation (
FixedPoints
class). - Added support for projected enumeration of symbolic sets (
SymbolicProjection
class). - Much better coverage of low-level symbolic operations provided by
lib-bdd
. - Many new "static analysis" methods like feedback vertex set, independent cycles computation, regulatory graph inference, input inlining, etc.
Complete list of changes (compared to 0.1.1
, some of this was previously available as the 0.2.0aX
pre-releases):
- AEON.py now comes with a bundled Z3 solver used for some internal features.
- Upgraded to Python
3.11
and Rust1.69.0
, both on PyPI and Conda. - There is now a more complete set of available workflows and case studies in the
example
directory. - Changes in
bdd
implementation:- [breaking] Methods implementing logical operators are now all prefixed with
l_*
to avoid clashing with Python keywords. Furthermore, logical operations accept an optionallimit
argument which allows them to fail when the result is too large. - [breaking] Replaced
Bdd.var_project
andBdd.project
with a single polymorphicBdd.project_exists
method. - [breaking] Replaced
Bdd.var_pick
andBdd.pick
with a single polymorphicBdd.pick
method. - [breaking] Replaced
Bdd.var_select
andBdd.select
with a single polymorphicBdd.select
method. - [breaking] Replaced
Bdd.sat_witness
with a richer API for extracting satisfying valuations (see below). - Added a
BddValuation
class. This is essentially a mutable fixed-length list indexed byBddVariable
objects. This replaces normal "generic" lists in many places as the "default" argument type. However, whenever possible, the API also accepts normal lists and performs the conversion automatically. - Added a
BddPartialValuation
class. This is essentially a mutable dictionary indexed byBddVariable
objects which returnsNone
instead of throwing aKeyError
for missing values. Similar toBddValuation
, this also now appears in many method types, but the API should be also fine with plain dictionaries. - Added actual API to the
BooleanExpression
class. Now we can manipulate Boolean expressions in Python, but there is a lot of memory copying involved. There is a plan how to fix this in the1.0
version though, so stay tuned :) - Added a
Bdd.sem_eq
semantic equality method (default==
implementation only supports structural equality). - Added a
Bdd.pick_random
method: similar toBdd.pick
, but selects a random valuation. Can be parametrized with a seed. - Added a
Bdd.project_for_all
method: similar toproject_exists
, but universal instead of existential quantification. - Added a
Bdd.restrict
operator: a combination ofselect
andproject_exists
. - Added
Bdd.support_set
to retrieve the variables in the BDD andBdd.size_per_variable
to retrieve the number of nodes that utilize individual variables. - Added
Bdd.valuation_witness
andBdd.valuation_random
as well asBdd.clause_witness
andBdd.clause_random
which allow picking elements (either full valuations or partial "cubes"/"clauses"). - Added
Bdd.valuation_iterator
andBdd.clause_iterator
which are actual iterable objects through which we can explore all satisfying valuations of a BDD. These are implemented throughBddValuationIterator
andBddClauseIterator
classes. - Added
BddVariableSet.mk_valuation
which "materializes" aBddValuation
(or a compatible type) into a singletonBdd
(this was already supported forBddPartialValuation
). Bdd.to_dot
now optionally supportszero-pruned
argument (defaultTrue
matches the previous behavior).
- [breaking] Methods implementing logical operators are now all prefixed with
- Changes in the
param-bn
implementation:- [breaking] A
BooleanNetwork
now inherits from aRegulatoryNetwork
. This means that all methods available on theRegulatoryNetwork
are available on aBooleanNetwork
as well, typically with no performance impact. As such, some of the original re-implementations were removed. - [breaking] Instead of using just strings, there is now a
FnUpdate
type which represents a single update function that can be queried and manipulated similar to theBooleanExpression
. In general, the API should still accept a string wherever possible, but some new methods only acceptFnUpdate
. - [breaking]
RegulatoryGraph.targets
,RegulatoryGraph.regulators
,RegulatoryGraph.targets_transitive
andRegulatoryGraph.regulators_transitive
now return aset
instead of alist
. - [breaking]
RegulatoryGraph.components
replaced with a betterRegulatoryGraph.strongly_connected_components
implementation. - Added a
ModelAnnotation
class which can extract annotation data from.aeon
files. - Added a new
SymbolicContext
class which provides mostly the same low-level functionality as its Rust counterpart. - Added a
SymbolicProjection
class which allows iteration over projected elements of a symbolic set (both the state data as well as the "mateiralized" update functions). - Classes
BooleanNetwork
andRegulatoryGraph
can now be "pickled". Later, this should extend to more classes, but it will require careful consideration for things like the symbolic sets (ideally, we should just make everything serializable by default, but that will need a bit more work). VariableId
andParameterId
now support explicit conversions from/to numbers (from_index
andto_index
).- Added
RegulatoryNetwork.shortest_cycle
,RegulatoryNetwork.feedback_vertex_set
andRegulatoryNetwork.independent_cycles
that provide naive algorithms for exploring the network structure. - Added
BooleanNetwork.num_implicit_parameters
andBooleanNetwork.implicit_parameters
to list variables with no update functions. - Added
BooleanNetwork.parameter_appears_in
to track which functions contain a specific parameter. - Added
BooleanNetwork.infer_regulatory_graph
(creates a new regulatory graph which is compliant with the current update functions) andBooleanNetwork.inline_inputs
(turns input nodes into explicit parameters). - Added a
FixedPoints
class which implements various algorithms for quickly computing fixed points of a symbolic state transition graph. Right now, some of the methods return lists instead of iterators, which will be fixed in the1.0
release. - Added
GraphColoredVertices.is_subspace
,GraphColoredVertices.is_singleton
,GraphColoredVertices.fix_network_variable
andGraphColoredVertices.restrict_network_variable
. Also added aGraphColoredVertices.new
which constructs the set from a "raw" Bdd object. Similar methods were added toGraphColors
andGraphVertices
. GraphVertices.list_vertices
replaced withGraphVertices.iterator
(and native__iter__
method), which actually iterates through the members of the set instead of listing them directly.- Added several methods for creating and inspecting symbolic sets:
SymbolicAsyncGraph.fix_variable_in_vertices
,SymbolicAsyncGraph.wrap_in_subspace
,SymbolicAsyncGraph.wrap_in_symbolic_subspace
,SymbolicAsyncGraph.fix_subspace
,SymbolicAsyncGraph.fix_subnetwork_colors
, andSymbolicAsyncGraph.is_trap_set
. - Added several naive fixed-point algorithms for exploring the symbolic graph:
SymbolicAsyncGraph.reach_forward
,SymbolicAsyncGraph.reach_backward
,SymbolicAsyncGraph.trap_forward
, andSymbolicAsyncGraph.trap_backward
. BooleanNetwork.to_bnet
now has an optionalrename_if_necessary
argument (defaultFalse
, i.e. previous behavior).
- [breaking] A
- Other:
find_attractors
can be now optionally restricted to a specific subset of states.
Internal changes:
- There is now a
Wrapper
derivation macro which automatically implementsFrom
andAsNative
conversions between Rust types and their Python wrapper types. In the future, we might be able to also generate other Python-related functionality, such as a workingEq
andOrd
translation. - Upgraded to
maturin
version1.0.1
for hopefully fewer CI breaking changes in the future and added a custommanylinux
Docker image for linux packaging.