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