17th International Symposium INFOTEH-JAHORINA, 21-23 March 2018
Blockchain Technology, Bitcoin, and Ethereum: A
Brief Overview
Dejan Vujičić, Dijana Jagodić, Siniša Ranđić
Faculty of Technical Sciences in Čačak
University of Kragujevac
Čačak, Serbia
dejan.vujicic@ftn.kg.ac.rs, dijana.jagodic@ftn.kg.ac.rs, sinisa.randjic@ftn.kg.ac.rs
Abstract—The blockchain technology is a relatively new approach and the correspondents could be anonymous. Law et al.
in the field of information technologies. As one of its first presented with an idea of electronic cash also with public key
implementations, bitcoin as a cryptocurrency has gained a lot of cryptography, but their approach was intended for use with
attention. Together with Ethereum, blockchain implementation banks as central trust authorities [2].
with focus on smart contracts, they represent the very core of
modern cryptocurrency development. This paper is meant to give Dwork and Naor [3] proposed a system for usage in combat
a brief introduction to these topics. against junk mail, by demanding the user to provide a
computation of a relatively hard pricing function. This was one
Keywords – Bitcoin; blockchain; cryptocurrency; Ethereum; of the first ideas of providing a proof-of-work as a system for
smart contracts exchanging digital commodities. In similar manners, authors of
b-money [4], reusable proof-of-work [5], and bit gold [6]
I. INTRODUCTION represented ideas of using computational power as an asset with
Bitcoin and blockchain technology have begun to shape and actual and usable value, comparing it with a precious metal or a
define new aspects in the computer science and information minted coin [7].
technology. The need for a decentralized money has been
Vishnumurthy et al. proposed a system for secure peer-to-
exploited more as a theoretical concept, but in the past decade,
peer (P2P) resource sharing, KARMA [8]. They dealt with the
it became viable, all thanks to the famous paper of Satoshi
problem of having nodes in P2P networks that use more network
Nakamoto in 2008, introducing Bitcoin and blockchain
resources than they contribute. With each contribution, a node’s
technology.
karma is increased, and with each consummation, it is decreased.
While there are controversies about Nakamoto’s true A set of nodes is responsible for keeping records of each node’s
identity, one is for sure: he brought something revolutionary to karma.
the world, and it is up to the users to decide what they want to
However, these approaches either required a trusted party in
do with it. Some will take this opportunity and develop their own
the form of banks or didn’t quite solve the double-spending
application for solving various problems in the society, others
problem. In the centralized solution, banks or other trusted
will invest money in those ideas or simply trade with ups and
authorities can prevent the attempt of parallel issuance of two
downs of the cryptocurrencies’ values at the market.
transactions, but in decentralized system, as in cryptocurrency,
In this paper, we thought of bringing a small introduction to this problem carries great importance [7]. Also, since the central
the matter of blockchain and cryptocurrencies. We begin with a authority doesn’t exist, the users have to maintain a consistent
quick retrospective of some of the most famous solutions for state of the P2P network, thus disabling the possible attackers to
decentralized digital money before Bitcoin, and then we go into compromise the system with false data.
the very core of its function, together with Ethereum. These two
One of the possible solutions to these problems was the
cryptocurrencies hold majority of the cryptocurrency market
introduction of quorum systems [9], [10]. In these systems, the
capitalization. Of course, as it happens with new technologies,
possibility of having incorrect information and malicious
some limitations and problems emerged, and we described them
entities in the network is assumed as true, but the concept of
as well.
voting is supposed to surpass them [7]. If the majority of nodes
II. SOME EARLY IDEAS ON DECENTRALIZED DIGITAL in the network is consent about some information, they have the
CURRENCIES control of the network. However, this approach is prone to Sybil
attack [11], where hostile node(s) could manipulate many peers
The idea of digital currency is not a relatively new one, but with incorrect information, thus overcoming the election and
not until recently has it been successfully implemented. In his injecting false information.
paper, Chaum presented an idea of untraceable electronic mail,
return addresses, and digital pseudonyms, based on public key
cryptography [1]. His technique didn’t require a trusted authority
978-1-5386-4907-7/18/$31.00 ©2018 IEEE
III. BITCOIN AND BLOCKCHAIN TECHNOLOGY its correctness. However, a user can try to manipulate the
network and issue more than one transaction of the same coin to
A. Bitcoin essentials the different users (double-spending problem). Moreover, the
In his now famous work, Satoshi Nakamoto showed a same user can set up several instances to confirm his initial intent
solution to the problems that the implementation and usability and thus perform a Sybil attack.
of digital currency faced, especially the double-spending
problem [12]. While the true identity of Nakamoto is a point of C. Proof-of-work and blockchain
speculations, what is known is that until 2010 he remained active These situations are prevented (or at least minimized) in
on the Bitcoin project, and then he stepped back and gave the Bitcoin network by demanding a proof-of-work from each node
project to the community for further development [7]. that verifies the transaction. The nodes have to do some heavy
computations to prove that they are valid members of the
He proposed a system with P2P distributed timestamp server network. As long as the total computational power of the honest
that serves as a generator of the computational proof of the nodes is greater than the computational power of the attacker,
chronological orders of transactions [12]. An electronic coin is the system will remain consistent and all legit transactions will
defined as a chain of digital signatures. Each transaction is occur [7], [12].
defined as a set of digitally signed hash of the previous
transaction and the public key of the next owner. The private key A set of transactions, together with the hash of the previous
is used for signing the transaction, and the public key is used for block and a nonce, declares a block. A timestamp server makes
verification of the transaction, as shown in Fig.1 [12]. The public a hash of a block and publicly announces it, thus proving that the
key is kept in the wallet, which can be implemented in software, data inside the block must have existed at the time of hashing.
hardware, or online. The timestamp server has to verify that the timestamp of the
block is greater than the timestamp of the previous block in chain
and less than two hours into the future. These hashes are linked
in a chain and this is called a blockchain, as shown in Fig. 2 [12].
The important property of the blockchain is that the transactions
can be traced back at any time in history.
Figure 2. The blockchain scheme
Figure 1. The structure of transaction in a Bitcoin blockchain
The proof-of-work hashing scheme Bitcoin uses is similar to
The Bitcoin ledger is defined as a state transition system, Hashcash [14] and based on SHA-256 hash function [15]. The
consisting of a state that shows ownership status of all existing proof-of-work is done by incrementing a nonce in the block until
bitcoins and a state transition function, in the form of the value is produced that has the required number of zero bits
transaction. The output of the state transition function is a new at the beginning of the block hash. Once it is done, it cannot be
state [13]. The results of this process are state changes of the undone without repeating the computations. If it is somehow
sender and recipient if the sender has enough bitcoins to make a changed by a malicious attacker, then all the following blocks
transaction, or an error, otherwise. would have invalid hashes. The rule is that the longest chain that
B. Bitcoin transactions has the majority consensus in the network is the correct one, so
if the attacker wishes to change a block, he needs to have enough
Each transaction is determined with its hash value computational power to overcome the voting of the majority of
representing a transaction identifier and a set of inputs and honest nodes, thus entering the race problem.
outputs. Each output of the transaction can only be used once as
an input in the entire blockchain [7]. The attempt of referencing The transactions within a block are hashed in a Merkle tree
the same output twice leads to the double-spending problem and [16], [17]. A Merkle tree is a type of binary tree with many leaf
is forbidden in the network. If the output of the transaction hasn’t nodes, and a root of the leaf nodes is a hash of its children. The
been referenced before, it is called an unspent transaction output Fig. 4 shows a Bitcoin block consisted of a Merkle tree of
(UTXO), and if it has been referenced, it is called a spent transaction hashes. Any inconsistency in the tree will reflect
transaction output (STXO). A transaction can have multiple somewhere in the chain, so the Merkle tree is vital for long-term
inputs and only up to two outputs. Multiple inputs can be used maintainability [13]. This is done to free up the storage space
to combine smaller amounts of coins being transferred, and needed to store the blockchain on the nodes. The current size of
outputs can be either an amount sent to the other party or the the Bitcoin blockchain is about 144.8 GB [18]. After the
change that is sent back to the sender [12]. transactions are incorporated in a block and this block is verified,
the network discards all hashes in a tree except the root hash
Bitcoin distributed ledger describes all transactions and included in the block header. Bitcoin introduced a Simplified
ownerships in the network. Every node in this P2P network Payment Verification (SPV), which doesn’t require the nodes to
keeps a copy of the ledger record [13]. If one user wants to send keep a full record of transactions, but only the copy of the block
some amount of coins to another, he can do that by publicly headers of the longest chain [12].
announcing this transaction and it is up to the network to verify
this block size is less than seven transactions per second (tps)
[19]. In comparison, the payment network Visa achieved 47,000
tps during the 2013 holidays, and currently averages with
hundreds of millions per day [20]. To achieve such rate on
Bitcoin network with 1MB block size, assuming that the
transaction is 300 bytes in size, it would require a throughput of
8GB per Bitcoin block every ten minutes, which would lead to
over 400TB of data per year [19]. This would highly centralize
the Bitcoin network to support only those nodes with such
storage capacities, and this is the very opposite of what Bitcoin
and blockchain are intended for.
Several solutions were suggested in order to tackle this issue
Figure 3. A Bitcoin block with hashed transactions into a Merkle tree efficiently. As a result, number of soft and hard forks of Bitcoin
occurred. A soft fork is any change that is backward compatible,
D. Bitcoin network and mining i.e. enabling the old software to recognize newly created blocks
The first transaction in a block creates a new coin which is as valid. A hard fork, on the other hand, is a software update
owned by the creator of the block [12]. This gives stimulus to introducing a new rule to the network, thus rendering the old
nodes to verify transactions, and puts coins into circulation, software unable to recognize new blocks [21].
since there is not a central authority that issues them. This
transaction is called a coinbase transaction. With this approach, F. SegWit and Lightning
the nodes are incentive to stay honest. The Bitcoin network is SegWit (Segregated Witness) is one of the proposed
intended to produce one block in approximately ten minutes solutions to the Bitcoin scalability issue, dealing with the
[13]. Since the computational power increases in time, the block problem of transaction malleability. This problem is caused by
time is remained somewhat constant by gradually increasing the the fact that the transaction signature doesn’t cover all the data
difficulty of generating new blocks. in the transaction, so it is possible for some malicious node on
the network to change a transaction and invalidate its hash [22].
The Bitcoin network starts with new transactions being
broadcasted to all nodes. Each node gathers transactions into a SegWit enables increasing the block size to a maximum of
block and works on finding proof-of-work, after which it 4MB and adding the second layer on top of the existing network
broadcast its block to the network. The nodes in the network [23]. It separates the signature data from other transaction data
accept the block as valid only if all transactions within it are and facilitates the introduction of the Lightning network as a
correct and not already spent. If the block is accepted by the second-layer protocol. It was activated on the 24th of August
network, the chain is being continued by creating the next block 2017 on the block 481,824 [24].
and adding the hash of the previously added block to it [12]. The Lightning network is “the next big thing” on the Bitcoin
Beside the reward based on the block creation, the nodes are network. It is supposed to facilitate micropayments by using a
rewarded with coins and by verifying transactions. The process network of micropayment channels. A micropayment channel is
of adding new blocks to the blockchain is called mining [7]. The a consensus between two parties to delay with announcing of the
initial block reward was set to 50 coins (50 BTC) and was transaction to the network, while actually making the
intended to be gradually split in half with every 210,000 blocks. transaction. The both parties can guarantee their current balance
The first block in the blockchain is the genesis block and is used on the blockchain, but they choose to defer sending information
to supply the initial 50 BTC to the network. The halving of the about transaction to the network [19].
block creation reward will continue until the reward drops below The successful trial of the Lightning network was conducted
one satoshi, which is the minimal unit of Bitcoin and is equal to by Blockstream in January 2018 [25].
10-8 BTC [7].
G. Bitcoin Cash and Bitcoin Gold
Taking the nature of distributed decentralized systems in
account, there are situations where several nodes almost With Bitcoin becoming more and more popular, the network
simultaneously broadcast the same block, but with probably was unable to handle so many transactions, so the confirmations
different set of transactions. This situation is known as fork and took even days [26]. The hard fork of Bitcoin Cash (BCH)
leads to the inconsistent state of the network. Basically, there are occurred on the block 478,558 on the 1st of August, 2017. The
several chains that originated from different blocks. This owners of Bitcoin at the time of the fork became also the owners
situation is resolved in the way that the network always of the Bitcoin Cash. The block size was upgraded to 8MB,
continues with the longest chain. Gradually, there will be a leading to faster confirmation times.
consensus within the network about the correct path of the Bitcoin Gold (BTG) is a hard fork of Bitcoin which
blockchain, and the chains generated as a result of a fork will be happened on the block 491,407, on the 24th of October, 2017
invalid [7]. [27]. Like with Bitcoin Cash, any holders of Bitcoin before the
E. Bitcoin scalability problem fork became also the holders of Bitcoin Gold. The reason behind
this fork is that instead of CPUs, the Bitcoin was primarily
With a block size of 1MB, Bitcoin has severe scalability mined with ASIC machines. The creators of Bitcoin Gold sought
issues. The amount of transactions that can be supported with to change that by changing the proof-of-work algorithm from
SHA-256 to Equihash [28]. This algorithm is memory heavy and Patricia tree that represents the content of the account [31].
mostly suitable for mining on graphic processors. The mining Merkle Patricia trees (tries) are used for storage of all (key,
difficulty is adjusted for every new block created, instead of value) bindings in Ethereum ecosystem. The block header
adjusting after every 2016 blocks in Bitcoin [27]. contains three roots from three tries representing state,
transactions, and receipts [32].
IV. ETHEREUM
C. Ethereum transactions and messages
A. Overcoming Bitcoin’s limitations
A transaction is a single instruction that is cryptographically
Ethereum was introduced in Vitalik Buterin’s paper [29] and signed. There are two types of transactions based on their
addressed several limitations of the Bitcoin’s scripting language. products (ones that result in message calls and ones that create
The main contributions are full Turing-completeness, meaning new accounts). The transaction is defined as a signed data
that Ethereum supports all types of computations, including package dispatched from an externally owned account. Each
loops. Then Ethereum supports the state of the transaction, as transaction is consisted of the recipient of the message, a
well as several other improvements over the blockchain signature identifying the sender, amount of Ether to be sent, an
structure. optional data field, STARTGAS, and GASPRICE values [13],
Ethereum represents a blockchain with a built-in Turing- [31].
complete programming language. It provides an abstract layer STARTGAS and GASPRICE fields are vital in the combat
enabling anyone to create their own rules for ownership, formats with attackers on the network. “Gas” is a fundamental unit of
of transactions, and state transition functions. This is done by computation. Each transaction requires certain amount of
involving smart contracts, a set of cryptographic rules that are computations, and the STARTGAS field denotes the maximum
executed only if certain conditions are met [29]. number of computational steps the transaction is allowed to
The consensus in the Ethereum network is based on modified consume. Usual price is 1 gas per 1 computational step plus
GHOST protocol (Greedy Heaviest Observed Subtree) [30]. It fixed additional price of 5 gas for every byte in the data area, but
is created to tackle the issue of stale blocks in the network. The this value can be greater and is defined in GASPRICE field [13].
stale blocks can occur if one group of miners combined in a Since the miners are rewarded more if they process the
mining pool has more computing power than the others, transaction with higher GASPRICE, the sender has to choose
meaning that the blocks from the first pool will contribute more carefully the GASPRICE value if he wants his transaction to be
to the network, thus creating the centralization issue. GHOST processed. On the other hand, miners also have to acknowledge
protocol includes those stale blocks into calculations of the some minimal GASPRICE under which they refuse to process a
longest chain. transaction [31].
The centralization problem is removed through providing The Ethereum state transition function, which changes states
block rewards to stales, where the stale block receives 87.5% of of the sender and the recipient by executing a transaction, starts
the reward, and the nephew of that stale block receives the with verifying the correctness of the transaction (the signature is
remaining 12.5% of the reward. In this way, the miners are still valid and the nonce matches the nonce in the sender’s account).
rewarded even if their block didn’t become the part of the main If this is correct, then it calculates the transaction fee as
blockchain (those blocks are called uncles). Ethereum uses the STARTGAS * GASPRICE, subtracts this value from sender’s
modification of the GHOST protocol which includes uncles up account balance, and increments his nonce. If this is correct, the
to seven generations [13]. fee is paid per byte in the transaction and the requested amount
B. Ethereum accounts of Ether is transferred to the recipient. The receiving account is
created if it doesn’t already exist, and if it is a contract, then the
The Ethereum state is consisted of accounts, where each contract’s code is executed. If the sender doesn’t have enough
account has a 20-byte address and state transitions. The world amount of Ether for transaction or the code execution spend all
state is a mapping between addresses and account states [31]. the gas, the state transition function reverts all state changes
Ethereum supports two types of accounts: externally owned except the payment fees for the miners [13].
(controlled by private keys) and contract accounts (controlled by One contract can send a message to the other in the Ethereum
their contract code) [13]. An Ethereum account is made of four network. The message resembles the transaction, but is produced
fields: nonce, ether balance, contract code hash, and storage root by a contract. Same as with transactions, the message induces
[30], [31]. that the recipient account runs its code.
Nonce represents the number of transactions sent from D. Ethereum blockchain
particular address or the number of contract creations made by
an account and is used as a guarantee that each transaction can An Ethereum blockchain is similar to the Bitcoin blockchain.
only be processed once. Ether balance is the number of Wei The main difference is that Ethereum blocks contain not only the
owned by this address (Wei represents the smallest fraction of block number, difficulty, nonce, etc. but also the transaction list
Ether, one Ether – ETH, Đ, being equal to 1018 Wei). Ether is and the most recent state. For every transaction in the transaction
used for paying transaction fees. Contract code hash is the list, the new state is created by applying the previous state.
Keccak-256 hash of Ethereum Virtual Machine (EVM) code of The block header in the Ethereum blockchain consists of the
the account, which is executed if an address receives a message Keccak 256-bit hash of the parent block’s header, the address of
call. Storage root is the 256-bit hash of the root node of a Merkle the mining fee recipient, hashes of the roots of state, transaction,
and receipts tries, the difficulty, the current gas limit of the F. ERC20 Token
block, a number representing total gas used in the block Ethereum as a platform is suitable for the issuance of tokens.
transactions, timestamp, nonce, and several extra hashes for Ethereum based tokens are smart contracts that implement the
verification purposes [31]. ERC20 Token Standard. This standard defines a contract that
One of the biggest problems of the Bitcoin’s network is the has to be implemented and is consisted of 6 functions and 2
eligibility for ASIC mining. Ethereum uses Ethash as the proof- events that fully describe an account [42]:
of-work algorithm which is memory heavy and thus less suitable contract ERC20Interface {
for ASIC mining. Ethash represents the modification of the function totalSupply() public constant returns (uint);
Dagger-Hashimoto algorithm [33], [34]. function balanceOf(address tokenOwner) public constant returns (uint
balance);
Every node in the Ethereum network runs under EVM and function allowance(address tokenOwner, address spender) public constant
executes its instructions. The smart contracts are translated into returns (uint remaining);
EVM code and then executed by the nodes [31]. One of the most function transfer(address to, uint tokens) public returns (bool success);
function approve(address spender, uint tokens) public returns (bool
popular programming language for writing smart contracts is success);
Solidity. function transferFrom(address from, address to, uint tokens) public returns
(bool success);
Ethereum block time is around 15 seconds, with several event Transfer(address indexed from, address indexed to, uint tokens);
peaks up to 30 seconds for a period of time. Using Geth event Approval(address indexed tokenOwner, address indexed spender, uint
blockchain client with fast sync, the Ethereum blockchain size tokens);
is 47.43GB as of the 29th of January 2018 [35]. }
Although there are concerns about Ethereum scalability, it V. CONCLUSION
was recorded that the Ethereum network successfully managed
Bitcoin and Ethereum today are the most known and
over one million unique transactions in 24 hours, averaging at
valuable cryptocurrencies. They are based on blockchain
around 11 transactions per second [36]. “Serenity” prototype of
technology that is intended to promote a trust mechanism in a
Ethereum platform based on the Casper consensus algorithm,
peer-to-peer network based on the consensus of the majority of
intended for later implementation, is supposed to enable the
the nodes. We have shown in this paper a short chronological
transition to the proof-of-stake mining paradigm, where the
survey of the early stages of the digital money implementation,
reward is given to the miners not based on their computations,
as well as the foundations of blockchain technology, and it’s
but on their coin holdings (the more coins the user possesses, the
most promising (or popular) implementations, Bitcoin and
bigger reward gains) [37].
Ethereum.
The potential usages of Ethereum are described as token
In the past few years, there has been a rapid growth of
systems, financial derivatives, identity and reputation systems,
numerous cryptocurrencies, hashing algorithms, and consensus
file storage, insurance, cloud computing, prediction markets, etc.
agreements in the networks. Some of the cryptocurrencies worth
[29]. The most important use case of Ethereum are decentralized
mentioning are Ripple, Cardano, NEO, Stellar, Litecoin, EOS,
apps (Dapps). Some of them are Golem (supercomputing),
IOTA, Dash, Monero, TRON, Qtum, Lisk, Tether, Stratis,
Augur (prediction markets), Civic (identity verification and
Zcash, Steem, Siacoin, Verge, Electroneum, Nxt, Dogecoin, and
protection), OmiseGO (exchanges on a public blockchain), Storj
many more. The full list can be found at [43], and there are total
(renting the hard drive space), and many more who succeeded in
of 1,498 cryptocurrencies listed with 8,250 markets, with total
raising enough money through ICOs (Initial Coin Offerings) to
market capitalization of $556.471.064.589, as of the 30th of
be represented on the cryptocurrency market [38].
January 2018, 03:00 GMT.
E. Ethereum Classic
ACKNOWLEDGEMENT
The DAO (Decentralized Autonomous Organization) was
the venture capital fund with no management structure, who The work presented in this paper was funded by grant
aimed to raise the money for Ethereum Dapps that were TR32043 for the period 2011-2018, by the Ministry of
promising, by their own belief. The investments were distributed Education, Science, and Technological Development of the
via DAO tokens. Republic of Serbia.
The DAO succeeded to raise over $150 million in Ether from REFERENCE
more than 11,000 investors [38]. However, it was hacked for $50 [1] D. Chaum, “Untraceable electronic main, return addresses, and digital
million and this caused a disagreement in the Ethereum pseudonyms,” in Communications of the ACM, vol. 24, no. 2, pp. 84-88,
community should the investors get their Ether balances back. February 1981
This lead to a hard fork and on the block 1,920,000, on the 20th [2] L. Law, S. Sabett, and J. Solinas, “How to make a mint: the cryptography
of July 2016, the Ethereum Classic (ETC) was born. The hard of anonymous electronic cash,” American University Law Review, vol.
46, no. 4, pp. 1131-1162, 1996
fork continued under the old name Ethereum (ETH), while the
[3] C. Dwork and M. Naor, “Pricing via processing or combatting junk mail,”
original Ethereum before the hard fork was renamed to ETC in 12th Annual International Cryptology Conference, pp. 139-147, 1992
[38].
[4] W. Dai, “B-money,” 1998, available at: http://www:weidai:com/bmoney
Some of the announced Ethereum forks to come are Expanse [5] H. Finney, “RPOW,” 2004, available at:
[39], Ethereum Fog [40], and Ethereum Zero [41]. http://nakamotoinstitute.org/finney/rpow/
[6] N. Szabo, “Bit Gold,” 2005, available at: https://www.coindesk.com/50-blocks-segwit-bitcoins-coming-upgrade-
http://unenumerated.blogspot.rs/2005/12/bit-gold.html blockchain-game-changer/
[7] F. Tschorsch and B. Scheuermann, “Bitcoin and beyond: a technical [25] S. Sundararajan, “Blockstream launches micropayments processing
survey on decentralized digital currencies,” IEEE Communications system for Bitcoin apps,” January 2018, available at:
Surveys & Tutorials, vol. 18, no. 3, pp. 2084-2123, March 2016 https://www.coindesk.com/blockstream-launches-micropayments-
[8] V. Vishnumurthy, S. Chandrakumar, and E. G. Sirer, “KARMA: A secure processing-system-for-bitcoin-apps/
economic framework for peer-to-peer resourse sharing,” 1st Workshop on [26] Bitcoin Cash, https://www.bitcoincash.org
Economics of Peer-To-Peer Systems, 2003 [27] Bitcoin Gold Roadmap, available at: https://bitcoingold.org/wp-
[9] N. Szabo, “Secure property titles with owner authority,” 1998, available content/uploads/2017/10/BitcoinGold-Roadmap.pdf
at: http://nakamotoinstitute.org/secure-property-titles/ [28] A. Biryukov, D. Khovratovich, “Equihash: asymmetric proof-of-work
[10] D. Malkhi and M. Reiter, “Byzantine quorum systems,” Distributed based on the generalized birthday problem,” Ledger, vol. 2, pp. 1-30,
Computing, vol. 11, no. 4, pp. 203-213, 1998 April 2017
[11] J. Douceur, “The Sybil attack,” in Proceedings of IPTPS '01 Revised [29] V. Buterin, “Ethereum white paper: a next generation smart contract &
Papers from the First International Workshop on Peer-to-Peer Systems, decentralized application platform,” 2013, available at: http://www.the-
pp. 251-260, March 2002 blockchain.com/docs/Ethereum_white_paper-
[12] S. Nakamoto, “Bitcoin: a peer-to-peer electronic cash system,” 2008, a_next_generation_smart_contract_and_decentralized_application_platf
available at: https://bitcoin.org/bitcoin.pdf orm-vitalik-buterin.pdf
[13] Ethereum Community, “A next-generation smart contract and [30] Y. Sompolinsky and A. Zohar, “Secure high-rate transaction processing
decentralized application platform,” White Paper, available at: in Bitcoin,” Financial Cryptography, pp. 507-527, 2015
https://github.com/ethereum/wiki/wiki/White-Paper [31] G. Wood, “Ethereum: a secure decentralised generalised transaction
[14] A. Back, “Hashcash – a denial of service counter-measure,” 2002, ledger, Byzantium version,” 2018, available at:
available at: http://www.hashcash.org/papers/hashcash.pdf https://ethereum.github.io/yellowpaper/paper.pdf
[15] D. Eastlake, 3rd and T. Hansen, “US Secure Hash Algorithms (SHA and [32] Merkle Patricia Trie Specification (also Merkle Patricia Tree), available
SHA-based HMAC and HKDF),” RFC 6234 (Informational), May 2011, at: https://github.com/ethereum/wiki/wiki/Patricia-Tree
available at: http://www.ietf.org/rfc/rfc6234.txt [33] V. Buterin, “Dagger: A Memory-Hard to Compute, Memory-Easy to
[16] R. Merkle, “A digital signature based on a conventional encryption Verify Scrypt Alternative,” 2013, available at:
function,” In: Pomerance C. (eds) Advances in Cryptology — CRYPTO http://www.hashcash.org/papers/dagger.html
’87. CRYPTO 1987. Lecture Notes in Computer Science, vol 293. [34] T. Dryja, “Hashimoto: I/O bound proof of work,” 2014
Springer, Berlin, Heidelberg, pp. 369-378, 1987 [35] Etherscan, https://etherscan.io
[17] R. Merkle, “Protocols for public key cryptosystems,” in Proc. 1980 [36] J. Filiba, “Ethereum Breaks One Million Transactions in a Single Day,”
Symposium on Security and Privacy, IEEE Computer Society, pp. 122- December 2017, available at:
133, April 1980 https://discover.coinsquare.io/tech/ethereum-one-million-transaction-
[18] Bitcoin Blockchain Size, https://charts.bitcoin.com/chart/blockchain-size day/
[19] J. Poon and T. Dryja, “The bitcoin lightning netwiork: scalable off-chain [37] L. Silva, “Ethereum’s road map for 2017,” available at:
instant payments,”, 2016, available at: https://www.ethnews.com/ethereums-road-map-for-2017
https://lightning.network/lightning-network-paper.pdf [38] A. Moskov, “What is Ethereum?”, 2017, available at:
[20] M. Trillo, “Stress test prepares VisaNet for the most wonderful time of https://coincentral.com/what-is-ethereum/
the year,” 2013, available at: [39] M. Warner, “Expanse DAO Seeks to Develop Decentralised Ethereum,”
https://www.visa.com/blogarchives/us/2013/10/10/stress-test-prepares- November 2017, available at:
visanet-for-the-most-wonderful-time-of-the-year/index.html http://allcoinsnews.com/2017/11/09/expanse-dao-seeks-to-develop-
[21] A. Castor, “A short guide to Bitcoin forks,” March 2017, available at: decentralised-ethereum/
https://www.coindesk.com/short-guide-bitcoin-forks-explained/ [40] JP Buntinx, “What is Ethereum Fog?,” December 2017, available at:
[22] Transaction malleability, available at: https://themerkle.com/what-is-ethereum-fog/
https://en.bitcoin.it/wiki/Transaction_malleability [41] EtherZero — a Revolutionary Ethereum Hard Fork, Forking on 19th Jan
[23] Cointelegraph, SegWit explained, available at: 2018, available at: https://news.bitcoin.com/pr-etherzero-a-revolutionary-
https://cointelegraph.com/explained/segwit-explained ethereum-hard-fork-forking-on-19th-jan-2018/
[24] A. Hertig, “SegWit goes live: why Bitcoin’s big upgrade is a blockchain [42] ERC20 Token Standard, available at:
game-changer,” August 2017, available at: https://theethereum.wiki/w/index.php/ERC20_Token_Standard
[43] Cryptocurrency Market Capitalizations, https://coinmarketcap.com/