27 Apr30 Apr 2024 · 30,000 TON

TVM Challenge

The contest for smart contract developers with a prize pool of 30,000 TON.

About the contest

We’re excited to announce a new contest for all smart contract developers on TON titled TVM Challenge. This competition aims to explore and showcase the new features and opcode use cases introduced in the upcoming TVM update. As a smart contract developer, this contest allows you to delve into the latest advancements in TVM and discover new possibilities for creating innovative products on TON.

How to apply

  1. Project name
  2. A short description of up to three sentences. If necessary, an additional explanation of why new TVM operations are needed
  3. Link to GitHub or project web-page
  4. TON address

More details about the process of proposals will be published on the Telegram channel.

Prize Pool

We have allocated a total prize pool of 30,000 Toncoin (TON) for this contest. The prize money will be distributed among the participants who showcase the best utilization of the new TVM features. A panel of esteemed jury members will do the evaluations.

Evaluation Criteria

The jury will evaluate each project submitted to the contest. The jury will use a combination of different criteria to score each project on a scale from 0 to 3.

The criteria include the following:

  • Relevance: The jury will assess how much the project addresses a genuine need for new TVM instructions in smart contracts.
  • Efficiency: The jury will evaluate the optimization of the project and the use of gas, exploring ways to improve and optimize implementation.
  • The uniqueness of the idea: The jury will consider the originality and novelty of the project, taking into account the possibility of applications that the committee may not have been aware of previously.
  • Technical difficulty: The jury will assess the level of technical complexity involved in the project’s implementation.

For each criterion, the jury will assign a score ranging from 0 to 3 based on the following scale:

  • 0 points: The solution does not satisfy the given criteria.
  • 1 point: The solution barely satisfies the given criteria.
  • 2 points: The solution fits the given criteria but requires improvements.
  • 3 points: The solution fully meets the given criteria.

It is important to note that the score for technical difficulty carries a weight of 1.5, giving it additional significance in the evaluation process. The maximum score a project can achieve is calculated as 3 (assuming that each project is assessed by 3 judges) multiplied by the sum of the scores for the other criteria plus 1.5 times the score for technical difficulty, resulting in a maximum score of 40.5.

The Jury

  • Andrey Tvorozhkov - Disintar / dton
  • Steve Korshakov - Independent TON evangelist, Tact Lead
  • Tim - TON Diamonds
  • Dan Volkov - TON Whales
  • Nikita Kuznetsov - OpenMask
  • Shahar - Orbs
  • Amin Rezaei - Skyring Foundation / Rift framework
  • Andrey Pfau - TON Foundation
  • Nick Nekilov - DeDust
  • Vladimir Lebedev - Independent TON Researcher
  • Dario - STON.fi
  • Dr. Awesome Doge - TonX Studio

Resources

To participate in the contest and familiarize yourself with the new TVM update, please refer to the following resources:

We encourage you to explore these resources thoroughly to gain a comprehensive understanding of the changes introduced in the upcoming TVM update.

Bonus

If you find vulnerabilities or bugs in new TVM features on the testnet, you may be eligible for a bug bounty. We wish all participants the best of luck. Our jury is looking forward to seeing your ideas.

Results

RankProject nameJudge 1Judge 2Judge 3Judge 1Judge 2Judge 3TotalReward in TON
1snarkjs-funcIt is awesome that in addition to the working examples and Groth16 / Plonk tests there is an integration in snarkjs. Although the project template can be greatly improved, at the moment it is static and not very convenient.11.511.511.534.55 691
2Snarkjs TVM IntegrationThis is good work, but project of hrmon is more complex.The project is compatible with common phase 1 for any zk-snark project to start their circuit-specific phase 2 ceremony. It's high-performing and can be used directly in the browser or in node.js, with the low-level cryptography executed in wasm. Overall, it seems like a well-thought-out project with a detailed outline of its features.I'm not very familiar with zk, but to me the addition in this project over the original is pretty basic. It does use new opcodes for BLS, seems like in a basic way.910.5928.55 053
3Wallet v51. Making all functions inline is not the optimal way if you call them in different parts of code. 2. Plugins and continuations in signed messages are considered by trusted sources and called without isolation but they should not be trusted. 3. Timestamp of the signed message does not have upper limit, delayed message attack is possible.9109284 268
3Clean.tonThe project has single contract that stores all pools, I'm seeing a bit of scalability and efficiency issue here. Contracts repository should've had testing suites and running examples. Also ring signatures are a bit of controversial topic, there has been a lot of discussion that through probabilstic models one can trace back identities using EAE attacks. Large ring sizes may decrease the chance signifcantly but they also decrease practicallity and efficiency.RIST255, HASHEXT9109284 268
4Tonnel Network - Tornado implementation on TON blockchainThe contracts are equivalent to tornado-core, and they seem to work properly. However, the code can be heavily optimized and there are more efficient solutions than sha256 that can be used for the project.The code could be optimized and written in more readable and efficient manner. Looks good overall.999273 359
5Circom integrationProject use PLONK (it can be less efficient in certain cases but more flexible)Project use and test BLS12-381 and Hashes79.5824.52 391
5FrosTON8.57.58.524.52 391
6Merkle Proof for BridgingThe efficiency of such a project would primarily depend on the execution of the cross-chain transactions and the data verification procedures implemented. An efficient implementation should minimize unnecessary computational steps and optimize data storage and retrieval.665.517.51 476
7zero-gas-vote-ton4.53.54.512.5744
8TBDt & TDA Concept — Tokenized Decentralized Backend template & Tokenized Decentralized App ConceptThe project is implementation of a special structure. The general expediency of the project and what benefits can be obtained by implementing the project in the blockchain and not in a simple database are not clear.Further performance optimization may be necessary due to the potential involvement of significant data storage, retrieval, and updating operations in this model.Overall, the "TDBt" project appears to be an innovative and technically complex project with the potential to advance the use-cases of NFTs and expand the scope of decentralized applications. However, a closer look at the project's efficiency, particularly in its contract optim ization and gas usage, would be beneficial for a more thorough evaluation.56112281
9evm-over-ton-voteThe front-end is not implemented as well, it's just a starter without ton-connect implementation and without filling page content. The idea is reasonable but project implement <5% out 100. The project generally not needed new instructions.All elements are partially implementedThe project seems to only provide a frontend, while the contract itself is almost unimplemented!2.5204.571