32 const auto keccakf1600_POW_ROT_LEN_04 =
FF(262144);
33 const auto keccakf1600_ROT_LEN_10 =
FF(1);
34 const auto keccakf1600_POW_ROT_LEN_10 =
FF(2);
35 const auto keccakf1600_ROT_LEN_11 =
FF(44);
36 const auto keccakf1600_POW_ROT_64_MIN_LEN_11 =
FF(1048576);
37 const auto keccakf1600_ROT_LEN_12 =
FF(10);
38 const auto keccakf1600_POW_ROT_LEN_12 =
FF(1024);
39 const auto keccakf1600_ROT_LEN_13 =
FF(45);
40 const auto keccakf1600_POW_ROT_64_MIN_LEN_13 =
FF(524288);
41 const auto keccakf1600_ROT_LEN_14 =
FF(2);
42 const auto keccakf1600_POW_ROT_LEN_14 =
FF(4);
43 const auto keccakf1600_ROT_LEN_20 =
FF(62);
44 const auto keccakf1600_POW_ROT_64_MIN_LEN_20 =
FF(4);
45 const auto keccakf1600_ROT_LEN_21 =
FF(6);
46 const auto keccakf1600_POW_ROT_LEN_21 =
FF(64);
47 const auto keccakf1600_ROT_LEN_22 =
FF(43);
48 const auto keccakf1600_POW_ROT_64_MIN_LEN_22 =
FF(2097152);
49 const auto keccakf1600_ROT_LEN_23 =
FF(15);
50 const auto keccakf1600_POW_ROT_LEN_23 =
FF(32768);
51 const auto keccakf1600_ROT_LEN_24 =
FF(61);
52 const auto keccakf1600_POW_ROT_64_MIN_LEN_24 =
FF(8);
53 const auto keccakf1600_ROT_LEN_30 =
FF(28);
54 const auto keccakf1600_POW_ROT_LEN_30 =
FF(268435456);
55 const auto keccakf1600_ROT_LEN_31 =
FF(55);
56 const auto keccakf1600_POW_ROT_64_MIN_LEN_31 =
FF(512);
57 const auto keccakf1600_ROT_LEN_32 =
FF(25);
58 const auto keccakf1600_POW_ROT_LEN_32 =
FF(33554432);
59 const auto keccakf1600_ROT_LEN_33 =
FF(21);
60 const auto keccakf1600_POW_ROT_LEN_33 =
FF(2097152);
61 const auto keccakf1600_ROT_LEN_34 =
FF(56);
62 const auto keccakf1600_POW_ROT_64_MIN_LEN_34 =
FF(256);
63 const auto keccakf1600_ROT_LEN_40 =
FF(27);
64 const auto keccakf1600_POW_ROT_LEN_40 =
FF(134217728);
65 const auto keccakf1600_ROT_LEN_41 =
FF(20);
66 const auto keccakf1600_POW_ROT_LEN_41 =
FF(1048576);
67 const auto keccakf1600_ROT_LEN_42 =
FF(39);
68 const auto keccakf1600_POW_ROT_64_MIN_LEN_42 =
FF(33554432);
69 const auto keccakf1600_ROT_LEN_43 =
FF(8);
70 const auto keccakf1600_POW_ROT_LEN_43 =
FF(256);
71 const auto keccakf1600_ROT_LEN_44 =
FF(14);
72 const auto keccakf1600_POW_ROT_LEN_44 =
FF(16384);
73 const auto keccakf1600_STATE_RHO_00 = in.get(C::keccakf1600_state_theta_00);
74 const auto keccakf1600_STATE_PI_00 = keccakf1600_STATE_RHO_00;
75 const auto keccakf1600_STATE_PI_01 = in.get(C::keccakf1600_state_rho_30);
76 const auto keccakf1600_STATE_PI_02 = in.get(C::keccakf1600_state_rho_10);
77 const auto keccakf1600_STATE_PI_03 = in.get(C::keccakf1600_state_rho_40);
78 const auto keccakf1600_STATE_PI_04 = in.get(C::keccakf1600_state_rho_20);
79 const auto keccakf1600_STATE_PI_10 = in.get(C::keccakf1600_state_rho_11);
80 const auto keccakf1600_STATE_PI_11 = in.get(C::keccakf1600_state_rho_41);
81 const auto keccakf1600_STATE_PI_12 = in.get(C::keccakf1600_state_rho_21);
82 const auto keccakf1600_STATE_PI_13 = in.get(C::keccakf1600_state_rho_01);
83 const auto keccakf1600_STATE_PI_14 = in.get(C::keccakf1600_state_rho_31);
84 const auto keccakf1600_STATE_PI_20 = in.get(C::keccakf1600_state_rho_22);
85 const auto keccakf1600_STATE_PI_21 = in.get(C::keccakf1600_state_rho_02);
86 const auto keccakf1600_STATE_PI_22 = in.get(C::keccakf1600_state_rho_32);
87 const auto keccakf1600_STATE_PI_23 = in.get(C::keccakf1600_state_rho_12);
88 const auto keccakf1600_STATE_PI_24 = in.get(C::keccakf1600_state_rho_42);
89 const auto keccakf1600_STATE_PI_30 = in.get(C::keccakf1600_state_rho_33);
90 const auto keccakf1600_STATE_PI_31 = in.get(C::keccakf1600_state_rho_13);
91 const auto keccakf1600_STATE_PI_32 = in.get(C::keccakf1600_state_rho_43);
92 const auto keccakf1600_STATE_PI_33 = in.get(C::keccakf1600_state_rho_23);
93 const auto keccakf1600_STATE_PI_34 = in.get(C::keccakf1600_state_rho_03);
94 const auto keccakf1600_STATE_PI_40 = in.get(C::keccakf1600_state_rho_44);
95 const auto keccakf1600_STATE_PI_41 = in.get(C::keccakf1600_state_rho_24);
96 const auto keccakf1600_STATE_PI_42 = in.get(C::keccakf1600_state_rho_04);
97 const auto keccakf1600_STATE_PI_43 = in.get(C::keccakf1600_state_rho_34);
98 const auto keccakf1600_STATE_PI_44 = in.get(C::keccakf1600_state_rho_14);
99 const auto keccakf1600_POW_64_MIN_1 =
FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL });
100 const auto keccakf1600_HIGHEST_SLICE_ADDRESS =
101 (constants_AVM_HIGHEST_MEM_ADDRESS - constants_AVM_KECCAKF1600_STATE_SIZE) +
FF(1);
104 using View =
typename std::tuple_element_t<0, ContainerOverSubrelations>::View;
106 static_cast<View
>(in.get(C::keccakf1600_sel)) * (
FF(1) -
static_cast<View
>(in.get(C::keccakf1600_sel)));
110 using View =
typename std::tuple_element_t<1, ContainerOverSubrelations>::View;
112 static_cast<View
>(in.get(C::keccakf1600_start)) * (
FF(1) -
static_cast<View
>(in.get(C::keccakf1600_start)));
116 using View =
typename std::tuple_element_t<2, ContainerOverSubrelations>::View;
118 static_cast<View
>(in.get(C::keccakf1600_end)) * (
FF(1) -
static_cast<View
>(in.get(C::keccakf1600_end)));
122 using View =
typename std::tuple_element_t<3, ContainerOverSubrelations>::View;
123 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_start)) +
static_cast<View
>(in.get(C::keccakf1600_end))) *
124 (
FF(1) -
static_cast<View
>(in.get(C::keccakf1600_sel)));
128 using View =
typename std::tuple_element_t<4, ContainerOverSubrelations>::View;
129 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) * (
static_cast<View
>(in.get(C::keccakf1600_sel)) -
130 static_cast<View
>(in.get(C::keccakf1600_sel_shift)));
134 using View =
typename std::tuple_element_t<5, ContainerOverSubrelations>::View;
135 auto tmp =
static_cast<View
>(in.get(C::keccakf1600_sel_shift)) *
136 (
static_cast<View
>(in.get(C::keccakf1600_start_shift)) -
CView(keccakf1600_LATCH_CONDITION));
140 using View =
typename std::tuple_element_t<6, ContainerOverSubrelations>::View;
141 auto tmp =
static_cast<View
>(in.get(C::keccakf1600_sel)) *
142 ((
static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) -
FF(1)) +
143 static_cast<View
>(in.get(C::keccakf1600_error)));
147 using View =
typename std::tuple_element_t<7, ContainerOverSubrelations>::View;
149 static_cast<View
>(in.get(C::keccakf1600_start)) * (
static_cast<View
>(in.get(C::keccakf1600_round)) -
FF(1));
153 using View =
typename std::tuple_element_t<8, ContainerOverSubrelations>::View;
155 static_cast<View
>(in.get(C::keccakf1600_error)) * (
static_cast<View
>(in.get(C::keccakf1600_end)) -
FF(1));
159 using View =
typename std::tuple_element_t<9, ContainerOverSubrelations>::View;
161 static_cast<View
>(in.get(C::keccakf1600_sel)) * (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
162 ((
static_cast<View
>(in.get(C::keccakf1600_round_shift)) -
static_cast<View
>(in.get(C::keccakf1600_round))) -
167 using View =
typename std::tuple_element_t<10, ContainerOverSubrelations>::View;
169 static_cast<View
>(in.get(C::keccakf1600_sel)) *
170 (
static_cast<View
>(in.get(C::keccakf1600_bitwise_xor_op_id)) -
CView(constants_AVM_BITWISE_XOR_OP_ID));
174 using View =
typename std::tuple_element_t<11, ContainerOverSubrelations>::View;
176 static_cast<View
>(in.get(C::keccakf1600_sel)) *
177 (
static_cast<View
>(in.get(C::keccakf1600_bitwise_and_op_id)) -
CView(constants_AVM_BITWISE_AND_OP_ID));
181 using View =
typename std::tuple_element_t<12, ContainerOverSubrelations>::View;
182 auto tmp =
static_cast<View
>(in.get(C::keccakf1600_sel)) *
183 (
static_cast<View
>(in.get(C::keccakf1600_tag_u64)) -
CView(constants_MEM_TAG_U64));
187 using View =
typename std::tuple_element_t<13, ContainerOverSubrelations>::View;
188 auto tmp =
static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_msb_0)) *
189 (
FF(1) -
static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_msb_0)));
193 using View =
typename std::tuple_element_t<14, ContainerOverSubrelations>::View;
194 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_rotl1_0)) -
195 (
FF(2) *
static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_0)) -
196 static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_msb_0)) *
197 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
201 using View =
typename std::tuple_element_t<15, ContainerOverSubrelations>::View;
202 auto tmp =
static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_msb_1)) *
203 (
FF(1) -
static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_msb_1)));
207 using View =
typename std::tuple_element_t<16, ContainerOverSubrelations>::View;
208 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_rotl1_1)) -
209 (
FF(2) *
static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_1)) -
210 static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_msb_1)) *
211 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
215 using View =
typename std::tuple_element_t<17, ContainerOverSubrelations>::View;
216 auto tmp =
static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_msb_2)) *
217 (
FF(1) -
static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_msb_2)));
221 using View =
typename std::tuple_element_t<18, ContainerOverSubrelations>::View;
222 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_rotl1_2)) -
223 (
FF(2) *
static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_2)) -
224 static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_msb_2)) *
225 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
229 using View =
typename std::tuple_element_t<19, ContainerOverSubrelations>::View;
230 auto tmp =
static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_msb_3)) *
231 (
FF(1) -
static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_msb_3)));
235 using View =
typename std::tuple_element_t<20, ContainerOverSubrelations>::View;
236 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_rotl1_3)) -
237 (
FF(2) *
static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_3)) -
238 static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_msb_3)) *
239 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
243 using View =
typename std::tuple_element_t<21, ContainerOverSubrelations>::View;
244 auto tmp =
static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_msb_4)) *
245 (
FF(1) -
static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_msb_4)));
249 using View =
typename std::tuple_element_t<22, ContainerOverSubrelations>::View;
250 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_rotl1_4)) -
251 (
FF(2) *
static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_4)) -
252 static_cast<View
>(in.get(C::keccakf1600_theta_xor_row_msb_4)) *
253 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
257 using View =
typename std::tuple_element_t<23, ContainerOverSubrelations>::View;
258 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_theta_01)) -
259 (
CView(keccakf1600_POW_ROT_64_MIN_LEN_01) *
static_cast<View
>(in.get(C::keccakf1600_state_rho_01)) -
260 static_cast<View
>(in.get(C::keccakf1600_state_theta_low_01)) *
261 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
265 using View =
typename std::tuple_element_t<24, ContainerOverSubrelations>::View;
266 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_rho_02)) -
267 (
CView(keccakf1600_POW_ROT_LEN_02) *
static_cast<View
>(in.get(C::keccakf1600_state_theta_02)) -
268 static_cast<View
>(in.get(C::keccakf1600_state_theta_hi_02)) *
269 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
273 using View =
typename std::tuple_element_t<25, ContainerOverSubrelations>::View;
274 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_theta_03)) -
275 (
CView(keccakf1600_POW_ROT_64_MIN_LEN_03) *
static_cast<View
>(in.get(C::keccakf1600_state_rho_03)) -
276 static_cast<View
>(in.get(C::keccakf1600_state_theta_low_03)) *
277 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
281 using View =
typename std::tuple_element_t<26, ContainerOverSubrelations>::View;
282 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_rho_04)) -
283 (
CView(keccakf1600_POW_ROT_LEN_04) *
static_cast<View
>(in.get(C::keccakf1600_state_theta_04)) -
284 static_cast<View
>(in.get(C::keccakf1600_state_theta_hi_04)) *
285 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
289 using View =
typename std::tuple_element_t<27, ContainerOverSubrelations>::View;
290 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_rho_10)) -
291 (
CView(keccakf1600_POW_ROT_LEN_10) *
static_cast<View
>(in.get(C::keccakf1600_state_theta_10)) -
292 static_cast<View
>(in.get(C::keccakf1600_state_theta_hi_10)) *
293 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
297 using View =
typename std::tuple_element_t<28, ContainerOverSubrelations>::View;
298 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_theta_11)) -
299 (
CView(keccakf1600_POW_ROT_64_MIN_LEN_11) *
static_cast<View
>(in.get(C::keccakf1600_state_rho_11)) -
300 static_cast<View
>(in.get(C::keccakf1600_state_theta_low_11)) *
301 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
305 using View =
typename std::tuple_element_t<29, ContainerOverSubrelations>::View;
306 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_rho_12)) -
307 (
CView(keccakf1600_POW_ROT_LEN_12) *
static_cast<View
>(in.get(C::keccakf1600_state_theta_12)) -
308 static_cast<View
>(in.get(C::keccakf1600_state_theta_hi_12)) *
309 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
313 using View =
typename std::tuple_element_t<30, ContainerOverSubrelations>::View;
314 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_theta_13)) -
315 (
CView(keccakf1600_POW_ROT_64_MIN_LEN_13) *
static_cast<View
>(in.get(C::keccakf1600_state_rho_13)) -
316 static_cast<View
>(in.get(C::keccakf1600_state_theta_low_13)) *
317 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
321 using View =
typename std::tuple_element_t<31, ContainerOverSubrelations>::View;
322 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_rho_14)) -
323 (
CView(keccakf1600_POW_ROT_LEN_14) *
static_cast<View
>(in.get(C::keccakf1600_state_theta_14)) -
324 static_cast<View
>(in.get(C::keccakf1600_state_theta_hi_14)) *
325 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
329 using View =
typename std::tuple_element_t<32, ContainerOverSubrelations>::View;
330 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_theta_20)) -
331 (
CView(keccakf1600_POW_ROT_64_MIN_LEN_20) *
static_cast<View
>(in.get(C::keccakf1600_state_rho_20)) -
332 static_cast<View
>(in.get(C::keccakf1600_state_theta_low_20)) *
333 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
337 using View =
typename std::tuple_element_t<33, ContainerOverSubrelations>::View;
338 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_rho_21)) -
339 (
CView(keccakf1600_POW_ROT_LEN_21) *
static_cast<View
>(in.get(C::keccakf1600_state_theta_21)) -
340 static_cast<View
>(in.get(C::keccakf1600_state_theta_hi_21)) *
341 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
345 using View =
typename std::tuple_element_t<34, ContainerOverSubrelations>::View;
346 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_theta_22)) -
347 (
CView(keccakf1600_POW_ROT_64_MIN_LEN_22) *
static_cast<View
>(in.get(C::keccakf1600_state_rho_22)) -
348 static_cast<View
>(in.get(C::keccakf1600_state_theta_low_22)) *
349 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
353 using View =
typename std::tuple_element_t<35, ContainerOverSubrelations>::View;
354 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_rho_23)) -
355 (
CView(keccakf1600_POW_ROT_LEN_23) *
static_cast<View
>(in.get(C::keccakf1600_state_theta_23)) -
356 static_cast<View
>(in.get(C::keccakf1600_state_theta_hi_23)) *
357 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
361 using View =
typename std::tuple_element_t<36, ContainerOverSubrelations>::View;
362 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_theta_24)) -
363 (
CView(keccakf1600_POW_ROT_64_MIN_LEN_24) *
static_cast<View
>(in.get(C::keccakf1600_state_rho_24)) -
364 static_cast<View
>(in.get(C::keccakf1600_state_theta_low_24)) *
365 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
369 using View =
typename std::tuple_element_t<37, ContainerOverSubrelations>::View;
370 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_rho_30)) -
371 (
CView(keccakf1600_POW_ROT_LEN_30) *
static_cast<View
>(in.get(C::keccakf1600_state_theta_30)) -
372 static_cast<View
>(in.get(C::keccakf1600_state_theta_hi_30)) *
373 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
377 using View =
typename std::tuple_element_t<38, ContainerOverSubrelations>::View;
378 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_theta_31)) -
379 (
CView(keccakf1600_POW_ROT_64_MIN_LEN_31) *
static_cast<View
>(in.get(C::keccakf1600_state_rho_31)) -
380 static_cast<View
>(in.get(C::keccakf1600_state_theta_low_31)) *
381 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
385 using View =
typename std::tuple_element_t<39, ContainerOverSubrelations>::View;
386 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_rho_32)) -
387 (
CView(keccakf1600_POW_ROT_LEN_32) *
static_cast<View
>(in.get(C::keccakf1600_state_theta_32)) -
388 static_cast<View
>(in.get(C::keccakf1600_state_theta_hi_32)) *
389 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
393 using View =
typename std::tuple_element_t<40, ContainerOverSubrelations>::View;
394 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_rho_33)) -
395 (
CView(keccakf1600_POW_ROT_LEN_33) *
static_cast<View
>(in.get(C::keccakf1600_state_theta_33)) -
396 static_cast<View
>(in.get(C::keccakf1600_state_theta_hi_33)) *
397 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
401 using View =
typename std::tuple_element_t<41, ContainerOverSubrelations>::View;
402 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_theta_34)) -
403 (
CView(keccakf1600_POW_ROT_64_MIN_LEN_34) *
static_cast<View
>(in.get(C::keccakf1600_state_rho_34)) -
404 static_cast<View
>(in.get(C::keccakf1600_state_theta_low_34)) *
405 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
409 using View =
typename std::tuple_element_t<42, ContainerOverSubrelations>::View;
410 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_rho_40)) -
411 (
CView(keccakf1600_POW_ROT_LEN_40) *
static_cast<View
>(in.get(C::keccakf1600_state_theta_40)) -
412 static_cast<View
>(in.get(C::keccakf1600_state_theta_hi_40)) *
413 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
417 using View =
typename std::tuple_element_t<43, ContainerOverSubrelations>::View;
418 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_rho_41)) -
419 (
CView(keccakf1600_POW_ROT_LEN_41) *
static_cast<View
>(in.get(C::keccakf1600_state_theta_41)) -
420 static_cast<View
>(in.get(C::keccakf1600_state_theta_hi_41)) *
421 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
425 using View =
typename std::tuple_element_t<44, ContainerOverSubrelations>::View;
426 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_theta_42)) -
427 (
CView(keccakf1600_POW_ROT_64_MIN_LEN_42) *
static_cast<View
>(in.get(C::keccakf1600_state_rho_42)) -
428 static_cast<View
>(in.get(C::keccakf1600_state_theta_low_42)) *
429 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
433 using View =
typename std::tuple_element_t<45, ContainerOverSubrelations>::View;
434 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_rho_43)) -
435 (
CView(keccakf1600_POW_ROT_LEN_43) *
static_cast<View
>(in.get(C::keccakf1600_state_theta_43)) -
436 static_cast<View
>(in.get(C::keccakf1600_state_theta_hi_43)) *
437 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
441 using View =
typename std::tuple_element_t<46, ContainerOverSubrelations>::View;
442 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_rho_44)) -
443 (
CView(keccakf1600_POW_ROT_LEN_44) *
static_cast<View
>(in.get(C::keccakf1600_state_theta_44)) -
444 static_cast<View
>(in.get(C::keccakf1600_state_theta_hi_44)) *
445 FF(
uint256_t{ 18446744073709551615UL, 0UL, 0UL, 0UL })));
449 using View =
typename std::tuple_element_t<47, ContainerOverSubrelations>::View;
450 auto tmp =
static_cast<View
>(in.get(C::keccakf1600_sel)) *
451 (
static_cast<View
>(in.get(C::keccakf1600_rot_len_02)) -
CView(keccakf1600_ROT_LEN_02));
455 using View =
typename std::tuple_element_t<48, ContainerOverSubrelations>::View;
456 auto tmp =
static_cast<View
>(in.get(C::keccakf1600_sel)) *
457 (
static_cast<View
>(in.get(C::keccakf1600_rot_len_04)) -
CView(keccakf1600_ROT_LEN_04));
461 using View =
typename std::tuple_element_t<49, ContainerOverSubrelations>::View;
462 auto tmp =
static_cast<View
>(in.get(C::keccakf1600_sel)) *
463 (
static_cast<View
>(in.get(C::keccakf1600_rot_len_10)) -
CView(keccakf1600_ROT_LEN_10));
467 using View =
typename std::tuple_element_t<50, ContainerOverSubrelations>::View;
468 auto tmp =
static_cast<View
>(in.get(C::keccakf1600_sel)) *
469 (
static_cast<View
>(in.get(C::keccakf1600_rot_len_12)) -
CView(keccakf1600_ROT_LEN_12));
473 using View =
typename std::tuple_element_t<51, ContainerOverSubrelations>::View;
474 auto tmp =
static_cast<View
>(in.get(C::keccakf1600_sel)) *
475 (
static_cast<View
>(in.get(C::keccakf1600_rot_len_14)) -
CView(keccakf1600_ROT_LEN_14));
479 using View =
typename std::tuple_element_t<52, ContainerOverSubrelations>::View;
480 auto tmp =
static_cast<View
>(in.get(C::keccakf1600_sel)) *
481 (
static_cast<View
>(in.get(C::keccakf1600_rot_len_21)) -
CView(keccakf1600_ROT_LEN_21));
485 using View =
typename std::tuple_element_t<53, ContainerOverSubrelations>::View;
486 auto tmp =
static_cast<View
>(in.get(C::keccakf1600_sel)) *
487 (
static_cast<View
>(in.get(C::keccakf1600_rot_len_23)) -
CView(keccakf1600_ROT_LEN_23));
491 using View =
typename std::tuple_element_t<54, ContainerOverSubrelations>::View;
492 auto tmp =
static_cast<View
>(in.get(C::keccakf1600_sel)) *
493 (
static_cast<View
>(in.get(C::keccakf1600_rot_len_30)) -
CView(keccakf1600_ROT_LEN_30));
497 using View =
typename std::tuple_element_t<55, ContainerOverSubrelations>::View;
498 auto tmp =
static_cast<View
>(in.get(C::keccakf1600_sel)) *
499 (
static_cast<View
>(in.get(C::keccakf1600_rot_len_32)) -
CView(keccakf1600_ROT_LEN_32));
503 using View =
typename std::tuple_element_t<56, ContainerOverSubrelations>::View;
504 auto tmp =
static_cast<View
>(in.get(C::keccakf1600_sel)) *
505 (
static_cast<View
>(in.get(C::keccakf1600_rot_len_33)) -
CView(keccakf1600_ROT_LEN_33));
509 using View =
typename std::tuple_element_t<57, ContainerOverSubrelations>::View;
510 auto tmp =
static_cast<View
>(in.get(C::keccakf1600_sel)) *
511 (
static_cast<View
>(in.get(C::keccakf1600_rot_len_40)) -
CView(keccakf1600_ROT_LEN_40));
515 using View =
typename std::tuple_element_t<58, ContainerOverSubrelations>::View;
516 auto tmp =
static_cast<View
>(in.get(C::keccakf1600_sel)) *
517 (
static_cast<View
>(in.get(C::keccakf1600_rot_len_41)) -
CView(keccakf1600_ROT_LEN_41));
521 using View =
typename std::tuple_element_t<59, ContainerOverSubrelations>::View;
522 auto tmp =
static_cast<View
>(in.get(C::keccakf1600_sel)) *
523 (
static_cast<View
>(in.get(C::keccakf1600_rot_len_43)) -
CView(keccakf1600_ROT_LEN_43));
527 using View =
typename std::tuple_element_t<60, ContainerOverSubrelations>::View;
528 auto tmp =
static_cast<View
>(in.get(C::keccakf1600_sel)) *
529 (
static_cast<View
>(in.get(C::keccakf1600_rot_len_44)) -
CView(keccakf1600_ROT_LEN_44));
533 using View =
typename std::tuple_element_t<61, ContainerOverSubrelations>::View;
535 static_cast<View
>(in.get(C::keccakf1600_sel)) *
536 (
static_cast<View
>(in.get(C::keccakf1600_rot_64_min_len_01)) - (
FF(64) -
CView(keccakf1600_ROT_LEN_01)));
540 using View =
typename std::tuple_element_t<62, ContainerOverSubrelations>::View;
542 static_cast<View
>(in.get(C::keccakf1600_sel)) *
543 (
static_cast<View
>(in.get(C::keccakf1600_rot_64_min_len_03)) - (
FF(64) -
CView(keccakf1600_ROT_LEN_03)));
547 using View =
typename std::tuple_element_t<63, ContainerOverSubrelations>::View;
549 static_cast<View
>(in.get(C::keccakf1600_sel)) *
550 (
static_cast<View
>(in.get(C::keccakf1600_rot_64_min_len_11)) - (
FF(64) -
CView(keccakf1600_ROT_LEN_11)));
554 using View =
typename std::tuple_element_t<64, ContainerOverSubrelations>::View;
556 static_cast<View
>(in.get(C::keccakf1600_sel)) *
557 (
static_cast<View
>(in.get(C::keccakf1600_rot_64_min_len_13)) - (
FF(64) -
CView(keccakf1600_ROT_LEN_13)));
561 using View =
typename std::tuple_element_t<65, ContainerOverSubrelations>::View;
563 static_cast<View
>(in.get(C::keccakf1600_sel)) *
564 (
static_cast<View
>(in.get(C::keccakf1600_rot_64_min_len_20)) - (
FF(64) -
CView(keccakf1600_ROT_LEN_20)));
568 using View =
typename std::tuple_element_t<66, ContainerOverSubrelations>::View;
570 static_cast<View
>(in.get(C::keccakf1600_sel)) *
571 (
static_cast<View
>(in.get(C::keccakf1600_rot_64_min_len_22)) - (
FF(64) -
CView(keccakf1600_ROT_LEN_22)));
575 using View =
typename std::tuple_element_t<67, ContainerOverSubrelations>::View;
577 static_cast<View
>(in.get(C::keccakf1600_sel)) *
578 (
static_cast<View
>(in.get(C::keccakf1600_rot_64_min_len_24)) - (
FF(64) -
CView(keccakf1600_ROT_LEN_24)));
582 using View =
typename std::tuple_element_t<68, ContainerOverSubrelations>::View;
584 static_cast<View
>(in.get(C::keccakf1600_sel)) *
585 (
static_cast<View
>(in.get(C::keccakf1600_rot_64_min_len_31)) - (
FF(64) -
CView(keccakf1600_ROT_LEN_31)));
589 using View =
typename std::tuple_element_t<69, ContainerOverSubrelations>::View;
591 static_cast<View
>(in.get(C::keccakf1600_sel)) *
592 (
static_cast<View
>(in.get(C::keccakf1600_rot_64_min_len_34)) - (
FF(64) -
CView(keccakf1600_ROT_LEN_34)));
596 using View =
typename std::tuple_element_t<70, ContainerOverSubrelations>::View;
598 static_cast<View
>(in.get(C::keccakf1600_sel)) *
599 (
static_cast<View
>(in.get(C::keccakf1600_rot_64_min_len_42)) - (
FF(64) -
CView(keccakf1600_ROT_LEN_42)));
603 using View =
typename std::tuple_element_t<71, ContainerOverSubrelations>::View;
604 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_00)) -
605 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
606 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_00)));
610 using View =
typename std::tuple_element_t<72, ContainerOverSubrelations>::View;
611 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_01)) -
612 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
613 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_01)));
617 using View =
typename std::tuple_element_t<73, ContainerOverSubrelations>::View;
618 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_02)) -
619 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
620 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_02)));
624 using View =
typename std::tuple_element_t<74, ContainerOverSubrelations>::View;
625 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_03)) -
626 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
627 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_03)));
631 using View =
typename std::tuple_element_t<75, ContainerOverSubrelations>::View;
632 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_04)) -
633 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
634 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_04)));
638 using View =
typename std::tuple_element_t<76, ContainerOverSubrelations>::View;
639 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_10)) -
640 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
641 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_10)));
645 using View =
typename std::tuple_element_t<77, ContainerOverSubrelations>::View;
646 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_11)) -
647 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
648 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_11)));
652 using View =
typename std::tuple_element_t<78, ContainerOverSubrelations>::View;
653 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_12)) -
654 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
655 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_12)));
659 using View =
typename std::tuple_element_t<79, ContainerOverSubrelations>::View;
660 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_13)) -
661 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
662 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_13)));
666 using View =
typename std::tuple_element_t<80, ContainerOverSubrelations>::View;
667 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_14)) -
668 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
669 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_14)));
673 using View =
typename std::tuple_element_t<81, ContainerOverSubrelations>::View;
674 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_20)) -
675 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
676 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_20)));
680 using View =
typename std::tuple_element_t<82, ContainerOverSubrelations>::View;
681 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_21)) -
682 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
683 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_21)));
687 using View =
typename std::tuple_element_t<83, ContainerOverSubrelations>::View;
688 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_22)) -
689 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
690 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_22)));
694 using View =
typename std::tuple_element_t<84, ContainerOverSubrelations>::View;
695 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_23)) -
696 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
697 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_23)));
701 using View =
typename std::tuple_element_t<85, ContainerOverSubrelations>::View;
702 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_24)) -
703 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
704 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_24)));
708 using View =
typename std::tuple_element_t<86, ContainerOverSubrelations>::View;
709 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_30)) -
710 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
711 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_30)));
715 using View =
typename std::tuple_element_t<87, ContainerOverSubrelations>::View;
716 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_31)) -
717 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
718 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_31)));
722 using View =
typename std::tuple_element_t<88, ContainerOverSubrelations>::View;
723 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_32)) -
724 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
725 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_32)));
729 using View =
typename std::tuple_element_t<89, ContainerOverSubrelations>::View;
730 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_33)) -
731 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
732 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_33)));
736 using View =
typename std::tuple_element_t<90, ContainerOverSubrelations>::View;
737 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_34)) -
738 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
739 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_34)));
743 using View =
typename std::tuple_element_t<91, ContainerOverSubrelations>::View;
744 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_40)) -
745 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
746 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_40)));
750 using View =
typename std::tuple_element_t<92, ContainerOverSubrelations>::View;
751 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_41)) -
752 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
753 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_41)));
757 using View =
typename std::tuple_element_t<93, ContainerOverSubrelations>::View;
758 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_42)) -
759 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
760 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_42)));
764 using View =
typename std::tuple_element_t<94, ContainerOverSubrelations>::View;
765 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_43)) -
766 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
767 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_43)));
771 using View =
typename std::tuple_element_t<95, ContainerOverSubrelations>::View;
772 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_state_pi_not_44)) -
773 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
774 (
CView(keccakf1600_POW_64_MIN_1) -
CView(keccakf1600_STATE_PI_44)));
778 using View =
typename std::tuple_element_t<96, ContainerOverSubrelations>::View;
779 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
780 (
static_cast<View
>(in.get(C::keccakf1600_state_in_00_shift)) -
781 static_cast<View
>(in.get(C::keccakf1600_state_iota_00)));
785 using View =
typename std::tuple_element_t<97, ContainerOverSubrelations>::View;
786 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
787 (
static_cast<View
>(in.get(C::keccakf1600_state_in_01_shift)) -
788 static_cast<View
>(in.get(C::keccakf1600_state_chi_01)));
792 using View =
typename std::tuple_element_t<98, ContainerOverSubrelations>::View;
793 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
794 (
static_cast<View
>(in.get(C::keccakf1600_state_in_02_shift)) -
795 static_cast<View
>(in.get(C::keccakf1600_state_chi_02)));
799 using View =
typename std::tuple_element_t<99, ContainerOverSubrelations>::View;
800 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
801 (
static_cast<View
>(in.get(C::keccakf1600_state_in_03_shift)) -
802 static_cast<View
>(in.get(C::keccakf1600_state_chi_03)));
806 using View =
typename std::tuple_element_t<100, ContainerOverSubrelations>::View;
807 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
808 (
static_cast<View
>(in.get(C::keccakf1600_state_in_04_shift)) -
809 static_cast<View
>(in.get(C::keccakf1600_state_chi_04)));
813 using View =
typename std::tuple_element_t<101, ContainerOverSubrelations>::View;
814 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
815 (
static_cast<View
>(in.get(C::keccakf1600_state_in_10_shift)) -
816 static_cast<View
>(in.get(C::keccakf1600_state_chi_10)));
820 using View =
typename std::tuple_element_t<102, ContainerOverSubrelations>::View;
821 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
822 (
static_cast<View
>(in.get(C::keccakf1600_state_in_11_shift)) -
823 static_cast<View
>(in.get(C::keccakf1600_state_chi_11)));
827 using View =
typename std::tuple_element_t<103, ContainerOverSubrelations>::View;
828 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
829 (
static_cast<View
>(in.get(C::keccakf1600_state_in_12_shift)) -
830 static_cast<View
>(in.get(C::keccakf1600_state_chi_12)));
834 using View =
typename std::tuple_element_t<104, ContainerOverSubrelations>::View;
835 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
836 (
static_cast<View
>(in.get(C::keccakf1600_state_in_13_shift)) -
837 static_cast<View
>(in.get(C::keccakf1600_state_chi_13)));
841 using View =
typename std::tuple_element_t<105, ContainerOverSubrelations>::View;
842 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
843 (
static_cast<View
>(in.get(C::keccakf1600_state_in_14_shift)) -
844 static_cast<View
>(in.get(C::keccakf1600_state_chi_14)));
848 using View =
typename std::tuple_element_t<106, ContainerOverSubrelations>::View;
849 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
850 (
static_cast<View
>(in.get(C::keccakf1600_state_in_20_shift)) -
851 static_cast<View
>(in.get(C::keccakf1600_state_chi_20)));
855 using View =
typename std::tuple_element_t<107, ContainerOverSubrelations>::View;
856 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
857 (
static_cast<View
>(in.get(C::keccakf1600_state_in_21_shift)) -
858 static_cast<View
>(in.get(C::keccakf1600_state_chi_21)));
862 using View =
typename std::tuple_element_t<108, ContainerOverSubrelations>::View;
863 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
864 (
static_cast<View
>(in.get(C::keccakf1600_state_in_22_shift)) -
865 static_cast<View
>(in.get(C::keccakf1600_state_chi_22)));
869 using View =
typename std::tuple_element_t<109, ContainerOverSubrelations>::View;
870 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
871 (
static_cast<View
>(in.get(C::keccakf1600_state_in_23_shift)) -
872 static_cast<View
>(in.get(C::keccakf1600_state_chi_23)));
876 using View =
typename std::tuple_element_t<110, ContainerOverSubrelations>::View;
877 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
878 (
static_cast<View
>(in.get(C::keccakf1600_state_in_24_shift)) -
879 static_cast<View
>(in.get(C::keccakf1600_state_chi_24)));
883 using View =
typename std::tuple_element_t<111, ContainerOverSubrelations>::View;
884 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
885 (
static_cast<View
>(in.get(C::keccakf1600_state_in_30_shift)) -
886 static_cast<View
>(in.get(C::keccakf1600_state_chi_30)));
890 using View =
typename std::tuple_element_t<112, ContainerOverSubrelations>::View;
891 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
892 (
static_cast<View
>(in.get(C::keccakf1600_state_in_31_shift)) -
893 static_cast<View
>(in.get(C::keccakf1600_state_chi_31)));
897 using View =
typename std::tuple_element_t<113, ContainerOverSubrelations>::View;
898 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
899 (
static_cast<View
>(in.get(C::keccakf1600_state_in_32_shift)) -
900 static_cast<View
>(in.get(C::keccakf1600_state_chi_32)));
904 using View =
typename std::tuple_element_t<114, ContainerOverSubrelations>::View;
905 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
906 (
static_cast<View
>(in.get(C::keccakf1600_state_in_33_shift)) -
907 static_cast<View
>(in.get(C::keccakf1600_state_chi_33)));
911 using View =
typename std::tuple_element_t<115, ContainerOverSubrelations>::View;
912 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
913 (
static_cast<View
>(in.get(C::keccakf1600_state_in_34_shift)) -
914 static_cast<View
>(in.get(C::keccakf1600_state_chi_34)));
918 using View =
typename std::tuple_element_t<116, ContainerOverSubrelations>::View;
919 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
920 (
static_cast<View
>(in.get(C::keccakf1600_state_in_40_shift)) -
921 static_cast<View
>(in.get(C::keccakf1600_state_chi_40)));
925 using View =
typename std::tuple_element_t<117, ContainerOverSubrelations>::View;
926 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
927 (
static_cast<View
>(in.get(C::keccakf1600_state_in_41_shift)) -
928 static_cast<View
>(in.get(C::keccakf1600_state_chi_41)));
932 using View =
typename std::tuple_element_t<118, ContainerOverSubrelations>::View;
933 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
934 (
static_cast<View
>(in.get(C::keccakf1600_state_in_42_shift)) -
935 static_cast<View
>(in.get(C::keccakf1600_state_chi_42)));
939 using View =
typename std::tuple_element_t<119, ContainerOverSubrelations>::View;
940 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
941 (
static_cast<View
>(in.get(C::keccakf1600_state_in_43_shift)) -
942 static_cast<View
>(in.get(C::keccakf1600_state_chi_43)));
946 using View =
typename std::tuple_element_t<120, ContainerOverSubrelations>::View;
947 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
948 (
static_cast<View
>(in.get(C::keccakf1600_state_in_44_shift)) -
949 static_cast<View
>(in.get(C::keccakf1600_state_chi_44)));
953 using View =
typename std::tuple_element_t<121, ContainerOverSubrelations>::View;
954 auto tmp =
static_cast<View
>(in.get(C::keccakf1600_start)) *
955 (
static_cast<View
>(in.get(C::keccakf1600_highest_slice_address)) -
956 CView(keccakf1600_HIGHEST_SLICE_ADDRESS));
960 using View =
typename std::tuple_element_t<122, ContainerOverSubrelations>::View;
961 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_error)) -
962 (
FF(1) - (
FF(1) -
static_cast<View
>(in.get(C::keccakf1600_src_out_of_range_error))) *
963 (
FF(1) -
static_cast<View
>(in.get(C::keccakf1600_dst_out_of_range_error))) *
964 (
FF(1) -
static_cast<View
>(in.get(C::keccakf1600_tag_error)))));
968 using View =
typename std::tuple_element_t<123, ContainerOverSubrelations>::View;
970 (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) * (
static_cast<View
>(in.get(C::keccakf1600_dst_addr_shift)) -
971 static_cast<View
>(in.get(C::keccakf1600_dst_addr)));
975 using View =
typename std::tuple_element_t<124, ContainerOverSubrelations>::View;
976 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) * (
static_cast<View
>(in.get(C::keccakf1600_clk_shift)) -
977 static_cast<View
>(in.get(C::keccakf1600_clk)));
981 using View =
typename std::tuple_element_t<125, ContainerOverSubrelations>::View;
983 (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) * (
static_cast<View
>(in.get(C::keccakf1600_space_id_shift)) -
984 static_cast<View
>(in.get(C::keccakf1600_space_id)));
988 using View =
typename std::tuple_element_t<126, ContainerOverSubrelations>::View;
989 auto tmp = (
FF(1) -
CView(keccakf1600_LATCH_CONDITION)) *
990 (
static_cast<View
>(in.get(C::keccakf1600_sel_no_error_shift)) -
991 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)));
995 using View =
typename std::tuple_element_t<127, ContainerOverSubrelations>::View;
996 auto tmp = (
static_cast<View
>(in.get(C::keccakf1600_sel_slice_read)) -
997 static_cast<View
>(in.get(C::keccakf1600_start)) *
998 (
FF(1) -
static_cast<View
>(in.get(C::keccakf1600_src_out_of_range_error))) *
999 (
FF(1) -
static_cast<View
>(in.get(C::keccakf1600_dst_out_of_range_error))));
1003 using View =
typename std::tuple_element_t<128, ContainerOverSubrelations>::View;
1005 (
static_cast<View
>(in.get(C::keccakf1600_sel_slice_write)) -
1006 static_cast<View
>(in.get(C::keccakf1600_sel_no_error)) *
static_cast<View
>(in.get(C::keccakf1600_end)));
1010 using View =
typename std::tuple_element_t<129, ContainerOverSubrelations>::View;
1011 auto tmp =
static_cast<View
>(in.get(C::keccakf1600_sel_slice_write)) *
1012 (
static_cast<View
>(in.get(C::keccakf1600_round)) -
CView(constants_AVM_KECCAKF1600_NUM_ROUNDS));