Staking
Last updated
Last updated
The Autonomys Network relies on staking from both domain operators and farmers to secure the network and provide resources. Subspace implements a Nominated Proof-of-Stake algorithm where farmers endorse operators who execute transactions and produce blocks.
Our staking model consists of two tiers:
Operators stake to gain the right to execute transactions within a domain and produce blocks. They are responsible for validating and executing transactions, producing execution receipts, applying state transitions and earn rewards for their work. The operator's chances to be elected as a slot leader are weighted by stake. Operators can be nominated by farmers and currently each operator can have up to 256 nominators.
Farmers earn rewards proportional to their pledged storage. Farmers can nominate operators and back them with their tokens, increasing their stake and chance of being elected as slot leaders.
Generally speaking, any ATC token holder can stake their tokens by nominating a domain operator, without having to become an operator or farmer themselves.
NPoS allows for virtually all ATC holders to participate, thus maintaining high levels of security by putting more value at stake and allowing more people to earn a yield based on their holdings.
Operators must stake an amount higher than this domain's minimum stake for a right to participate in the execution and earn execution fees. An operator's chances to become a slot leader are directly proportional to the percentage of their stake against the total amount staked by all operators of this domain. As such, operators are incentivized to recruit nominators to increase their stake. This means that each domain operator stake acts essentially as a pool for nominators. When registering as an operator, each operator specifies their minimum nominator stake and nomination tax of their pool. The nomination tax is a percentage that the operator collects on all fees earned by executing blocks, before they are shared with nominators, a commission for the operator's work. The tax amount is automatically restaked as part of the operator's stake.
Any ATC token holder who has more than the minimum nominator stake (currently 1 ATC may choose to join this operator’s pool by submitting the nomination extrinsic with the deposit amount of ATC they wish to stake).
The amount of deposited ATC is added to the list of pending deposits within the operator's pool.
At the end of an epoch (currently 100 blocks, ~ 10 minutes), the nominator's deposit is processed.
A part of the deposit is taken as a reserve towards a storage fee fund. This reserve is calculated as a percentage of the deposit (currently, 20%), and is used to pay for the storage fees of bundles created by the operator of the pool and does not affect the stake distribution. The reserved amount is transferred to the operator's storage fee fund, while the rest of the deposit remains locked in the nominator's account. This amount is partially refunded with each withdrawal.
The nominator is awarded their shares in the pool. The stake shares are the percentage of the total stake that is allocated to each nominator. The stake shares are used to calculate the share of the operator's fees that the nominator is entitled to based on the amount they have staked and for how long. The stake shares are calculated as follows:
Compute the operator’s pool end-of-epoch shares_per_atc as the total number of shares divided by the sum of all stake in the pool and fees collected during the previous epoch
.
Assign the shares to this nominator based on the shares_per_atc of the pool
The deposit_amount is added to pool_total_stake of the operator's pool and domain’s total stake.
The shares of this nominator are added to total_shares of the operator's pool.
The nomination pools in Autonomys Network are "lazy": any fees earned by the operator are assigned to the pool and are not deposited to the nominators wallet unless they ask for a withdrawal. Unless withdrawn, the fees are "auto-staked" - they count towards the total stake of the pool, increasing its chance of being elected to produce bundles.
When the nominator decides to withdraw their stake or fees, they submit a withdraw extrinsic. The withdraw extrinsic is processed at the end of the epoch and the stake is removed from the operator's pool and the domain's total stake. The nominator is then entitled to the fees percentage based on the stake shares and the amount of time they have staked.
Operators can also withdraw their stake and fees at any time by submitting a withdraw_stake
extrinsic. Operators who wish to withdraw all of their stake and earned fees have to submit a deregistration extrinsic, as it is forbidden to withdraw below the domain's minimum stake requirements. The deregistered operator will be removed from the domain and their stake and the stakes of all nominators will be returned to their accounts.
Withdrawals have a lock period of roughly 1 day (currently 14 400 domain blocks). After the locking period, the withdrawn amount can be unlocked in the user's account with the unlock_funds
extrinsic. All withdrawals requested in the same stake epoch are aggregated together and the total amount is unlocked at once. This locking period is necessary to ensure that the domain block executing the withdrawal is confirmed and not challenged by a fraud proof in order to increase the economic stability of domains.
Operator 𝑂 has staked 100 ATC and registered as an operator with minimum nominator stake of 10 ATC and nomination tax of 5%. The required storage fee reserve deposit is 20%. Operator 𝑂 has 2 nominators and each staked 50 ATC. Initially shares_per_atc=1, so O gets 80 shares, and and each get 40 shares and total_shares=80+40+40=160 in the stake. Each deposit transfers 20% towards a storage fee fund: O reserves 20 ATC, and reserve 10 each, with total of 40 ATC reserved.
The staking summary will look like this:
Nominator | O | N1 | N2 |
Shares | 80 | 40 | 40 |
Storage fee deposit | 20 | 10 | 10 |
Total stake | Total shares | Total storage fee deposits | Storage fee fund |
---|---|---|---|
160 ATC | 160 | 40 ATC | 40 ATC |
In the next epoch, the pool has earned 20 ATC of compute fees and refunded an extra 4 ATC of storage fees. The operator took 5% of compute fees as tax (1 ATC) automatically restaked for 1 share and 0.05 ATC deposited to storage fee fund. The pool stake is now 160+20+1=181 ATC and storage reserve is now 40+4=44 ATC. The pool end-of-epoch shares_per_atc is now 160/(160+20*(1−0.05))=0.893855. Notice that 4 ATC of storage fees refunded do not count into shares_per_atc calculation, which allows us to sustain stable stake distribution despite the fluctuating size of the storage fee fund.
If a new nominator stakes 33.6 ATC, 6.72 ATC will be transferred to the storage fee fund, and the shares will get is ((33.6−6.72)*0.893855)=24. The pool total stake becomes 181+26.88=207.88 ATC, total shares 160+24+1=185 and storage fee reserve 50.72 ATC.
At the end of the epoch, the updated staking summary for the next epoch will look like this:
Nominator | O | N1 | N2 | N3 |
Shares | 81 | 40 | 40 | 24 |
Storage fee deposit | 20.05 | 10 | 10 | 6.72 |
Total stake | Total shares | Total storage fee deposits | Storage fee fund |
---|---|---|---|
207.88 ATC | 185 | 46.72 ATC | 50.72 ATC |
Suppose after some time shares_per_atc value of this pool becomes 0.8 and the storage fee fund balance is 52 ATC. Suppose wants to "sell" withdraw_shares=20. At the end of the epoch, the 20 shares will be unstaked, and the corresponding amount of 20/0.8=25 ATC will be deducted from the pool's total stake. The total amount of credits will get is
If wanted to withdraw all their stake and fees, that is sell all their withdraw_shares=40 shares, they would get , earning 11.13 ATC in fees. After waiting the locking period, the withdrawn amount can be unlocked in their account.
The example is intended for illustration, the actual calculation is performed with shannons shannons).
Staking epoch is a period of time during which staking distribution remains the same. This period is currently set to 100 blocks, or roughly 10 minutes. The end of each epoch triggers a series of events to transition to the next epoch. These events include:
allocation of fees earned for the blocks confirmed during the epoch,
deposits and withdrawals of stake,
operator registrations and deregistrations,
recalculation of stake distribution for the slot leader election.
Because of this, new operators must wait for the end of the current epoch to register as an operator, new nominators must wait for the end of the current epoch to nominate, and new stake deposits and withdrawals must wait for the end of the current epoch to be processed. As soon as the end of the epoch transition is finalized, the next epoch begins.
Token holders and farmers who have earned storage rewards can nominate operators to execute transactions. This system balances the power between nominating farmers (or holders) and operators, and both parties share the fees and the potential penalties (slashing). Nominated operators get a higher chance to produce blocks proportional to the amount of stake backing them, thus, higher revenues. Farmers and holders have the power to nominate operators they trust to execute transactions properly. On the other hand, operators compete to be nominated by providing good service, maintaining a good reputation within the community, and having reasonable commission. Nominators also retain the power to withdraw their nominations at any time, ensuring operators remain accountable.
This two-tiered structure provides robust security guarantees. By enabling the consolidation of vast quantities of stake — far exceeding the ATC holdings of any individual party — it creates significant barriers for malicious actors trying to elect dishonest operators. Gaining the necessary backing requires building a considerable reputation, making it challenging for adversaries. Additionally, attacking the system would be prohibitively expensive, leading to large amounts of stake slashed. We anticipate that a substantial portion of the ATC supply will be staked in the NPoS system at any time.