What is the optimal way to increment extranonce?


I'm trying to learn how to block headers are created and an efficient way of doing so. Given a list .of transactions, can I change the extranonce without having to rehash the entire list?

EDIT: To clarify, I am not asking about what the extranonce is but whether there are algorithms to recompute the merkletree better than others.


Posted 2020-06-17T10:43:46.130

Reputation: 13

If one has only one change in the Merkle tree the complexity to compute the hash is O(lg(n)) because other branches are hashes are reused. No further speedup is possible (except Asicboost) as even one bit change in coinbase transaction causes avalon effect. – MCCCS – 2020-06-18T15:07:01.097

Thanks! This answers the question. I take it that the coinbase Tx must go into the start then – Wil – 2020-06-18T17:20:30.230

The extra nonce is indeed additional space in coinbase. I don't see any reason why you cannot precompute all the extranonce fields. So, even the log(n) time could be amortized – sanket1729 – 2020-06-19T07:54:20.350

I think you can get ln(n)/ln(2) with precomputation. But it is less if the coinbase tx didn’t go into the bottom. And I guess it needs to go into the bottom? – Wil – 2020-06-20T09:00:06.340

Each transactions is a leaf at the bottom level of the Merkle tree. – Murch – 2020-07-18T17:20:08.783



The Merkle root of the transactions is calculated by building a binary tree from the transactions as leaves where each parent node is the hash of its two children. As the coinbase transaction is the first transaction in the block, you can store the hashing partners on the coinbase transaction's Merkle branch and only repeat all the hashes to which the coinbase transaction contributes. This reduces the required number of hashes to calculate the new Merkle root for n transactions from O(n) to O(log(n)) given that no other transactions in the block were changed.

There is no way around repeating the whole left flank of hashes in the binary tree, since changing the extranonce in the coinbase transaction changes the outcome of the bottom left hash combining coinbase transaction and first regular transaction.


Posted 2020-06-17T10:43:46.130

Reputation: 51 063


The extranonce is a part of the coinbase transaction, inside the coinbase transaction there is an arbitrary data, and when you change this data, your merkle will change too


Posted 2020-06-17T10:43:46.130

Reputation: 79

I ask about algorithms to achieve this efficiently, not what the extranonce is – Wil – 2020-06-18T14:31:02.267