forked from mlabs-haskell/cem-script
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
4 changed files
with
476 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,43 @@ | ||
# Constraints design | ||
|
||
## Principles | ||
|
||
* Generic compilation across: on-chain code, | ||
offchain Tx construction and indexing backend | ||
* Simple normalization and SMT conversion for: | ||
* Equivalence checking | ||
* Bi-simulation checking | ||
* Constraints determine TxIn/Outs up to UTxO coin-selection | ||
(we call it almost-determinacy) | ||
@todo #3: wording for almost-determinacy | ||
* Datum properties encoded as class types | ||
* Common on-chain optimizations are perfomed if possible | ||
* Constraints normalization, and CSE | ||
* Best error short-cutting | ||
* Common security problems prevention | ||
|
||
## Potential obstacles | ||
|
||
* Ease and optimality of backend compilation | ||
* Robustnes of SMT conversion and overall normalization | ||
* Possibility for parsing and correct offchain usage | ||
of almost-determinacy | ||
* Having enough information for Tx submit retrying strategies | ||
* Desing for using custom Datum properties is not obvious | ||
|
||
# CEM machine design | ||
|
||
As it is done on top of constraints language, | ||
all their principles and obstacles are affecting CEM as well. | ||
|
||
## Principles | ||
|
||
* State-machine is deterministic modulo coin-change | ||
* Transaction can always be parsed back into SM transitions | ||
* Potential non-deterministic on-chain optimizations | ||
should not affect this principle. | ||
|
||
## Potential obstacles | ||
|
||
* Some scripts inexpressible by such model (as it happens in PAB) | ||
* Sub-optimal code from determenistic transitions model |
Oops, something went wrong.