Barretenberg
The ZK-SNARK library at the core of Aztec
Loading...
Searching...
No Matches
ecc_mem.hpp
Go to the documentation of this file.
1// AUTOGENERATED FILE
2#pragma once
3
4#include <string_view>
5
10
11namespace bb::avm2 {
12
13template <typename FF_> class ecc_memImpl {
14 public:
15 using FF = FF_;
16
17 static constexpr std::array<size_t, 15> SUBRELATION_PARTIAL_LENGTHS = {
18 3, 3, 3, 3, 3, 6, 5, 6, 5, 4, 3, 4, 4, 4, 4
19 };
20
21 template <typename AllEntities> inline static bool skip(const AllEntities& in)
22 {
23 using C = ColumnAndShifts;
24
25 return (in.get(C::ecc_add_mem_sel)).is_zero();
26 }
27
28 template <typename ContainerOverSubrelations, typename AllEntities>
29 void static accumulate(ContainerOverSubrelations& evals,
30 const AllEntities& in,
31 [[maybe_unused]] const RelationParameters<FF>&,
32 [[maybe_unused]] const FF& scaling_factor);
33};
34
35template <typename FF> class ecc_mem : public Relation<ecc_memImpl<FF>> {
36 public:
37 static constexpr const std::string_view NAME = "ecc_mem";
38
39 // Subrelation indices constants, to be used in tests.
40 static constexpr size_t SR_WRITE_INCR_DST_ADDR = 1;
41 static constexpr size_t SR_P_CURVE_EQN = 5;
42 static constexpr size_t SR_P_ON_CURVE_CHECK = 6;
43 static constexpr size_t SR_Q_CURVE_EQN = 7;
44 static constexpr size_t SR_Q_ON_CURVE_CHECK = 8;
45 static constexpr size_t SR_P_INF_X_CHECK = 11;
46 static constexpr size_t SR_P_INF_Y_CHECK = 12;
47 static constexpr size_t SR_Q_INF_X_CHECK = 13;
48 static constexpr size_t SR_Q_INF_Y_CHECK = 14;
49
50 static std::string get_subrelation_label(size_t index)
51 {
52 switch (index) {
54 return "WRITE_INCR_DST_ADDR";
55 case SR_P_CURVE_EQN:
56 return "P_CURVE_EQN";
58 return "P_ON_CURVE_CHECK";
59 case SR_Q_CURVE_EQN:
60 return "Q_CURVE_EQN";
62 return "Q_ON_CURVE_CHECK";
64 return "P_INF_X_CHECK";
66 return "P_INF_Y_CHECK";
68 return "Q_INF_X_CHECK";
70 return "Q_INF_Y_CHECK";
71 }
72 return std::to_string(index);
73 }
74};
75
76} // namespace bb::avm2
A wrapper for Relations to expose methods used by the Sumcheck prover or verifier to add the contribu...
static constexpr size_t SR_Q_INF_Y_CHECK
Definition ecc_mem.hpp:48
static std::string get_subrelation_label(size_t index)
Definition ecc_mem.hpp:50
static constexpr size_t SR_P_INF_Y_CHECK
Definition ecc_mem.hpp:46
static constexpr size_t SR_Q_CURVE_EQN
Definition ecc_mem.hpp:43
static constexpr size_t SR_P_INF_X_CHECK
Definition ecc_mem.hpp:45
static constexpr const std::string_view NAME
Definition ecc_mem.hpp:37
static constexpr size_t SR_P_ON_CURVE_CHECK
Definition ecc_mem.hpp:42
static constexpr size_t SR_Q_ON_CURVE_CHECK
Definition ecc_mem.hpp:44
static constexpr size_t SR_Q_INF_X_CHECK
Definition ecc_mem.hpp:47
static constexpr size_t SR_WRITE_INCR_DST_ADDR
Definition ecc_mem.hpp:40
static constexpr size_t SR_P_CURVE_EQN
Definition ecc_mem.hpp:41
static void accumulate(ContainerOverSubrelations &evals, const AllEntities &in, const RelationParameters< FF > &, const FF &scaling_factor)
static constexpr std::array< size_t, 15 > SUBRELATION_PARTIAL_LENGTHS
Definition ecc_mem.hpp:17
static bool skip(const AllEntities &in)
Definition ecc_mem.hpp:21
AvmFlavorSettings::FF FF
Definition field.hpp:10
ColumnAndShifts
Definition columns.hpp:34
std::string to_string(bb::avm2::ValueTag tag)
Container for parameters used by the grand product (permutation, lookup) Honk relations.