The recent events with the Hive/Steem situation are really remarkable. While a lot of users of the platforms are undergoing quite a stressful time it is worth noting that these events are providing a real life example for blockchain governance.
Things that have been only theorized, now we are seeing them developing in front of our eyes in real time. Amazing! We are pioneering a totally unmarked waters with this.
What is quadratic voting?
I’m not really sure how I stumbled upon the topic, but I have been exploring blockchain governance lately, reading a bit more about it and quadratic voting has come up.
Here is the Wikipedia definition:
Quadratic voting is a collective decision-making procedure where individuals allocate votes to express the degree of their preferences, rather than just the direction of their preferences. By doing so, quadratic voting helps enable users to address issues of voting paradox and majority-rule. Quadratic voting works by allowing users to 'pay' for additional votes on a given matter to express their preference for given issues more strongly, resulting in voting outcomes that are aligned with the highest willingness to pay outcome, rather than just the outcome preferred by the majority regardless of the intensity of individual preferences.
Basically, what it says that people can buy votes to express their opinion more strongly on a subject. The usual rule for democracies one vote per man (1p 1v), does not apply here.
|Number of votes||Vote Cost|
That is why the term quadratic. Each next vote is a squared in value, making votes more and more expensive.
The Wikepedia article describes the quadratic voting for real life democracies.
A blockchain oriented paper for Quadratic Voting can be find here. A 20 page material (if you have the time 😊) from 2017 with some very interesting points. It is noting that blockchains have copied/adapted existing governance models that have created fault lines in the industry.
Quadratic voting (“QV”) has the potential to “bring the logic of the market” to blockchain governance and, in so doing, allow blockchain to better meet the needs of their stakeholders.
QV also has the potential to address problems inherent in traditional blockchain-related voting mechanisms, such as vulnerability to Sybil or sockpuppet attacks. Those attacks attempt to subvert reputation systems in peerto-peer networks, such as a blockchains, by creating pseudonymous identities (sockpuppets) to gain influence.
Sybyl attack from sockpuppets. Sounds familiar 😊.
The paper explores the current stake based models and point outs some of the cons:
Plutocracy and Collusion: A plutocracy is government by the wealthy.In an on-chain system, a plutocracy indicates control by individuals or entities who hold a significant percentage of the tokens, which allows them to collude and act primarily in their own interest, to the detriment of those with fewer resources
Mutability: One of the most important features of blockchain technologies is the inability to change transactions recorded on what is supposed to be a permanent leger. In an on-chain governance system, a vote can be taken to “undo” a transaction or series of transactions, and roll back and edit the history of the ledger.
Excluded Stakeholders: In many on-chain governance systems, nontoken holders are excluded from governance. However, by excluding those voices, their participation in governance becomes “completely unnecessary,” and removes “an important check to balance against the power” of the token holders.1
There is much more to talk about the quadratic voting but we will cut it here.
Possible implementation in Hive and DPoS
As mentioned, the example above is for real life democracies systems. It allows people to have more than one vote and preventing what is called Tyranny of the majority.
What about DPoS?
Buying votes, having more than one vote is the standard here 😊. Your stake is your vote. As we already saw this has its disadvantages as pointed out in the paper above, and it opens the gate for:
- Plutocracy and Collusion
- Puts in danger the immutability of the transactions and the stake
- Small stakeholders feel excluded
We have actually witnessed all of these things. In real time before our eyes. The paper was written in 2017 and all the potential weaknesses pointed out in there happened.
What will prevent these events from happening again?
We have a better witnesses now? Better humans in charge?
IMO humans are humans and if the system is setup in a way that incentives certain behavior, that will happen. Also blockchain is all about trustless systems. No need for trust.
System improvements > Changing players
Implementing quadratic voting in DPoS is basically the opposite that the implementation in real life democracies.
It means that the vote of the larger stakeholders will be worth less.
|Stake||Square root of stake (votes)|
In the first column (stake) the ratio between the top and the bottom is 1:1000, while in the second column the ration between these two is 1:31. Quite a difference. We can play with the root value as well, it doesn't have to be 2.
The votes represented above are just for governance purpose, electing witnesses and proposals. The votes for content creators, curation rewards (profit) will remain the same.
People can just distribute the stake between multiple accounts to get more governance votes!
Yes, this is one of the major problems in applying this system.
This is where the importance of an account comes in place. In real life democracies we have government ID to be eligible to vote. Should we do a KYC for each account? EOS Voice seems to be going in this direction.
But we all want the freedom to choose will we discover our identity online or not.
Something called account weight can come in place.
This name is basically mathematically chosen, and we can call it whatever we want. Reputation is probably the most suitable. For the purpose of describing the model we will call it as above. The Hive blockchain already have a reputation system for the accounts. Unfortunate it is broken. Especially from the bid bot’s era that is luckily behind us now.
The idea behind the account weight (blockchain ID) is that account weight can be a value between 0 and 1 (or 1 and 10), and the value of the stake will be multiplied by the weight of the account.
Governance votes = (Square root of stake) x (Account weight/reputation)
In this way creating multiple new accounts and spreading the stake between them to gain more votes will be not worthen. The new accounts will have zero, or very low weight and when multiplied by the stake the votes will be very low.
Building up one account (increasing weight) will be incentivized.
How to determine account weight/reputation will be crucial in this system!
Some factors for doing this can be:
- Other accounts feedback
With the latest changes there is a rule that a newly powered up stake can’t vote witnesses immediately. This is basically a small step in this direction. It takes some time for the stake to be eligible for votes. The older the account the better the score.
The amount of stake can also be used as and indicator for an account weight, but just a partial one. Activity of the account, does it post, comment, vote etc. And of course, accounts can rate them self’s with some sort of rating mechanism. As mentioned, this is just a rough draft of possible solutions.
There are probably ways to manipulate the system above as well. No system is ideal. But I think if some of the things mentioned above, are implemented in some distant future in the blockchain governance models it will be a step in a right direction. It adds a bit more complexity and confusion at first, than the pure stake based voting, but once it settles can work better. Probably :) We just cant tell until we try it out.
It will bring a bigger trust in the DPoS systems in general, as we have seen they can be vulnerable for attacks. Making it more agile,providing more security in the sanctity of private property and the fast and fluid experience of DPoS at the same time.
A fast, efficient and trustworthy system!
Is it possible? What you think?
All the best