Barretenberg
The ZK-SNARK library at the core of Aztec
Loading...
Searching...
No Matches
poseidon2_hash.hpp
Go to the documentation of this file.
1
// AUTOGENERATED FILE
2
#pragma once
3
4
#include <string_view>
5
6
#include "
barretenberg/common/bb_bench.hpp
"
7
#include "
barretenberg/relations/relation_parameters.hpp
"
8
#include "
barretenberg/relations/relation_types.hpp
"
9
#include "
barretenberg/vm2/generated/columns.hpp
"
10
11
namespace
bb::avm2
{
12
13
template
<
typename
FF_>
class
poseidon2_hashImpl
{
14
public
:
15
using
FF
= FF_;
16
17
static
constexpr
std::array<size_t, 20>
SUBRELATION_PARTIAL_LENGTHS
= { 3, 4, 4, 3, 3, 3, 3, 4, 4, 4,
18
5, 4, 4, 4, 4, 4, 4, 4, 4, 4 };
19
20
template
<
typename
AllEntities>
inline
static
bool
skip
(
const
AllEntities& in)
21
{
22
using
C
=
ColumnAndShifts
;
23
24
return
(in.get(C::poseidon2_hash_sel)).is_zero();
25
}
26
27
template
<
typename
ContainerOverSubrelations,
typename
AllEntities>
28
void
static
accumulate
(ContainerOverSubrelations& evals,
29
const
AllEntities& in,
30
[[maybe_unused]]
const
RelationParameters<FF>
&,
31
[[maybe_unused]]
const
FF
& scaling_factor);
32
};
33
34
template
<
typename
FF>
class
poseidon2_hash
:
public
Relation
<poseidon2_hashImpl<FF>> {
35
public
:
36
static
constexpr
const
std::string_view
NAME
=
"poseidon2_hash"
;
37
38
// Subrelation indices constants, to be used in tests.
39
static
constexpr
size_t
SR_TRACE_CONTINUITY
= 1;
40
static
constexpr
size_t
SR_SELECTOR_ON_END
= 6;
41
42
static
std::string
get_subrelation_label
(
size_t
index
)
43
{
44
switch
(
index
) {
45
case
SR_TRACE_CONTINUITY
:
46
return
"TRACE_CONTINUITY"
;
47
case
SR_SELECTOR_ON_END
:
48
return
"SELECTOR_ON_END"
;
49
}
50
return
std::to_string
(
index
);
51
}
52
};
53
54
}
// namespace bb::avm2
bb_bench.hpp
bb::Relation
A wrapper for Relations to expose methods used by the Sumcheck prover or verifier to add the contribu...
Definition
relation_types.hpp:96
bb::avm2::poseidon2_hash
Definition
poseidon2_hash.hpp:34
bb::avm2::poseidon2_hash::SR_TRACE_CONTINUITY
static constexpr size_t SR_TRACE_CONTINUITY
Definition
poseidon2_hash.hpp:39
bb::avm2::poseidon2_hash::NAME
static constexpr const std::string_view NAME
Definition
poseidon2_hash.hpp:36
bb::avm2::poseidon2_hash::SR_SELECTOR_ON_END
static constexpr size_t SR_SELECTOR_ON_END
Definition
poseidon2_hash.hpp:40
bb::avm2::poseidon2_hash::get_subrelation_label
static std::string get_subrelation_label(size_t index)
Definition
poseidon2_hash.hpp:42
bb::avm2::poseidon2_hashImpl
Definition
poseidon2_hash.hpp:13
bb::avm2::poseidon2_hashImpl::SUBRELATION_PARTIAL_LENGTHS
static constexpr std::array< size_t, 20 > SUBRELATION_PARTIAL_LENGTHS
Definition
poseidon2_hash.hpp:17
bb::avm2::poseidon2_hashImpl::accumulate
static void accumulate(ContainerOverSubrelations &evals, const AllEntities &in, const RelationParameters< FF > &, const FF &scaling_factor)
Definition
poseidon2_hash_impl.hpp:11
bb::avm2::poseidon2_hashImpl::skip
static bool skip(const AllEntities &in)
Definition
poseidon2_hash.hpp:20
bb::avm2::poseidon2_hashImpl::FF
FF_ FF
Definition
poseidon2_hash.hpp:15
columns.hpp
AddressRefMutationOptions::index
@ index
bb::avm2
Definition
dbs.cpp:13
bb::avm2::Column
Column
Definition
columns.hpp:31
bb::avm2::ColumnAndShifts
ColumnAndShifts
Definition
columns.hpp:34
bb::avm2::FF
AvmFlavorSettings::FF FF
Definition
field.hpp:10
std::to_string
std::string to_string(bb::avm2::ValueTag tag)
Definition
tagged_value.cpp:402
relation_parameters.hpp
relation_types.hpp
bb::RelationParameters
Container for parameters used by the grand product (permutation, lookup) Honk relations.
Definition
relation_parameters.hpp:19
src
barretenberg
vm2
generated
relations
poseidon2_hash.hpp
Generated by
1.9.8