Barretenberg
The ZK-SNARK library at the core of Aztec
Loading...
Searching...
No Matches
emit_nullifier_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 emit_nullifierImpl<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_MAX_NULLIFIERS_PER_TX = FF(64);
19 const auto execution_REMAINING_NULLIFIER_WRITES =
20 (constants_MAX_NULLIFIERS_PER_TX - in.get(C::execution_prev_num_nullifiers_emitted));
21 const auto execution_SUCCESSFUL_WRITE =
22 in.get(C::execution_sel_write_nullifier) * (FF(1) - in.get(C::execution_sel_opcode_error));
23
24 {
25 using View = typename std::tuple_element_t<0, ContainerOverSubrelations>::View;
26 auto tmp = static_cast<View>(in.get(C::execution_sel_reached_max_nullifiers)) *
27 (FF(1) - static_cast<View>(in.get(C::execution_sel_reached_max_nullifiers)));
28 std::get<0>(evals) += (tmp * scaling_factor);
29 }
30 { // MAX_NULLIFIER_WRITES_REACHED
31 using View = typename std::tuple_element_t<1, ContainerOverSubrelations>::View;
32 auto tmp = static_cast<View>(in.get(C::execution_sel_execute_emit_nullifier)) *
33 ((CView(execution_REMAINING_NULLIFIER_WRITES) *
34 (static_cast<View>(in.get(C::execution_sel_reached_max_nullifiers)) *
35 (FF(1) - static_cast<View>(in.get(C::execution_remaining_nullifiers_inv))) +
36 static_cast<View>(in.get(C::execution_remaining_nullifiers_inv))) -
37 FF(1)) +
38 static_cast<View>(in.get(C::execution_sel_reached_max_nullifiers)));
39 std::get<1>(evals) += (tmp * scaling_factor);
40 }
41 { // VALIDATION_ERROR_DISABLE_WRITE
42 using View = typename std::tuple_element_t<2, ContainerOverSubrelations>::View;
43 auto tmp = static_cast<View>(in.get(C::execution_sel_execute_emit_nullifier)) *
44 ((FF(1) - static_cast<View>(in.get(C::execution_sel_reached_max_nullifiers))) *
45 (FF(1) - static_cast<View>(in.get(C::execution_is_static))) -
46 static_cast<View>(in.get(C::execution_sel_write_nullifier)));
47 std::get<2>(evals) += (tmp * scaling_factor);
48 }
49 { // OPCODE_ERROR_IF_VALIDATION_ERROR
50 using View = typename std::tuple_element_t<3, ContainerOverSubrelations>::View;
51 auto tmp = static_cast<View>(in.get(C::execution_sel_execute_emit_nullifier)) *
52 (FF(1) - static_cast<View>(in.get(C::execution_sel_write_nullifier))) *
53 (FF(1) - static_cast<View>(in.get(C::execution_sel_opcode_error)));
54 std::get<3>(evals) += (tmp * scaling_factor);
55 }
56 { // EMIT_NULLIFIER_TREE_ROOT_NOT_CHANGED
57 using View = typename std::tuple_element_t<4, ContainerOverSubrelations>::View;
58 auto tmp = static_cast<View>(in.get(C::execution_sel_execute_emit_nullifier)) *
59 static_cast<View>(in.get(C::execution_sel_opcode_error)) *
60 (static_cast<View>(in.get(C::execution_prev_nullifier_tree_root)) -
61 static_cast<View>(in.get(C::execution_nullifier_tree_root)));
62 std::get<4>(evals) += (tmp * scaling_factor);
63 }
64 { // EMIT_NULLIFIER_TREE_SIZE_INCREASE
65 using View = typename std::tuple_element_t<5, ContainerOverSubrelations>::View;
66 auto tmp =
67 static_cast<View>(in.get(C::execution_sel_execute_emit_nullifier)) *
68 ((static_cast<View>(in.get(C::execution_prev_nullifier_tree_size)) + CView(execution_SUCCESSFUL_WRITE)) -
69 static_cast<View>(in.get(C::execution_nullifier_tree_size)));
70 std::get<5>(evals) += (tmp * scaling_factor);
71 }
72 { // EMIT_NULLIFIER_NUM_NULLIFIERS_EMITTED_INCREASE
73 using View = typename std::tuple_element_t<6, ContainerOverSubrelations>::View;
74 auto tmp =
75 static_cast<View>(in.get(C::execution_sel_execute_emit_nullifier)) *
76 ((static_cast<View>(in.get(C::execution_prev_num_nullifiers_emitted)) + CView(execution_SUCCESSFUL_WRITE)) -
77 static_cast<View>(in.get(C::execution_num_nullifiers_emitted)));
78 std::get<6>(evals) += (tmp * scaling_factor);
79 }
80}
81
82} // namespace bb::avm2
static void accumulate(ContainerOverSubrelations &evals, const AllEntities &in, const RelationParameters< FF > &, const FF &scaling_factor)
ColumnAndShifts
Definition columns.hpp:34
AvmFlavorSettings::FF FF
Definition field.hpp:10
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.