Paper 2015/702

Demystifying incentives in the consensus computer

Loi Luu, Jason Teutsch, Raghav Kulkarni, and Prateek Saxena


Cryptocurrencies like Bitcoin and the more recent Ethereum system allow users to specify scripts in transactions and contracts to support applications beyond simple cash transactions. In this work, we analyze the extent to which these systems can enforce the correct semantics of scripts. We show that when a script execution requires nontrivial computation effort, practical attacks exist which either waste miners' computational resources or lead miners to accept incorrect script results. These attacks drive miners to an ill-fated choice, which we call the {\em verifier's dilemma}, whereby rational miners are well-incentivized to accept unvalidated blockchains. We call the framework of computation through a scriptable cryptocurrency a consensus computer and develop a model that captures incentives for verifying computation in it. We propose a resolution to the verifier's dilemma which incentivizes correct execution of certain applications, including outsourced computation, where scripts require minimal time to verify. Finally we discuss two distinct, practical implementations of our consensus computer in real cryptocurrency networks like Ethereum.

Available format(s)
Publication info
Published elsewhere. MINOR revision.22nd ACM Conference on Computer and Communications Security, CCS 2015
BitcoinEthereumcryptocurrencyincentive compatibilityverifiable computationconsensus computer
Contact author(s)
loiluu @ comp nus edu sg
2015-11-05: revised
2015-07-14: received
See all versions
Short URL
Creative Commons Attribution


      author = {Loi Luu and Jason Teutsch and Raghav Kulkarni and Prateek Saxena},
      title = {Demystifying incentives in the consensus computer},
      howpublished = {Cryptology ePrint Archive, Paper 2015/702},
      year = {2015},
      note = {\url{}},
      url = {}
Note: In order to protect the privacy of readers, does not use cookies or embedded third party content.