Barretenberg
The ZK-SNARK library at the core of Aztec
Loading...
Searching...
No Matches
ecc_mem_impl.hpp
Go to the documentation of this file.
1// AUTOGENERATED FILE
2#pragma once
3
6
7namespace bb::avm2 {
8
9template <typename FF_>
10template <typename ContainerOverSubrelations, typename AllEntities>
11void ecc_memImpl<FF_>::accumulate(ContainerOverSubrelations& evals,
12 const AllEntities& in,
13 [[maybe_unused]] const RelationParameters<FF_>&,
14 [[maybe_unused]] const FF_& scaling_factor)
15{
16 using C = ColumnAndShifts;
17
18 const auto constants_AVM_HIGHEST_MEM_ADDRESS = FF(4294967295UL);
19 const auto ecc_INFINITY_X = FF(0);
20 const auto ecc_INFINITY_Y = FF(0);
21 const auto ecc_add_mem_P_X3 = in.get(C::ecc_add_mem_p_x) * in.get(C::ecc_add_mem_p_x) * in.get(C::ecc_add_mem_p_x);
22 const auto ecc_add_mem_P_Y2 = in.get(C::ecc_add_mem_p_y) * in.get(C::ecc_add_mem_p_y);
23 const auto ecc_add_mem_Q_X3 = in.get(C::ecc_add_mem_q_x) * in.get(C::ecc_add_mem_q_x) * in.get(C::ecc_add_mem_q_x);
24 const auto ecc_add_mem_Q_Y2 = in.get(C::ecc_add_mem_q_y) * in.get(C::ecc_add_mem_q_y);
25
26 {
27 using View = typename std::tuple_element_t<0, ContainerOverSubrelations>::View;
28 auto tmp =
29 static_cast<View>(in.get(C::ecc_add_mem_sel)) * (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_sel)));
30 std::get<0>(evals) += (tmp * scaling_factor);
31 }
32 { // WRITE_INCR_DST_ADDR
33 using View = typename std::tuple_element_t<1, ContainerOverSubrelations>::View;
34 auto tmp = (static_cast<View>(in.get(C::ecc_add_mem_dst_addr_1_)) -
35 static_cast<View>(in.get(C::ecc_add_mem_sel)) *
36 (static_cast<View>(in.get(C::ecc_add_mem_dst_addr_0_)) + FF(1)));
37 std::get<1>(evals) += (tmp * scaling_factor);
38 }
39 {
40 using View = typename std::tuple_element_t<2, ContainerOverSubrelations>::View;
41 auto tmp = (static_cast<View>(in.get(C::ecc_add_mem_dst_addr_2_)) -
42 static_cast<View>(in.get(C::ecc_add_mem_sel)) *
43 (static_cast<View>(in.get(C::ecc_add_mem_dst_addr_0_)) + FF(2)));
44 std::get<2>(evals) += (tmp * scaling_factor);
45 }
46 {
47 using View = typename std::tuple_element_t<3, ContainerOverSubrelations>::View;
48 auto tmp = static_cast<View>(in.get(C::ecc_add_mem_sel)) *
49 (static_cast<View>(in.get(C::ecc_add_mem_max_mem_addr)) - CView(constants_AVM_HIGHEST_MEM_ADDRESS));
50 std::get<3>(evals) += (tmp * scaling_factor);
51 }
52 {
53 using View = typename std::tuple_element_t<4, ContainerOverSubrelations>::View;
54 auto tmp = static_cast<View>(in.get(C::ecc_add_mem_sel_p_not_on_curve_err)) *
55 (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_sel_p_not_on_curve_err)));
56 std::get<4>(evals) += (tmp * scaling_factor);
57 }
58 {
59 using View = typename std::tuple_element_t<5, ContainerOverSubrelations>::View;
60 auto tmp = static_cast<View>(in.get(C::ecc_add_mem_sel_q_not_on_curve_err)) *
61 (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_sel_q_not_on_curve_err)));
62 std::get<5>(evals) += (tmp * scaling_factor);
63 }
64 { // P_CURVE_EQN
65 using View = typename std::tuple_element_t<6, ContainerOverSubrelations>::View;
66 auto tmp = (static_cast<View>(in.get(C::ecc_add_mem_p_is_on_curve_eqn)) -
67 static_cast<View>(in.get(C::ecc_add_mem_sel)) *
68 (CView(ecc_add_mem_P_Y2) - (CView(ecc_add_mem_P_X3) - FF(17))) *
69 (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_p_is_inf))));
70 std::get<6>(evals) += (tmp * scaling_factor);
71 }
72 { // P_ON_CURVE_CHECK
73 using View = typename std::tuple_element_t<7, ContainerOverSubrelations>::View;
74 auto tmp = static_cast<View>(in.get(C::ecc_add_mem_sel)) *
75 (static_cast<View>(in.get(C::ecc_add_mem_p_is_on_curve_eqn)) *
76 ((FF(1) - static_cast<View>(in.get(C::ecc_add_mem_sel_p_not_on_curve_err))) *
77 (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_p_is_on_curve_eqn_inv))) +
78 static_cast<View>(in.get(C::ecc_add_mem_p_is_on_curve_eqn_inv))) -
79 static_cast<View>(in.get(C::ecc_add_mem_sel_p_not_on_curve_err)));
80 std::get<7>(evals) += (tmp * scaling_factor);
81 }
82 { // Q_CURVE_EQN
83 using View = typename std::tuple_element_t<8, ContainerOverSubrelations>::View;
84 auto tmp = (static_cast<View>(in.get(C::ecc_add_mem_q_is_on_curve_eqn)) -
85 static_cast<View>(in.get(C::ecc_add_mem_sel)) *
86 (CView(ecc_add_mem_Q_Y2) - (CView(ecc_add_mem_Q_X3) - FF(17))) *
87 (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_q_is_inf))));
88 std::get<8>(evals) += (tmp * scaling_factor);
89 }
90 { // Q_ON_CURVE_CHECK
91 using View = typename std::tuple_element_t<9, ContainerOverSubrelations>::View;
92 auto tmp = static_cast<View>(in.get(C::ecc_add_mem_sel)) *
93 (static_cast<View>(in.get(C::ecc_add_mem_q_is_on_curve_eqn)) *
94 ((FF(1) - static_cast<View>(in.get(C::ecc_add_mem_sel_q_not_on_curve_err))) *
95 (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_q_is_on_curve_eqn_inv))) +
96 static_cast<View>(in.get(C::ecc_add_mem_q_is_on_curve_eqn_inv))) -
97 static_cast<View>(in.get(C::ecc_add_mem_sel_q_not_on_curve_err)));
98 std::get<9>(evals) += (tmp * scaling_factor);
99 }
100 {
101 using View = typename std::tuple_element_t<10, ContainerOverSubrelations>::View;
102 auto tmp = (static_cast<View>(in.get(C::ecc_add_mem_err)) -
103 (FF(1) - (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_sel_dst_out_of_range_err))) *
104 (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_sel_p_not_on_curve_err))) *
105 (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_sel_q_not_on_curve_err)))));
106 std::get<10>(evals) += (tmp * scaling_factor);
107 }
108 {
109 using View = typename std::tuple_element_t<11, ContainerOverSubrelations>::View;
110 auto tmp =
111 (static_cast<View>(in.get(C::ecc_add_mem_sel_should_exec)) -
112 static_cast<View>(in.get(C::ecc_add_mem_sel)) * (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_err))));
113 std::get<11>(evals) += (tmp * scaling_factor);
114 }
115 {
116 using View = typename std::tuple_element_t<12, ContainerOverSubrelations>::View;
117 auto tmp = static_cast<View>(in.get(C::ecc_add_mem_sel_should_exec)) *
118 ((static_cast<View>(in.get(C::ecc_add_mem_p_x_n)) -
119 (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_p_is_inf))) *
120 static_cast<View>(in.get(C::ecc_add_mem_p_x))) -
121 static_cast<View>(in.get(C::ecc_add_mem_p_is_inf)) * CView(ecc_INFINITY_X));
122 std::get<12>(evals) += (tmp * scaling_factor);
123 }
124 {
125 using View = typename std::tuple_element_t<13, ContainerOverSubrelations>::View;
126 auto tmp = static_cast<View>(in.get(C::ecc_add_mem_sel_should_exec)) *
127 ((static_cast<View>(in.get(C::ecc_add_mem_p_y_n)) -
128 (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_p_is_inf))) *
129 static_cast<View>(in.get(C::ecc_add_mem_p_y))) -
130 static_cast<View>(in.get(C::ecc_add_mem_p_is_inf)) * CView(ecc_INFINITY_Y));
131 std::get<13>(evals) += (tmp * scaling_factor);
132 }
133 {
134 using View = typename std::tuple_element_t<14, ContainerOverSubrelations>::View;
135 auto tmp = static_cast<View>(in.get(C::ecc_add_mem_sel_should_exec)) *
136 ((static_cast<View>(in.get(C::ecc_add_mem_q_x_n)) -
137 (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_q_is_inf))) *
138 static_cast<View>(in.get(C::ecc_add_mem_q_x))) -
139 static_cast<View>(in.get(C::ecc_add_mem_q_is_inf)) * CView(ecc_INFINITY_X));
140 std::get<14>(evals) += (tmp * scaling_factor);
141 }
142 {
143 using View = typename std::tuple_element_t<15, ContainerOverSubrelations>::View;
144 auto tmp = static_cast<View>(in.get(C::ecc_add_mem_sel_should_exec)) *
145 ((static_cast<View>(in.get(C::ecc_add_mem_q_y_n)) -
146 (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_q_is_inf))) *
147 static_cast<View>(in.get(C::ecc_add_mem_q_y))) -
148 static_cast<View>(in.get(C::ecc_add_mem_q_is_inf)) * CView(ecc_INFINITY_Y));
149 std::get<15>(evals) += (tmp * scaling_factor);
150 }
151}
152
153} // namespace bb::avm2
static void accumulate(ContainerOverSubrelations &evals, const AllEntities &in, const RelationParameters< FF > &, const FF &scaling_factor)
ColumnAndShifts
Definition columns.hpp:34
AvmFlavorSettings::FF FF
Definition field.hpp:10
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
Definition tuple.hpp:13
#define CView(v)
Container for parameters used by the grand product (permutation, lookup) Honk relations.