Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

docs: clarify circuits parameters #1575

Merged
merged 1 commit into from
Jun 18, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,22 @@ pnpm circom:build $CIRCUIT_NAME

> Please note that the name should match one of the circuit names inside the `circom.json` file.

### Parameters

MACI's circuits are parameterized, and thus can be configured to support different number of users, messages (votes), and vote options. Please ensure you understand what each of these parameter means and correctly configure them when building circuits from scratch, and when deploying the smart contracts.

- **STATE_TREE_DEPTH** = how many users the system supports
- **MESSAGE_TREE_DEPTH** = how many messages (votes) the system supports
- **VOTE_OPTIONS_TREE_DEPTH** = how many vote options the system supports
- **MESSAGE_BATCH_TREE_DEPTH** = how many messages in a batch can the circuit process
- **INT_STATE_TREE_DEPTH** = how many ballots can be processed per batch when tallying the results

For instance, given a binary tree for signups, if you set `STATE_TREE_DEPTH` to 2, the system will support 4 users, as 2 \*\* 2 = 4.

For messages, we use a quinary (five leaves) merkle tree, so if you set `MESSAGE_TREE_DEPTH` to 2, the system will support 32 messages, as 5 \*\* 2 = 32.

Please refer to the individual circuit documentation for more details on the inner working of each circuit and where parameters fit.

### Generating zKeys

Run from the root directory to save to the `cli/zkeys` folder:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,14 @@ We recommend to use the hardhat tasks inside the `maci-contracts` folder, due to

## Deployment Steps

:::info
Before deploying the contracts, please ensure that you have compiled the project using the correct state tree depth argument. This defines the maximum number of users that the system supports, and by default the parameter is set to 10 (to support 2 \*\* 10 users) for testing purposes. For production use, you might need to change this parameter to a different value. For more information about the parameters please refer to the [circuits page](/docs/developers-references/zk-snark-circuits/setup#Parameters).

To re-compile with a different state tree depth parameter please run:

`export STATE_TREE_DEPTH=$ENTER_VALUE_HERE && pnpm build`
:::

In order, these are the steps for a full MACI deployment:

1. Deploy crypto (Hasher, Poseidon)
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -68,6 +68,14 @@ pnpm i && \
pnpm run build
```

:::info
Depending on the number of signups you would like to support, you will be required to re-compile the contracts with a different STATE_TREE_DEPTH parameter. This is by default 10 and can be used for testing purposes. For more information about the parameters please refer to the [circuits page](/docs/developers-references/zk-snark-circuits/setup#Parameters).

To re-compile with a different state tree depth parameter please run:

`export STATE_TREE_DEPTH=$ENTER_VALUE_HERE && pnpm build`
:::

#### On Intel chips (no ARM64)

Install dependencies:
Expand Down
Loading