Skip to content

Commit

Permalink
deploy: 5ca6362
Browse files Browse the repository at this point in the history
  • Loading branch information
Dominik1999 committed Nov 30, 2023
1 parent 72858f4 commit e0790ec
Show file tree
Hide file tree
Showing 7 changed files with 96 additions and 78 deletions.
42 changes: 27 additions & 15 deletions architecture.html
Original file line number Diff line number Diff line change
Expand Up @@ -183,26 +183,38 @@ <h1 id="architecture"><a class="header" href="#architecture">Architecture</a></h
<ul>
<li><strong>High throughput</strong></li>
<li><strong>Privacy</strong></li>
<li><strong>Asset Safety</strong></li>
<li><strong>Asset safety</strong></li>
</ul>
<p>On Miden, developers can build dApps currently infeasible anywhere else.</p>
<h2 id="actor-model"><a class="header" href="#actor-model">Actor Model</a></h2>
<p>The <a href="https://en.wikipedia.org/wiki/Actor_model">Actor Model</a> inspires Miden to achieve concurrent and local state changes. Actors are little state machines with inboxes, meaning each actor is responsible for their state. Actors can send and receive messages to communicate with other actors. Messages can be read asynchronously.</p>
<h2 id="concepts-in-miden"><a class="header" href="#concepts-in-miden">Concepts in Miden</a></h2>
<p>There are accounts and notes which can hold assets. Accounts consume and produce notes in transactions. Transactions are account state changes of single accounts. The state model captures all individual states of all accounts and notes. Finally, the execution model describes state progress in a sequence of blocks.</p>
<h2 id="inspired-by-the-actor-model"><a class="header" href="#inspired-by-the-actor-model">Inspired by the Actor model</a></h2>
<p>The <a href="https://en.wikipedia.org/wiki/Actor_model">Actor Model</a> inspired Miden to achieve concurrent and local state changes. In the model, actors are little state machines with inboxes, meaning each actor is responsible for their own state. Actors can send and receive messages to communicate with other actors. Messages can be read asynchronously.</p>
<h2 id="core-concepts-in-miden"><a class="header" href="#core-concepts-in-miden">Core Concepts in Miden</a></h2>
<p>In Miden, there are accounts and notes which can hold assets. Accounts consume and produce notes in transactions. Transactions describe account state changes of single accounts. The state model captures all individual states of all accounts and notes. Finally, the execution model describes state progress in a sequence of blocks.</p>
<p align="center">
<img src="../diagrams/architecture/miden_architecture.gif" style="width: 80%;">
</p>
<h3 id="accounts"><a class="header" href="#accounts">Accounts</a></h3>
<p>Accounts can hold assets and define rules how those can be transferred. Accounts can represent users or autonomous smart contracts. This chapter describes the design, the storage types, and the creation of an account.</p>
<p><a href="./architecture/accounts.html">Accounts</a> can hold assets and define rules how assets can be transferred. Accounts can represent users or autonomous smart contracts. This chapter describes the design, the storage types, and the creation of an account.</p>
<h3 id="notes"><a class="header" href="#notes">Notes</a></h3>
<p>Notes are messages carrying assets that accounts can send to each other. A note stores assets and a script that defines how this note can be consumed. This chapter describes the design, the storage types, and the creation of a note.</p>
<p><a href="./architecture/notes.html">Notes</a> are messages that accounts send to each other. A note stores assets and a script that defines how this note can be consumed. This chapter describes the design, the storage types, and the creation of a note.</p>
<h3 id="assets"><a class="header" href="#assets">Assets</a></h3>
<p>Assets can be fungible and non-fungible. They are stored in the owner’s account itself or in a note. This chapter describes asset issuance, customization, and storage.</p>
<p><a href="./architecture/assets.html">Assets</a> can be fungible and non-fungible. They are stored in the owner’s account itself or in a note. This chapter describes asset issuance, customization, and storage.</p>
<h3 id="transactions"><a class="header" href="#transactions">Transactions</a></h3>
<p>Transactions describe production or consumption of notes by a single account. For every transaction there is always a STARK proof in Miden. This chapter describes the transaction design and the different transaction modes.</p>
<h3 id="state-model"><a class="header" href="#state-model">State Model</a></h3>
<p>State describes everything that is the case at a certain point in time. Individual state of accounts or notes can be stored onchain and offchain to provide privacy. This chapter describes the three different state databases in Miden.</p>
<h3 id="execution-model"><a class="header" href="#execution-model">Execution Model</a></h3>
<p>Execution describes how the state progresses - on an individual level via transactions and at the global level expressed as aggregated state updates in blocks. This chapter describes the execution model and how blocks are built.</p>

