Barretenberg
The ZK-SNARK library at the core of Aztec
Loading...
Searching...
No Matches
alu.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 aluImpl {
14 public:
15 using FF = FF_;
16
17 static constexpr std::array<size_t, 63> SUBRELATION_PARTIAL_LENGTHS = {
18 3, 3, 3, 3, 3, 2, 5, 5, 4, 3, 3, 4, 6, 3, 6, 5, 3, 3, 4, 3, 3, 6, 3, 6, 3, 5, 3, 3, 3, 6, 6, 3,
19 3, 5, 6, 3, 6, 3, 3, 3, 3, 3, 3, 3, 4, 3, 4, 6, 6, 5, 2, 3, 4, 3, 3, 3, 3, 2, 2, 3, 3, 4, 3
20 };
21
22 template <typename AllEntities> inline static bool skip(const AllEntities& in)
23 {
24 using C = ColumnAndShifts;
25
26 return (in.get(C::alu_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 alu : public Relation<aluImpl<FF>> {
37 public:
38 static constexpr const std::string_view NAME = "alu";
39
40 // Subrelation indices constants, to be used in tests.
41 static constexpr size_t SR_ERR_CHECK = 4;
42 static constexpr size_t SR_OP_ID_CHECK = 5;
43 static constexpr size_t SR_TAG_IS_FF = 6;
44 static constexpr size_t SR_TAG_IS_U128 = 7;
45 static constexpr size_t SR_C_TAG_CHECK = 8;
46 static constexpr size_t SR_TAG_ERR_CHECK = 11;
47 static constexpr size_t SR_AB_TAGS_CHECK = 12;
48 static constexpr size_t SR_A_DECOMPOSITION = 14;
49 static constexpr size_t SR_B_DECOMPOSITION = 15;
50 static constexpr size_t SR_A_LO_BITS = 17;
51 static constexpr size_t SR_A_HI_BITS = 18;
52 static constexpr size_t SR_ALU_ADD_SUB = 21;
53 static constexpr size_t SR_ALU_MUL_NON_U128 = 23;
54 static constexpr size_t SR_ALU_MUL_U128 = 25;
55 static constexpr size_t SR_ALU_DIV_U128_CHECK = 29;
56 static constexpr size_t SR_ALU_DIV_U128 = 30;
57 static constexpr size_t SR_DIV_0_ERR = 33;
58 static constexpr size_t SR_ALU_FDIV_DIV_NON_U128 = 34;
59 static constexpr size_t SR_EQ_OP_MAIN = 36;
60 static constexpr size_t SR_LT_SWAP_INPUTS_A = 42;
61 static constexpr size_t SR_LT_SWAP_INPUTS_B = 43;
62 static constexpr size_t SR_LTE_NEGATE_RESULT_C = 44;
63 static constexpr size_t SR_NOT_OP_MAIN = 46;
64 static constexpr size_t SR_SHL_TWO_POW_SHIFT = 47;
65 static constexpr size_t SR_ALU_SHL = 48;
66 static constexpr size_t SR_ALU_SHR = 49;
67 static constexpr size_t SR_SHIFTS_LO_BITS = 52;
68 static constexpr size_t SR_SEL_TRUNC_NON_TRIVIAL = 57;
69 static constexpr size_t SR_SEL_TRUNCATE = 58;
70 static constexpr size_t SR_TRUNC_TRIVIAL_CASE = 59;
71 static constexpr size_t SR_SMALL_TRUNC_VAL_IS_LO = 60;
72 static constexpr size_t SR_TRUNC_LO_128_DECOMPOSITION = 61;
73 static constexpr size_t SR_TRUNC_MID_BITS = 62;
74
75 static std::string get_subrelation_label(size_t index)
76 {
77 switch (index) {
78 case SR_ERR_CHECK:
79 return "ERR_CHECK";
80 case SR_OP_ID_CHECK:
81 return "OP_ID_CHECK";
82 case SR_TAG_IS_FF:
83 return "TAG_IS_FF";
84 case SR_TAG_IS_U128:
85 return "TAG_IS_U128";
86 case SR_C_TAG_CHECK:
87 return "C_TAG_CHECK";
89 return "TAG_ERR_CHECK";
91 return "AB_TAGS_CHECK";
93 return "A_DECOMPOSITION";
95 return "B_DECOMPOSITION";
96 case SR_A_LO_BITS:
97 return "A_LO_BITS";
98 case SR_A_HI_BITS:
99 return "A_HI_BITS";
100 case SR_ALU_ADD_SUB:
101 return "ALU_ADD_SUB";
103 return "ALU_MUL_NON_U128";
104 case SR_ALU_MUL_U128:
105 return "ALU_MUL_U128";
107 return "ALU_DIV_U128_CHECK";
108 case SR_ALU_DIV_U128:
109 return "ALU_DIV_U128";
110 case SR_DIV_0_ERR:
111 return "DIV_0_ERR";
113 return "ALU_FDIV_DIV_NON_U128";
114 case SR_EQ_OP_MAIN:
115 return "EQ_OP_MAIN";
117 return "LT_SWAP_INPUTS_A";
119 return "LT_SWAP_INPUTS_B";
121 return "LTE_NEGATE_RESULT_C";
122 case SR_NOT_OP_MAIN:
123 return "NOT_OP_MAIN";
125 return "SHL_TWO_POW_SHIFT";
126 case SR_ALU_SHL:
127 return "ALU_SHL";
128 case SR_ALU_SHR:
129 return "ALU_SHR";
131 return "SHIFTS_LO_BITS";
133 return "SEL_TRUNC_NON_TRIVIAL";
134 case SR_SEL_TRUNCATE:
135 return "SEL_TRUNCATE";
137 return "TRUNC_TRIVIAL_CASE";
139 return "SMALL_TRUNC_VAL_IS_LO";
141 return "TRUNC_LO_128_DECOMPOSITION";
143 return "TRUNC_MID_BITS";
144 }
145 return std::to_string(index);
146 }
147};
148
149} // 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_OP_ID_CHECK
Definition alu.hpp:42
static constexpr size_t SR_SHIFTS_LO_BITS
Definition alu.hpp:67
static constexpr size_t SR_LT_SWAP_INPUTS_B
Definition alu.hpp:61
static constexpr size_t SR_ALU_SHR
Definition alu.hpp:66
static constexpr size_t SR_SEL_TRUNC_NON_TRIVIAL
Definition alu.hpp:68
static constexpr size_t SR_AB_TAGS_CHECK
Definition alu.hpp:47
static constexpr const std::string_view NAME
Definition alu.hpp:38
static constexpr size_t SR_SEL_TRUNCATE
Definition alu.hpp:69
static constexpr size_t SR_A_HI_BITS
Definition alu.hpp:51
static constexpr size_t SR_A_LO_BITS
Definition alu.hpp:50
static constexpr size_t SR_TRUNC_MID_BITS
Definition alu.hpp:73
static constexpr size_t SR_SMALL_TRUNC_VAL_IS_LO
Definition alu.hpp:71
static constexpr size_t SR_B_DECOMPOSITION
Definition alu.hpp:49
static constexpr size_t SR_TRUNC_LO_128_DECOMPOSITION
Definition alu.hpp:72
static constexpr size_t SR_LTE_NEGATE_RESULT_C
Definition alu.hpp:62
static constexpr size_t SR_C_TAG_CHECK
Definition alu.hpp:45
static constexpr size_t SR_ERR_CHECK
Definition alu.hpp:41
static constexpr size_t SR_DIV_0_ERR
Definition alu.hpp:57
static constexpr size_t SR_A_DECOMPOSITION
Definition alu.hpp:48
static std::string get_subrelation_label(size_t index)
Definition alu.hpp:75
static constexpr size_t SR_LT_SWAP_INPUTS_A
Definition alu.hpp:60
static constexpr size_t SR_TAG_ERR_CHECK
Definition alu.hpp:46
static constexpr size_t SR_EQ_OP_MAIN
Definition alu.hpp:59
static constexpr size_t SR_ALU_DIV_U128
Definition alu.hpp:56
static constexpr size_t SR_ALU_DIV_U128_CHECK
Definition alu.hpp:55
static constexpr size_t SR_NOT_OP_MAIN
Definition alu.hpp:63
static constexpr size_t SR_SHL_TWO_POW_SHIFT
Definition alu.hpp:64
static constexpr size_t SR_TAG_IS_U128
Definition alu.hpp:44
static constexpr size_t SR_ALU_MUL_U128
Definition alu.hpp:54
static constexpr size_t SR_ALU_FDIV_DIV_NON_U128
Definition alu.hpp:58
static constexpr size_t SR_TAG_IS_FF
Definition alu.hpp:43
static constexpr size_t SR_TRUNC_TRIVIAL_CASE
Definition alu.hpp:70
static constexpr size_t SR_ALU_SHL
Definition alu.hpp:65
static constexpr size_t SR_ALU_ADD_SUB
Definition alu.hpp:52
static constexpr size_t SR_ALU_MUL_NON_U128
Definition alu.hpp:53
static bool skip(const AllEntities &in)
Definition alu.hpp:22
static void accumulate(ContainerOverSubrelations &evals, const AllEntities &in, const RelationParameters< FF > &, const FF &scaling_factor)
Definition alu_impl.hpp:11
static constexpr std::array< size_t, 63 > SUBRELATION_PARTIAL_LENGTHS
Definition alu.hpp:17
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.