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/op_count.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
static
std::string
get_subrelation_label
(
size_t
index)
41
{
42
switch
(index) {
43
case
3:
44
return
"LATCH_HAS_SEL_ON"
;
45
case
4:
46
return
"START_AFTER_LAST"
;
47
case
5:
48
return
"CONTINUITY_SEL"
;
49
case
6:
50
return
"CONTINUITY_EXEC_CLK"
;
51
case
7:
52
return
"CONTINUITY_SPACE_ID"
;
53
case
8:
54
return
"CONTINUITY_OUTPUT_ADDR"
;
55
case
15:
56
return
"START_OR_LAST_MEM"
;
57
case
34:
58
return
"BATCH_ZERO_CHECK_READ"
;
59
case
35:
60
return
"BATCH_ENFORCE_ZERO_WRITE"
;
61
case
37:
62
return
"SEL_IS_INPUT_ROUND_START_COND"
;
63
case
38:
64
return
"SEL_IS_INPUT_END"
;
65
case
39:
66
return
"SEL_IS_INPUT_PROPAGATE"
;
67
case
40:
68
return
"INPUT_ROUND_CTR_START_COND"
;
69
case
41:
70
return
"INPUT_ROUND_CTR_DECR_COND"
;
71
case
46:
72
return
"INPUT_TAG_DIFF_CHECK"
;
73
case
48:
74
return
"TAG_ERROR_INIT"
;
75
case
49:
76
return
"TAG_ERROR_PROPAGATION"
;
77
}
78
return
std::to_string
(index);
79
}
80
81
// Subrelation indices constants, to be used in tests.
82
static
constexpr
size_t
SR_LATCH_HAS_SEL_ON
= 3;
83
static
constexpr
size_t
SR_START_AFTER_LAST
= 4;
84
static
constexpr
size_t
SR_CONTINUITY_SEL
= 5;
85
static
constexpr
size_t
SR_CONTINUITY_EXEC_CLK
= 6;
86
static
constexpr
size_t
SR_CONTINUITY_SPACE_ID
= 7;
87
static
constexpr
size_t
SR_CONTINUITY_OUTPUT_ADDR
= 8;
88
static
constexpr
size_t
SR_START_OR_LAST_MEM
= 15;
89
static
constexpr
size_t
SR_BATCH_ZERO_CHECK_READ
= 34;
90
static
constexpr
size_t
SR_BATCH_ENFORCE_ZERO_WRITE
= 35;
91
static
constexpr
size_t
SR_SEL_IS_INPUT_ROUND_START_COND
= 37;
92
static
constexpr
size_t
SR_SEL_IS_INPUT_END
= 38;
93
static
constexpr
size_t
SR_SEL_IS_INPUT_PROPAGATE
= 39;
94
static
constexpr
size_t
SR_INPUT_ROUND_CTR_START_COND
= 40;
95
static
constexpr
size_t
SR_INPUT_ROUND_CTR_DECR_COND
= 41;
96
static
constexpr
size_t
SR_INPUT_TAG_DIFF_CHECK
= 46;
97
static
constexpr
size_t
SR_TAG_ERROR_INIT
= 48;
98
static
constexpr
size_t
SR_TAG_ERROR_PROPAGATION
= 49;
99
};
100
101
}
// namespace bb::avm2
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:98
bb::avm2::sha256_mem::SR_CONTINUITY_EXEC_CLK
static constexpr size_t SR_CONTINUITY_EXEC_CLK
Definition
sha256_mem.hpp:85
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:91
bb::avm2::sha256_mem::SR_CONTINUITY_SPACE_ID
static constexpr size_t SR_CONTINUITY_SPACE_ID
Definition
sha256_mem.hpp:86
bb::avm2::sha256_mem::SR_CONTINUITY_SEL
static constexpr size_t SR_CONTINUITY_SEL
Definition
sha256_mem.hpp:84
bb::avm2::sha256_mem::SR_BATCH_ENFORCE_ZERO_WRITE
static constexpr size_t SR_BATCH_ENFORCE_ZERO_WRITE
Definition
sha256_mem.hpp:90
bb::avm2::sha256_mem::SR_INPUT_TAG_DIFF_CHECK
static constexpr size_t SR_INPUT_TAG_DIFF_CHECK
Definition
sha256_mem.hpp:96
bb::avm2::sha256_mem::get_subrelation_label
static std::string get_subrelation_label(size_t index)
Definition
sha256_mem.hpp:40
bb::avm2::sha256_mem::SR_START_OR_LAST_MEM
static constexpr size_t SR_START_OR_LAST_MEM
Definition
sha256_mem.hpp:88
bb::avm2::sha256_mem::SR_SEL_IS_INPUT_END
static constexpr size_t SR_SEL_IS_INPUT_END
Definition
sha256_mem.hpp:92
bb::avm2::sha256_mem::SR_BATCH_ZERO_CHECK_READ
static constexpr size_t SR_BATCH_ZERO_CHECK_READ
Definition
sha256_mem.hpp:89
bb::avm2::sha256_mem::SR_LATCH_HAS_SEL_ON
static constexpr size_t SR_LATCH_HAS_SEL_ON
Definition
sha256_mem.hpp:82
bb::avm2::sha256_mem::SR_TAG_ERROR_INIT
static constexpr size_t SR_TAG_ERROR_INIT
Definition
sha256_mem.hpp:97
bb::avm2::sha256_mem::SR_START_AFTER_LAST
static constexpr size_t SR_START_AFTER_LAST
Definition
sha256_mem.hpp:83
bb::avm2::sha256_mem::SR_INPUT_ROUND_CTR_START_COND
static constexpr size_t SR_INPUT_ROUND_CTR_START_COND
Definition
sha256_mem.hpp:94
bb::avm2::sha256_mem::SR_CONTINUITY_OUTPUT_ADDR
static constexpr size_t SR_CONTINUITY_OUTPUT_ADDR
Definition
sha256_mem.hpp:87
bb::avm2::sha256_mem::SR_SEL_IS_INPUT_PROPAGATE
static constexpr size_t SR_SEL_IS_INPUT_PROPAGATE
Definition
sha256_mem.hpp:93
bb::avm2::sha256_mem::SR_INPUT_ROUND_CTR_DECR_COND
static constexpr size_t SR_INPUT_ROUND_CTR_DECR_COND
Definition
sha256_mem.hpp:95
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:10
columns.hpp
bb::avm2
Definition
flavor.hpp:472
bb::avm2::Column
Column
Definition
columns.hpp:32
bb::avm2::ColumnAndShifts
ColumnAndShifts
Definition
columns.hpp:35
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:399
op_count.hpp
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