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, 52>
SUBRELATION_PARTIAL_LENGTHS
= { 3, 4, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
18
3, 5, 2, 3, 5, 5, 5, 5, 5, 5, 5, 5, 5,
19
5, 5, 5, 5, 5, 5, 5, 3, 3, 6, 4, 3, 3,
20
5, 4, 3, 4, 5, 3, 3, 3, 5, 5, 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_TRACE_CONTINUITY
= 1;
42
static
constexpr
size_t
SR_LATCH_HAS_SEL_ON
= 4;
43
static
constexpr
size_t
SR_START_AFTER_LAST
= 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_CONTINUITY_INPUT_ADDR
= 9;
48
static
constexpr
size_t
SR_START_OR_LAST_MEM
= 16;
49
static
constexpr
size_t
SR_BATCH_ZERO_CHECK_READ
= 35;
50
static
constexpr
size_t
SR_BATCH_ENFORCE_ZERO_WRITE
= 36;
51
static
constexpr
size_t
SR_SEL_IS_INPUT_ROUND_START_COND
= 38;
52
static
constexpr
size_t
SR_SEL_IS_INPUT_END
= 39;
53
static
constexpr
size_t
SR_SEL_IS_INPUT_PROPAGATE
= 40;
54
static
constexpr
size_t
SR_INPUT_ROUND_CTR_START_COND
= 41;
55
static
constexpr
size_t
SR_INPUT_ROUND_CTR_DECR_COND
= 42;
56
static
constexpr
size_t
SR_INPUT_TAG_DIFF_CHECK
= 47;
57
static
constexpr
size_t
SR_TAG_ERROR_INIT
= 49;
58
static
constexpr
size_t
SR_TAG_ERROR_PROPAGATION
= 50;
59
60
static
std::string
get_subrelation_label
(
size_t
index
)
61
{
62
switch
(
index
) {
63
case
SR_TRACE_CONTINUITY
:
64
return
"TRACE_CONTINUITY"
;
65
case
SR_LATCH_HAS_SEL_ON
:
66
return
"LATCH_HAS_SEL_ON"
;
67
case
SR_START_AFTER_LAST
:
68
return
"START_AFTER_LAST"
;
69
case
SR_CONTINUITY_EXEC_CLK
:
70
return
"CONTINUITY_EXEC_CLK"
;
71
case
SR_CONTINUITY_SPACE_ID
:
72
return
"CONTINUITY_SPACE_ID"
;
73
case
SR_CONTINUITY_OUTPUT_ADDR
:
74
return
"CONTINUITY_OUTPUT_ADDR"
;
75
case
SR_CONTINUITY_INPUT_ADDR
:
76
return
"CONTINUITY_INPUT_ADDR"
;
77
case
SR_START_OR_LAST_MEM
:
78
return
"START_OR_LAST_MEM"
;
79
case
SR_BATCH_ZERO_CHECK_READ
:
80
return
"BATCH_ZERO_CHECK_READ"
;
81
case
SR_BATCH_ENFORCE_ZERO_WRITE
:
82
return
"BATCH_ENFORCE_ZERO_WRITE"
;
83
case
SR_SEL_IS_INPUT_ROUND_START_COND
:
84
return
"SEL_IS_INPUT_ROUND_START_COND"
;
85
case
SR_SEL_IS_INPUT_END
:
86
return
"SEL_IS_INPUT_END"
;
87
case
SR_SEL_IS_INPUT_PROPAGATE
:
88
return
"SEL_IS_INPUT_PROPAGATE"
;
89
case
SR_INPUT_ROUND_CTR_START_COND
:
90
return
"INPUT_ROUND_CTR_START_COND"
;
91
case
SR_INPUT_ROUND_CTR_DECR_COND
:
92
return
"INPUT_ROUND_CTR_DECR_COND"
;
93
case
SR_INPUT_TAG_DIFF_CHECK
:
94
return
"INPUT_TAG_DIFF_CHECK"
;
95
case
SR_TAG_ERROR_INIT
:
96
return
"TAG_ERROR_INIT"
;
97
case
SR_TAG_ERROR_PROPAGATION
:
98
return
"TAG_ERROR_PROPAGATION"
;
99
}
100
return
std::to_string
(
index
);
101
}
102
};
103
104
}
// 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::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:58
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:51
bb::avm2::sha256_mem::SR_CONTINUITY_INPUT_ADDR
static constexpr size_t SR_CONTINUITY_INPUT_ADDR
Definition
sha256_mem.hpp:47
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_BATCH_ENFORCE_ZERO_WRITE
static constexpr size_t SR_BATCH_ENFORCE_ZERO_WRITE
Definition
sha256_mem.hpp:50
bb::avm2::sha256_mem::SR_INPUT_TAG_DIFF_CHECK
static constexpr size_t SR_INPUT_TAG_DIFF_CHECK
Definition
sha256_mem.hpp:56
bb::avm2::sha256_mem::get_subrelation_label
static std::string get_subrelation_label(size_t index)
Definition
sha256_mem.hpp:60
bb::avm2::sha256_mem::SR_START_OR_LAST_MEM
static constexpr size_t SR_START_OR_LAST_MEM
Definition
sha256_mem.hpp:48
bb::avm2::sha256_mem::SR_SEL_IS_INPUT_END
static constexpr size_t SR_SEL_IS_INPUT_END
Definition
sha256_mem.hpp:52
bb::avm2::sha256_mem::SR_BATCH_ZERO_CHECK_READ
static constexpr size_t SR_BATCH_ZERO_CHECK_READ
Definition
sha256_mem.hpp:49
bb::avm2::sha256_mem::SR_LATCH_HAS_SEL_ON
static constexpr size_t SR_LATCH_HAS_SEL_ON
Definition
sha256_mem.hpp:42
bb::avm2::sha256_mem::SR_TRACE_CONTINUITY
static constexpr size_t SR_TRACE_CONTINUITY
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:57
bb::avm2::sha256_mem::SR_START_AFTER_LAST
static constexpr size_t SR_START_AFTER_LAST
Definition
sha256_mem.hpp:43
bb::avm2::sha256_mem::SR_INPUT_ROUND_CTR_START_COND
static constexpr size_t SR_INPUT_ROUND_CTR_START_COND
Definition
sha256_mem.hpp:54
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:53
bb::avm2::sha256_mem::SR_INPUT_ROUND_CTR_DECR_COND
static constexpr size_t SR_INPUT_ROUND_CTR_DECR_COND
Definition
sha256_mem.hpp:55
bb::avm2::sha256_memImpl
Definition
sha256_mem.hpp:13
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::SUBRELATION_PARTIAL_LENGTHS
static constexpr std::array< size_t, 52 > SUBRELATION_PARTIAL_LENGTHS
Definition
sha256_mem.hpp:17
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
VariableRefMutationOptions::index
@ index
bb::avm2
Definition
dbs.cpp:19
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
sha256_mem.hpp
Generated by
1.9.8