Phoenix Circuits
Phoenix is the transaction model used by Dusk, an open-source public blockchain with a UTXO-based architecture that allows for the execution of obfuscated transactions and confidential smart contracts.
This library contains the implementation of the Phoenix-circuits, to prove, in zero-knowledge, that the following conditions hold true:
- Membership: every note that is about to be spent is included in the Merkle tree of notes.
- Ownership: the sender holds the note secret key for every note that is about to be spent.
- Nullification: the nullifier is calculated correctly.
- Minting: the value commitment for the newly minted notes are computed correctly.
- Balance integrity: the sum of the values of all spent notes is equal to the sum of the values of all minted notes + the gas fee + a deposit, where a deposit refers to funds being transfered to a contract.