Revision as of 00:27, 19 November 2020 by Brendan (talk | contribs)

Coinbase is the special name given to the first transaction in every block. These can also be called 'Generation Transactions'.

The winning Miner creates this special transaction as part of the block templating process.

A coinbase transaction follows the same format as a normal transaction, except:

  • It has exactly one txin.
  • This txin's prevout hash is 0000...0000.
  • This txin's prevout index is 0xFFFFFFFF.
  • The txin's prevout script is an arbitrary byte array which has historically been used by Miners to signal identity and pass messages from block winning nodes to the rest of the network.
  • The sum of the values of all txout's cannot exceed the total of the Miner subsidy and the mining fees paid by all other transactions included in the block.

A part of the coinbase can also used as an 'extra nonce' during the block discovery process due to a single ASIC Miner being able to test more combinations than allowed for, in the 2^32 possible combinations that changing the nonce in the block header can create. The extra nonce field is incremented in the Coinbase transaction, which requires that a small number of hashes in the merkle tree are updated, changing the Merkle root in the block header allowing for a further 2^32 possible block hashes to be attempted.

A Coinbase transaction can have as many outputs attached as are needed by the miner. Thes can be used for second layer functions including:

  • Merchant API, otherwise known as MAPI, allows the winning Miner to create multiple as needed to distribute the funds to stakeholders, and may use False Return scripts to embed data such as details of the details of the transaction pricing service.
  • MinerID also uses the Coinbase transaction to present information to the network such as node identity, transaction pricing data and more. This data will use standard formats such that user wallets shall be able to read and parse the information, giving them up-to-date knowledge of which nodes are competing on the network and more.

[BIP 0034] mandated that the block height value be specified in the first item of the coinbase transaction. Prior to this, the coinbase script size was between 2 and 100 bytes. Currently the minimum length is 4 bytes which is needed to hold the blockheight in a VarInt. The maximum value storable in 3 bytes is 16,777,215 so with the generating blocks at a rate of approximately 59,000 per year so if this level of network activity is sustained then from approximately the year 2,300 the minimum length of a coinbase script size will need to increase to 5 bytes.