<p><a href="./architecture/transactions.html">Transactions</a> describe production and consumption of notes by a single account. Executing a transaction always results in a STARK proof. This chapter describes the transaction design and the different transaction types.</p>
<h3 id="state-model"><a class="header" href="#state-model">State model</a></h3>
<p><a href="./architecture/state.html">State</a> describes everything that is the case at a certain point in time. Individual states of accounts or notes can be stored onchain and offchain. This chapter describes the three different state databases in Miden.</p>
<h3 id="execution-model"><a class="header" href="#execution-model">Execution model</a></h3>
<p><a href="./architecture/execution.html">Execution</a> describes how the state progresses - on an individual level via transactions and at the global level expressed as aggregated state updates in blocks. This chapter describes the execution model and how blocks are built.</p>
<h1 id="architecture-tradeoffs"><a class="header" href="#architecture-tradeoffs">Architecture tradeoffs</a></h1>
<details>
<summary>Want to know more on why we designed Miden as is?</summary>
<h3 id="polygon-midens-architecture"><a class="header" href="#polygon-midens-architecture">Polygon Miden's architecture</a></h3>
<p>Polygon Miden’s architecture departs considerably from typical blockchain designs to support privacy and parallel transaction exection. In traditional blockchains state and transactions must be transparent to be verifiable. This is necessary for block production and execution. User generated zero-knowledge proofs allow state transitions, e.g. transactions, to be verifiable without being transparent. </p>
<h3 id="actor-based-execution-model"><a class="header" href="#actor-based-execution-model">Actor-based execution model</a></h3>
<p>The actor model inspires Polygon Miden’s execution model. This is a well-known design paradigm in concurrent systems. In the actor model, actors are state machines responsible for maintaining their own state. In the context of Polygon Miden, each account is an actor. Actors communicate with each other by exchanging messages asynchronously. One actor can send a message to another, but it is up to the recipient to apply the requested change to their state. </p>
<p>Polygon Miden’s architecture takes the actor model further and combines it with zero-knowledge proofs. Now, actors not only maintain and update their own state, but they can also prove the validity of their own state transitions to the rest of the network. This ability to independently prove state transitions enables local smart contract execution, private smart contracts, and much more. And it is quite unique in the rollup space. Normally only centralized entities - sequencer or prover - create zero-knowledge proofs, not the users. </p>
<h3 id="hybrid-state-model"><a class="header" href="#hybrid-state-model">Hybrid state model</a></h3>
<p>The actor-based execution model requires a radically different approach to recording the system's state. Actors and the messages they exchange must be treated as first-class citizens. Polygon Miden addresses this by combining the state models of account-based systems like Ethereum and UTXO-based systems like Bitcoin and Zcash.</p>
</details>
</main>

