![]() |
Feathercoin
0.5.0
P2P Digital Currency
|
Data structure that represents a partial merkle tree. More...
#include <main.h>
Public Member Functions | |
uint256 | ExtractMatches (std::vector< uint256 > &vMatch) |
Protected Member Functions | |
unsigned int | CalcTreeWidth (int height) |
uint256 | CalcHash (int height, unsigned int pos, const std::vector< uint256 > &vTxid) |
void | TraverseAndBuild (int height, unsigned int pos, const std::vector< uint256 > &vTxid, const std::vector< bool > &vMatch) |
uint256 | TraverseAndExtract (int height, unsigned int pos, unsigned int &nBitsUsed, unsigned int &nHashUsed, std::vector< uint256 > &vMatch) |
Protected Attributes | |
unsigned int | nTransactions |
std::vector< bool > | vBits |
std::vector< uint256 > | vHash |
bool | fBad |
Data structure that represents a partial merkle tree.
It respresents a subset of the txid's of a known block, in a way that allows recovery of the list of txid's and the merkle root, in an authenticated way.
The encoding works as follows: we traverse the tree in depth-first order, storing a bit for each traversed node, signifying whether the node is the parent of at least one matched leaf txid (or a matched txid itself). In case we are at the leaf level, or this bit is 0, its merkle node hash is stored, and its children are not explorer further. Otherwise, no hash is stored, but we recurse into both (or the only) child branch. During decoding, the same depth-first traversal is performed, consuming bits and hashes as they written during encoding.
The serialization is fixed and provides a hard guarantee about the encoded size:
SIZE <= 10 + ceil(32.25*N)
Where N represents the number of leaf nodes of the partial tree. N itself is bounded by:
N <= total_transactions N <= 1 + matched_transactions*tree_height
The serialization format:
|
inlineprotected |
|
protected |