SUTD researchers enhance security in proof of stake blockchain protocols

IMAGE: Multiplicative Weights Updates
view more 

Credit: SUTD

Blockchain Technology is known to be one of the top disruptive technologies of today that is driving the fourth industrial revolution. A blockchain, designed to be resistant to the modification of its data, offers security and privacy benefits that are well appreciated particularly by banks, governments and techno-corporations.

One of the ways that Blockchain Technology provides such security is through Proof of Stake (PoS). POS Blockchain protocols rely on voting mechanisms to reach consensus on the current state of data. If an enhanced majority of staking nodes, also called validators, agree on a proposed block of data, then this block is appended to the blockchain. Yet, these protocols remain vulnerable to faults caused by validators who abstain either accidentally or maliciously. In particular, while selecting staking nodes proportionally to their stake to form block-creating committees, current PoS protocols do not guarantee that selected committees will create blocks. This in turn violates the perceived fairness in the distribution of rewards in proportion to the stake of participating nodes.

To protect against such faults while retaining the PoS selection and reward allocation schemes, Singapore University of Technology and Design (SUTD) researchers studied weighted voting in validator committees. First, they introduced validators’ voting profiles – this helps to quantify the probability that a validator will cast a correct vote based on the validator’s previous contributions to date to the protocol. Then they defined the mathematical framework to apply optimal decision rules in committee voting. The researchers designed a generalised multiplicative weights algorithm to update individual validators’ profiles according to their voting behaviour, consensus outcome and collective blockchain welfare as illustrated in table 1.

The result is a two-layered scheme in…

Source Link