Barretenberg
The ZK-SNARK library at the core of Aztec
Loading...
Searching...
No Matches
nullifier_exists_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 nullifier_existsImpl<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_NULLIFIER_TREE_HEIGHT = FF(42);
19 const auto constants_MEM_TAG_U1 = FF(1);
20 const auto constants_DOM_SEP__NULLIFIER_MERKLE = FF(1157584160);
21
22 {
23 using View = typename std::tuple_element_t<0, ContainerOverSubrelations>::View;
24 auto tmp =
25 static_cast<View>(in.get(C::execution_sel_execute_nullifier_exists)) *
26 (static_cast<View>(in.get(C::execution_nullifier_tree_height)) - CView(constants_NULLIFIER_TREE_HEIGHT));
27 std::get<0>(evals) += (tmp * scaling_factor);
28 }
29 {
30 using View = typename std::tuple_element_t<1, ContainerOverSubrelations>::View;
31 auto tmp = static_cast<View>(in.get(C::execution_sel_execute_nullifier_exists)) *
32 (static_cast<View>(in.get(C::execution_nullifier_merkle_separator)) -
33 CView(constants_DOM_SEP__NULLIFIER_MERKLE));
34 std::get<1>(evals) += (tmp * scaling_factor);
35 }
36 { // NULLIFIER_EXISTS_U1_OUTPUT_TAG
37 using View = typename std::tuple_element_t<2, ContainerOverSubrelations>::View;
38 auto tmp = static_cast<View>(in.get(C::execution_sel_execute_nullifier_exists)) *
39 (CView(constants_MEM_TAG_U1) - static_cast<View>(in.get(C::execution_mem_tag_reg_1_)));
40 std::get<2>(evals) += (tmp * scaling_factor);
41 }
42}
43
44} // namespace bb::avm2
static void accumulate(ContainerOverSubrelations &evals, const AllEntities &in, const RelationParameters< FF > &, const FF &scaling_factor)
AvmFlavorSettings::FF FF
Definition field.hpp:10
ColumnAndShifts
Definition columns.hpp:34
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.