Package io.crums.util.mrkl
Class FixedLeafTree
java.lang.Object
io.crums.util.mrkl.Tree
io.crums.util.mrkl.FixedLeafTree
public class FixedLeafTree extends Tree
A more compact Tree appropriate if the leaves are fixed-width
 and it'all fits under 2 gigabytes.
- See Also:
- treeDataLength(int, int, int)
- 
Field SummaryFields Modifier and Type Field Description static intMIN_ALGO_WIDTHstatic intMIN_LEAF_WIDTHFields inherited from class io.crums.util.mrkl.TreeBRANCH_PAD, LEAF_PAD
- 
Constructor SummaryConstructors Modifier Constructor Description FixedLeafTree(int leaves, java.lang.String algo, byte[] data, int algoWidth, int leafWidth)Creates a new instance.protectedFixedLeafTree(FixedLeafTree copy)Copy constructor.
- 
Method SummaryModifier and Type Method Description byte[]data(int level, int index)Returns [a copy of] the data for the node at the specified coordinates.java.nio.ByteBufferdataBlock()Returns entire data block.protected java.nio.ByteBufferextraBlock()Returns the data beyond the standard definition of the tree.static booleanfitsModelCapacity(int leaves, int algoWidth, int leafWidth)inthashWidth()intleafWidth()Returns the fixed-size leaf width.java.nio.ByteBufferleavesBlock()Returns the leaves' data block.static inttreeDataLength(int leaves, int algoWidth, int leafWidth)Returns the number of bytes needed to encode the state of the tree, or -1 if that number exceeds the maximum int Java allows.Methods inherited from class io.crums.util.mrkl.TreeappendToStringDetail, getHashAlgo, hash, hashAlgoWidth, hashInternals, hashLeaves, hashUncommon, idx, isLeafWidthFixed, isOmniWidth, proof, root, toString, verifyMethods inherited from class java.lang.Objectclone, equals, finalize, getClass, hashCode, notify, notifyAll, wait, wait, wait
- 
Field Details- 
MIN_ALGO_WIDTHpublic static final int MIN_ALGO_WIDTH- See Also:
- Constant Field Values
 
- 
MIN_LEAF_WIDTHpublic static final int MIN_LEAF_WIDTH- See Also:
- Constant Field Values
 
 
- 
- 
Constructor Details- 
FixedLeafTreepublic FixedLeafTree(int leaves, java.lang.String algo, byte[] data, int algoWidth, int leafWidth) throws java.lang.IllegalArgumentExceptionCreates a new instance.- Parameters:
- leaves- number of leaf nodes in the tree
- algo- hash algo used for the trees internal nodes
- data- node data in serial form (interpreted by next parameters)
- algoWidth- number of bytes in the hash generated by algo
- leafWidth- number of bytes in a leaf node
- Throws:
- java.lang.IllegalArgumentException
 
- 
FixedLeafTreeCopy constructor.
 
- 
- 
Method Details- 
datapublic byte[] data(int level, int index)Description copied from class:TreeReturns [a copy of] the data for the node at the specified coordinates.- Specified by:
- datain class- Tree
- See Also:
- Node.data(),- #data(int, int, ByteBuffer)
 
- 
leafWidthpublic int leafWidth()Returns the fixed-size leaf width.
- 
dataBlockpublic java.nio.ByteBuffer dataBlock()Returns entire data block.- Returns:
- a new read-only view of the entire block.
 
- 
leavesBlockpublic java.nio.ByteBuffer leavesBlock()Returns the leaves' data block.- Returns:
- a new read-only view of leaves' block.
 
- 
extraBlockprotected java.nio.ByteBuffer extraBlock()Returns the data beyond the standard definition of the tree. This is a view of whatever bytes remain in the data block after the tree definition.- Returns:
- possibly empty extra block
 
- 
hashWidthpublic int hashWidth()
- 
fitsModelCapacitypublic static boolean fitsModelCapacity(int leaves, int algoWidth, int leafWidth)
- 
treeDataLengthpublic static int treeDataLength(int leaves, int algoWidth, int leafWidth)Returns the number of bytes needed to encode the state of the tree, or -1 if that number exceeds the maximum int Java allows.
 
-