unique-logic-tf: Solve simple simultaneous equations
This is a package candidate release! Here you can preview how this package release will appear once published to the main package index (which can be accomplished via the 'maintain' link below). Please note that once a package has been published to the main package index it cannot be undone! Please consult the package uploading documentation for more information.
Solve a number of equations simultaneously. This is not Computer Algebra, better think of a kind of type inference algorithm or logic programming with only one allowed solution.
Only one solution is computed. Simultaneous equations with multiple solutions are not allowed. However, variables may remain undefined. The solver may optionally check for consistency. It does not do so by default since with floating point numbers or symbolic expressions even simple rules may not be consistent.
The modules ordered with respect to abstraction level are:
UniqueLogic.ST.TF.System: Construct and solve sets of functional dependencies. Example:
assignment3 (+) a b c
meaning dependencya+b -> c
.UniqueLogic.ST.TF.Rule: Combine functional dependencies to rules that can apply in multiple directions. Example:
add a b c
means relationa+b = c
which resolves to dependenciesa+b -> c, c-a -> b, c-b -> a
. For an executable example see UniqueLogic.ST.TF.Example.Rule.UniqueLogic.ST.TF.Expression: Allows to write rules using arithmetic operators. It creates temporary variables automatically. Example:
(a+b)*c =:= d
resolves toa+b = x, x*c = d
. For an executable example see UniqueLogic.ST.TF.Example.Expression.UniqueLogic.ST.TF.System.Simple: Provides specialised functions from UniqueLogic.ST.TF.System for the case of a system without labels and consistency checks.
UniqueLogic.ST.TF.System.Label: Provides a custom constructor for variables. When creating a variable you decide whether and how an assignment to this variable shall be logged. There is an example that shows how to solve a logic system using symbolic expressions. The naming and logging allows us to observe shared intermediate results. For an executable example see UniqueLogic.ST.TF.Example.Label.
By using more sophisticated monad transformers, we can check the equations for consistency, report inconsistencies and how they arised. We demonstrate that in UniqueLogic.ST.TF.Example.Verify.
This variant of the package requires type families.
Properties
Versions | 0.4, 0.4.0.1, 0.4.1, 0.4.1.1, 0.4.1.2, 0.5, 0.5.0.1, 0.5.0.1, 0.5.0.2, 0.5.1 |
---|---|
Change log | Changes.md |
Dependencies | base (>=4 && <5), containers (>=0.4 && <0.7), data-ref (>=0.0 && <0.1), semigroups (>=0.1 && <1.0), transformers (>=0.4 && <0.6), utility-ht (>=0.0.9 && <0.1) [details] |
License | BSD-3-Clause |
Author | Henning Thielemann |
Maintainer | Henning Thielemann <haskell@henning-thielemann.de> |
Category | Logic programming |
Home page | http://hub.darcs.net/thielema/unique-logic-tf/ |
Source repo | this: darcs get http://hub.darcs.net/thielema/unique-logic-tf/ --tag 0.5.0.1 head: darcs get http://hub.darcs.net/thielema/unique-logic-tf/ |
Uploaded | by HenningThielemann at 2018-09-02T16:27:46Z |
Modules
[Index] [Quick Jump]
Downloads
- unique-logic-tf-0.5.0.1.tar.gz [browse] (Cabal source package)
- Package description (as included in the package)
Maintainer's Corner
Package maintainers
For package maintainers and hackage trustees