Barretenberg
The ZK-SNARK library at the core of Aztec
Loading...
Searching...
No Matches
merkle_check_impl.hpp
Go to the documentation of this file.
1// AUTOGENERATED FILE
2#pragma once
3
5
6namespace bb::avm2 {
7
8template <typename FF_>
9template <typename ContainerOverSubrelations, typename AllEntities>
10void merkle_checkImpl<FF_>::accumulate(ContainerOverSubrelations& evals,
11 const AllEntities& in,
12 [[maybe_unused]] const RelationParameters<FF_>&,
13 [[maybe_unused]] const FF_& scaling_factor)
14{
15 using C = ColumnAndShifts;
16
17 PROFILE_THIS_NAME("accumulate/merkle_check");
18
19 const auto merkle_check_NOT_END = in.get(C::merkle_check_sel) * (FF(1) - in.get(C::merkle_check_end));
20 const auto merkle_check_LATCH_CONDITION = in.get(C::merkle_check_end) + in.get(C::precomputed_first_row);
21 const auto merkle_check_REMAINING_PATH_LEN = (in.get(C::merkle_check_path_len) - FF(1));
22 const auto merkle_check_INDEX_IS_ODD = (FF(1) - in.get(C::merkle_check_index_is_even));
23
24 {
25 using Accumulator = typename std::tuple_element_t<0, ContainerOverSubrelations>;
26 auto tmp = in.get(C::merkle_check_sel) * (FF(1) - in.get(C::merkle_check_sel));
27 tmp *= scaling_factor;
28 std::get<0>(evals) += typename Accumulator::View(tmp);
29 }
30 { // TRACE_CONTINUITY
31 using Accumulator = typename std::tuple_element_t<1, ContainerOverSubrelations>;
32 auto tmp = (FF(1) - in.get(C::precomputed_first_row)) * (FF(1) - in.get(C::merkle_check_sel)) *
33 in.get(C::merkle_check_sel_shift);
34 tmp *= scaling_factor;
35 std::get<1>(evals) += typename Accumulator::View(tmp);
36 }
37 {
38 using Accumulator = typename std::tuple_element_t<2, ContainerOverSubrelations>;
39 auto tmp = in.get(C::merkle_check_write) * (FF(1) - in.get(C::merkle_check_write));
40 tmp *= scaling_factor;
41 std::get<2>(evals) += typename Accumulator::View(tmp);
42 }
43 {
44 using Accumulator = typename std::tuple_element_t<3, ContainerOverSubrelations>;
45 auto tmp = in.get(C::merkle_check_start) * (FF(1) - in.get(C::merkle_check_start));
46 tmp *= scaling_factor;
47 std::get<3>(evals) += typename Accumulator::View(tmp);
48 }
49 {
50 using Accumulator = typename std::tuple_element_t<4, ContainerOverSubrelations>;
51 auto tmp = in.get(C::merkle_check_end) * (FF(1) - in.get(C::merkle_check_end));
52 tmp *= scaling_factor;
53 std::get<4>(evals) += typename Accumulator::View(tmp);
54 }
55 {
56 using Accumulator = typename std::tuple_element_t<5, ContainerOverSubrelations>;
57 auto tmp = in.get(C::merkle_check_end) * in.get(C::precomputed_first_row);
58 tmp *= scaling_factor;
59 std::get<5>(evals) += typename Accumulator::View(tmp);
60 }
61 { // START_AFTER_LATCH
62 using Accumulator = typename std::tuple_element_t<6, ContainerOverSubrelations>;
63 auto tmp =
64 in.get(C::merkle_check_sel_shift) * (in.get(C::merkle_check_start_shift) - merkle_check_LATCH_CONDITION);
65 tmp *= scaling_factor;
66 std::get<6>(evals) += typename Accumulator::View(tmp);
67 }
68 { // SELECTOR_ON_END
69 using Accumulator = typename std::tuple_element_t<7, ContainerOverSubrelations>;
70 auto tmp = in.get(C::merkle_check_end) * (FF(1) - in.get(C::merkle_check_sel));
71 tmp *= scaling_factor;
72 std::get<7>(evals) += typename Accumulator::View(tmp);
73 }
74 { // PROPAGATE_READ_ROOT
75 using Accumulator = typename std::tuple_element_t<8, ContainerOverSubrelations>;
76 auto tmp = merkle_check_NOT_END * (in.get(C::merkle_check_read_root_shift) - in.get(C::merkle_check_read_root));
77 tmp *= scaling_factor;
78 std::get<8>(evals) += typename Accumulator::View(tmp);
79 }
80 { // PROPAGATE_WRITE
81 using Accumulator = typename std::tuple_element_t<9, ContainerOverSubrelations>;
82 auto tmp = merkle_check_NOT_END * (in.get(C::merkle_check_write_shift) - in.get(C::merkle_check_write));
83 tmp *= scaling_factor;
84 std::get<9>(evals) += typename Accumulator::View(tmp);
85 }
86 { // PROPAGATE_WRITE_ROOT
87 using Accumulator = typename std::tuple_element_t<10, ContainerOverSubrelations>;
88 auto tmp =
89 merkle_check_NOT_END * (in.get(C::merkle_check_write_root_shift) - in.get(C::merkle_check_write_root));
90 tmp *= scaling_factor;
91 std::get<10>(evals) += typename Accumulator::View(tmp);
92 }
93 { // PATH_LEN_DECREMENTS
94 using Accumulator = typename std::tuple_element_t<11, ContainerOverSubrelations>;
95 auto tmp = merkle_check_NOT_END *
96 ((in.get(C::merkle_check_path_len_shift) - in.get(C::merkle_check_path_len)) + FF(1));
97 tmp *= scaling_factor;
98 std::get<11>(evals) += typename Accumulator::View(tmp);
99 }
100 { // END_WHEN_PATH_EMPTY
101 using Accumulator = typename std::tuple_element_t<12, ContainerOverSubrelations>;
102 auto tmp = in.get(C::merkle_check_sel) *
103 ((merkle_check_REMAINING_PATH_LEN *
104 (in.get(C::merkle_check_end) * (FF(1) - in.get(C::merkle_check_remaining_path_len_inv)) +
105 in.get(C::merkle_check_remaining_path_len_inv)) -
106 FF(1)) +
107 in.get(C::merkle_check_end));
108 tmp *= scaling_factor;
109 std::get<12>(evals) += typename Accumulator::View(tmp);
110 }
111 {
112 using Accumulator = typename std::tuple_element_t<13, ContainerOverSubrelations>;
113 auto tmp = in.get(C::merkle_check_index_is_even) * (FF(1) - in.get(C::merkle_check_index_is_even));
114 tmp *= scaling_factor;
115 std::get<13>(evals) += typename Accumulator::View(tmp);
116 }
117 { // NEXT_INDEX_IS_HALVED
118 using Accumulator = typename std::tuple_element_t<14, ContainerOverSubrelations>;
119 auto tmp = merkle_check_NOT_END * ((in.get(C::merkle_check_index_shift) * FF(2) + merkle_check_INDEX_IS_ODD) -
120 in.get(C::merkle_check_index));
121 tmp *= scaling_factor;
122 std::get<14>(evals) += typename Accumulator::View(tmp);
123 }
124 { // FINAL_INDEX_IS_0_OR_1
125 using Accumulator = typename std::tuple_element_t<15, ContainerOverSubrelations>;
126 auto tmp =
127 in.get(C::merkle_check_end) * in.get(C::merkle_check_index) * (FF(1) - in.get(C::merkle_check_index));
128 tmp *= scaling_factor;
129 std::get<15>(evals) += typename Accumulator::View(tmp);
130 }
131 { // ASSIGN_NODE_LEFT_OR_RIGHT_READ
132 using Accumulator = typename std::tuple_element_t<16, ContainerOverSubrelations>;
133 auto tmp = in.get(C::merkle_check_sel) *
134 ((in.get(C::merkle_check_index_is_even) *
135 (in.get(C::merkle_check_read_left_node) - in.get(C::merkle_check_read_right_node)) +
136 in.get(C::merkle_check_read_right_node)) -
137 in.get(C::merkle_check_read_node));
138 tmp *= scaling_factor;
139 std::get<16>(evals) += typename Accumulator::View(tmp);
140 }
141 { // ASSIGN_SIBLING_LEFT_OR_RIGHT_READ
142 using Accumulator = typename std::tuple_element_t<17, ContainerOverSubrelations>;
143 auto tmp = in.get(C::merkle_check_sel) *
144 ((in.get(C::merkle_check_index_is_even) *
145 (in.get(C::merkle_check_read_right_node) - in.get(C::merkle_check_read_left_node)) +
146 in.get(C::merkle_check_read_left_node)) -
147 in.get(C::merkle_check_sibling));
148 tmp *= scaling_factor;
149 std::get<17>(evals) += typename Accumulator::View(tmp);
150 }
151 { // ASSIGN_NODE_LEFT_OR_RIGHT_WRITE
152 using Accumulator = typename std::tuple_element_t<18, ContainerOverSubrelations>;
153 auto tmp = in.get(C::merkle_check_write) *
154 ((in.get(C::merkle_check_index_is_even) *
155 (in.get(C::merkle_check_write_left_node) - in.get(C::merkle_check_write_right_node)) +
156 in.get(C::merkle_check_write_right_node)) -
157 in.get(C::merkle_check_write_node));
158 tmp *= scaling_factor;
159 std::get<18>(evals) += typename Accumulator::View(tmp);
160 }
161 { // ASSIGN_SIBLING_LEFT_OR_RIGHT_WRITE
162 using Accumulator = typename std::tuple_element_t<19, ContainerOverSubrelations>;
163 auto tmp = in.get(C::merkle_check_write) *
164 ((in.get(C::merkle_check_index_is_even) *
165 (in.get(C::merkle_check_write_right_node) - in.get(C::merkle_check_write_left_node)) +
166 in.get(C::merkle_check_write_left_node)) -
167 in.get(C::merkle_check_sibling));
168 tmp *= scaling_factor;
169 std::get<19>(evals) += typename Accumulator::View(tmp);
170 }
171 {
172 using Accumulator = typename std::tuple_element_t<20, ContainerOverSubrelations>;
173 auto tmp = in.get(C::merkle_check_sel) * (in.get(C::merkle_check_constant_2) - FF(2));
174 tmp *= scaling_factor;
175 std::get<20>(evals) += typename Accumulator::View(tmp);
176 }
177 { // OUTPUT_HASH_IS_NEXT_ROWS_READ_NODE
178 using Accumulator = typename std::tuple_element_t<21, ContainerOverSubrelations>;
179 auto tmp =
180 merkle_check_NOT_END * (in.get(C::merkle_check_read_node_shift) - in.get(C::merkle_check_read_output_hash));
181 tmp *= scaling_factor;
182 std::get<21>(evals) += typename Accumulator::View(tmp);
183 }
184 { // OUTPUT_HASH_IS_NEXT_ROWS_WRITE_NODE
185 using Accumulator = typename std::tuple_element_t<22, ContainerOverSubrelations>;
186 auto tmp = merkle_check_NOT_END *
187 (in.get(C::merkle_check_write_node_shift) - in.get(C::merkle_check_write_output_hash));
188 tmp *= scaling_factor;
189 std::get<22>(evals) += typename Accumulator::View(tmp);
190 }
191 { // READ_OUTPUT_HASH_IS_READ_ROOT
192 using Accumulator = typename std::tuple_element_t<23, ContainerOverSubrelations>;
193 auto tmp = in.get(C::merkle_check_end) *
194 (in.get(C::merkle_check_read_output_hash) - in.get(C::merkle_check_read_root));
195 tmp *= scaling_factor;
196 std::get<23>(evals) += typename Accumulator::View(tmp);
197 }
198 { // WRITE_OUTPUT_HASH_IS_WRITE_ROOT
199 using Accumulator = typename std::tuple_element_t<24, ContainerOverSubrelations>;
200 auto tmp = in.get(C::merkle_check_end) *
201 (in.get(C::merkle_check_write_output_hash) - in.get(C::merkle_check_write_root));
202 tmp *= scaling_factor;
203 std::get<24>(evals) += typename Accumulator::View(tmp);
204 }
205}
206
207} // namespace bb::avm2
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
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
Definition tuple.hpp:13
#define PROFILE_THIS_NAME(name)
Definition op_count.hpp:16
Container for parameters used by the grand product (permutation, lookup) Honk relations.