-
Notifications
You must be signed in to change notification settings - Fork 0
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
Potential Summa::submitCommitment()
Gas limits
#4
Comments
After testing in #5, seems like 402 is the max no. of cryptocurrencies before overflowing 30M block gas limit |
Also related: Are there / Could there be limits to the number of currencies that can be used in the circuit as well that prohibit practical use due to increase in proof size / verification cost. |
There is another limitation to the number of currencies from the verifier contract. As you may already know, the size of the verifier contract is linearly correlated with the number of currencies it supports. Practically, the inclusion of additional currencies is limited to around 24 to 25 due to the contract code size limit. |
Description
Summa::submitCommitment()
takes in two arrays and loops once over them:https://github.com/zBlock-2/summa-solvency-schneier/blob/95d63fe1a55935542810138aa5d8de7f50f4e94b/contracts/src/Summa.sol#L146-L147
https://github.com/zBlock-2/summa-solvency-schneier/blob/95d63fe1a55935542810138aa5d8de7f50f4e94b/contracts/src/Summa.sol#L159-L171
rootBalances
array contains the root balances of each cryptocurrency.cryptocurrencies
array contains details of each cryptocurrency:name
,chain
There could be practical limitations to the number of rootBalances and cryptocurrencies that could be submitted in a single txn, imposed by block gas limits
According to Coingecko, Binance hosts 376 cryptocurrencies.
Current tests in the Summa contract codebase doesn't test this limitation as it only seems to be using 2 cryptocurrencies. See here, here and here
It shouldn't be too hard to add a test that tests such limits and it is WIP. But if it turns out that the contract is not able to handle such large number of cryptocurrencies, it would be a limitation to be aware of. It might be necessary to split the submission into multiple commitments for the same
timestamp
.This would warrant if the circuit implementation supports this kind of split submission. Afaik, a single commitment is for the entire state of the exchange at a given time. If I'm wrong, please correct me, and feel free to close this issue.
The text was updated successfully, but these errors were encountered: