You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
0.10.1 (2024-09-13)
- Added
Serializable and Deserializable implementations for PartialMmr and InOrderIndex (#329).
0.10.0 (2024-08-06)
- Added more
RpoDigest and RpxDigest conversions (#311).
- [BREAKING] Migrated to Winterfell v0.9 (#315).
- Fixed encoding of Falcon secret key (#319).
0.9.3 (2024-04-24)
- Added
RpxRandomCoin struct (#307).
0.9.2 (2024-04-21)
- Implemented serialization for the
Smt struct (#304).
- Fixed a bug in Falcon signature generation (#305).
0.9.1 (2024-04-02)
- Added
num_leaves() method to SimpleSmt (#302).
0.9.0 (2024-03-24)
- [BREAKING] Removed deprecated re-exports from liballoc/libstd (#290).
- [BREAKING] Refactored RpoFalcon512 signature to work with pure Rust (#285).
- [BREAKING] Added
RngCore as supertrait for FeltRng (#299).
0.8.4 (2024-03-17)
- Re-added unintentionally removed re-exported liballoc macros (
vec and format macros).
0.8.3 (2024-03-17)
- Re-added unintentionally removed re-exported liballoc macros (#292).
0.8.2 (2024-03-17)
- Updated
no-std approach to be in sync with winterfell v0.8.3 release (#290).
0.8.1 (2024-02-21)
- Fixed clippy warnings (#280)
0.8.0 (2024-02-14)
- Implemented the
PartialMmr data structure (#195).
- Implemented RPX hash function (#201).
- Added
FeltRng and RpoRandomCoin (#237).
- Accelerated RPO/RPX hash functions using AVX512 instructions (#234).
- Added
inner_nodes() method to PartialMmr (#238).
- Improved
PartialMmr::apply_delta() (#242).
- Refactored
SimpleSmt struct (#245).
- Replaced
TieredSmt struct with Smt struct (#254, #277).
- Updated Winterfell dependency to v0.8 (#275).
0.7.1 (2023-10-10)
- Fixed RPO Falcon signature build on Windows.
0.7.0 (2023-10-05)
- Replaced
MerklePathSet with PartialMerkleTree (#165).
- Implemented clearing of nodes in
TieredSmt (#173).
- Added ability to generate inclusion proofs for
TieredSmt (#174).
- Implemented Falcon DSA (#179).
- Added conditional `serde`` support for various structs (#180).
- Implemented benchmarking for
TieredSmt (#182).
- Added more leaf traversal methods for
MerkleStore (#185).
- Added SVE acceleration for RPO hash function (#189).
0.6.0 (2023-06-25)
- [BREAKING] Added support for recording capabilities for
MerkleStore (#162).
- [BREAKING] Refactored Merkle struct APIs to use
RpoDigest instead of Word (#157).
- Added initial implementation of
PartialMerkleTree (#156).
0.5.0 (2023-05-26)
- Implemented
TieredSmt (#152, #153).
- Implemented ability to extract a subset of a
MerkleStore (#151).
- Cleaned up
SimpleSmt interface (#149).
- Decoupled hashing and padding of peaks in
Mmr (#148).
- Added
inner_nodes() to MerkleStore (#146).
0.4.0 (2023-04-21)
- Exported
MmrProof from the crate (#137).
- Allowed merging of leaves in
MerkleStore (#138).
- [BREAKING] Refactored how existing data structures are added to
MerkleStore (#139).
0.3.0 (2023-04-08)
- Added
depth parameter to SMT constructors in MerkleStore (#115).
- Optimized MMR peak hashing for Miden VM (#120).
- Added
get_leaf_depth method to MerkleStore (#119).
- Added inner node iterators to
MerkleTree, SimpleSmt, and Mmr (#117, #118, #121).
0.2.0 (2023-03-24)
- Implemented
Mmr and related structs (#67).
- Implemented
MerkleStore (#93, #94, #95, #107 #112).
- Added benchmarks for
MerkleStore vs. other structs (#97).
- Added Merkle path containers (#99).
- Fixed depth handling in
MerklePathSet (#110).
- Updated Winterfell dependency to v0.6.
0.1.4 (2023-02-22)
- Re-export winter-crypto Hasher, Digest & ElementHasher (#72)
0.1.3 (2023-02-20)
- Updated Winterfell dependency to v0.5.1 (#68)
0.1.2 (2023-02-17)
- Fixed
Rpo256::hash pad that was panicking on input (#44)
- Added
MerklePath wrapper to encapsulate Merkle opening verification and root computation (#53)
- Added
NodeIndex Merkle wrapper to encapsulate Merkle tree traversal and mappings (#54)
0.1.1 (2023-02-06)
- Introduced
merge_in_domain for the RPO hash function, to allow using a specified domain value in the second capacity register when hashing two digests together.
- Added a simple sparse Merkle tree implementation.
- Added re-exports of Winterfell RandomCoin and RandomCoinError.
0.1.0 (2022-12-02)
- Initial release on crates.io containing the cryptographic primitives used in Miden VM and the Miden Rollup.
- Hash module with the BLAKE3 and Rescue Prime Optimized hash functions.
- BLAKE3 is implemented with 256-bit, 192-bit, or 160-bit output.
- RPO is implemented with 256-bit output.
- Merkle module, with a set of data structures related to Merkle trees, implemented using the RPO hash function.