Barretenberg
The ZK-SNARK library at the core of Aztec
Loading...
Searching...
No Matches
poseidon2_mem_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 poseidon2_memImpl<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/poseidon2_mem");
18
19 const auto constants_MEM_TAG_FF = FF(0);
20 const auto constants_AVM_HIGHEST_MEM_ADDRESS = FF(4294967295UL);
21 const auto poseidon2_perm_mem_INPUT_TAG_DIFF_0 =
22 (in.get(C::poseidon2_perm_mem_input_tag_0_) - constants_MEM_TAG_FF);
23 const auto poseidon2_perm_mem_INPUT_TAG_DIFF_1 =
24 (in.get(C::poseidon2_perm_mem_input_tag_1_) - constants_MEM_TAG_FF);
25 const auto poseidon2_perm_mem_INPUT_TAG_DIFF_2 =
26 (in.get(C::poseidon2_perm_mem_input_tag_2_) - constants_MEM_TAG_FF);
27 const auto poseidon2_perm_mem_INPUT_TAG_DIFF_3 =
28 (in.get(C::poseidon2_perm_mem_input_tag_3_) - constants_MEM_TAG_FF);
29 const auto poseidon2_perm_mem_BATCHED_TAG_CHECK =
30 FF(1) * poseidon2_perm_mem_INPUT_TAG_DIFF_0 + FF(8) * poseidon2_perm_mem_INPUT_TAG_DIFF_1 +
31 FF(64) * poseidon2_perm_mem_INPUT_TAG_DIFF_2 + FF(512) * poseidon2_perm_mem_INPUT_TAG_DIFF_3;
32
33 { // READ_ADDR_INCR
34 using Accumulator = typename std::tuple_element_t<0, ContainerOverSubrelations>;
35 auto tmp = (in.get(C::poseidon2_perm_mem_read_address_1_) -
36 in.get(C::poseidon2_perm_mem_sel) * (in.get(C::poseidon2_perm_mem_read_address_0_) + FF(1)));
37 tmp *= scaling_factor;
38 std::get<0>(evals) += typename Accumulator::View(tmp);
39 }
40 {
41 using Accumulator = typename std::tuple_element_t<1, ContainerOverSubrelations>;
42 auto tmp = (in.get(C::poseidon2_perm_mem_read_address_2_) -
43 in.get(C::poseidon2_perm_mem_sel) * (in.get(C::poseidon2_perm_mem_read_address_0_) + FF(2)));
44 tmp *= scaling_factor;
45 std::get<1>(evals) += typename Accumulator::View(tmp);
46 }
47 {
48 using Accumulator = typename std::tuple_element_t<2, ContainerOverSubrelations>;
49 auto tmp = (in.get(C::poseidon2_perm_mem_read_address_3_) -
50 in.get(C::poseidon2_perm_mem_sel) * (in.get(C::poseidon2_perm_mem_read_address_0_) + FF(3)));
51 tmp *= scaling_factor;
52 std::get<2>(evals) += typename Accumulator::View(tmp);
53 }
54 { // WRITE_ADDR_INCR
55 using Accumulator = typename std::tuple_element_t<3, ContainerOverSubrelations>;
56 auto tmp = (in.get(C::poseidon2_perm_mem_write_address_1_) -
57 in.get(C::poseidon2_perm_mem_sel) * (in.get(C::poseidon2_perm_mem_write_address_0_) + FF(1)));
58 tmp *= scaling_factor;
59 std::get<3>(evals) += typename Accumulator::View(tmp);
60 }
61 {
62 using Accumulator = typename std::tuple_element_t<4, ContainerOverSubrelations>;
63 auto tmp = (in.get(C::poseidon2_perm_mem_write_address_2_) -
64 in.get(C::poseidon2_perm_mem_sel) * (in.get(C::poseidon2_perm_mem_write_address_0_) + FF(2)));
65 tmp *= scaling_factor;
66 std::get<4>(evals) += typename Accumulator::View(tmp);
67 }
68 {
69 using Accumulator = typename std::tuple_element_t<5, ContainerOverSubrelations>;
70 auto tmp = (in.get(C::poseidon2_perm_mem_write_address_3_) -
71 in.get(C::poseidon2_perm_mem_sel) * (in.get(C::poseidon2_perm_mem_write_address_0_) + FF(3)));
72 tmp *= scaling_factor;
73 std::get<5>(evals) += typename Accumulator::View(tmp);
74 }
75 {
76 using Accumulator = typename std::tuple_element_t<6, ContainerOverSubrelations>;
77 auto tmp = in.get(C::poseidon2_perm_mem_sel_src_out_of_range_err) *
78 (FF(1) - in.get(C::poseidon2_perm_mem_sel_src_out_of_range_err));
79 tmp *= scaling_factor;
80 std::get<6>(evals) += typename Accumulator::View(tmp);
81 }
82 {
83 using Accumulator = typename std::tuple_element_t<7, ContainerOverSubrelations>;
84 auto tmp = in.get(C::poseidon2_perm_mem_sel_dst_out_of_range_err) *
85 (FF(1) - in.get(C::poseidon2_perm_mem_sel_dst_out_of_range_err));
86 tmp *= scaling_factor;
87 std::get<7>(evals) += typename Accumulator::View(tmp);
88 }
89 {
90 using Accumulator = typename std::tuple_element_t<8, ContainerOverSubrelations>;
91 auto tmp = in.get(C::poseidon2_perm_mem_sel) *
92 (in.get(C::poseidon2_perm_mem_max_mem_addr) - constants_AVM_HIGHEST_MEM_ADDRESS);
93 tmp *= scaling_factor;
94 std::get<8>(evals) += typename Accumulator::View(tmp);
95 }
96 {
97 using Accumulator = typename std::tuple_element_t<9, ContainerOverSubrelations>;
98 auto tmp =
99 (in.get(C::poseidon2_perm_mem_sel_should_read_mem) -
100 in.get(C::poseidon2_perm_mem_sel) * (FF(1) - in.get(C::poseidon2_perm_mem_sel_src_out_of_range_err)) *
101 (FF(1) - in.get(C::poseidon2_perm_mem_sel_dst_out_of_range_err)));
102 tmp *= scaling_factor;
103 std::get<9>(evals) += typename Accumulator::View(tmp);
104 }
105 { // BATCH_ZERO_CHECK
106 using Accumulator = typename std::tuple_element_t<10, ContainerOverSubrelations>;
107 auto tmp =
108 (poseidon2_perm_mem_BATCHED_TAG_CHECK * ((FF(1) - in.get(C::poseidon2_perm_mem_sel_invalid_tag_err)) *
109 (FF(1) - in.get(C::poseidon2_perm_mem_batch_tag_inv)) +
110 in.get(C::poseidon2_perm_mem_batch_tag_inv)) -
111 in.get(C::poseidon2_perm_mem_sel_invalid_tag_err));
112 tmp *= scaling_factor;
113 std::get<10>(evals) += typename Accumulator::View(tmp);
114 }
115 {
116 using Accumulator = typename std::tuple_element_t<11, ContainerOverSubrelations>;
117 auto tmp = (in.get(C::poseidon2_perm_mem_err) -
118 (FF(1) - (FF(1) - in.get(C::poseidon2_perm_mem_sel_src_out_of_range_err)) *
119 (FF(1) - in.get(C::poseidon2_perm_mem_sel_dst_out_of_range_err)) *
120 (FF(1) - in.get(C::poseidon2_perm_mem_sel_invalid_tag_err))));
121 tmp *= scaling_factor;
122 std::get<11>(evals) += typename Accumulator::View(tmp);
123 }
124 {
125 using Accumulator = typename std::tuple_element_t<12, ContainerOverSubrelations>;
126 auto tmp = (in.get(C::poseidon2_perm_mem_sel_should_exec) -
127 in.get(C::poseidon2_perm_mem_sel) * (FF(1) - in.get(C::poseidon2_perm_mem_err)));
128 tmp *= scaling_factor;
129 std::get<12>(evals) += typename Accumulator::View(tmp);
130 }
131}
132
133} // 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.