27 (in.get(C::poseidon2_perm_mem_input_tag_3_) - constants_MEM_TAG_FF);
28 const auto poseidon2_perm_mem_BATCHED_TAG_CHECK =
29 FF(1) * poseidon2_perm_mem_INPUT_TAG_DIFF_0 +
FF(8) * poseidon2_perm_mem_INPUT_TAG_DIFF_1 +
30 FF(64) * poseidon2_perm_mem_INPUT_TAG_DIFF_2 +
FF(512) * poseidon2_perm_mem_INPUT_TAG_DIFF_3;
33 using View =
typename std::tuple_element_t<0, ContainerOverSubrelations>::View;
34 auto tmp = (
static_cast<View
>(in.get(C::poseidon2_perm_mem_read_address_1_)) -
35 static_cast<View
>(in.get(C::poseidon2_perm_mem_sel)) *
36 (
static_cast<View
>(in.get(C::poseidon2_perm_mem_read_address_0_)) +
FF(1)));
40 using View =
typename std::tuple_element_t<1, ContainerOverSubrelations>::View;
41 auto tmp = (
static_cast<View
>(in.get(C::poseidon2_perm_mem_read_address_2_)) -
42 static_cast<View
>(in.get(C::poseidon2_perm_mem_sel)) *
43 (
static_cast<View
>(in.get(C::poseidon2_perm_mem_read_address_0_)) +
FF(2)));
47 using View =
typename std::tuple_element_t<2, ContainerOverSubrelations>::View;
48 auto tmp = (
static_cast<View
>(in.get(C::poseidon2_perm_mem_read_address_3_)) -
49 static_cast<View
>(in.get(C::poseidon2_perm_mem_sel)) *
50 (
static_cast<View
>(in.get(C::poseidon2_perm_mem_read_address_0_)) +
FF(3)));
54 using View =
typename std::tuple_element_t<3, ContainerOverSubrelations>::View;
55 auto tmp = (
static_cast<View
>(in.get(C::poseidon2_perm_mem_write_address_1_)) -
56 static_cast<View
>(in.get(C::poseidon2_perm_mem_sel)) *
57 (
static_cast<View
>(in.get(C::poseidon2_perm_mem_write_address_0_)) +
FF(1)));
61 using View =
typename std::tuple_element_t<4, ContainerOverSubrelations>::View;
62 auto tmp = (
static_cast<View
>(in.get(C::poseidon2_perm_mem_write_address_2_)) -
63 static_cast<View
>(in.get(C::poseidon2_perm_mem_sel)) *
64 (
static_cast<View
>(in.get(C::poseidon2_perm_mem_write_address_0_)) +
FF(2)));
68 using View =
typename std::tuple_element_t<5, ContainerOverSubrelations>::View;
69 auto tmp = (
static_cast<View
>(in.get(C::poseidon2_perm_mem_write_address_3_)) -
70 static_cast<View
>(in.get(C::poseidon2_perm_mem_sel)) *
71 (
static_cast<View
>(in.get(C::poseidon2_perm_mem_write_address_0_)) +
FF(3)));
75 using View =
typename std::tuple_element_t<6, ContainerOverSubrelations>::View;
77 static_cast<View
>(in.get(C::poseidon2_perm_mem_sel)) *
78 (
static_cast<View
>(in.get(C::poseidon2_perm_mem_max_mem_addr)) -
CView(constants_AVM_HIGHEST_MEM_ADDRESS));
82 using View =
typename std::tuple_element_t<7, ContainerOverSubrelations>::View;
83 auto tmp = (
static_cast<View
>(in.get(C::poseidon2_perm_mem_sel_should_read_mem)) -
84 static_cast<View
>(in.get(C::poseidon2_perm_mem_sel)) *
85 (
FF(1) -
static_cast<View
>(in.get(C::poseidon2_perm_mem_sel_src_out_of_range_err))) *
86 (
FF(1) -
static_cast<View
>(in.get(C::poseidon2_perm_mem_sel_dst_out_of_range_err))));
90 using View =
typename std::tuple_element_t<8, ContainerOverSubrelations>::View;
91 auto tmp =
static_cast<View
>(in.get(C::poseidon2_perm_mem_sel_invalid_tag_err)) *
92 (
FF(1) -
static_cast<View
>(in.get(C::poseidon2_perm_mem_sel_invalid_tag_err)));
96 using View =
typename std::tuple_element_t<9, ContainerOverSubrelations>::View;
97 auto tmp = (
CView(poseidon2_perm_mem_BATCHED_TAG_CHECK) *
98 ((
FF(1) -
static_cast<View
>(in.get(C::poseidon2_perm_mem_sel_invalid_tag_err))) *
99 (
FF(1) -
static_cast<View
>(in.get(C::poseidon2_perm_mem_batch_tag_inv))) +
100 static_cast<View
>(in.get(C::poseidon2_perm_mem_batch_tag_inv))) -
101 static_cast<View
>(in.get(C::poseidon2_perm_mem_sel_invalid_tag_err)));
105 using View =
typename std::tuple_element_t<10, ContainerOverSubrelations>::View;
106 auto tmp = (
static_cast<View
>(in.get(C::poseidon2_perm_mem_err)) -
107 (
FF(1) - (
FF(1) -
static_cast<View
>(in.get(C::poseidon2_perm_mem_sel_src_out_of_range_err))) *
108 (
FF(1) -
static_cast<View
>(in.get(C::poseidon2_perm_mem_sel_dst_out_of_range_err))) *
109 (
FF(1) -
static_cast<View
>(in.get(C::poseidon2_perm_mem_sel_invalid_tag_err)))));
113 using View =
typename std::tuple_element_t<11, ContainerOverSubrelations>::View;
114 auto tmp = (
static_cast<View
>(in.get(C::poseidon2_perm_mem_sel_should_exec)) -
115 static_cast<View
>(in.get(C::poseidon2_perm_mem_sel)) *
116 (
FF(1) -
static_cast<View
>(in.get(C::poseidon2_perm_mem_err))));