Runtime Flow
Gradual Consensus - Act quickly, react faster, and reward slowly.
While the task standard supports a wide range of possible applications, the most straightforward approach is to follow a multi-round confirmation process, which we refer to as Gradual Consensus.
Why is it gradual?
One of the major limitations of stake-based games is the potential for an actor with a large number of tokens to temporarily take over the unfair system and potentially even extract rewards. Koii tasks naturally avoid this issue by slowing down reward distributions and using proportionately high numbers of audit nodes compared to task executors.
How does it work?
The key to building community-based products is to regularly appraise contributions through a commonly agreed-upon set of rules. Under the Koii model, this system runs in regularly timed rounds, during which each participating device participates as much as it can, and rewards or penalties are regularly deployed to correct the course of the system towards a desired outcome.
In each task cycle, there must be:
- Work to do
- A mechanism to review work done by other participants
- Rewards for good behavior
- Penalties for bad behavior
For help designing your task, you might want to try using the task organizer, which provides a simple whiteboard for brainstorming your product.
Task Outline
Copy this whiteboard to start brainstorming how your task will work.
Note: In most cases, the actual management of (3) and (4) above depends on tracking digital signatures from participating nodes, community members, or outside Oracle services. Reviewing these signatures is usually referred to as an audit.
Gradual consensus is a multi-round game under which nodes first perform a task, and then vote on a reward distribution. It's important to understand that while the process takes three rounds to complete, each cycle operates independently once per round, such that there is always one cycle starting and completing within every round.
The Task Lifecycle
1. Submission Phase
During this phase, the task node(s) submit data to K2 to request rewards for work they've done.
- The first submission phase occurs during the review period, each task node submits proofs of work done during the work period to K2, and these proofs are in turn audited by other participating nodes still in the review period.
- The second submission phase occurs during the distribution period, where the selected task node submits the distribution list to K2.
2. Audit Phase
During this phase, the participating nodes verify data submitted to K2.
- The first audit phase occurs during the review period after the submission phase. Each participating node audits proofs submitted by other nodes, if there is an invalid submission, an audit is triggered on K2, and the stake can be confiscated from the offending node. While the nodes are verifying data submitted on-chain, they're also checking if an audit has been raised against a node, and they can either vote in favor of or against the audit.
- The second audit phase occurs during the distribution period after the selected node submits the distribution list on-chain. Each participating node audits the distribution list submitted by the selected node. After auditing, if the distribution list is invalid, a newly selected node generates a distribution new list and submits it on-chain.
3. Distribution Phase
This is the final step once the distribution list has been validated, rewards are distributed among participating nodes.
At first, it can be difficult to imagine this process, but a helpful analogy would be a batch production line, where one group produces a product all day while the other evaluates its quality and may reject entire batches or penalize individual workers for sub-par performance.
Applications
Gradual consensus works well on tasks that have a deterministic outcome but require some significant computation that cannot be done on-chain on networks like Ethereum or Solana due to computation costs or network call limitations. Some particular applications include web scraping, indexing on-chain content, compiling or hosting web apps or sites, or even managing databases and caches of on-chain content.