Skip to content

Commit

Permalink
Crypto3, transpiler and other submodules updated #597
Browse files Browse the repository at this point in the history
  • Loading branch information
ETatuzova authored and martun committed May 7, 2024
1 parent eb13b79 commit 0756fd7
Show file tree
Hide file tree
Showing 8 changed files with 43 additions and 62 deletions.
7 changes: 3 additions & 4 deletions .github/workflows/build_linux.yml
Original file line number Diff line number Diff line change
Expand Up @@ -42,7 +42,7 @@ jobs:
CONTAINER_TMP: /opt/
HOST_TMP: /home/runner/work/_temp/
DEBIAN_FRONTEND: noninteractive
BOOST_VERSION: "1.80.0"
BOOST_VERSION: "1.78.0"
INTEGRATION_TESTING_TARGETS: |
arithmetics_cpp_example
polynomial_cpp_example
Expand Down Expand Up @@ -327,11 +327,11 @@ jobs:
always() && !cancelled() &&
(needs.handle-syncwith.result == 'success' || needs.handle-syncwith.result == 'skipped') &&
needs.build-and-test-linux.result == 'success'
uses: NilFoundation/proof-producer/.github/workflows/reusable-generate-proofs-linux.yml@b1e380040b4714b6ad5fe9223555d854c49cf065
uses: NilFoundation/proof-producer/.github/workflows/reusable-generate-proofs-linux.yml@ef8cd9152b4bec871e7efdc1d6b606e445bad274
with:
artifact-name: ${{ needs.build-and-test-linux.outputs.examples-artifact-name }}
# Update next line if you need new version of proof producer
proof-producer-ref: 938426d309e586d87cd2b7895a0dea05ff88c0c5
proof-producer-ref: ef8cd9152b4bec871e7efdc1d6b606e445bad274
refs: ${{ needs.handle-syncwith.outputs.prs-refs }}
targets: ${{ needs.build-and-test-linux.outputs.prover-targets }}

Expand Down Expand Up @@ -412,7 +412,6 @@ jobs:
refs: ${{ needs.handle-syncwith.outputs.prs-refs }}
test-names: ${{ needs.build-and-test-linux.outputs.evm-targets }}


