Barretenberg
The ZK-SNARK library at the core of Aztec
Loading...
Searching...
No Matches
nullifier_check.hpp
Go to the documentation of this file.
1
// AUTOGENERATED FILE
2
#pragma once
3
4
#include <string_view>
5
6
#include "
barretenberg/common/op_count.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
nullifier_checkImpl
{
14
public
:
15
using
FF
= FF_;
16
17
static
constexpr
std::array<size_t, 18>
SUBRELATION_PARTIAL_LENGTHS
= { 3, 3, 3, 3, 3, 3, 3, 3, 4,
18
3, 3, 3, 5, 3, 3, 5, 3, 3 };
19
20
template
<
typename
AllEntities>
inline
static
bool
skip
(
const
AllEntities& in)
21
{
22
using
C
=
ColumnAndShifts
;
23
24
return
(in.get(C::nullifier_check_sel)).is_zero();
25
}
26
27
template
<
typename
ContainerOverSubrelations,
typename
AllEntities>
28
void
static
accumulate
(ContainerOverSubrelations& evals,
29
const
AllEntities& in,
30
[[maybe_unused]]
const
RelationParameters<FF>
&,
31
[[maybe_unused]]
const
FF
& scaling_factor);
32
};
33
34
template
<
typename
FF>
class
nullifier_check
:
public
Relation
<nullifier_checkImpl<FF>> {
35
public
:
36
static
constexpr
const
std::string_view
NAME
=
"nullifier_check"
;
37
38
static
std::string
get_subrelation_label
(
size_t
index)
39
{
40
switch
(index) {
41
case
5:
42
return
"PASSTHROUGH_SILOING"
;
43
case
12:
44
return
"EXISTS_CHECK"
;
45
case
15:
46
return
"NEXT_NULLIFIER_IS_ZERO_CHECK"
;
47
}
48
return
std::to_string
(index);
49
}
50
51
// Subrelation indices constants, to be used in tests.
52
static
constexpr
size_t
SR_PASSTHROUGH_SILOING
= 5;
53
static
constexpr
size_t
SR_EXISTS_CHECK
= 12;
54
static
constexpr
size_t
SR_NEXT_NULLIFIER_IS_ZERO_CHECK
= 15;
55
};
56
57
}
// namespace bb::avm2
bb::Relation
A wrapper for Relations to expose methods used by the Sumcheck prover or verifier to add the contribu...
Definition
relation_types.hpp:153
bb::avm2::nullifier_check
Definition
nullifier_check.hpp:34
bb::avm2::nullifier_check::SR_NEXT_NULLIFIER_IS_ZERO_CHECK
static constexpr size_t SR_NEXT_NULLIFIER_IS_ZERO_CHECK
Definition
nullifier_check.hpp:54
bb::avm2::nullifier_check::NAME
static constexpr const std::string_view NAME
Definition
nullifier_check.hpp:36
bb::avm2::nullifier_check::SR_PASSTHROUGH_SILOING
static constexpr size_t SR_PASSTHROUGH_SILOING
Definition
nullifier_check.hpp:52
bb::avm2::nullifier_check::SR_EXISTS_CHECK
static constexpr size_t SR_EXISTS_CHECK
Definition
nullifier_check.hpp:53
bb::avm2::nullifier_check::get_subrelation_label
static std::string get_subrelation_label(size_t index)
Definition
nullifier_check.hpp:38
bb::avm2::nullifier_checkImpl
Definition
nullifier_check.hpp:13
bb::avm2::nullifier_checkImpl::accumulate
static void accumulate(ContainerOverSubrelations &evals, const AllEntities &in, const RelationParameters< FF > &, const FF &scaling_factor)
Definition
nullifier_check_impl.hpp:10
bb::avm2::nullifier_checkImpl::FF
FF_ FF
Definition
nullifier_check.hpp:15
bb::avm2::nullifier_checkImpl::skip
static bool skip(const AllEntities &in)
Definition
nullifier_check.hpp:20
bb::avm2::nullifier_checkImpl::SUBRELATION_PARTIAL_LENGTHS
static constexpr std::array< size_t, 18 > SUBRELATION_PARTIAL_LENGTHS
Definition
nullifier_check.hpp:17
columns.hpp
bb::avm2
Definition
flavor.hpp:472
bb::avm2::Column
Column
Definition
columns.hpp:32
bb::avm2::ColumnAndShifts
ColumnAndShifts
Definition
columns.hpp:35
bb::avm2::FF
AvmFlavorSettings::FF FF
Definition
field.hpp:10
std::to_string
std::string to_string(bb::avm2::ValueTag tag)
Definition
tagged_value.cpp:399
op_count.hpp
relation_parameters.hpp
relation_types.hpp
bb::RelationParameters
Container for parameters used by the grand product (permutation, lookup) Honk relations.
Definition
relation_parameters.hpp:19
src
barretenberg
vm2
generated
relations
nullifier_check.hpp
Generated by
1.9.8