#poseidon-hash #sponge #prime-field #poseidon #rescue

nightly rescue_poseidon

Sponge construction based Algebraic Hash Functions

12 releases

0.30.10 Nov 28, 2024
0.30.9 Nov 21, 2024
0.30.6 Oct 31, 2024
0.30.1 Sep 5, 2024
0.4.1 Jul 5, 2024

#229 in Cryptography

Download history 14902/week @ 2024-08-21 17832/week @ 2024-08-28 18670/week @ 2024-09-04 15946/week @ 2024-09-11 5627/week @ 2024-09-18 5198/week @ 2024-09-25 7098/week @ 2024-10-02 10233/week @ 2024-10-09 8449/week @ 2024-10-16 9956/week @ 2024-10-23 7523/week @ 2024-10-30 6030/week @ 2024-11-06 5722/week @ 2024-11-13 3761/week @ 2024-11-20 3827/week @ 2024-11-27 2066/week @ 2024-12-04

16,667 downloads per month
Used in 16 crates (2 directly)

MIT/Apache

2MB
41K SLoC

Rescue and Poseidon

Overview

This repo contains implementations of arithmetization oriented hash functions(Rescue, Poseidon, Rescue Prime) that constructed by a sponge construction over prime field for both out-of circuits and in-circuit usages. Each algebraic hash function uses same sponge construction with different round function or permutation function. Gadgets are optimal in the constraint systems while also supporting different scalar fields which supported by bellman.

Usage

Add dependency

rescue_poseidon = 0.1
    use franklin_crypto::bellman::bn256::Fr;
    use franklin_crypto::bellman::Field;
    use rescue_poseidon::rescue_hash;

    const L: usize = 2;
    let input = [Fr::one(); L]; // dummy input

    // fixed length rescue hash
    let result = rescue_hash::<Bn256, L>(&input);
    assert_eq!(result.len(), 2);

More examples can be found in examples folder.

Testing

cargo test -- --nocapture

Benchmarks & Constraint System Costs

cargo bench -- --nocapture

CPU: 3,1 GHz Intel Core i5

hashes 1x permutation runtime (μs) 1x permutation gates number of rounds
Poseidon 13 166 8f + 33p
Rescue 680 266 44f
Rescue Prime 300 104 9f

References

Dependencies

~18MB
~328K SLoC