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
5
6namespace bb::avm2 {
7
8template <typename FF_>
9template <typename ContainerOverSubrelations, typename AllEntities>
10void emit_nullifierImpl<FF_>::accumulate(ContainerOverSubrelations& evals,
11 const AllEntities& in,
12 [[maybe_unused]] const RelationParameters<FF_>&,
13 [[maybe_unused]] const FF_& scaling_factor)
14{
15 using C = ColumnAndShifts;
16
17 PROFILE_THIS_NAME("accumulate/emit_nullifier");
18
19 const auto constants_MAX_NULLIFIERS_PER_TX = FF(64);
20 const auto execution_REMAINING_NULLIFIER_WRITES =
21 (constants_MAX_NULLIFIERS_PER_TX - in.get(C::execution_prev_num_nullifiers_emitted));
22 const auto execution_SUCCESSFUL_WRITE =
23 in.get(C::execution_sel_write_nullifier) * (FF(1) - in.get(C::execution_sel_opcode_error));
24
25 {
26 using Accumulator = typename std::tuple_element_t<0, ContainerOverSubrelations>;
27 auto tmp =
28 in.get(C::execution_sel_reached_max_nullifiers) * (FF(1) - in.get(C::execution_sel_reached_max_nullifiers));
29 tmp *= scaling_factor;
30 std::get<0>(evals) += typename Accumulator::View(tmp);
31 }
32 { // MAX_NULLIFIER_WRITES_REACHED
33 using Accumulator = typename std::tuple_element_t<1, ContainerOverSubrelations>;
34 auto tmp =
35 in.get(C::execution_sel_execute_emit_nullifier) *
36 ((execution_REMAINING_NULLIFIER_WRITES * (in.get(C::execution_sel_reached_max_nullifiers) *
37 (FF(1) - in.get(C::execution_remaining_nullifiers_inv)) +
38 in.get(C::execution_remaining_nullifiers_inv)) -
39 FF(1)) +
40 in.get(C::execution_sel_reached_max_nullifiers));
41 tmp *= scaling_factor;
42 std::get<1>(evals) += typename Accumulator::View(tmp);
43 }
44 { // VALIDATION_ERROR_DISABLE_WRITE
45 using Accumulator = typename std::tuple_element_t<2, ContainerOverSubrelations>;
46 auto tmp =
47 in.get(C::execution_sel_execute_emit_nullifier) *
48 ((FF(1) - in.get(C::execution_sel_reached_max_nullifiers)) * (FF(1) - in.get(C::execution_is_static)) -
49 in.get(C::execution_sel_write_nullifier));
50 tmp *= scaling_factor;
51 std::get<2>(evals) += typename Accumulator::View(tmp);
52 }
53 { // OPCODE_ERROR_IF_VALIDATION_ERROR
54 using Accumulator = typename std::tuple_element_t<3, ContainerOverSubrelations>;
55 auto tmp = in.get(C::execution_sel_execute_emit_nullifier) *
56 (FF(1) - in.get(C::execution_sel_write_nullifier)) * (FF(1) - in.get(C::execution_sel_opcode_error));
57 tmp *= scaling_factor;
58 std::get<3>(evals) += typename Accumulator::View(tmp);
59 }
60 { // EMIT_NULLIFIER_TREE_ROOT_NOT_CHANGED
61 using Accumulator = typename std::tuple_element_t<4, ContainerOverSubrelations>;
62 auto tmp = in.get(C::execution_sel_execute_emit_nullifier) * in.get(C::execution_sel_opcode_error) *
63 (in.get(C::execution_prev_nullifier_tree_root) - in.get(C::execution_nullifier_tree_root));
64 tmp *= scaling_factor;
65 std::get<4>(evals) += typename Accumulator::View(tmp);
66 }
67 { // EMIT_NULLIFIER_TREE_SIZE_INCREASE
68 using Accumulator = typename std::tuple_element_t<5, ContainerOverSubrelations>;
69 auto tmp = in.get(C::execution_sel_execute_emit_nullifier) *
70 ((in.get(C::execution_prev_nullifier_tree_size) + execution_SUCCESSFUL_WRITE) -
71 in.get(C::execution_nullifier_tree_size));
72 tmp *= scaling_factor;
73 std::get<5>(evals) += typename Accumulator::View(tmp);
74 }
75 { // EMIT_NULLIFIER_NUM_NULLIFIERS_EMITTED_INCREASE
76 using Accumulator = typename std::tuple_element_t<6, ContainerOverSubrelations>;
77 auto tmp = in.get(C::execution_sel_execute_emit_nullifier) *
78 ((in.get(C::execution_prev_num_nullifiers_emitted) + execution_SUCCESSFUL_WRITE) -
79 in.get(C::execution_num_nullifiers_emitted));
80 tmp *= scaling_factor;
81 std::get<6>(evals) += typename Accumulator::View(tmp);
82 }
83}
84
85} // namespace bb::avm2
static void accumulate(ContainerOverSubrelations &evals, const AllEntities &in, const RelationParameters< FF > &, const FF &scaling_factor)
ColumnAndShifts
Definition columns.hpp:35
AvmFlavorSettings::FF FF
Definition field.hpp:10
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
Definition tuple.hpp:13
#define PROFILE_THIS_NAME(name)
Definition op_count.hpp:16
Container for parameters used by the grand product (permutation, lookup) Honk relations.