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
6
#include "
barretenberg/common/bb_bench.hpp
"
7
#include "
barretenberg/relations/relation_parameters.hpp
"
8
#include "
barretenberg/relations/relation_types.hpp
"
9
#include "
barretenberg/vm2/generated/columns.hpp
"
10
11
namespace
bb::avm2
{
12
13
template
<
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
35
template
<
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
) {
53
case
SR_WRITE_INCR_DST_ADDR
:
54
return
"WRITE_INCR_DST_ADDR"
;
55
case
SR_P_CURVE_EQN
:
56
return
"P_CURVE_EQN"
;
57
case
SR_P_ON_CURVE_CHECK
:
58
return
"P_ON_CURVE_CHECK"
;
59
case
SR_Q_CURVE_EQN
:
60
return
"Q_CURVE_EQN"
;
61
case
SR_Q_ON_CURVE_CHECK
:
62
return
"Q_ON_CURVE_CHECK"
;
63
case
SR_P_INF_X_CHECK
:
64
return
"P_INF_X_CHECK"
;
65
case
SR_P_INF_Y_CHECK
:
66
return
"P_INF_Y_CHECK"
;
67
case
SR_Q_INF_X_CHECK
:
68
return
"Q_INF_X_CHECK"
;
69
case
SR_Q_INF_Y_CHECK
:
70
return
"Q_INF_Y_CHECK"
;
71
}
72
return
std::to_string
(
index
);
73
}
74
};
75
76
}
// namespace bb::avm2
bb_bench.hpp
bb::Relation
A wrapper for Relations to expose methods used by the Sumcheck prover or verifier to add the contribu...
Definition
relation_types.hpp:96
bb::avm2::ecc_mem
Definition
ecc_mem.hpp:35
bb::avm2::ecc_mem::SR_Q_INF_Y_CHECK
static constexpr size_t SR_Q_INF_Y_CHECK
Definition
ecc_mem.hpp:48
bb::avm2::ecc_mem::get_subrelation_label
static std::string get_subrelation_label(size_t index)
Definition
ecc_mem.hpp:50
bb::avm2::ecc_mem::SR_P_INF_Y_CHECK
static constexpr size_t SR_P_INF_Y_CHECK
Definition
ecc_mem.hpp:46
bb::avm2::ecc_mem::SR_Q_CURVE_EQN
static constexpr size_t SR_Q_CURVE_EQN
Definition
ecc_mem.hpp:43
bb::avm2::ecc_mem::SR_P_INF_X_CHECK
static constexpr size_t SR_P_INF_X_CHECK
Definition
ecc_mem.hpp:45
bb::avm2::ecc_mem::NAME
static constexpr const std::string_view NAME
Definition
ecc_mem.hpp:37
bb::avm2::ecc_mem::SR_P_ON_CURVE_CHECK
static constexpr size_t SR_P_ON_CURVE_CHECK
Definition
ecc_mem.hpp:42
bb::avm2::ecc_mem::SR_Q_ON_CURVE_CHECK
static constexpr size_t SR_Q_ON_CURVE_CHECK
Definition
ecc_mem.hpp:44
bb::avm2::ecc_mem::SR_Q_INF_X_CHECK
static constexpr size_t SR_Q_INF_X_CHECK
Definition
ecc_mem.hpp:47
bb::avm2::ecc_mem::SR_WRITE_INCR_DST_ADDR
static constexpr size_t SR_WRITE_INCR_DST_ADDR
Definition
ecc_mem.hpp:40
bb::avm2::ecc_mem::SR_P_CURVE_EQN
static constexpr size_t SR_P_CURVE_EQN
Definition
ecc_mem.hpp:41
bb::avm2::ecc_memImpl
Definition
ecc_mem.hpp:13
bb::avm2::ecc_memImpl::accumulate
static void accumulate(ContainerOverSubrelations &evals, const AllEntities &in, const RelationParameters< FF > &, const FF &scaling_factor)
Definition
ecc_mem_impl.hpp:11
bb::avm2::ecc_memImpl::SUBRELATION_PARTIAL_LENGTHS
static constexpr std::array< size_t, 15 > SUBRELATION_PARTIAL_LENGTHS
Definition
ecc_mem.hpp:17
bb::avm2::ecc_memImpl::FF
FF_ FF
Definition
ecc_mem.hpp:15
bb::avm2::ecc_memImpl::skip
static bool skip(const AllEntities &in)
Definition
ecc_mem.hpp:21
columns.hpp
VariableRefMutationOptions::index
@ index
bb::avm2
Definition
dbs.cpp:19
bb::avm2::Column
Column
Definition
columns.hpp:31
bb::avm2::FF
AvmFlavorSettings::FF FF
Definition
field.hpp:10
bb::avm2::ColumnAndShifts
ColumnAndShifts
Definition
columns.hpp:34
std::to_string
std::string to_string(bb::avm2::ValueTag tag)
Definition
tagged_value.cpp:402
relation_parameters.hpp
relation_types.hpp
bb::RelationParameters
Container for parameters used by the grand product (permutation, lookup) Honk relations.
Definition
relation_parameters.hpp:18
src
barretenberg
vm2
generated
relations
ecc_mem.hpp
Generated by
1.9.8