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
10
11namespace bb::avm2 {
12
13template <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
36template <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
A wrapper for Relations to expose methods used by the Sumcheck prover or verifier to add the contribu...
static constexpr const std::string_view NAME
static constexpr size_t SR_TAG_ERROR_PROPAGATION
static constexpr size_t SR_CONTINUITY_EXEC_CLK
static constexpr size_t SR_SEL_IS_INPUT_ROUND_START_COND
static constexpr size_t SR_CONTINUITY_SPACE_ID
static constexpr size_t SR_CONTINUITY_SEL
static constexpr size_t SR_BATCH_ENFORCE_ZERO_WRITE
static constexpr size_t SR_INPUT_TAG_DIFF_CHECK
static std::string get_subrelation_label(size_t index)
static constexpr size_t SR_START_OR_LAST_MEM
static constexpr size_t SR_SEL_IS_INPUT_END
static constexpr size_t SR_BATCH_ZERO_CHECK_READ
static constexpr size_t SR_LATCH_HAS_SEL_ON
static constexpr size_t SR_TAG_ERROR_INIT
static constexpr size_t SR_START_AFTER_LAST
static constexpr size_t SR_INPUT_ROUND_CTR_START_COND
static constexpr size_t SR_CONTINUITY_OUTPUT_ADDR
static constexpr size_t SR_SEL_IS_INPUT_PROPAGATE
static constexpr size_t SR_INPUT_ROUND_CTR_DECR_COND
static constexpr std::array< size_t, 51 > SUBRELATION_PARTIAL_LENGTHS
static bool skip(const AllEntities &in)
static void accumulate(ContainerOverSubrelations &evals, const AllEntities &in, const RelationParameters< FF > &, const FF &scaling_factor)
ColumnAndShifts
Definition columns.hpp:35
AvmFlavorSettings::FF FF
Definition field.hpp:10
std::string to_string(bb::avm2::ValueTag tag)
Container for parameters used by the grand product (permutation, lookup) Honk relations.