Barretenberg
The ZK-SNARK library at the core of Aztec
Loading...
Searching...
No Matches
sha256.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 sha256Impl {
14 public:
15 using FF = FF_;
16
17 static constexpr std::array<size_t, 98> SUBRELATION_PARTIAL_LENGTHS = {
18 3, 2, 4, 4, 3, 4, 6, 4, 4, 4, 4, 4, 4, 4, 4, 4, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
19 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
20 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3
21 };
22
23 template <typename AllEntities> inline static bool skip(const AllEntities& in)
24 {
25 using C = ColumnAndShifts;
26
27 return (in.get(C::sha256_sel)).is_zero();
28 }
29
30 template <typename ContainerOverSubrelations, typename AllEntities>
31 void static accumulate(ContainerOverSubrelations& evals,
32 const AllEntities& in,
33 [[maybe_unused]] const RelationParameters<FF>&,
34 [[maybe_unused]] const FF& scaling_factor);
35};
36
37template <typename FF> class sha256 : public Relation<sha256Impl<FF>> {
38 public:
39 static constexpr const std::string_view NAME = "sha256";
40
41 // Subrelation indices constants, to be used in tests.
42 static constexpr size_t SR_PROPAGATE_INIT_A = 16;
43 static constexpr size_t SR_PROPAGATE_INIT_B = 17;
44 static constexpr size_t SR_PROPAGATE_INIT_C = 18;
45 static constexpr size_t SR_PROPAGATE_INIT_D = 19;
46 static constexpr size_t SR_PROPAGATE_INIT_E = 20;
47 static constexpr size_t SR_PROPAGATE_INIT_F = 21;
48 static constexpr size_t SR_PROPAGATE_INIT_G = 22;
49 static constexpr size_t SR_PROPAGATE_INIT_H = 23;
50
51 static std::string get_subrelation_label(size_t index)
52 {
53 switch (index) {
55 return "PROPAGATE_INIT_A";
57 return "PROPAGATE_INIT_B";
59 return "PROPAGATE_INIT_C";
61 return "PROPAGATE_INIT_D";
63 return "PROPAGATE_INIT_E";
65 return "PROPAGATE_INIT_F";
67 return "PROPAGATE_INIT_G";
69 return "PROPAGATE_INIT_H";
70 }
71 return std::to_string(index);
72 }
73};
74
75} // namespace bb::avm2
A wrapper for Relations to expose methods used by the Sumcheck prover or verifier to add the contribu...
static constexpr size_t SR_PROPAGATE_INIT_H
Definition sha256.hpp:49
static constexpr size_t SR_PROPAGATE_INIT_E
Definition sha256.hpp:46
static constexpr size_t SR_PROPAGATE_INIT_C
Definition sha256.hpp:44
static constexpr size_t SR_PROPAGATE_INIT_F
Definition sha256.hpp:47
static std::string get_subrelation_label(size_t index)
Definition sha256.hpp:51
static constexpr const std::string_view NAME
Definition sha256.hpp:39
static constexpr size_t SR_PROPAGATE_INIT_A
Definition sha256.hpp:42
static constexpr size_t SR_PROPAGATE_INIT_D
Definition sha256.hpp:45
static constexpr size_t SR_PROPAGATE_INIT_B
Definition sha256.hpp:43
static constexpr size_t SR_PROPAGATE_INIT_G
Definition sha256.hpp:48
static constexpr std::array< size_t, 98 > SUBRELATION_PARTIAL_LENGTHS
Definition sha256.hpp:17
static void accumulate(ContainerOverSubrelations &evals, const AllEntities &in, const RelationParameters< FF > &, const FF &scaling_factor)
static bool skip(const AllEntities &in)
Definition sha256.hpp:23
ColumnAndShifts
Definition columns.hpp:34
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.