18 3, 3, 3, 3, 4, 4, 3, 3, 3, 3, 3, 2, 2, 3, 2, 2, 3, 2, 2, 3, 2, 2, 3, 2, 2, 2, 2, 2, 2, 2, 2,
19 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2,
20 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 2, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3,
21 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,
22 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 3, 4, 3, 3, 3, 3, 4, 3
25 template <
typename AllEntities>
inline static bool skip(
const AllEntities& in)
29 return (in.get(C::keccakf1600_sel)).is_zero();
32 template <
typename ContainerOverSubrelations,
typename AllEntities>
33 void static accumulate(ContainerOverSubrelations& evals,
34 const AllEntities& in,
36 [[maybe_unused]]
const FF& scaling_factor);
41 static constexpr const std::string_view
NAME =
"keccakf1600";
172 return "SEL_NO_ERROR";
174 return "KECCAK_SEL_ROUND_NON_ZERO";
176 return "KECCAK_ROUND_INCREMENT";
178 return "THETA_XOR_ROW_MSB_0_BOOLEAN";
180 return "THETA_XOR_ROW_0_DECOMPOSITION";
182 return "THETA_XOR_ROW_ROTL1_0";
184 return "THETA_XOR_ROW_MSB_1_BOOLEAN";
186 return "THETA_XOR_ROW_1_DECOMPOSITION";
188 return "THETA_XOR_ROW_ROTL1_1";
190 return "THETA_XOR_ROW_MSB_2_BOOLEAN";
192 return "THETA_XOR_ROW_2_DECOMPOSITION";
194 return "THETA_XOR_ROW_ROTL1_2";
196 return "THETA_XOR_ROW_MSB_3_BOOLEAN";
198 return "THETA_XOR_ROW_3_DECOMPOSITION";
200 return "THETA_XOR_ROW_ROTL1_3";
202 return "THETA_XOR_ROW_MSB_4_BOOLEAN";
204 return "THETA_XOR_ROW_4_DECOMPOSITION";
206 return "THETA_XOR_ROW_ROTL1_4";
208 return "STATE_THETA_01_DECOMPOSE";
210 return "STATE_RHO_01";
212 return "STATE_THETA_02_DECOMPOSE";
214 return "STATE_RHO_02";
216 return "STATE_THETA_03_DECOMPOSE";
218 return "STATE_RHO_03";
220 return "STATE_THETA_04_DECOMPOSE";
222 return "STATE_RHO_04";
224 return "STATE_THETA_10_DECOMPOSE";
226 return "STATE_RHO_10";
228 return "STATE_THETA_11_DECOMPOSE";
230 return "STATE_RHO_11";
232 return "STATE_THETA_12_DECOMPOSE";
234 return "STATE_RHO_12";
236 return "STATE_THETA_13_DECOMPOSE";
238 return "STATE_RHO_13";
240 return "STATE_THETA_14_DECOMPOSE";
242 return "STATE_RHO_14";
244 return "STATE_THETA_20_DECOMPOSE";
246 return "STATE_RHO_20";
248 return "STATE_THETA_21_DECOMPOSE";
250 return "STATE_RHO_21";
252 return "STATE_THETA_22_DECOMPOSE";
254 return "STATE_RHO_22";
256 return "STATE_THETA_23_DECOMPOSE";
258 return "STATE_RHO_23";
260 return "STATE_THETA_24_DECOMPOSE";
262 return "STATE_RHO_24";
264 return "STATE_THETA_30_DECOMPOSE";
266 return "STATE_RHO_30";
268 return "STATE_THETA_31_DECOMPOSE";
270 return "STATE_RHO_31";
272 return "STATE_THETA_32_DECOMPOSE";
274 return "STATE_RHO_32";
276 return "STATE_THETA_33_DECOMPOSE";
278 return "STATE_RHO_33";
280 return "STATE_THETA_34_DECOMPOSE";
282 return "STATE_RHO_34";
284 return "STATE_THETA_40_DECOMPOSE";
286 return "STATE_RHO_40";
288 return "STATE_THETA_41_DECOMPOSE";
290 return "STATE_RHO_41";
292 return "STATE_THETA_42_DECOMPOSE";
294 return "STATE_RHO_42";
296 return "STATE_THETA_43_DECOMPOSE";
298 return "STATE_RHO_43";
300 return "STATE_THETA_44_DECOMPOSE";
302 return "STATE_RHO_44";
304 return "STATE_PI_NOT_00";
306 return "STATE_PI_NOT_01";
308 return "STATE_PI_NOT_02";
310 return "STATE_PI_NOT_03";
312 return "STATE_PI_NOT_04";
314 return "STATE_PI_NOT_10";
316 return "STATE_PI_NOT_11";
318 return "STATE_PI_NOT_12";
320 return "STATE_PI_NOT_13";
322 return "STATE_PI_NOT_14";
324 return "STATE_PI_NOT_20";
326 return "STATE_PI_NOT_21";
328 return "STATE_PI_NOT_22";
330 return "STATE_PI_NOT_23";
332 return "STATE_PI_NOT_24";
334 return "STATE_PI_NOT_30";
336 return "STATE_PI_NOT_31";
338 return "STATE_PI_NOT_32";
340 return "STATE_PI_NOT_33";
342 return "STATE_PI_NOT_34";
344 return "STATE_PI_NOT_40";
346 return "STATE_PI_NOT_41";
348 return "STATE_PI_NOT_42";
350 return "STATE_PI_NOT_43";
352 return "STATE_PI_NOT_44";
354 return "NEXT_STATE_IN_00";
356 return "NEXT_STATE_IN_01";
358 return "NEXT_STATE_IN_02";
360 return "NEXT_STATE_IN_03";
362 return "NEXT_STATE_IN_04";
364 return "NEXT_STATE_IN_10";
366 return "NEXT_STATE_IN_11";
368 return "NEXT_STATE_IN_12";
370 return "NEXT_STATE_IN_13";
372 return "NEXT_STATE_IN_14";
374 return "NEXT_STATE_IN_20";
376 return "NEXT_STATE_IN_21";
378 return "NEXT_STATE_IN_22";
380 return "NEXT_STATE_IN_23";
382 return "NEXT_STATE_IN_24";
384 return "NEXT_STATE_IN_30";
386 return "NEXT_STATE_IN_31";
388 return "NEXT_STATE_IN_32";
390 return "NEXT_STATE_IN_33";
392 return "NEXT_STATE_IN_34";
394 return "NEXT_STATE_IN_40";
396 return "NEXT_STATE_IN_41";
398 return "NEXT_STATE_IN_42";
400 return "NEXT_STATE_IN_43";
402 return "NEXT_STATE_IN_44";
406 return "DST_ADDR_PROPAGATION";
408 return "CLK_PROPAGATION";
410 return "SPACE_ID_PROPAGATION";
412 return "SEL_NO_ERROR_PROPAGATION";
414 return "SEL_SLICE_READ";
416 return "SEL_SLICE_WRITE";
A wrapper for Relations to expose methods used by the Sumcheck prover or verifier to add the contribu...
static constexpr size_t SR_STATE_THETA_30_DECOMPOSE
static constexpr size_t SR_STATE_THETA_14_DECOMPOSE
static constexpr size_t SR_STATE_THETA_01_DECOMPOSE
static constexpr size_t SR_STATE_THETA_40_DECOMPOSE
static constexpr size_t SR_STATE_RHO_20
static constexpr size_t SR_STATE_THETA_10_DECOMPOSE
static constexpr size_t SR_THETA_XOR_ROW_ROTL1_0
static constexpr size_t SR_NEXT_STATE_IN_10
static constexpr size_t SR_SEL_NO_ERROR
static constexpr size_t SR_NEXT_STATE_IN_41
static constexpr size_t SR_STATE_RHO_14
static constexpr size_t SR_STATE_PI_NOT_12
static constexpr size_t SR_NEXT_STATE_IN_21
static constexpr size_t SR_STATE_PI_NOT_01
static constexpr size_t SR_STATE_RHO_44
static constexpr size_t SR_THETA_XOR_ROW_ROTL1_2
static constexpr size_t SR_STATE_PI_NOT_00
static constexpr size_t SR_NEXT_STATE_IN_04
static constexpr size_t SR_NEXT_STATE_IN_33
static constexpr size_t SR_STATE_PI_NOT_11
static constexpr size_t SR_STATE_PI_NOT_10
static constexpr size_t SR_KECCAK_ROUND_INCREMENT
static constexpr size_t SR_STATE_RHO_22
static constexpr size_t SR_NEXT_STATE_IN_34
static constexpr size_t SR_THETA_XOR_ROW_MSB_4_BOOLEAN
static constexpr size_t SR_STATE_RHO_11
static constexpr size_t SR_NEXT_STATE_IN_20
static constexpr size_t SR_STATE_RHO_12
static constexpr size_t SR_STATE_PI_NOT_20
static std::string get_subrelation_label(size_t index)
static constexpr size_t SR_STATE_PI_NOT_03
static constexpr size_t SR_STATE_THETA_32_DECOMPOSE
static constexpr size_t SR_THETA_XOR_ROW_MSB_3_BOOLEAN
static constexpr const std::string_view NAME
static constexpr size_t SR_CLK_PROPAGATION
static constexpr size_t SR_STATE_PI_NOT_32
static constexpr size_t SR_STATE_PI_NOT_02
static constexpr size_t SR_NEXT_STATE_IN_23
static constexpr size_t SR_NEXT_STATE_IN_02
static constexpr size_t SR_STATE_PI_NOT_04
static constexpr size_t SR_NEXT_STATE_IN_01
static constexpr size_t SR_THETA_XOR_ROW_1_DECOMPOSITION
static constexpr size_t SR_SEL_NO_ERROR_PROPAGATION
static constexpr size_t SR_STATE_PI_NOT_23
static constexpr size_t SR_STATE_RHO_24
static constexpr size_t SR_STATE_RHO_21
static constexpr size_t SR_STATE_RHO_04
static constexpr size_t SR_STATE_PI_NOT_22
static constexpr size_t SR_STATE_THETA_02_DECOMPOSE
static constexpr size_t SR_STATE_RHO_13
static constexpr size_t SR_STATE_RHO_02
static constexpr size_t SR_THETA_XOR_ROW_ROTL1_4
static constexpr size_t SR_STATE_RHO_43
static constexpr size_t SR_STATE_THETA_44_DECOMPOSE
static constexpr size_t SR_STATE_PI_NOT_43
static constexpr size_t SR_NEXT_STATE_IN_14
static constexpr size_t SR_SEL_SLICE_READ
static constexpr size_t SR_NEXT_STATE_IN_43
static constexpr size_t SR_NEXT_STATE_IN_32
static constexpr size_t SR_STATE_THETA_31_DECOMPOSE
static constexpr size_t SR_STATE_PI_NOT_42
static constexpr size_t SR_STATE_PI_NOT_14
static constexpr size_t SR_SEL_SLICE_WRITE
static constexpr size_t SR_STATE_PI_NOT_13
static constexpr size_t SR_STATE_RHO_42
static constexpr size_t SR_STATE_THETA_23_DECOMPOSE
static constexpr size_t SR_STATE_THETA_13_DECOMPOSE
static constexpr size_t SR_THETA_XOR_ROW_MSB_1_BOOLEAN
static constexpr size_t SR_STATE_RHO_10
static constexpr size_t SR_STATE_THETA_21_DECOMPOSE
static constexpr size_t SR_KECCAK_SEL_ROUND_NON_ZERO
static constexpr size_t SR_THETA_XOR_ROW_ROTL1_3
static constexpr size_t SR_STATE_PI_NOT_21
static constexpr size_t SR_STATE_THETA_24_DECOMPOSE
static constexpr size_t SR_STATE_RHO_32
static constexpr size_t SR_STATE_RHO_33
static constexpr size_t SR_STATE_PI_NOT_41
static constexpr size_t SR_STATE_PI_NOT_30
static constexpr size_t SR_NEXT_STATE_IN_13
static constexpr size_t SR_STATE_THETA_04_DECOMPOSE
static constexpr size_t SR_THETA_XOR_ROW_3_DECOMPOSITION
static constexpr size_t SR_STATE_RHO_34
static constexpr size_t SR_DST_ADDR_PROPAGATION
static constexpr size_t SR_THETA_XOR_ROW_0_DECOMPOSITION
static constexpr size_t SR_NEXT_STATE_IN_30
static constexpr size_t SR_STATE_PI_NOT_34
static constexpr size_t SR_STATE_PI_NOT_33
static constexpr size_t SR_NEXT_STATE_IN_00
static constexpr size_t SR_STATE_PI_NOT_31
static constexpr size_t SR_STATE_RHO_31
static constexpr size_t SR_STATE_RHO_41
static constexpr size_t SR_STATE_PI_NOT_40
static constexpr size_t SR_STATE_RHO_01
static constexpr size_t SR_NEXT_STATE_IN_42
static constexpr size_t SR_STATE_PI_NOT_44
static constexpr size_t SR_NEXT_STATE_IN_40
static constexpr size_t SR_THETA_XOR_ROW_2_DECOMPOSITION
static constexpr size_t SR_THETA_XOR_ROW_ROTL1_1
static constexpr size_t SR_STATE_THETA_20_DECOMPOSE
static constexpr size_t SR_STATE_RHO_23
static constexpr size_t SR_STATE_RHO_40
static constexpr size_t SR_ERROR
static constexpr size_t SR_NEXT_STATE_IN_11
static constexpr size_t SR_STATE_RHO_03
static constexpr size_t SR_STATE_PI_NOT_24
static constexpr size_t SR_STATE_THETA_11_DECOMPOSE
static constexpr size_t SR_NEXT_STATE_IN_44
static constexpr size_t SR_STATE_THETA_43_DECOMPOSE
static constexpr size_t SR_THETA_XOR_ROW_4_DECOMPOSITION
static constexpr size_t SR_STATE_THETA_22_DECOMPOSE
static constexpr size_t SR_NEXT_STATE_IN_24
static constexpr size_t SR_THETA_XOR_ROW_MSB_0_BOOLEAN
static constexpr size_t SR_STATE_THETA_12_DECOMPOSE
static constexpr size_t SR_NEXT_STATE_IN_12
static constexpr size_t SR_STATE_THETA_34_DECOMPOSE
static constexpr size_t SR_STATE_THETA_33_DECOMPOSE
static constexpr size_t SR_NEXT_STATE_IN_03
static constexpr size_t SR_THETA_XOR_ROW_MSB_2_BOOLEAN
static constexpr size_t SR_NEXT_STATE_IN_22
static constexpr size_t SR_STATE_RHO_30
static constexpr size_t SR_STATE_THETA_41_DECOMPOSE
static constexpr size_t SR_STATE_THETA_03_DECOMPOSE
static constexpr size_t SR_NEXT_STATE_IN_31
static constexpr size_t SR_SPACE_ID_PROPAGATION
static constexpr size_t SR_STATE_THETA_42_DECOMPOSE
static constexpr std::array< size_t, 155 > SUBRELATION_PARTIAL_LENGTHS
static bool skip(const AllEntities &in)
static void accumulate(ContainerOverSubrelations &evals, const AllEntities &in, const RelationParameters< FF > &, const FF &scaling_factor)
std::string to_string(bb::avm2::ValueTag tag)
Container for parameters used by the grand product (permutation, lookup) Honk relations.