<nav class="nav-wrapper" aria-label="Page navigation">
Expand Down
43 changes: 20 additions & 23 deletions architecture/accounts.html
Original file line number Diff line number Diff line change
Expand Up @@ -182,33 +182,22 @@ <h1 id="accounts"><a class="header" href="#accounts">Accounts</a></h1>
<h2 id="account-design"><a class="header" href="#account-design">Account Design</a></h2>
<p>The diagram below illustrates basic components of an account. In Miden every account is a smart contract.</p>
<p align="center">
<img src="../diagrams/architecture/account/Account_Definition.png">
<img src="../diagrams/architecture/account/Account_Definition.png" style="width: 25%;">
</p>
<p>In the above picture, you can see:</p>
<ul>
<li><strong>Account ID →</strong> a unique identifier of an account which does not change throughout its lifetime</li>
<li><strong>Storage →</strong> a user-defined data which can be stored in an account</li>
<li><strong>Nonce →</strong> a counter which must be incremented whenever account state changes</li>
<li><strong>Storage →</strong> user-defined data which can be stored in an account</li>
<li><strong>Nonce →</strong> a counter which must be incremented whenever the account state changes</li>
<li><strong>Vault →</strong> a collection of assets stored in an account</li>
<li><strong>Code →</strong> a collection of functions which define an external interface for an account</li>
<li><strong>Code →</strong> a collection of functions which define the external interface for an account</li>
</ul>
<h3 id="account-id"><a class="header" href="#account-id">Account ID</a></h3>
<p>~63 bits (1 Felt) long identifier for the account. The first three significant bits specify its type and the <a href="https://0xpolygonmiden.github.io/miden-base/architecture/accounts.html#account-storage-modes">storage mode</a>. There are four types of accounts in Miden:</p>
<div class="table-wrapper"><table><thead><tr><th></th><th>Regular updatable account</th><th>Regular immutable account</th><th>Faucet for fungible assets</th><th>Faucet for non-fungible assets</th></tr></thead><tbody>
<tr><td><strong>Description</strong></td><td>Will be used by most users for a wallet. Code specification and changes possible.</td><td>Will be used by most smart contracts. Once deployed code cannot be changed</td><td>Users can issue fungible assets and customize them.</td><td>Users can issue non-fungible assets and customize them.</td></tr>
<tr><td><strong>Code updatability</strong></td><td>yes</td><td>no</td><td>no</td><td>no</td></tr>
<tr><td><strong>Most significant bits</strong></td><td><code>00</code></td><td><code>01</code></td><td><code>10</code></td><td><code>11</code></td></tr>
</tbody></table>
</div>
<h4 id="example-account-id-big-endian"><a class="header" href="#example-account-id-big-endian">Example account ID (big-endian)</a></h4>
<p align="center">
<img src="../diagrams/architecture/account/Account_ID.png">
</p>
<p><em>Note: Miden uses little-endian by default, but big_endian for better readability in the picture above.</em></p>
<p>~63 bits (1 field element) long identifier for the account. The four most significant bits specify its <a href="https://0xpolygonmiden.github.io/miden-base/architecture/accounts.html#account-types">account type</a> - regular, immutable, faucet - and the <a href="https://0xpolygonmiden.github.io/miden-base/architecture/accounts.html#account-storage-modes">storage mode</a> - public or private. </p>
<h3 id="account-storage"><a class="header" href="#account-storage">Account Storage</a></h3>
<p>User-defined data that can be stored in an account. <code>AccountStorage</code> is composed of two components.</p>
<p>Storage for user-defined data. <code>AccountStorage</code> is composed of two components.</p>
<p>The first component is a simple sparse Merkle tree of depth <code>8</code> which is index addressable. This provides the user with <code>256</code> <code>Word</code> slots.</p>
<p>Users requiring additional storage can use the second component a <code>MerkleStore</code>. It allows users to store any Merkle structures they need. The root of the Merkle structure can be stored as a leaf in the simple sparse Merkle tree. When <code>AccountStorage</code> is serialized it will check to see if any of the leafs in the simple sparse Merkle tree are Merkle roots of other Merkle structures. If any Merkle roots are found then the Merkle structures will be persisted in the <code>AccountStorage</code> <code>MerkleStore</code>.</p>
<p>Users requiring additional storage can use the second component a <code>MerkleStore</code>. It allows users to store any Merkle structures they need. The root of the Merkle structure can be stored as a leaf in a simple sparse Merkle tree. When <code>AccountStorage</code> is serialized it will check if any of the leafs in the simple sparse Merkle tree are Merkle roots of other Merkle structures. If any Merkle roots are found then the Merkle structures will be persisted in the <code>AccountStorage</code> <code>MerkleStore</code>.</p>
<h3 id="nonce"><a class="header" href="#nonce">Nonce</a></h3>
<p>Counter which must be incremented whenever the account state changes. Nonce values must be strictly monotonically increasing and can be incremented by any value smaller than 2^{32} for every account update.</p>
<h3 id="vault"><a class="header" href="#vault">Vault</a></h3>
Expand All @@ -226,8 +215,8 @@ <h3 id="vault"><a class="header" href="#vault">Vault</a></h3>
<h3 id="code"><a class="header" href="#code">Code</a></h3>
<p>Interface for accounts. In Miden every account is a smart contract. It has an interface that exposes functions that can be called by note scripts. Functions exposed by the account have the following properties:</p>
<ul>
<li>Functions are actually roots of <a href="https://0xpolygonmiden.github.io/miden-vm/user_docs/assembly/main.html">Miden program MASTs</a> (i.e., 32-byte hash). Thus, function identifier is a commitment to the code which is executed when a function is invoked.</li>
<li>Only account functions have mutable access to an account's storage and vault. Therefore, the only way to modify an account's internal state is through one of account's functions.</li>
<li>Functions are actually roots of <a href="https://0xpolygonmiden.github.io/miden-vm/user_docs/assembly/main.html">Miden program MASTs</a> (i.e., a 32-byte hash). Thus, function identifier is a commitment to the code which is executed when a function is invoked.</li>
<li>Only account functions have mutable access to an account's storage and vault. Therefore, the only way to modify an account's internal state is through one of the account's functions.</li>
<li>Account functions can take parameters and can create new notes.</li>
</ul>
<p><em>Note: Since code in Miden is expresed as MAST, every function is a commitment to the underlying code. The code cannot change unnoticed to the user because its hash would change. Behind any MAST root there can only be <code>256</code> functions</em></p>
Expand All @@ -240,15 +229,23 @@ <h2 id="account-creation"><a class="header" href="#account-creation">Account cre
<li>Alice shares the new Account ID to Bob (eg. when Alice wants to receive funds)</li>
<li>Bob executes a transaction and creates a note that contains an asset for Alice</li>
<li>Alice consumes Bob's note to receive the asset in a transaction</li>
<li>Depending on the account storage mode (private vs. public) and transaction type (local vs. network) the Operator receives new Account ID eventually and - if transaction is correct - adds the ID to the Account DB</li>
<li>Depending on the account storage mode (private vs. public) and transaction type (local vs. network) the Operator receives the new Account ID eventually and - if the transaction is correct - adds the ID to the Account DB</li>
</ul>
<h2 id="account-storage-modes"><a class="header" href="#account-storage-modes">Account storage modes</a></h2>
<h2 id="account-types"><a class="header" href="#account-types">Account types</a></h2>
<p>There are four types of accounts in Miden:</p>
<div class="table-wrapper"><table><thead><tr><th></th><th>Regular updatable account</th><th>Regular immutable account</th><th>Faucet for fungible assets</th><th>Faucet for non-fungible assets</th></tr></thead><tbody>
<tr><td><strong>Description</strong></td><td>For most users, e.g. a wallet. Code changes allowed, including public API.</td><td>For most smart contracts. Once deployed code is immutable.</td><td>Users can issue fungible assets and customize them.</td><td>Users can issue non-fungible assets and customize them.</td></tr>
<tr><td><strong>Code updatability</strong></td><td>yes</td><td>no</td><td>no</td><td>no</td></tr>
<tr><td><strong>Most significant bits</strong></td><td><code>00</code></td><td><code>01</code></td><td><code>10</code></td><td><code>11</code></td></tr>
</tbody></table>
</div>
<h2 id="account-storage-mode"><a class="header" href="#account-storage-mode">Account storage mode</a></h2>
<p>Account data - stored by the Miden Node - can be public, private, or encrypted. The third and fourth most significant bits of the account ID specifies whether the account data is public <code>00</code>, encrypted <code>01</code>, or private <code>11</code>.</p>
<ul>
<li>Accounts with <strong>public state</strong>, where the actual state is stored onchain. These would be similar to how accounts work in public blockchains. Smart contracts that depend on public shared state should be stored public on Miden, e.g., DEX contract.</li>
<li>Account with <strong>encrypted state</strong>, where the account data is stored onchain but in encrypted text. It provides liveness guarantee of the protocol for the account in question.</li>
<li>Accounts with <strong>private state</strong>, where only the hash of the account is stored onchain. Users who want stay private and take care of their own data should choose this mode. The hash is defined as: <code>hash([account ID, 0, 0, nonce], [vault root], [storage root], [code root])</code>.</li>
</ul>
<p>In the future we will also support <strong>encrypted state</strong> which will be onchain but encrypted. * Depending on the account storage mode (private vs. encrypted vs. public) and transaction type (local vs. network) the operator receives the new Account ID eventually and - if the transaction is correct - adds the ID to the Account DB</p>

</main>

Expand Down
Binary file removed diagrams/architecture/account/Account_ID.png
Binary file not shown.
Binary file added diagrams/architecture/miden_architecture.gif
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading

0 comments on commit e0790ec

Please sign in to comment.