diff --git a/bip-op_energy.mediawiki b/bip-op_energy.mediawiki index cd27826..1db75ae 100644 --- a/bip-op_energy.mediawiki +++ b/bip-op_energy.mediawiki @@ -12,23 +12,36 @@ ==Abstract== -This BIP describes the new opcode OP_ENERGY, which is used to write and settle binary call contracts using bitcoin. The price for these contracts is a protocol measure of the energy cost of mining between two blocks, in hashes per satoshi. +This BIP describes the new opcode OP_ENERGY, which provides a price that can be used to write energy derivative contracts using bitcoin. This price is a protocol measure of the energy cost of mining between two blocks, in expected future hashes per satoshi. ==Summary== ===Calculation of OP_ENERGY Price=== -The motivation for this formula is given in the OP_ENERGY whitepaper.https://github.com/tphyahoo/bip-thomashartman-op_energy/blob/master/OP_ENERGY_Whitepaper.mediawiki#OP_ENERGY_The_Dampened_Price_of_Satoshis_in_Hashes_Between_Two_Blocks +Roughly, price is: + +
+(miner hashes / miner revenue) * (expected seconds / actual seconds) ++ +Assuming stable revenue: + +
+price(difficulty epoch) = hashes_per_satoshi (difficulty epoch + 1) ++ +So, generalizing from difficulty epoch to any block span, price is expected future hashes_per_satoshi.https://github.com/tphyahoo/bip-thomashartman-op_energy/blob/master/OP_ENERGY_Whitepaper.mediawiki#OP_ENERGY_The_Dampened_Price_of_Satoshis_in_Hashes_Between_Two_Blocks The exact definition is:
op_energy_price block1 block2 = pack_uint256 price' - where - price' = ( ( hashes `div` satoshis ) * expectedSeconds ) `div` actualSeconds + where + price' = ( hashes * expectedSeconds ) `div` (actualSeconds * satoshis) hashes = chainwork (block2) - chainwork (block1) - satoshis = chainRevenue (block2) - chainRevenue (block1) - where chainRevenue is sum of all miner rewards (subsidy + fees) up to this block + satoshis = if revenue == 0 then 1 else revenue + where revenue = chainRevenue (block2) - chainRevenue (block1) + chainRevenue is sum of all coinbase rewards (coinbase) up to this block expectedSeconds = 600 * (block2 - block1) actualSeconds = median_time_past (block2) - median_time_past (block1) where median_time_past is median time of previous 11 blocks as defined in bip 113 @@ -36,20 +49,21 @@ op_energy_price block1 block2 = pack_uint256 price' div = integer division-Implementation notes: -* Unless otherwise noted, all values in the above calculation are ordinary integers.=Due to the cbits packing in the last step, this could technically overflow if price' overflows 2^256, but this seems to be impossible given that bitcoin is already using on the order of 0.1% of global energy and is thus unlikely to rise more than 1000x. A great many orders of magnitude more than 1000x would be required for the overflow issue to arise. +* Unless otherwise noted, all values in the above calculation are ordinary integers. -* ActualSeconds is guaranteed to be positive, as the 11 block median time past increases with every block. This is because, per protocol rules, the block time stamp must be greater than the block median time past https://en.bitcoin.it/wiki/Block_timestamp. +* Due to the cbits packing in the last step, price could technically overflow if price' overflows 2^256, but this seems to be impossible given that bitcoin is already using on the order of 0.1% of global energy and is thus unlikely to rise more than 1000x. A great many orders of magnitude more than 1000x would be required for the overflow issue to arise. -* The subsidy part of the miner reward is the protocol approved subsidy, which can be looked up from the block number. Actual subsidy differs from this by a few satoshis, presumably due to miner error https://medium.com/amberdata/why-the-bitcoin-supply-will-never-reach-21-million-7263e322de1. +todo: double check this. Note also that if satoshis and actualSeconds are both 1, price could be hashes * expectedSeconds, so verify this is no overflow problem with this as well. -===Script Interpreter Behavior=== +* ActualSeconds is guaranteed to be positive, as the 11 block median time past increases with every block. This is because, per protocol rules, the block time stamp must be greater than the block median time past https://en.bitcoin.it/wiki/Block_timestamp. -OP_ENERGY redefines the existing NOP_TBD (to be determined) opcode to write and settle binary calls. +===Script Interpreter Behavior=== ====Writing (Buy/Sell)==== +todo: maybe this should only return the price after all. + OP_ENERGY block1 block2 strike-price funds-address Alice (the buyer) and Bob (the seller) agree on terms of an OP_ENERGY binary call contract: block span (block1 to block2), strike, premium, and settlement. @@ -98,10 +112,6 @@ The same 100 block burying condition as for spending miner rewards applies to OP todo: if we are using taproot, as I believe zmnscpxj claimed is necessary, what are implications of nodes enforcing this 100 block burying condition, if the script itself is obfuscated via taproot? -===Penalization of Uneconomic Transactions=== - -To do - ==Motivation== As Bitcoin lets untrusted parties send value over a communications channel, OP_ENERGY lets untrusted parties trade energy derivatives over a communications channel. Rather than price financial instruments in dollars per unit of some commodity, or bitcoin per unit of some asset, prices for OP_ENERGY contracts are given in hashes per satoshi.