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_NULLIFIER_TREE_HEIGHT = FF(42);
19 const auto constants_MAX_NULLIFIERS_PER_TX = FF(64);
20 const auto constants_AVM_PUBLIC_INPUTS_AVM_ACCUMULATED_DATA_NULLIFIERS_ROW_IDX = FF(450);
21 const auto constants_DOM_SEP__SILOED_NULLIFIER = FF(57496191);
22 const auto constants_DOM_SEP__NULLIFIER_MERKLE = FF(1157584160);
23 const auto execution_REMAINING_NULLIFIER_WRITES =
24 (constants_MAX_NULLIFIERS_PER_TX - in.get(C::execution_prev_num_nullifiers_emitted));
25 const auto execution_SUCCESSFUL_WRITE =
26 in.get(C::execution_sel_write_nullifier) * (FF(1) - in.get(C::execution_sel_opcode_error));
28 {
29 using View = typename std::tuple_element_t<0, ContainerOverSubrelations>::View;
30 auto tmp = static_cast<View>(in.get(C::execution_sel_reached_max_nullifiers)) *
31 (FF(1) - static_cast<View>(in.get(C::execution_sel_reached_max_nullifiers)));
32 std::get<0>(evals) += (tmp * scaling_factor);
33 }
34 { // MAX_NULLIFIER_WRITES_REACHED
35 using View = typename std::tuple_element_t<1, ContainerOverSubrelations>::View;
36 auto tmp = static_cast<View>(in.get(C::execution_sel_execute_emit_nullifier)) *
37 ((CView(execution_REMAINING_NULLIFIER_WRITES) *
38 (static_cast<View>(in.get(C::execution_sel_reached_max_nullifiers)) *
39 (FF(1) - static_cast<View>(in.get(C::execution_remaining_nullifiers_inv))) +
40 static_cast<View>(in.get(C::execution_remaining_nullifiers_inv))) -
41 FF(1)) +
42 static_cast<View>(in.get(C::execution_sel_reached_max_nullifiers)));
43 std::get<1>(evals) += (tmp * scaling_factor);
44 }
45 { // VALIDATION_ERROR_DISABLE_WRITE
46 using View = typename std::tuple_element_t<2, ContainerOverSubrelations>::View;
47 auto tmp = (static_cast<View>(in.get(C::execution_sel_write_nullifier)) -
48 static_cast<View>(in.get(C::execution_sel_execute_emit_nullifier)) *
49 (FF(1) - static_cast<View>(in.get(C::execution_sel_reached_max_nullifiers))) *
50 (FF(1) - static_cast<View>(in.get(C::execution_is_static))));
51 std::get<2>(evals) += (tmp * scaling_factor);
52 }
53 { // OPCODE_ERROR_IF_VALIDATION_ERROR
54 using View = typename std::tuple_element_t<3, ContainerOverSubrelations>::View;
55 auto tmp = static_cast<View>(in.get(C::execution_sel_execute_emit_nullifier)) *
56 (FF(1) - static_cast<View>(in.get(C::execution_sel_write_nullifier))) *
57 (FF(1) - static_cast<View>(in.get(C::execution_sel_opcode_error)));
58 std::get<3>(evals) += (tmp * scaling_factor);
59 }
60 {
61 using View = typename std::tuple_element_t<4, ContainerOverSubrelations>::View;
62 auto tmp = static_cast<View>(in.get(C::execution_sel_write_nullifier)) *
63 ((CView(constants_AVM_PUBLIC_INPUTS_AVM_ACCUMULATED_DATA_NULLIFIERS_ROW_IDX) +
64 static_cast<View>(in.get(C::execution_prev_num_nullifiers_emitted))) -
65 static_cast<View>(in.get(C::execution_nullifier_pi_offset)));
66 std::get<4>(evals) += (tmp * scaling_factor);
67 }
68 {
69 using View = typename std::tuple_element_t<5, ContainerOverSubrelations>::View;
70 auto tmp =
71 static_cast<View>(in.get(C::execution_sel_write_nullifier)) *
72 (static_cast<View>(in.get(C::execution_nullifier_tree_height)) - CView(constants_NULLIFIER_TREE_HEIGHT));
73 std::get<5>(evals) += (tmp * scaling_factor);
74 }
75 {
76 using View = typename std::tuple_element_t<6, ContainerOverSubrelations>::View;
77 auto tmp = static_cast<View>(in.get(C::execution_sel_write_nullifier)) *
78 (static_cast<View>(in.get(C::execution_nullifier_siloing_separator)) -
79 CView(constants_DOM_SEP__SILOED_NULLIFIER));
80 std::get<6>(evals) += (tmp * scaling_factor);
81 }
82 {
83 using View = typename std::tuple_element_t<7, ContainerOverSubrelations>::View;
84 auto tmp = static_cast<View>(in.get(C::execution_sel_write_nullifier)) *
85 (static_cast<View>(in.get(C::execution_nullifier_merkle_separator)) -
86 CView(constants_DOM_SEP__NULLIFIER_MERKLE));
87 std::get<7>(evals) += (tmp * scaling_factor);
88 }
89 { // EMIT_NULLIFIER_TREE_ROOT_NOT_CHANGED
90 using View = typename std::tuple_element_t<8, ContainerOverSubrelations>::View;
91 auto tmp = static_cast<View>(in.get(C::execution_sel_execute_emit_nullifier)) *
92 static_cast<View>(in.get(C::execution_sel_opcode_error)) *
93 (static_cast<View>(in.get(C::execution_prev_nullifier_tree_root)) -
94 static_cast<View>(in.get(C::execution_nullifier_tree_root)));
95 std::get<8>(evals) += (tmp * scaling_factor);
96 }
97 { // EMIT_NULLIFIER_TREE_SIZE_INCREASE
98 using View = typename std::tuple_element_t<9, ContainerOverSubrelations>::View;
99 auto tmp =
100 static_cast<View>(in.get(C::execution_sel_execute_emit_nullifier)) *
101 ((static_cast<View>(in.get(C::execution_prev_nullifier_tree_size)) + CView(execution_SUCCESSFUL_WRITE)) -
102 static_cast<View>(in.get(C::execution_nullifier_tree_size)));
103 std::get<9>(evals) += (tmp * scaling_factor);
104 }
105 { // EMIT_NULLIFIER_NUM_NULLIFIERS_EMITTED_INCREASE
106 using View = typename std::tuple_element_t<10, ContainerOverSubrelations>::View;
107 auto tmp =
108 static_cast<View>(in.get(C::execution_sel_execute_emit_nullifier)) *
109 ((static_cast<View>(in.get(C::execution_prev_num_nullifiers_emitted)) + CView(execution_SUCCESSFUL_WRITE)) -
110 static_cast<View>(in.get(C::execution_num_nullifiers_emitted)));
111 std::get<10>(evals) += (tmp * scaling_factor);
112 }
113}
114
115} // 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.