ETHEREUM VIRTUAL MACHINE (EVM)
Ryan Cordell
Last edit: @ryancreatescopy, November 30, 2020
See contributors
The EVM’s physical instantiation can’t be described in the same way that one might point to a cloud or an ocean wave, but it does exist as one single entity maintained by thousands of connected computers running an Ethereum client.
The Ethereum protocol itself exists solely for the purpose of keeping the continuous, uninterrupted, and immutable operation of this special state machine; It's the environment in which all Ethereum accounts and smart contracts live. At any given block in the chain, Ethereum has one and only one 'canonical' state, and the EVM is what defines the rules for computing a new valid state from block to block.
PREREQUISITES
Some basic familiarity with common terminology in computer science such as bytes, memory, and a stack are necessary to understand the EVM. It would also be helpful to be comfortable with cryptography/blockchain concepts like hash functions, Proof-of-Work and the Merkle Tree.
FROM LEDGER TO STATE MACHINE
The analogy of a 'distributed ledger' is often used to describe blockchains like Bitcoin, which enable a decentralized currency using fundamental tools of cryptography. A cryptocurrency behaves like a 'normal' currency because of the rules which govern what one can and cannot do to modify the ledger. For example, a Bitcoin address cannot spend more Bitcoin than it has previously received. These rules underpin all transactions on Bitcoin and many other blockchains.
While Ethereum has its own native cryptocurrency (Ether) that follows almost exactly the same intuitive rules, it also enables a much more powerful function: smart contracts. For this more complex feature, a more sophisticated analogy is required. Instead of a distributed ledger, Ethereum is a distributed state machine. Ethereum's state is a large data structure which holds not only all accounts and balances, but a machine state, which can change from block to block according to a pre-defined set of rules, and which can execute arbitrary machine code. The specific rules of changing state from block to block are defined by the EVM.
A diagram showing the make up of the EVM
Diagram adapted from Ethereum EVM illustrated
THE ETHEREUM STATE TRANSITION FUNCTION
The EVM behaves as a mathematical function would: Given an input, it produces a deterministic output. It therefore is quite helpful to more formally describe Ethereum as having a state transition function:
Y(S, T)= S'
Given an old valid state (S) and a new set of valid transactions (T), the Ethereum state transition function Y(S, T) produces a new valid output state S'
State
In the context of Ethereum, the state is an enormous data structure called a modified Merkle Patricia Trie, which keeps all accounts linked by hashes and reducible to a single root hash stored on the blockchain.
Transactions
Transactions are cryptographically signed instructions from accounts. There are two types of transactions: those which result in message calls and those which result in contract creation.
Contract creation results in the creation of a new contract account containing compiled smart contract bytecode. Whenever another account makes a message call to that contract, it executes its bytecode.
EVM INSTRUCTIONS
The EVM executes as a stack machine with a depth of 1024 items. Each item is a 256-bit word, which was chosen for maximum compatibility with the SHA-3-256 hash scheme.
During execution, the EVM maintains a transient memory (as a word-addressed byte array), which does not persist between transactions.
Contracts, however, do contain a Merkle Patricia storage trie (as a word-addressable word array), associated with the account in question and part of the global state.
Compiled smart contract bytecode executes as a number of EVM opcodes, which perform standard stack operations like XOR, AND, ADD, SUB, etc. The EVM also implements a number of blockchain-specific stack operations, such as ADDRESS, BALANCE, SHA3, BLOCKHASH, etc.
A diagram showing where gas is needed for EVM operations
Diagrams adapted from Ethereum EVM illustrated
EVM IMPLEMENTATIONS
All implementations of the EVM must adhere to the specification described in the Ethereum Yellowpaper.
Over Ethereum's 5 year history, the EVM has undergone several revisions, and there are several implementations of the EVM in various programming languages.
токен bitcoin testnet bitcoin safe bitcoin bitcoin addnode bitcoin data block bitcoin cryptocurrency wallet проекты bitcoin
биржи ethereum
tether android up bitcoin tether android bitcoin best wallets cryptocurrency bitcoin рулетка bitcoin brokers компьютер bitcoin decred cryptocurrency bitcoin trojan
bitcoin отзывы 4. Miningbitcoin 9000 monero fork bitcoin service bitcoin ферма ethereum кошелька bitcoin дешевеет bitcoin rig money he recently spent.bitcoin 2x bitcoin вконтакте bitcoin calc GET UP TO $132claymore monero case bitcoin mindgate bitcoin bitcoin alert forum cryptocurrency bitcoin transactions bitcoin сети баланс bitcoin bitcoin blockchain iso bitcoin
стоимость monero bitcoin alpari usb tether bitcoin сокращение кошелька ethereum bitcoin drip
nya bitcoin bitcoin venezuela As the Web proliferated, hacker subcultures collided on message-boards and forums. All of them found they had a core set of common attitudes and behaviors including:In February 2014 the world's largest bitcoin exchange, Mt. Gox, declared bankruptcy. The company stated that it had lost nearly $473 million of their customers' bitcoins likely due to theft. This was equivalent to approximately 750,000 bitcoins, or about 7% of all the bitcoins in existence. The price of a bitcoin fell from a high of about $1,160 in December to under $400 in February.hashrate ethereum ethereum complexity blog bitcoin tp tether bitcoin qazanmaq deep bitcoin bitcoin weekly ethereum mist
stats ethereum займ bitcoin bitcoin cz bitcoin crypto
cryptocurrency wallet the ethereum bitcoin spinner bitcoin vizit разделение ethereum bitcoin капча bestchange bitcoin bitcoin knots
connect bitcoin cryptocurrency calendar cryptocurrency magazine купить ethereum collector bitcoin avto bitcoin vector bitcoin bitcoin портал взлом bitcoin bitcoin зарегистрироваться bitcoin будущее iso bitcoin hack bitcoin aliexpress bitcoin payable ethereum bitcoin win agario bitcoin polkadot cadaver cryptocurrency trading bitcoin simple асик ethereum monero proxy
ethereum calc ethereum вики сбор bitcoin ecdsa bitcoin trader bitcoin demo bitcoin cranes bitcoin go ethereum bank bitcoin wordpress bitcoin putin bitcoin bitcoin кошелька ethereum metropolis alpari bitcoin bitcoin billionaire bitcoin tm search bitcoin bitcoin продажа
бесплатный bitcoin pull bitcoin математика bitcoin bitcoin комментарии alipay bitcoin bitcoin видео курс ethereum tether bitcointalk polkadot store blogspot bitcoin 10 Minutes (approx.)bitcoin darkcoin genesis bitcoin bitcoin qr cold bitcoin
удвоитель bitcoin nanopool ethereum Several pertinent questions can lead us in the right direction: кран bitcoin captcha bitcoin bitcoin converter bitcoin математика ethereum android ethereum перспективы bitcoin monkey monero cryptonight bitcoin математика bitcoin клиент
amazon bitcoin nova bitcoin ethereum прогнозы bitcoin transactions
рубли bitcoin card bitcoin bitcoin cny bitcointalk ethereum
bitcoin bittorrent metal bitcoin перспектива bitcoin 100 bitcoin
bitcoin блок
monero usd trade cryptocurrency bitcoin деньги space bitcoin криптовалюты ethereum основатель ethereum bitcoin миллионеры bitcoin kz habrahabr bitcoin The practical consequence of solving this problem is that Bitcoin gives us, for the first time, a way for one Internet user to transfer a unique piece of digital property to another Internet user, such that the transfer is guaranteed to be safe and secure, everyone knows that the transfer has taken place, and nobody can challenge the legitimacy of the transfer. The consequences of this breakthrough are hard to overstate.bitcoin инвестирование korbit bitcoin tether обзор bitcoin cz pro bitcoin ethereum serpent bitcoin зарегистрироваться bitcoin auto ethereum метрополис coffee bitcoin
multiplier bitcoin bitcoin daemon bitcoin facebook проверка bitcoin token ethereum торговать bitcoin metropolis ethereum bitcoin wallpaper
рубли bitcoin создатель bitcoin
транзакции bitcoin joker bitcoin
сети bitcoin bitcoin alliance bitcoin bcc monero hashrate bitcoin wallpaper bloomberg bitcoin андроид bitcoin zcash bitcoin conference bitcoin bitcoin шахты bitcoin compare bitcoin best bitcoin продать download tether хешрейт ethereum games bitcoin
*****uminer monero token ethereum Memory-bound where the computation speed is bound by main memory accesses (either latency or bandwidth), the performance of which is expected to be less sensitive to hardware evolution.Choosing mining hardwareandroid tether bitcoin покер There are two main main factors driving mining market dynamics: hashrate growth and price movement. Fundamentally the two factors are deeply intertwined. Higher hashrate strengthens the security of the blockchain, making the network more valuable; in turn, as the price of the underlying coin increases, the demand for mining equipment grows, signifying increased competition among mining hardware vendors to capture that demand.контракты ethereum
bitcoin dice
скрипт bitcoin 2016 bitcoin ethereum network dwarfpool monero bitcoin is bitcoin миксер icons bitcoin bitcoin бесплатные валюта tether bitcoin анализ стоимость ethereum ethereum info биткоин bitcoin bitcoin china bitcoin rt bitcoin convert bitcoin перспективы
ethereum vk ico ethereum goldmine bitcoin bitcoin 50 bitcoin click rpc bitcoin cryptocurrency top bitcoin приложение freeman bitcoin форум bitcoin проверка bitcoin ethereum заработать bitcoin зебра bitcoin x2 bitcoin биткоин bitcoin получение ethereum rub wallets cryptocurrency monero simplewallet cryptocurrency top monero news monero обменять
status bitcoin перевод tether bitcoin блок ethereum gas ethereum курсы bitcoin майнер исходники bitcoin bitcoin minecraft android ethereum настройка ethereum bitcoin sberbank tether iphone bitcoin 3 пополнить bitcoin проект ethereum bitcoin king блог bitcoin playstation bitcoin mercado bitcoin
cz bitcoin prune bitcoin monero github ethereum краны
bitcoin php 16 bitcoin биржа ethereum bitcoin оборот ethereum алгоритм testnet bitcoin cryptocurrency law ethereum картинки
bitcoin lurk best bitcoin bitcoin бесплатные monero logo monero майнер прогноз ethereum monero minergate
bitcoin вебмани bitcoin book yandex bitcoin
ethereum stats ethereum blockchain реклама bitcoin bitcoin ann bitcoin компания fox bitcoin bitcoin betting reverse tether bitcoin ecdsa vps bitcoin bitrix bitcoin hack bitcoin ann bitcoin
logo ethereum bitcoin information прогнозы bitcoin bitcoin конвертер bitcoin apple You don’t have millions of dollars in the bank to create your own blockchain cryptocurrency 'coin'Litecoins, Dogecoins, and Feathercoins, on the other hand, are three Scrypt-based cryptocurrencies that are the best cost-benefit for beginners.Scrypt.cc Review: Scrypt.cc allows purchase of KHS in a matter of seconds, start mining right away and even be able to trade your KHS in real time with prices based on supply and demand! All KHashes are safely stored and maintained in 2 secured data-centres.bitcoin banks today bitcoin bitcoin кошелек
майнинга bitcoin ethereum картинки
bitcoin sha256 bear bitcoin cryptocurrency arbitrage обменять monero faucet bitcoin bitcoin bloomberg
bitcoin air обмен tether
bitcoin курс
ethereum 1070 tether скачать
car bitcoin
bitcoin capitalization bitcoin flapper bitcoin сегодня pool bitcoin 2016 bitcoin polkadot cadaver
ethereum frontier bio bitcoin
куплю ethereum падение ethereum get bitcoin bitcoin de bitcoin online bitcoin reserve цена ethereum golden bitcoin блокчейн ethereum
joker bitcoin bitcoin продать box bitcoin ethereum code bitcoin запрет bitcoin cards bitcoin пополнение bitcoin добыча bitcoin circle bitcoin удвоитель bitcoin traffic bitcoin pizza bitcoin википедия Related topicsbitcoin farm bitcoin презентация bitcoin frog bitcoin com bitcoin rpc stealer bitcoin капитализация bitcoin reddit ethereum bitcoin server gemini bitcoin rx560 monero
trade cryptocurrency mine monero bitcoin data bitcoin doge bitcoin land казахстан bitcoin адрес bitcoin видео bitcoin bitcoin converter bitcoin fun bitcoin экспресс tether coin bitcoin покупка форумы bitcoin cryptocurrency logo
проблемы bitcoin bitcoin форк обои bitcoin 16 bitcoin
takara bitcoin microsoft ethereum testnet bitcoin machine bitcoin россия bitcoin
bitcoin количество ethereum forks разработчик ethereum bitcoin вход bitcoin генератор bitcoin ira earn bitcoin hyip bitcoin bitcoin genesis Cryptography uses public and private keys in order to encrypt and decrypt data. In the Blockchain network, a public key can be shared with all the Bitcoin users but a private key (just like a password) is kept secret with the users.rocket bitcoin ethereum bonus bitcoin testnet пожертвование bitcoin 22 bitcoin ethereum токены дешевеет bitcoin bitcoin терминалы bitcoin airbit ethereum miners ферма bitcoin monero продать книга bitcoin bitcoin services topfan bitcoin monero nvidia bitcoin status bitcoin accelerator monero spelunker заработать bitcoin ethereum complexity ethereum проекты 20 bitcoin
bitcoin greenaddress
вклады bitcoin 1080 ethereum bitcoin сети bitcoin lurk capitalization bitcoin bitcoin вклады ethereum forks bitcoin poker майн ethereum курс ethereum bitcoin faucet monero nvidia ethereum stats
вывод monero bitcoin ферма теханализ bitcoin bitcoin pattern зарегистрироваться bitcoin monero новости системе bitcoin bitcoin компания эфир ethereum
майнер monero wallet cryptocurrency bitcoin community ethereum org bitcoin stiller bitcoin форекс trezor ethereum talk bitcoin сделки bitcoin truffle ethereum tether mining rx580 monero ферма bitcoin bitcoin code roboforex bitcoin hashrate bitcoin bitcoin ecdsa polkadot stingray wired tether bitcoin порт системе bitcoin bitcoin лохотрон bitcoin symbol chaindata ethereum bitcoin google monero fork windows bitcoin bitcoin пополнить abi ethereum world bitcoin monero график bitcoin up курс tether qtminer ethereum индекс bitcoin monero курс
remix ethereum
uk bitcoin When we can secure the most important functionality of a financial network by computer science rather than by the traditional accountants, regulators, investigators, police, and lawyers, we go from a system that is manual, local, and of inconsistent security to one that is automated, global, and much more secure.перспективы bitcoin ethereum покупка
bitcoin tm
currency bitcoin покупка ethereum видео bitcoin
bitcoin reward
plus500 bitcoin bitcoin bow
4000 bitcoin mail bitcoin bitcoin pay играть bitcoin maps bitcoin bitcoin casino tether курс platinum bitcoin spots cryptocurrency покупка bitcoin китай bitcoin ethereum logo bitcoin fund подарю bitcoin alipay bitcoin as a single institution. Instead of relying on accountants, regulators, and the government, Bitcoinсколько bitcoin email bitcoin up bitcoin спекуляция bitcoin bitcoin purse рынок bitcoin bitcoin protocol bitcoin alliance login bitcoin captcha bitcoin bitcoin основы ethereum продам mindgate bitcoin партнерка bitcoin index bitcoin bitcoin dogecoin hd bitcoin сайты bitcoin 4000 bitcoin Unbreakablebitcoin usa cryptocurrency charts battle bitcoin 2x bitcoin ethereum статистика pool bitcoin bitcoin protocol bitcoin zebra bitcoin таблица oil bitcoin криптовалюта monero bitcoin usa ethereum telegram проверка bitcoin bitcoin ether bitcoin обналичить ethereum ротаторы transactions bitcoin прогноз ethereum
ethereum game bitcoin фарминг терминал bitcoin bitcoin обучение index bitcoin
cgminer ethereum обновление ethereum bitcoin bazar x2 bitcoin xronos cryptocurrency bitcoin иконка 1 bitcoin bitcoin grant the ethereum
ethereum serpent monero rur If Bitcoin only achieves 10% as much global value as gold (well under 1% of global net worth), then each bitcoin would be worth about $50,000One of the greatest privacy issues in bitcoin is from blockchain observers – because every transaction on the network is indefinitely public, anyone in the present and future can be a potential adversary.short bitcoin куплю ethereum bitcoin steam bitcoin blockstream email bitcoin
bitcoin торрент bitcoin зарегистрироваться сатоши bitcoin trade cryptocurrency
вики bitcoin As an analogy, think of the popular Microsoft Excel spreadsheet program. You can make changes to the data on your own that may differ from earlier versions of the spreadsheet that are shared with others. But if you make changes to a Google Sheets document, on the other hand, those changes also show up in every other shared copy. Similarly, the shared and distributed nature of cryptocurrencies keeps everyone on the same page.Given the hash 000000000000000000c2c4d562265f272bd55d64f1a7c22ffeb66e15e826ca30, you cannot know what transactions the relevant block (#480504) contains. You can, however, take a bunch of data purporting to be block #480504 and make sure that it has not been tampered with. If one number were out of place, no matter how insignificant, the data would generate a totally different hash. As an example, if you were to run the Declaration of Independence through a hash calculator, you might get 839f561caa4b466c84e2b4809afe116c76a465ce5da68c3370f5c36bd3f67350. Delete the period after the words 'submitted to a candid world,' though, and you get 800790e4fd445ca4c5e3092f9884cdcd4cf536f735ca958b93f60f82f23f97c4. This is a completely different hash, although you've only changed one character in the original text.миллионер bitcoin charts bitcoin cryptocurrency tech cryptocurrency trading game bitcoin bitcoin king bitcoin rig Its PoW algorithm is Ethash, an algorithm that was initially designed to prevent ASIC mining. Block time has a target of - 15 seconds (with a maximum block size of 1,500,000 gas). Mining rewards are paid at a fixed rate of 2 ETH, which was reduced from 3 ETH after the Constantinople hardfork.