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, 50>
SUBRELATION_PARTIAL_LENGTHS
= { 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
18
3, 5, 2, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
19
3, 3, 3, 3, 3, 3, 3, 2, 3, 5, 3, 3, 3,
20
3, 4, 4, 3, 3, 3, 5, 3, 3, 3, 2 };
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_SEL_ON_START_OR_END
= 3;
42
static
constexpr
size_t
SR_TRACE_CONTINUITY
= 4;
43
static
constexpr
size_t
SR_START_AFTER_LATCH
= 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_END_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_INPUT_ROUND_CTR_START_COND
= 37;
52
static
constexpr
size_t
SR_INPUT_ROUND_CTR_DECR_COND
= 38;
53
static
constexpr
size_t
SR_SEL_IS_INPUT_ROUND_ZERO_CHECK
= 40;
54
static
constexpr
size_t
SR_INPUT_TAG_DIFF_CHECK
= 45;
55
static
constexpr
size_t
SR_TAG_ERROR_INIT
= 47;
56
static
constexpr
size_t
SR_TAG_ERROR_PROPAGATION
= 48;
57
58
static
std::string
get_subrelation_label
(
size_t
index
)
59
{
60
switch
(
index
) {
61
case
SR_SEL_ON_START_OR_END
:
62
return
"SEL_ON_START_OR_END"
;
63
case
SR_TRACE_CONTINUITY
:
64
return
"TRACE_CONTINUITY"
;
65
case
SR_START_AFTER_LATCH
:
66
return
"START_AFTER_LATCH"
;
67
case
SR_CONTINUITY_EXEC_CLK
:
68
return
"CONTINUITY_EXEC_CLK"
;
69
case
SR_CONTINUITY_SPACE_ID
:
70
return
"CONTINUITY_SPACE_ID"
;
71
case
SR_CONTINUITY_OUTPUT_ADDR
:
72
return
"CONTINUITY_OUTPUT_ADDR"
;
73
case
SR_CONTINUITY_INPUT_ADDR
:
74
return
"CONTINUITY_INPUT_ADDR"
;
75
case
SR_START_OR_END_MEM
:
76
return
"START_OR_END_MEM"
;
77
case
SR_BATCH_ZERO_CHECK_READ
:
78
return
"BATCH_ZERO_CHECK_READ"
;
79
case
SR_BATCH_ENFORCE_ZERO_WRITE
:
80
return
"BATCH_ENFORCE_ZERO_WRITE"
;
81
case
SR_INPUT_ROUND_CTR_START_COND
:
82
return
"INPUT_ROUND_CTR_START_COND"
;
83
case
SR_INPUT_ROUND_CTR_DECR_COND
:
84
return
"INPUT_ROUND_CTR_DECR_COND"
;
85
case
SR_SEL_IS_INPUT_ROUND_ZERO_CHECK
:
86
return
"SEL_IS_INPUT_ROUND_ZERO_CHECK"
;
87
case
SR_INPUT_TAG_DIFF_CHECK
:
88
return
"INPUT_TAG_DIFF_CHECK"
;
89
case
SR_TAG_ERROR_INIT
:
90
return
"TAG_ERROR_INIT"
;
91
case
SR_TAG_ERROR_PROPAGATION
:
92
return
"TAG_ERROR_PROPAGATION"
;
93
}
94
return
std::to_string
(
index
);
95
}
96
};
97
98
}
// 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:56
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_ON_START_OR_END
static constexpr size_t SR_SEL_ON_START_OR_END
Definition
sha256_mem.hpp:41
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_SEL_IS_INPUT_ROUND_ZERO_CHECK
static constexpr size_t SR_SEL_IS_INPUT_ROUND_ZERO_CHECK
Definition
sha256_mem.hpp:53
bb::avm2::sha256_mem::SR_START_OR_END_MEM
static constexpr size_t SR_START_OR_END_MEM
Definition
sha256_mem.hpp:48
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:54
bb::avm2::sha256_mem::SR_START_AFTER_LATCH
static constexpr size_t SR_START_AFTER_LATCH
Definition
sha256_mem.hpp:43
bb::avm2::sha256_mem::get_subrelation_label
static std::string get_subrelation_label(size_t index)
Definition
sha256_mem.hpp:58
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_TRACE_CONTINUITY
static constexpr size_t SR_TRACE_CONTINUITY
Definition
sha256_mem.hpp:42
bb::avm2::sha256_mem::SR_TAG_ERROR_INIT
static constexpr size_t SR_TAG_ERROR_INIT
Definition
sha256_mem.hpp:55
bb::avm2::sha256_mem::SR_INPUT_ROUND_CTR_START_COND
static constexpr size_t SR_INPUT_ROUND_CTR_START_COND
Definition
sha256_mem.hpp:51
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_INPUT_ROUND_CTR_DECR_COND
static constexpr size_t SR_INPUT_ROUND_CTR_DECR_COND
Definition
sha256_mem.hpp:52
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::accumulate
static void accumulate(ContainerOverSubrelations &evals, const AllEntities &in, const RelationParameters< FF > &, const FF &scaling_factor)
Definition
sha256_mem_impl.hpp:11
bb::avm2::sha256_memImpl::SUBRELATION_PARTIAL_LENGTHS
static constexpr std::array< size_t, 50 > SUBRELATION_PARTIAL_LENGTHS
Definition
sha256_mem.hpp:17
columns.hpp
VariableRefMutationOptions::index
@ index
bb::avm2
Definition
dbs.cpp:19
bb::avm2::Column
Column
Definition
columns.hpp:31
bb::avm2::FF
AvmFlavorSettings::FF FF
Definition
field.hpp:10
bb::avm2::ColumnAndShifts
ColumnAndShifts
Definition
columns.hpp:34
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:18
src
barretenberg
vm2
generated
relations
sha256_mem.hpp
Generated by
1.9.8