cleanup-integration-testing:
# For now each artifact is 12 GB. Better clean it up to keep the space
name: Clean up after integration testing
Expand Down
2 changes: 1 addition & 1 deletion bin/assigner/src/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -147,7 +147,7 @@ void print_circuit(const circuit_proxy<ArithmetizationType> &circuit_proxy,
auto filled_val =
value_marshalling_type(std::make_tuple(
nil::crypto3::marshalling::types::fill_plonk_gates<Endianness, typename ConstraintSystemType::gates_container_type::value_type>(used_gates),
nil::crypto3::marshalling::types::fill_plonk_copy_constraints<Endianness, typename ConstraintSystemType::variable_type>(used_copy_constraints),
nil::crypto3::marshalling::types::fill_plonk_copy_constraints<Endianness, typename ConstraintSystemType::field_type>(used_copy_constraints),
nil::crypto3::marshalling::types::fill_plonk_lookup_gates<Endianness, typename ConstraintSystemType::lookup_gates_container_type::value_type>(used_lookup_gates),
nil::crypto3::marshalling::types::fill_plonk_lookup_tables<Endianness, typename ConstraintSystemType::lookup_tables_type::value_type>(used_lookup_tables),
public_input_sizes
Expand Down
43 changes: 18 additions & 25 deletions bin/recursive_gen/src/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@
#include <nil/crypto3/zk/snark/systems/plonk/placeholder/prover.hpp>
#include <nil/crypto3/zk/snark/systems/plonk/placeholder/verifier.hpp>
#include <nil/crypto3/zk/snark/systems/plonk/placeholder/params.hpp>
#include <nil/crypto3/zk/snark/systems/plonk/placeholder/profiling.hpp>
#include <nil/crypto3/zk/snark/systems/plonk/placeholder/detail/profiling.hpp>

#include <nil/crypto3/math/polynomial/polynomial.hpp>
#include <nil/crypto3/math/algorithms/calculate_domain_set.hpp>
Expand Down Expand Up @@ -166,18 +166,6 @@ inline std::vector<std::size_t> generate_random_step_list(const std::size_t r, c
return step_list;
}

template<typename FRIScheme, typename FieldType>
typename FRIScheme::params_type create_fri_params(std::size_t degree_log, const int max_step = 1, const int expand_factor = 2) {
std::size_t r = degree_log - 1;

return typename FRIScheme::params_type(
(1 << degree_log) - 1, // max_degree
math::calculate_domain_set<FieldType>(degree_log + expand_factor, r),
generate_random_step_list(r, max_step),
expand_factor
);
}

template<typename TIter>
void print_hex_byteblob(std::ostream &os, TIter iter_begin, TIter iter_end, bool endl) {
os << "0x" << std::hex;
Expand Down Expand Up @@ -231,6 +219,9 @@ int main(int argc, char *argv[]) {
It'll be better to create an empty folder for output")
("skip-verification", "Used with gen-test-proof, if set - skips verifiyng the generated proof")
("multi-prover", "Pass this flag if input circuit is a part of larger circuit, divided for faster paralel proving")
("lambda,l", boost::program_options::value<std::size_t>(), "Number of FRI rounds")
("expand-factor", boost::program_options::value<std::size_t>(), "FRI blow-up factor")
("max-quotient-chunks", boost::program_options::value<std::size_t>(), "Maximal parts of quotient polynomial")
("elliptic-curve-type,e", boost::program_options::value<std::string>(), "Native elliptic curve type (pallas, vesta, ed25519, bls12381)");

// clang-format on
Expand Down Expand Up @@ -376,7 +367,10 @@ int curve_dependent_main(
using AssignmentTableType =
nil::crypto3::zk::snark::plonk_table<BlueprintFieldType, ColumnType>;

const std::size_t Lambda = parameters_policy::lambda;
const std::size_t Lambda = vm.count("lambda")? vm["lambda"].as<std::size_t>() : parameters_policy::lambda;
const std::size_t max_quotient_chunks = vm.count("max-quotient-chunks")? vm["max-quotient-chunks"].as<std::size_t>() : 0;
const std::size_t expand_factor = vm.count("expand-factor")? vm["expand-factor"].as<std::size_t>() : 2;

using Hash = typename parameters_policy::hash;
using circuit_params = nil::crypto3::zk::snark::placeholder_circuit_params<
BlueprintFieldType
Expand All @@ -385,7 +379,6 @@ int curve_dependent_main(
using lpc_params_type = nil::crypto3::zk::commitments::list_polynomial_commitment_params<
Hash,
Hash,
Lambda,
2
>;
using lpc_type = nil::crypto3::zk::commitments::list_polynomial_commitment<BlueprintFieldType, lpc_params_type>;
Expand Down Expand Up @@ -437,10 +430,10 @@ int curve_dependent_main(
if (!marshalled_value) {
return false;
}
auto [c_data, description] = nil::crypto3::marshalling::types::make_placeholder_common_data<Endianness, CommonDataType>(
auto c_data = nil::crypto3::marshalling::types::make_placeholder_common_data<Endianness, CommonDataType>(
*marshalled_value
);
desc.emplace(description);
desc.emplace(c_data.desc);
common_data.emplace(c_data);
}

Expand All @@ -459,14 +452,14 @@ int curve_dependent_main(
using lpc_params_type = nil::crypto3::zk::commitments::list_polynomial_commitment_params<
Hash,
Hash,
Lambda,
2
>;
auto fri_params = create_fri_params<typename lpc_type::fri_type, BlueprintFieldType>(table_rows_log);
std::size_t permutation_size =
desc->witness_columns + desc->public_input_columns + desc->constant_columns;
lpc_scheme_type lpc_scheme(fri_params);

// TODO: grinding bits
typename lpc_type::fri_type::params_type fri_params(
1, table_rows_log, Lambda, expand_factor
);
lpc_scheme_type lpc_scheme(fri_params);

if( mode == "gen-verifier" && !assignment_table && !common_data ){
std::cerr << "Invalid command line argument - assignment table file name or common data file name should be specified" << std::endl;
Expand All @@ -489,7 +482,7 @@ int curve_dependent_main(
typename nil::crypto3::zk::snark::placeholder_public_preprocessor<
BlueprintFieldType, placeholder_params>::preprocessed_data_type public_preprocessed_data =
nil::crypto3::zk::snark::placeholder_public_preprocessor<BlueprintFieldType, placeholder_params>::process(
*constraint_system, assignment_table->public_table(), *desc, lpc_scheme, permutation_size);
*constraint_system, assignment_table->public_table(), *desc, lpc_scheme, max_quotient_chunks);
common_data.emplace(public_preprocessed_data.common_data);

if (mode == "gen-input") {
Expand All @@ -510,7 +503,7 @@ int curve_dependent_main(
std::cout << "Verifying proof..." << std::endl;
bool verification_result =
nil::crypto3::zk::snark::placeholder_verifier<BlueprintFieldType, placeholder_params>::process(
public_preprocessed_data, proof, *desc, *constraint_system, lpc_scheme
public_preprocessed_data.common_data, proof, *desc, *constraint_system, lpc_scheme
);

ASSERT_MSG(verification_result, "Proof is not verified" );
Expand Down Expand Up @@ -539,7 +532,7 @@ int curve_dependent_main(
nil::crypto3::zk::snark::placeholder_proof<BlueprintFieldType, placeholder_params>,
typename nil::crypto3::zk::snark::placeholder_public_preprocessor<BlueprintFieldType, placeholder_params>::preprocessed_data_type::common_data_type
>(*desc).generate_recursive_verifier(
*constraint_system, *common_data, lpc_scheme, permutation_size, public_input_sizes
*constraint_system, *common_data, public_input_sizes
);
output_file.close();
return 0;
Expand Down
45 changes: 17 additions & 28 deletions bin/transpiler/src/main.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -26,6 +26,7 @@
#include <nil/marshalling/status_type.hpp>
#include <nil/marshalling/field_type.hpp>
#include <nil/marshalling/endianness.hpp>
#include <nil/crypto3/marshalling/zk/types/commitments/lpc.hpp>
#include <nil/crypto3/marshalling/zk/types/placeholder/proof.hpp>
#include <nil/crypto3/marshalling/zk/types/plonk/constraint_system.hpp>
#include <nil/crypto3/marshalling/zk/types/plonk/assignment_table.hpp>
Expand All @@ -34,7 +35,7 @@
#include <nil/crypto3/zk/snark/systems/plonk/placeholder/prover.hpp>
#include <nil/crypto3/zk/snark/systems/plonk/placeholder/verifier.hpp>
#include <nil/crypto3/zk/snark/systems/plonk/placeholder/params.hpp>
#include <nil/crypto3/zk/snark/systems/plonk/placeholder/profiling.hpp>
#include <nil/crypto3/zk/snark/systems/plonk/placeholder/detail/profiling.hpp>

#include <nil/crypto3/math/polynomial/polynomial.hpp>
#include <nil/crypto3/math/algorithms/calculate_domain_set.hpp>
Expand Down Expand Up @@ -85,19 +86,6 @@ inline std::vector<std::size_t> generate_random_step_list(const std::size_t r, c
return step_list;
}

template<typename FRIScheme, typename FieldType>
typename FRIScheme::params_type create_fri_params(
std::size_t degree_log, const int max_step = 1, std::size_t expand_factor = 2) {
std::size_t r = degree_log - 1;

return typename FRIScheme::params_type(
(1 << degree_log) - 1, // max_degree
nil::crypto3::math::calculate_domain_set<FieldType>(degree_log + expand_factor, r),
generate_random_step_list(r, max_step),
expand_factor
);
}

template<typename TIter>
void print_hex_byteblob(std::ostream &os, TIter iter_begin, TIter iter_end, bool endl) {
os << "0x" << std::hex;
Expand Down Expand Up @@ -174,6 +162,9 @@ int main(int argc, char *argv[]) {
("deduce-horner", "Detect polynomials over one variable and deduce to Horner's formula")
("optimize-powers", "Optimize terms that are powers of single variable")
("multi-prover", "Pass this flag if input circuit is a part of larger circuit, divided for faster paralel proving")
("lambda,l", boost::program_options::value<std::size_t>(), "Number of FRI rounds")
("expand-factor", boost::program_options::value<std::size_t>(), "FRI blow-up factor")
("max-quotient-chunks", boost::program_options::value<std::size_t>(), "Maximal quotient polynomial parts amount")
("elliptic-curve-type,e", boost::program_options::value<std::string>(), "Native elliptic curve type (pallas, vesta, ed25519, bls12381)")
;
// clang-format on
Expand Down Expand Up @@ -394,13 +385,14 @@ int curve_dependent_main(
nil::crypto3::marshalling::types::make_assignment_table<Endianness, AssignmentTableType>(
marshalled_table_data
);
desc.rows_amount = assignment_table.rows_amount();
}


std::vector<std::set<int>> columns_rotations;

const std::size_t Lambda = 9;//ParametersPolicy::lambda;
std::size_t Lambda = vm.count("lambda") > 0 ? vm["lambda"].as<std::size_t>() : 9;//ParametersPolicy::lambda;
std::size_t expand_factor = vm.count("expand-factor") > 0 ? vm["expand-factor"].as<std::size_t>() : 2;//ParametersPolicy::lambda;
std::size_t max_quotient_chunks = vm.count("max-quotient-chunks") > 0 ? vm["max-quotient-chunks"].as<std::size_t>() : 0;
using Hash = nil::crypto3::hashes::keccak_1600<256>;
using circuit_params = nil::crypto3::zk::snark::placeholder_circuit_params<BlueprintFieldType>;

Expand All @@ -409,19 +401,18 @@ int curve_dependent_main(
using lpc_params_type = nil::crypto3::zk::commitments::list_polynomial_commitment_params<
Hash,
Hash,
Lambda,
2,
ParametersPolicy::UseGrinding,
nil::crypto3::zk::commitments::proof_of_work<Hash, std::uint32_t, ParametersPolicy::GrindingBits>
2
>;

using lpc_type = nil::crypto3::zk::commitments::list_polynomial_commitment<BlueprintFieldType, lpc_params_type>;
using lpc_scheme_type = typename nil::crypto3::zk::commitments::lpc_commitment_scheme<lpc_type>;
using placeholder_params = nil::crypto3::zk::snark::placeholder_params<circuit_params, lpc_scheme_type>;
using policy_type = nil::crypto3::zk::snark::detail::placeholder_policy<BlueprintFieldType, placeholder_params>;

auto fri_params = create_fri_params<typename lpc_type::fri_type, BlueprintFieldType>(table_rows_log);
std::size_t permutation_size =
desc.witness_columns + desc.public_input_columns + ParametersPolicy::ComponentConstantColumns;
// TODO: grinding bits
typename lpc_type::fri_type::params_type fri_params(
1, table_rows_log, Lambda, expand_factor
);
lpc_scheme_type lpc_scheme(fri_params);


Expand All @@ -442,7 +433,8 @@ int curve_dependent_main(
typename nil::crypto3::zk::snark::placeholder_public_preprocessor<
BlueprintFieldType, placeholder_params>::preprocessed_data_type public_preprocessed_data =
nil::crypto3::zk::snark::placeholder_public_preprocessor<BlueprintFieldType, placeholder_params>::process(
constraint_system, assignment_table.public_table(), desc, lpc_scheme, permutation_size);
constraint_system, assignment_table.public_table(), desc, lpc_scheme, max_quotient_chunks
);

if (mode == "gen-evm-verifier") {
std::size_t gates_contract_size_threshold = 800;
Expand Down Expand Up @@ -474,11 +466,8 @@ int curve_dependent_main(
optimize_powers = true;
}
nil::blueprint::evm_verifier_printer<placeholder_params>(
desc,
constraint_system,
public_preprocessed_data.common_data,
lpc_scheme,
permutation_size,
output_folder_path,
gates_contract_size_threshold,
lookups_library_threshold,
Expand Down Expand Up @@ -531,7 +520,7 @@ int curve_dependent_main(
std::cout << "Verifying proof..." << std::endl;
bool verification_result =
nil::crypto3::zk::snark::placeholder_verifier<BlueprintFieldType, placeholder_params>::process(
public_preprocessed_data,
public_preprocessed_data.common_data,
proof,
desc,
constraint_system,
Expand Down
2 changes: 1 addition & 1 deletion libs/assigner
2 changes: 1 addition & 1 deletion libs/blueprint
Submodule blueprint updated 110 files

0 comments on commit 0756fd7

Please sign in to comment.