Barretenberg
The ZK-SNARK library at the core of Aztec
Loading...
Searching...
No Matches
sha256_mem.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
sha256_memImpl
{
14
public
:
15
using
FF
= FF_;
16
17
static
constexpr
std::array<size_t, 51>
SUBRELATION_PARTIAL_LENGTHS
= { 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
18
4, 2, 3, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5,
19
5, 5, 5, 5, 5, 5, 3, 3, 6, 4, 3, 3, 5,
20
4, 3, 4, 5, 3, 3, 3, 5, 6, 3, 3, 4 };
21
22
template
<
typename
AllEntities>
inline
static
bool
skip
(
const
AllEntities& in)
23
{
24
using
C
=
ColumnAndShifts
;
25
26
return
(in.get(C::sha256_sel)).is_zero();
27
}
28
29
template
<
typename
ContainerOverSubrelations,
typename
AllEntities>
30
void
static
accumulate
(ContainerOverSubrelations& evals,
31
const
AllEntities& in,
32
[[maybe_unused]]
const
RelationParameters<FF>
&,
33
[[maybe_unused]]
const
FF
& scaling_factor);
34
};
35
36
template
<
typename
FF>
class
sha256_mem
:
public
Relation
<sha256_memImpl<FF>> {
37
public
:
38
static
constexpr
const
std::string_view
NAME
=
"sha256_mem"
;
39
40
// Subrelation indices constants, to be used in tests.
41
static
constexpr
size_t
SR_LATCH_HAS_SEL_ON
= 3;
42
static
constexpr
size_t
SR_START_AFTER_LAST
= 4;
43
static
constexpr
size_t
SR_CONTINUITY_SEL
= 5;
44
static
constexpr
size_t
SR_CONTINUITY_EXEC_CLK
= 6;
45
static
constexpr
size_t
SR_CONTINUITY_SPACE_ID
= 7;
46
static
constexpr
size_t
SR_CONTINUITY_OUTPUT_ADDR
= 8;
47
static
constexpr
size_t
SR_START_OR_LAST_MEM
= 15;
48
static
constexpr
size_t
SR_BATCH_ZERO_CHECK_READ
= 34;
49
static
constexpr
size_t
SR_BATCH_ENFORCE_ZERO_WRITE
= 35;
50
static
constexpr
size_t
SR_SEL_IS_INPUT_ROUND_START_COND
= 37;
51
static
constexpr
size_t
SR_SEL_IS_INPUT_END
= 38;
52
static
constexpr
size_t
SR_SEL_IS_INPUT_PROPAGATE
= 39;
53
static
constexpr
size_t
SR_INPUT_ROUND_CTR_START_COND
= 40;
54
static
constexpr
size_t
SR_INPUT_ROUND_CTR_DECR_COND
= 41;
55
static
constexpr
size_t
SR_INPUT_TAG_DIFF_CHECK
= 46;
56
static
constexpr
size_t
SR_TAG_ERROR_INIT
= 48;
57
static
constexpr
size_t
SR_TAG_ERROR_PROPAGATION
= 49;
58
59
static
std::string
get_subrelation_label
(
size_t
index)
60
{
61
switch
(index) {
62
case
SR_LATCH_HAS_SEL_ON
:
63
return
"LATCH_HAS_SEL_ON"
;
64
case
SR_START_AFTER_LAST
:
65
return
"START_AFTER_LAST"
;
66
case
SR_CONTINUITY_SEL
:
67
return
"CONTINUITY_SEL"
;
68
case
SR_CONTINUITY_EXEC_CLK
:
69
return
"CONTINUITY_EXEC_CLK"
;
70
case
SR_CONTINUITY_SPACE_ID
:
71
return
"CONTINUITY_SPACE_ID"
;
72
case
SR_CONTINUITY_OUTPUT_ADDR
:
73
return
"CONTINUITY_OUTPUT_ADDR"
;
74
case
SR_START_OR_LAST_MEM
:
75
return
"START_OR_LAST_MEM"
;
76
case
SR_BATCH_ZERO_CHECK_READ
:
77
return
"BATCH_ZERO_CHECK_READ"
;
78
case
SR_BATCH_ENFORCE_ZERO_WRITE
:
79
return
"BATCH_ENFORCE_ZERO_WRITE"
;
80
case
SR_SEL_IS_INPUT_ROUND_START_COND
:
81
return
"SEL_IS_INPUT_ROUND_START_COND"
;
82
case
SR_SEL_IS_INPUT_END
:
83
return
"SEL_IS_INPUT_END"
;
84
case
SR_SEL_IS_INPUT_PROPAGATE
:
85
return
"SEL_IS_INPUT_PROPAGATE"
;
86
case
SR_INPUT_ROUND_CTR_START_COND
:
87
return
"INPUT_ROUND_CTR_START_COND"
;
88
case
SR_INPUT_ROUND_CTR_DECR_COND
:
89
return
"INPUT_ROUND_CTR_DECR_COND"
;
90
case
SR_INPUT_TAG_DIFF_CHECK
:
91
return
"INPUT_TAG_DIFF_CHECK"
;
92
case
SR_TAG_ERROR_INIT
:
93
return
"TAG_ERROR_INIT"
;
94
case
SR_TAG_ERROR_PROPAGATION
:
95
return
"TAG_ERROR_PROPAGATION"
;
96
}
97
return
std::to_string
(index);
98
}
99
};
100
101
}
// 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:153
bb::avm2::sha256_mem
Definition
sha256_mem.hpp:36
bb::avm2::sha256_mem::NAME
static constexpr const std::string_view NAME
Definition
sha256_mem.hpp:38
bb::avm2::sha256_mem::SR_TAG_ERROR_PROPAGATION
static constexpr size_t SR_TAG_ERROR_PROPAGATION
Definition
sha256_mem.hpp:57
bb::avm2::sha256_mem::SR_CONTINUITY_EXEC_CLK
static constexpr size_t SR_CONTINUITY_EXEC_CLK
Definition
sha256_mem.hpp:44
bb::avm2::sha256_mem::SR_SEL_IS_INPUT_ROUND_START_COND
static constexpr size_t SR_SEL_IS_INPUT_ROUND_START_COND
Definition
sha256_mem.hpp:50
bb::avm2::sha256_mem::SR_CONTINUITY_SPACE_ID
static constexpr size_t SR_CONTINUITY_SPACE_ID
Definition
sha256_mem.hpp:45
bb::avm2::sha256_mem::SR_CONTINUITY_SEL
static constexpr size_t SR_CONTINUITY_SEL
Definition
sha256_mem.hpp:43
bb::avm2::sha256_mem::SR_BATCH_ENFORCE_ZERO_WRITE
static constexpr size_t SR_BATCH_ENFORCE_ZERO_WRITE
Definition
sha256_mem.hpp:49
bb::avm2::sha256_mem::SR_INPUT_TAG_DIFF_CHECK
static constexpr size_t SR_INPUT_TAG_DIFF_CHECK
Definition
sha256_mem.hpp:55
bb::avm2::sha256_mem::get_subrelation_label
static std::string get_subrelation_label(size_t index)
Definition
sha256_mem.hpp:59
bb::avm2::sha256_mem::SR_START_OR_LAST_MEM
static constexpr size_t SR_START_OR_LAST_MEM
Definition
sha256_mem.hpp:47
bb::avm2::sha256_mem::SR_SEL_IS_INPUT_END
static constexpr size_t SR_SEL_IS_INPUT_END
Definition
sha256_mem.hpp:51
bb::avm2::sha256_mem::SR_BATCH_ZERO_CHECK_READ
static constexpr size_t SR_BATCH_ZERO_CHECK_READ
Definition
sha256_mem.hpp:48
bb::avm2::sha256_mem::SR_LATCH_HAS_SEL_ON
static constexpr size_t SR_LATCH_HAS_SEL_ON
Definition
sha256_mem.hpp:41
bb::avm2::sha256_mem::SR_TAG_ERROR_INIT
static constexpr size_t SR_TAG_ERROR_INIT
Definition
sha256_mem.hpp:56
bb::avm2::sha256_mem::SR_START_AFTER_LAST
static constexpr size_t SR_START_AFTER_LAST
Definition
sha256_mem.hpp:42
bb::avm2::sha256_mem::SR_INPUT_ROUND_CTR_START_COND
static constexpr size_t SR_INPUT_ROUND_CTR_START_COND
Definition
sha256_mem.hpp:53
bb::avm2::sha256_mem::SR_CONTINUITY_OUTPUT_ADDR
static constexpr size_t SR_CONTINUITY_OUTPUT_ADDR
Definition
sha256_mem.hpp:46
bb::avm2::sha256_mem::SR_SEL_IS_INPUT_PROPAGATE
static constexpr size_t SR_SEL_IS_INPUT_PROPAGATE
Definition
sha256_mem.hpp:52
bb::avm2::sha256_mem::SR_INPUT_ROUND_CTR_DECR_COND
static constexpr size_t SR_INPUT_ROUND_CTR_DECR_COND
Definition
sha256_mem.hpp:54
bb::avm2::sha256_memImpl
Definition
sha256_mem.hpp:13
bb::avm2::sha256_memImpl::SUBRELATION_PARTIAL_LENGTHS
static constexpr std::array< size_t, 51 > SUBRELATION_PARTIAL_LENGTHS
Definition
sha256_mem.hpp:17
bb::avm2::sha256_memImpl::FF
FF_ FF
Definition
sha256_mem.hpp:15
bb::avm2::sha256_memImpl::skip
static bool skip(const AllEntities &in)
Definition
sha256_mem.hpp:22
bb::avm2::sha256_memImpl::accumulate
static void accumulate(ContainerOverSubrelations &evals, const AllEntities &in, const RelationParameters< FF > &, const FF &scaling_factor)
Definition
sha256_mem_impl.hpp:11
columns.hpp
bb::avm2
Definition
flavor.hpp:581
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:400
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
sha256_mem.hpp
Generated by
1.9.8