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_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);
20 const auto ecc_add_mem_P_Y2 = in.get(C::ecc_add_mem_p_y) * in.get(C::ecc_add_mem_p_y);
21 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);
22 const auto ecc_add_mem_Q_Y2 = in.get(C::ecc_add_mem_q_y) * in.get(C::ecc_add_mem_q_y);
23
24 {
25 using View = typename std::tuple_element_t<0, ContainerOverSubrelations>::View;
26 auto tmp =
27 static_cast<View>(in.get(C::ecc_add_mem_sel)) * (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_sel)));
28 std::get<0>(evals) += (tmp * scaling_factor);
29 }
30 { // WRITE_INCR_DST_ADDR
31 using View = typename std::tuple_element_t<1, ContainerOverSubrelations>::View;
32 auto tmp = (static_cast<View>(in.get(C::ecc_add_mem_dst_addr_1_)) -
33 static_cast<View>(in.get(C::ecc_add_mem_sel)) *
34 (static_cast<View>(in.get(C::ecc_add_mem_dst_addr_0_)) + FF(1)));
35 std::get<1>(evals) += (tmp * scaling_factor);
36 }
37 {
38 using View = typename std::tuple_element_t<2, ContainerOverSubrelations>::View;
39 auto tmp = (static_cast<View>(in.get(C::ecc_add_mem_dst_addr_2_)) -
40 static_cast<View>(in.get(C::ecc_add_mem_sel)) *
41 (static_cast<View>(in.get(C::ecc_add_mem_dst_addr_0_)) + FF(2)));
42 std::get<2>(evals) += (tmp * scaling_factor);
43 }
44 {
45 using View = typename std::tuple_element_t<3, ContainerOverSubrelations>::View;
46 auto tmp = static_cast<View>(in.get(C::ecc_add_mem_sel)) *
47 (static_cast<View>(in.get(C::ecc_add_mem_max_mem_addr)) - CView(constants_AVM_HIGHEST_MEM_ADDRESS));
48 std::get<3>(evals) += (tmp * scaling_factor);
49 }
50 {
51 using View = typename std::tuple_element_t<4, ContainerOverSubrelations>::View;
52 auto tmp = static_cast<View>(in.get(C::ecc_add_mem_sel_p_not_on_curve_err)) *
53 (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_sel_p_not_on_curve_err)));
54 std::get<4>(evals) += (tmp * scaling_factor);
55 }
56 {
57 using View = typename std::tuple_element_t<5, ContainerOverSubrelations>::View;
58 auto tmp = static_cast<View>(in.get(C::ecc_add_mem_sel_q_not_on_curve_err)) *
59 (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_sel_q_not_on_curve_err)));
60 std::get<5>(evals) += (tmp * scaling_factor);
61 }
62 { // P_CURVE_EQN
63 using View = typename std::tuple_element_t<6, ContainerOverSubrelations>::View;
64 auto tmp = (static_cast<View>(in.get(C::ecc_add_mem_p_is_on_curve_eqn)) -
65 static_cast<View>(in.get(C::ecc_add_mem_sel)) *
66 (CView(ecc_add_mem_P_Y2) - (CView(ecc_add_mem_P_X3) - FF(17))) *
67 (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_p_is_inf))));
68 std::get<6>(evals) += (tmp * scaling_factor);
69 }
70 { // P_ON_CURVE_CHECK
71 using View = typename std::tuple_element_t<7, ContainerOverSubrelations>::View;
72 auto tmp = static_cast<View>(in.get(C::ecc_add_mem_sel)) *
73 (static_cast<View>(in.get(C::ecc_add_mem_p_is_on_curve_eqn)) *
74 ((FF(1) - static_cast<View>(in.get(C::ecc_add_mem_sel_p_not_on_curve_err))) *
75 (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_p_is_on_curve_eqn_inv))) +
76 static_cast<View>(in.get(C::ecc_add_mem_p_is_on_curve_eqn_inv))) -
77 static_cast<View>(in.get(C::ecc_add_mem_sel_p_not_on_curve_err)));
78 std::get<7>(evals) += (tmp * scaling_factor);
79 }
80 { // Q_CURVE_EQN
81 using View = typename std::tuple_element_t<8, ContainerOverSubrelations>::View;
82 auto tmp = (static_cast<View>(in.get(C::ecc_add_mem_q_is_on_curve_eqn)) -
83 static_cast<View>(in.get(C::ecc_add_mem_sel)) *
84 (CView(ecc_add_mem_Q_Y2) - (CView(ecc_add_mem_Q_X3) - FF(17))) *
85 (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_q_is_inf))));
86 std::get<8>(evals) += (tmp * scaling_factor);
87 }
88 { // Q_ON_CURVE_CHECK
89 using View = typename std::tuple_element_t<9, ContainerOverSubrelations>::View;
90 auto tmp = static_cast<View>(in.get(C::ecc_add_mem_sel)) *
91 (static_cast<View>(in.get(C::ecc_add_mem_q_is_on_curve_eqn)) *
92 ((FF(1) - static_cast<View>(in.get(C::ecc_add_mem_sel_q_not_on_curve_err))) *
93 (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_q_is_on_curve_eqn_inv))) +
94 static_cast<View>(in.get(C::ecc_add_mem_q_is_on_curve_eqn_inv))) -
95 static_cast<View>(in.get(C::ecc_add_mem_sel_q_not_on_curve_err)));
96 std::get<9>(evals) += (tmp * scaling_factor);
97 }
98 {
99 using View = typename std::tuple_element_t<10, ContainerOverSubrelations>::View;
100 auto tmp = (static_cast<View>(in.get(C::ecc_add_mem_err)) -
101 (FF(1) - (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_sel_dst_out_of_range_err))) *
102 (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_sel_p_not_on_curve_err))) *
103 (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_sel_q_not_on_curve_err)))));
104 std::get<10>(evals) += (tmp * scaling_factor);
105 }
106 {
107 using View = typename std::tuple_element_t<11, ContainerOverSubrelations>::View;
108 auto tmp =
109 (static_cast<View>(in.get(C::ecc_add_mem_sel_should_exec)) -
110 static_cast<View>(in.get(C::ecc_add_mem_sel)) * (FF(1) - static_cast<View>(in.get(C::ecc_add_mem_err))));
111 std::get<11>(evals) += (tmp * scaling_factor);
112 }
113}
114
115} // 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.