Barretenberg
The ZK-SNARK library at the core of Aztec
Loading...
Searching...
No Matches
plookup_tables.cpp
Go to the documentation of this file.
1// === AUDIT STATUS ===
2// internal: { status: not started, auditors: [], date: YYYY-MM-DD }
3// external_1: { status: not started, auditors: [], date: YYYY-MM-DD }
4// external_2: { status: not started, auditors: [], date: YYYY-MM-DD }
5// =====================
6
7#include "plookup_tables.hpp"
16
22#include <mutex>
23namespace bb::plookup {
24
25using namespace bb;
26
27namespace {
28// TODO(@zac-williamson) convert these into static const members of a struct
29// NOLINTNEXTLINE(cppcoreguidelines-avoid-non-const-global-variables)
31// NOLINTNEXTLINE(cppcoreguidelines-avoid-non-const-global-variables)
32bool initialized = false;
33#ifndef NO_MULTITHREADING
34
35// The multitables initialisation procedure is not thread-safe, so we need to make sure only 1 thread gets to initialize
36// them.
37std::mutex multi_table_mutex;
38#endif
39void init_multi_tables()
40{
41#ifndef NO_MULTITHREADING
42 std::unique_lock<std::mutex> lock(multi_table_mutex);
43#endif
44 if (initialized) {
45 return;
46 }
48 MULTI_TABLES[MultiTableId::SHA256_MAJ_INPUT] =
52 MULTI_TABLES[MultiTableId::SHA256_CH_OUTPUT] =
61 MULTI_TABLES[MultiTableId::UINT8_XOR] = uint_tables::get_uint_xor_table<8>(MultiTableId::UINT8_XOR);
62 MULTI_TABLES[MultiTableId::UINT16_XOR] = uint_tables::get_uint_xor_table<16>(MultiTableId::UINT16_XOR);
63 MULTI_TABLES[MultiTableId::UINT32_XOR] = uint_tables::get_uint_xor_table<32>(MultiTableId::UINT32_XOR);
64 MULTI_TABLES[MultiTableId::UINT64_XOR] = uint_tables::get_uint_xor_table<64>(MultiTableId::UINT64_XOR);
65 MULTI_TABLES[MultiTableId::UINT8_AND] = uint_tables::get_uint_and_table<8>(MultiTableId::UINT8_AND);
66 MULTI_TABLES[MultiTableId::UINT16_AND] = uint_tables::get_uint_and_table<16>(MultiTableId::UINT16_AND);
67 MULTI_TABLES[MultiTableId::UINT32_AND] = uint_tables::get_uint_and_table<32>(MultiTableId::UINT32_AND);
68 MULTI_TABLES[MultiTableId::UINT64_AND] = uint_tables::get_uint_and_table<64>(MultiTableId::UINT64_AND);
117 MULTI_TABLES[MultiTableId::KECCAK_CHI_OUTPUT] =
122 fixed_base::table::get_fixed_base_table<0, 128>(MultiTableId::FIXED_BASE_LEFT_LO);
124 fixed_base::table::get_fixed_base_table<1, 126>(MultiTableId::FIXED_BASE_LEFT_HI);
126 fixed_base::table::get_fixed_base_table<2, 128>(MultiTableId::FIXED_BASE_RIGHT_LO);
128 fixed_base::table::get_fixed_base_table<3, 126>(MultiTableId::FIXED_BASE_RIGHT_HI);
129
130 bb::constexpr_for<0, 25, 1>([&]<size_t i>() {
131 MULTI_TABLES[static_cast<size_t>(MultiTableId::KECCAK_NORMALIZE_AND_ROTATE) + i] =
133 });
135 initialized = true;
136}
137} // namespace
148{
149 if (!initialized) {
150 init_multi_tables();
151 initialized = true;
152 }
153 return MULTI_TABLES[id];
154}
155
174 const fr& key_a,
175 const fr& key_b,
176 const bool is_2_to_1_lookup)
177{
178 // return multi-table, populating global array of all multi-tables if need be
179 const auto& multi_table = get_multitable(id);
180 const size_t num_lookups = multi_table.basic_table_ids.size();
181
182 ReadData<bb::fr> lookup;
183 const auto key_a_slices = numeric::slice_input_using_variable_bases(key_a, multi_table.slice_sizes);
184 const auto key_b_slices = numeric::slice_input_using_variable_bases(key_b, multi_table.slice_sizes);
185
186 std::vector<fr> column_1_raw_values;
187 std::vector<fr> column_2_raw_values;
188 std::vector<fr> column_3_raw_values;
189
190 for (size_t i = 0; i < num_lookups; ++i) {
191 // compute the value(s) corresponding to the key(s) using the i-th basic table query function
192 const auto values = multi_table.get_table_values[i]({ key_a_slices[i], key_b_slices[i] });
193 // store all query data in raw columns and key entry
194 column_1_raw_values.emplace_back(key_a_slices[i]);
195 column_2_raw_values.emplace_back(is_2_to_1_lookup ? key_b_slices[i] : values[0]);
196 column_3_raw_values.emplace_back(is_2_to_1_lookup ? values[0] : values[1]);
197
198 // Store the lookup entries for use in constructing the sorted table/lookup polynomials later on
199 const BasicTable::LookupEntry lookup_entry{ { key_a_slices[i], key_b_slices[i] }, values };
200 lookup.lookup_entries.emplace_back(lookup_entry);
201 }
202
203 lookup[C1].resize(num_lookups);
204 lookup[C2].resize(num_lookups);
205 lookup[C3].resize(num_lookups);
206
246 lookup[C1][num_lookups - 1] = column_1_raw_values[num_lookups - 1];
247 lookup[C2][num_lookups - 1] = column_2_raw_values[num_lookups - 1];
248 lookup[C3][num_lookups - 1] = column_3_raw_values[num_lookups - 1];
249
250 for (size_t i = num_lookups - 1; i > 0; --i) {
251 lookup[C1][i - 1] = column_1_raw_values[i - 1] + lookup[C1][i] * multi_table.column_1_step_sizes[i];
252 lookup[C2][i - 1] = column_2_raw_values[i - 1] + lookup[C2][i] * multi_table.column_2_step_sizes[i];
253 lookup[C3][i - 1] = column_3_raw_values[i - 1] + lookup[C3][i] * multi_table.column_3_step_sizes[i];
254 }
255 return lookup;
256}
257
258BasicTable create_basic_table(const BasicTableId id, const size_t index)
259{
260 // we have >50 basic fixed base tables so we match with some logic instead of a switch statement
261 auto id_var = static_cast<size_t>(id);
262 if (id_var >= static_cast<size_t>(FIXED_BASE_0_0) && id_var < static_cast<size_t>(FIXED_BASE_1_0)) {
263 return fixed_base::table::generate_basic_fixed_base_table<0>(
264 id, index, id_var - static_cast<size_t>(FIXED_BASE_0_0));
265 }
266 if (id_var >= static_cast<size_t>(FIXED_BASE_1_0) && id_var < static_cast<size_t>(FIXED_BASE_2_0)) {
267 return fixed_base::table::generate_basic_fixed_base_table<1>(
268 id, index, id_var - static_cast<size_t>(FIXED_BASE_1_0));
269 }
270 if (id_var >= static_cast<size_t>(FIXED_BASE_2_0) && id_var < static_cast<size_t>(FIXED_BASE_3_0)) {
271 return fixed_base::table::generate_basic_fixed_base_table<2>(
272 id, index, id_var - static_cast<size_t>(FIXED_BASE_2_0));
273 }
274 if (id_var >= static_cast<size_t>(FIXED_BASE_3_0) && id_var < static_cast<size_t>(HONK_DUMMY_BASIC1)) {
275 return fixed_base::table::generate_basic_fixed_base_table<3>(
276 id, index, id_var - static_cast<size_t>(FIXED_BASE_3_0));
277 }
278 switch (id) {
279 case AES_SPARSE_MAP: {
280 return sparse_tables::generate_sparse_table_with_rotation<9, 8, 0>(AES_SPARSE_MAP, index);
281 }
282 case AES_SBOX_MAP: {
284 }
287 }
290 }
292 return sparse_tables::generate_sparse_table_with_rotation<16, 3, 0>(SHA256_WITNESS_SLICE_3, index);
293 }
295 return sparse_tables::generate_sparse_table_with_rotation<16, 7, 4>(SHA256_WITNESS_SLICE_7_ROTATE_4, index);
296 }
298 return sparse_tables::generate_sparse_table_with_rotation<16, 8, 7>(SHA256_WITNESS_SLICE_8_ROTATE_7, index);
299 }
301 return sparse_tables::generate_sparse_table_with_rotation<16, 14, 1>(SHA256_WITNESS_SLICE_14_ROTATE_1, index);
302 }
303 case SHA256_CH_NORMALIZE: {
305 }
308 }
309 case SHA256_BASE28: {
310 return sparse_tables::generate_sparse_table_with_rotation<28, 11, 0>(SHA256_BASE28, index);
311 }
313 return sparse_tables::generate_sparse_table_with_rotation<28, 11, 6>(SHA256_BASE28_ROTATE6, index);
314 }
316 return sparse_tables::generate_sparse_table_with_rotation<28, 11, 3>(SHA256_BASE28_ROTATE3, index);
317 }
318 case SHA256_BASE16: {
319 return sparse_tables::generate_sparse_table_with_rotation<16, 11, 0>(SHA256_BASE16, index);
320 }
322 return sparse_tables::generate_sparse_table_with_rotation<16, 11, 2>(SHA256_BASE16_ROTATE2, index);
323 }
325 return uint_tables::generate_xor_rotate_table</*bits_per_slice=*/6, /*num_rotated_output_bits=*/0>(
327 }
329 return uint_tables::generate_xor_rotate_table</*bits_per_slice=*/4, /*num_rotated_output_bits=*/0>(
331 }
333 return uint_tables::generate_xor_rotate_table</*bits_per_slice=*/2, /*num_rotated_output_bits=*/0>(
335 }
337 return uint_tables::generate_and_rotate_table</*bits_per_slice=*/6, /*num_rotated_output_bits=*/0>(
339 }
341 return uint_tables::generate_and_rotate_table</*bits_per_slice=*/4, /*num_rotated_output_bits=*/0>(
343 }
345 return uint_tables::generate_and_rotate_table</*bits_per_slice=*/2, /*num_rotated_output_bits=*/0>(
347 }
348 case BN254_XLO_BASIC: {
350 }
351 case BN254_XHI_BASIC: {
353 }
354 case BN254_YLO_BASIC: {
356 }
357 case BN254_YHI_BASIC: {
359 }
360 case BN254_XYPRIME_BASIC: {
362 }
365 }
368 }
371 index);
372 }
373 case SECP256K1_XLO_BASIC: {
375 }
376 case SECP256K1_XHI_BASIC: {
378 }
379 case SECP256K1_YLO_BASIC: {
381 }
382 case SECP256K1_YHI_BASIC: {
384 }
387 index);
388 }
392 }
396 }
400 }
401 case BLAKE_XOR_ROTATE0: {
402 return blake2s_tables::generate_xor_rotate_table<6, 0>(BLAKE_XOR_ROTATE0, index);
403 }
405 return blake2s_tables::generate_xor_rotate_table<5, 0, true>(BLAKE_XOR_ROTATE0_SLICE5_MOD4, index);
406 }
407 case BLAKE_XOR_ROTATE2: {
408 return blake2s_tables::generate_xor_rotate_table<6, 2>(BLAKE_XOR_ROTATE2, index);
409 }
410 case BLAKE_XOR_ROTATE1: {
411 return blake2s_tables::generate_xor_rotate_table<6, 1>(BLAKE_XOR_ROTATE1, index);
412 }
413 case BLAKE_XOR_ROTATE4: {
414 return blake2s_tables::generate_xor_rotate_table<6, 4>(BLAKE_XOR_ROTATE4, index);
415 }
416 case HONK_DUMMY_BASIC1: {
417 return dummy_tables::generate_honk_dummy_table<HONK_DUMMY_BASIC1>(HONK_DUMMY_BASIC1, index);
418 }
419 case HONK_DUMMY_BASIC2: {
420 return dummy_tables::generate_honk_dummy_table<HONK_DUMMY_BASIC2>(HONK_DUMMY_BASIC2, index);
421 }
422 case KECCAK_INPUT: {
424 }
425 case KECCAK_THETA: {
427 }
428 case KECCAK_CHI: {
430 }
431 case KECCAK_OUTPUT: {
433 }
434 case KECCAK_RHO_1: {
436 }
437 case KECCAK_RHO_2: {
439 }
440 case KECCAK_RHO_3: {
442 }
443 case KECCAK_RHO_4: {
445 }
446 case KECCAK_RHO_5: {
448 }
449 case KECCAK_RHO_6: {
451 }
452 case KECCAK_RHO_7: {
454 }
455 case KECCAK_RHO_8: {
457 }
458 default: {
459 throw_or_abort("table id does not exist");
460 return sparse_tables::generate_sparse_table_with_rotation<9, 8, 0>(AES_SPARSE_MAP, index);
461 }
462 }
463}
464} // namespace bb::plookup
Container type for lookup table reads.
Definition types.hpp:418
std::vector< BasicTable::LookupEntry > lookup_entries
Definition types.hpp:424
static MultiTable get_yhi_table(const MultiTableId id, const BasicTableId basic_id)
static MultiTable get_xyprime_endo_table(const MultiTableId id, const BasicTableId basic_id)
static BasicTable generate_xlo_table(BasicTableId id, const size_t table_index)
static BasicTable generate_xyprime_endo_table(BasicTableId id, const size_t table_index)
static BasicTable generate_yhi_table(BasicTableId id, const size_t table_index)
static BasicTable generate_xlo_endo_table(BasicTableId id, const size_t table_index)
static BasicTable generate_ylo_table(BasicTableId id, const size_t table_index)
static BasicTable generate_xhi_table(BasicTableId id, const size_t table_index)
static MultiTable get_xlo_endo_table(const MultiTableId id, const BasicTableId basic_id)
static MultiTable get_xyprime_table(const MultiTableId id, const BasicTableId basic_id)
static MultiTable get_xhi_endo_table(const MultiTableId id, const BasicTableId basic_id)
static BasicTable generate_xyprime_table(BasicTableId id, const size_t table_index)
static BasicTable generate_xhi_endo_table(BasicTableId id, const size_t table_index)
static MultiTable get_xhi_table(const MultiTableId id, const BasicTableId basic_id)
static MultiTable get_xlo_table(const MultiTableId id, const BasicTableId basic_id)
static MultiTable get_ylo_table(const MultiTableId id, const BasicTableId basic_id)
static BasicTable generate_chi_renormalization_table(BasicTableId id, const size_t table_index)
Generate the CHI plookup table.
static MultiTable get_chi_output_table(const MultiTableId id=KECCAK_CHI_OUTPUT)
Create the CHI MultiTable used by plookup to generate a sequence of lookups.
static MultiTable get_keccak_input_table(const MultiTableId id=KECCAK_FORMAT_INPUT)
Create the KeccakInput MultiTable used by plookup to generate a sequence of lookups.
static BasicTable generate_keccak_input_table(BasicTableId id, const size_t table_index)
Generate plookup table that maps a TABLE_BITS-slice of a base-2 integer into a base-11 representation...
static MultiTable get_keccak_output_table(const MultiTableId id=KECCAK_FORMAT_OUTPUT)
Create the KeccakOutput MultiTable used by plookup to generate a sequence of lookups.
static BasicTable generate_keccak_output_table(BasicTableId id, const size_t table_index)
Generate plookup table that maps a TABLE_BITS-slice of a base-11 integer into a base-2 integer.
static MultiTable get_rho_output_table(const MultiTableId id=KECCAK_NORMALIZE_AND_ROTATE)
Create the Rho MultiTable used by plookup to generate a sequence of lookups.
static BasicTable generate_rho_renormalization_table(BasicTableId id, const size_t table_index)
Generate plookup table that normalizes a TABLE_BITS-slice of a base-11 integer and extracts the msb.
static MultiTable get_theta_output_table(const MultiTableId id=KECCAK_THETA_OUTPUT)
Create the THETA MultiTable used by plookup to generate a sequence of lookups.
static BasicTable generate_theta_renormalization_table(BasicTableId id, const size_t table_index)
Generate plookup table that normalizes a TABLE_BITS-slice of a base-11 integer.
This file contains functions for the dummy tables that we use in UltraHonk to make table,...
std::vector< uint64_t > slice_input_using_variable_bases(const uint256_t &input, const std::vector< uint64_t > &bases)
MultiTable get_aes_input_table(const MultiTableId id=AES_INPUT)
Definition aes128.hpp:116
BasicTable generate_aes_sparse_normalization_table(BasicTableId id, const size_t table_index)
Definition aes128.hpp:57
MultiTable get_aes_normalization_table(const MultiTableId id=AES_NORMALIZE)
Definition aes128.hpp:92
BasicTable generate_aes_sbox_table(BasicTableId id, const size_t table_index)
Definition aes128.hpp:140
MultiTable get_aes_sbox_table(const MultiTableId id=AES_SBOX)
Definition aes128.hpp:166
MultiTable get_blake2s_xor_rotate_8_table(const MultiTableId id=BLAKE_XOR_ROTATE_8)
Definition blake2s.hpp:152
MultiTable get_blake2s_xor_rotate_7_table(const MultiTableId id=BLAKE_XOR_ROTATE_7)
Definition blake2s.hpp:187
MultiTable get_blake2s_xor_rotate_16_table(const MultiTableId id=BLAKE_XOR_ROTATE_16)
Definition blake2s.hpp:117
MultiTable get_blake2s_xor_table(const MultiTableId id=BLAKE_XOR)
Definition blake2s.hpp:94
MultiTable get_honk_dummy_multitable()
Create a multitable for filling UltraHonk polynomials with non-zero values.
Definition dummy.hpp:83
MultiTable get_witness_extension_input_table(const MultiTableId id=SHA256_WITNESS_INPUT)
Definition sha256.hpp:224
MultiTable get_majority_input_table(const MultiTableId id=SHA256_MAJ_INPUT)
Definition sha256.hpp:344
BasicTable generate_choose_normalization_table(BasicTableId id, const size_t table_index)
Definition sha256.hpp:106
MultiTable get_witness_extension_output_table(const MultiTableId id=SHA256_WITNESS_OUTPUT)
Definition sha256.hpp:116
BasicTable generate_majority_normalization_table(BasicTableId id, const size_t table_index)
Definition sha256.hpp:111
MultiTable get_choose_output_table(const MultiTableId id=SHA256_CH_OUTPUT)
Definition sha256.hpp:132
MultiTable get_choose_input_table(const MultiTableId id=SHA256_CH_INPUT)
Definition sha256.hpp:246
MultiTable get_majority_output_table(const MultiTableId id=SHA256_MAJ_OUTPUT)
Definition sha256.hpp:148
plookup::BasicTable generate_witness_extension_normalization_table(BasicTableId id, const size_t table_index)
Definition sha256.hpp:100
BasicTable generate_xor_rotate_table(BasicTableId id, const size_t table_index)
Definition uint.hpp:22
BasicTable generate_and_rotate_table(BasicTableId id, const size_t table_index)
Definition uint.hpp:54
@ BLAKE_XOR_ROTATE0
Definition types.hpp:63
@ BLAKE_XOR_ROTATE0_SLICE5_MOD4
Definition types.hpp:64
@ BN254_XYPRIME_BASIC
Definition types.hpp:51
@ KECCAK_THETA
Definition types.hpp:75
@ SHA256_WITNESS_SLICE_8_ROTATE_7
Definition types.hpp:29
@ KECCAK_INPUT
Definition types.hpp:74
@ KECCAK_RHO_5
Definition types.hpp:83
@ UINT_AND_SLICE_6_ROTATE_0
Definition types.hpp:44
@ BN254_XYPRIME_ENDO_BASIC
Definition types.hpp:54
@ SECP256K1_XYPRIME_ENDO_BASIC
Definition types.hpp:62
@ BN254_XHI_ENDO_BASIC
Definition types.hpp:53
@ UINT_AND_SLICE_4_ROTATE_0
Definition types.hpp:46
@ UINT_XOR_SLICE_4_ROTATE_0
Definition types.hpp:43
@ KECCAK_RHO_4
Definition types.hpp:82
@ AES_SBOX_MAP
Definition types.hpp:24
@ KECCAK_RHO_6
Definition types.hpp:84
@ SHA256_BASE28
Definition types.hpp:33
@ SHA256_BASE16_ROTATE2
Definition types.hpp:37
@ AES_SPARSE_MAP
Definition types.hpp:23
@ SECP256K1_YLO_BASIC
Definition types.hpp:57
@ SHA256_CH_NORMALIZE
Definition types.hpp:31
@ UINT_XOR_SLICE_6_ROTATE_0
Definition types.hpp:41
@ FIXED_BASE_3_0
Definition types.hpp:71
@ BN254_XLO_ENDO_BASIC
Definition types.hpp:52
@ SHA256_WITNESS_SLICE_3
Definition types.hpp:27
@ SHA256_MAJ_NORMALIZE
Definition types.hpp:32
@ AES_SPARSE_NORMALIZE
Definition types.hpp:25
@ SHA256_BASE28_ROTATE6
Definition types.hpp:34
@ UINT_AND_SLICE_2_ROTATE_0
Definition types.hpp:45
@ SECP256K1_XYPRIME_BASIC
Definition types.hpp:59
@ HONK_DUMMY_BASIC2
Definition types.hpp:73
@ SECP256K1_XLO_ENDO_BASIC
Definition types.hpp:60
@ SECP256K1_XLO_BASIC
Definition types.hpp:55
@ FIXED_BASE_0_0
Definition types.hpp:68
@ BN254_XHI_BASIC
Definition types.hpp:48
@ KECCAK_RHO_7
Definition types.hpp:85
@ SHA256_BASE16
Definition types.hpp:36
@ KECCAK_RHO_1
Definition types.hpp:79
@ KECCAK_OUTPUT
Definition types.hpp:78
@ SECP256K1_XHI_ENDO_BASIC
Definition types.hpp:61
@ BLAKE_XOR_ROTATE1
Definition types.hpp:65
@ KECCAK_RHO_8
Definition types.hpp:86
@ BN254_YLO_BASIC
Definition types.hpp:49
@ SHA256_WITNESS_SLICE_7_ROTATE_4
Definition types.hpp:28
@ SECP256K1_YHI_BASIC
Definition types.hpp:58
@ FIXED_BASE_2_0
Definition types.hpp:70
@ FIXED_BASE_1_0
Definition types.hpp:69
@ BN254_YHI_BASIC
Definition types.hpp:50
@ SHA256_WITNESS_NORMALIZE
Definition types.hpp:26
@ SHA256_WITNESS_SLICE_14_ROTATE_1
Definition types.hpp:30
@ SECP256K1_XHI_BASIC
Definition types.hpp:56
@ KECCAK_RHO_3
Definition types.hpp:81
@ UINT_XOR_SLICE_2_ROTATE_0
Definition types.hpp:42
@ BLAKE_XOR_ROTATE2
Definition types.hpp:66
@ BLAKE_XOR_ROTATE4
Definition types.hpp:67
@ HONK_DUMMY_BASIC1
Definition types.hpp:72
@ BN254_XLO_BASIC
Definition types.hpp:47
@ KECCAK_RHO_2
Definition types.hpp:80
@ SHA256_BASE28_ROTATE3
Definition types.hpp:35
ReadData< bb::fr > get_lookup_accumulators(const MultiTableId id, const fr &key_a, const fr &key_b, const bool is_2_to_1_lookup)
Given a table ID and the key(s) for a key-value lookup, return the lookup accumulators.
@ KECCAK_FORMAT_INPUT
Definition types.hpp:135
@ SECP256K1_XLO
Definition types.hpp:120
@ BLAKE_XOR_ROTATE_16
Definition types.hpp:129
@ AES_NORMALIZE
Definition types.hpp:97
@ KECCAK_FORMAT_OUTPUT
Definition types.hpp:136
@ SECP256K1_XYPRIME
Definition types.hpp:124
@ SECP256K1_XYPRIME_ENDO
Definition types.hpp:127
@ HONK_DUMMY_MULTI
Definition types.hpp:132
@ BN254_XYPRIME
Definition types.hpp:116
@ SECP256K1_XLO_ENDO
Definition types.hpp:125
@ FIXED_BASE_RIGHT_HI
Definition types.hpp:103
@ FIXED_BASE_LEFT_LO
Definition types.hpp:100
@ KECCAK_NORMALIZE_AND_ROTATE
Definition types.hpp:137
@ SHA256_WITNESS_INPUT
Definition types.hpp:95
@ BN254_XHI_ENDO
Definition types.hpp:118
@ SHA256_CH_INPUT
Definition types.hpp:91
@ SHA256_MAJ_OUTPUT
Definition types.hpp:94
@ KECCAK_CHI_OUTPUT
Definition types.hpp:134
@ SHA256_CH_OUTPUT
Definition types.hpp:92
@ BN254_XYPRIME_ENDO
Definition types.hpp:119
@ FIXED_BASE_LEFT_HI
Definition types.hpp:101
@ BLAKE_XOR_ROTATE_7
Definition types.hpp:131
@ SECP256K1_XHI_ENDO
Definition types.hpp:126
@ SHA256_WITNESS_OUTPUT
Definition types.hpp:96
@ SECP256K1_XHI
Definition types.hpp:121
@ SECP256K1_YLO
Definition types.hpp:122
@ BN254_XLO_ENDO
Definition types.hpp:117
@ SHA256_MAJ_INPUT
Definition types.hpp:93
@ BLAKE_XOR_ROTATE_8
Definition types.hpp:130
@ KECCAK_THETA_OUTPUT
Definition types.hpp:133
@ SECP256K1_YHI
Definition types.hpp:123
@ FIXED_BASE_RIGHT_LO
Definition types.hpp:102
BasicTable create_basic_table(const BasicTableId id, const size_t index)
const MultiTable & get_multitable(const MultiTableId id)
Return the multitable with the provided ID; construct all MultiTables if not constructed already.
Entry point for Barretenberg command-line interface.
constexpr decltype(auto) get(::tuplet::tuple< T... > &&t) noexcept
Definition tuple.hpp:13
Definition types.hpp:349
A basic table from which we can perform lookups (for example, an xor table)
Definition types.hpp:348
Container for managing multiple BasicTables plus the data needed to combine basic table outputs (e....
Definition types.hpp:154
void throw_or_abort(std::string const &err)