diff --git a/bin/assigner/src/main.cpp b/bin/assigner/src/main.cpp index ad31cebd..c37c22ba 100644 --- a/bin/assigner/src/main.cpp +++ b/bin/assigner/src/main.cpp @@ -62,6 +62,8 @@ #include #include +#include + using namespace nil; using namespace nil::crypto3; using namespace nil::blueprint; @@ -193,6 +195,7 @@ void print_assignment_table(const assignment_proxy &table_p max_public_inputs_size = std::max(max_public_inputs_size, table_proxy.public_input_column_size(i)); } + auto calc_params_start = std::chrono::high_resolution_clock::now(); if (print_kind == print_table_kind::MULTI_PROVER) { total_columns = witness_size + shared_size + public_input_size + constant_size + selector_size; std::uint32_t max_shared_size = 0; @@ -270,7 +273,10 @@ void print_assignment_table(const assignment_proxy &table_p > >; using column_type = typename crypto3::zk::snark::plonk_column; + auto calc_params_duration = std::chrono::duration_cast(std::chrono::high_resolution_clock::now() - calc_params_start); + BOOST_LOG_TRIVIAL(info) << "calc_params_duration: " << calc_params_duration.count() << "ms"; + auto fill_columns_start = std::chrono::high_resolution_clock::now(); std::vector table_witness_values( padded_rows_amount * witness_size , 0); std::vector table_public_input_values(padded_rows_amount * (public_input_size + shared_size), 0); std::vector table_constant_values( padded_rows_amount * constant_size, 0); @@ -379,7 +385,10 @@ void print_assignment_table(const assignment_proxy &table_p } ASSERT_MSG(witness_idx + pub_inp_idx + constant_idx + selector_idx == total_size, "Printed index not equal required assignment size" ); } + auto fill_columns_duration = std::chrono::duration_cast(std::chrono::high_resolution_clock::now() - fill_columns_start); + BOOST_LOG_TRIVIAL(info) << "fill_columns_duration: " << fill_columns_duration.count() << "ms"; + auto fill_table_start = std::chrono::high_resolution_clock::now(); auto filled_val = plonk_assignment_table(std::make_tuple( nil::marshalling::types::integral(witness_size), nil::marshalling::types::integral(public_input_size + shared_size), @@ -392,7 +401,10 @@ void print_assignment_table(const assignment_proxy &table_p nil::crypto3::marshalling::types::fill_field_element_vector(table_constant_values), nil::crypto3::marshalling::types::fill_field_element_vector(table_selector_values) )); + auto fill_table_duration = std::chrono::duration_cast(std::chrono::high_resolution_clock::now() - fill_table_start); + BOOST_LOG_TRIVIAL(info) << "fill_table_duration: " << fill_table_duration.count() << "ms"; + auto clear_vectors_start = std::chrono::high_resolution_clock::now(); table_witness_values.clear(); table_witness_values.shrink_to_fit(); @@ -404,12 +416,28 @@ void print_assignment_table(const assignment_proxy &table_p table_selector_values.clear(); table_selector_values.shrink_to_fit(); + auto clear_vectors_duration = std::chrono::duration_cast(std::chrono::high_resolution_clock::now() - clear_vectors_start); + BOOST_LOG_TRIVIAL(info) << "clear_vectors_duration: " << clear_vectors_duration.count() << "ms"; + + auto create_cv_vector_start = std::chrono::high_resolution_clock::now(); std::vector cv; cv.resize(filled_val.length(), 0x00); + auto create_cv_vector_duration = std::chrono::duration_cast(std::chrono::high_resolution_clock::now() - create_cv_vector_start); + BOOST_LOG_TRIVIAL(info) << "create_cv_vector_duration: " << create_cv_vector_duration.count() << "ms"; + + + auto filled_val_write_start = std::chrono::high_resolution_clock::now(); auto write_iter = cv.begin(); nil::marshalling::status_type status = filled_val.write(write_iter, cv.size()); + auto filled_val_write_duration = std::chrono::duration_cast(std::chrono::high_resolution_clock::now() - filled_val_write_start); + BOOST_LOG_TRIVIAL(info) << "filled_val_write_duration: " << filled_val_write_duration.count() << "ms"; + + + auto out_write_start = std::chrono::high_resolution_clock::now(); out.write(reinterpret_cast(cv.data()), cv.size()); + auto out_write_duration = std::chrono::duration_cast(std::chrono::high_resolution_clock::now() - out_write_start); + BOOST_LOG_TRIVIAL(info) << "out_write_duration: " << out_write_duration.count() << "ms"; } bool read_json( @@ -509,6 +537,7 @@ int curve_dependent_main(std::string bytecode_file_name, return 1; } + auto assigner_instance_creation_start = std::chrono::high_resolution_clock::now(); nil::blueprint::assigner assigner_instance( desc, stack_size, @@ -520,7 +549,10 @@ int curve_dependent_main(std::string bytecode_file_name, circuit_output_print_format, check_validity ); + auto assigner_instance_creation_duration = std::chrono::duration_cast(std::chrono::high_resolution_clock::now() - assigner_instance_creation_start); + BOOST_LOG_TRIVIAL(info) << "assigner_instance_creation_duration: " << assigner_instance_creation_duration.count() << "ms"; + auto parse_ir_file_start = std::chrono::high_resolution_clock::now(); if (!assigner_instance.parse_ir_file(bytecode_file_name.c_str())) { return 1; } @@ -530,10 +562,15 @@ int curve_dependent_main(std::string bytecode_file_name, } return 0; } + auto parse_ir_file_duration = std::chrono::duration_cast(std::chrono::high_resolution_clock::now() - parse_ir_file_start); + BOOST_LOG_TRIVIAL(info) << "parse_ir_file_duration: " << parse_ir_file_duration.count() << "ms"; + auto parser_evaluation_start = std::chrono::high_resolution_clock::now(); if (!assigner_instance.evaluate(public_input_json_value.as_array(), private_input_json_value.as_array())) { return 1; } + auto parser_evaluation_duration = std::chrono::duration_cast(std::chrono::high_resolution_clock::now() - parser_evaluation_start); + BOOST_LOG_TRIVIAL(info) << "parser_evaluation_duration: " << parser_evaluation_duration.count() << "ms"; ASSERT_MSG(!assigner_instance.assignments.empty() && !assigner_instance.circuits.empty(), "Not found any proxy for prover" ); @@ -541,6 +578,7 @@ int curve_dependent_main(std::string bytecode_file_name, return 0; } + auto pack_lookup_start = std::chrono::high_resolution_clock::now(); // pack lookup tables if (assigner_instance.circuits[0].get_reserved_tables().size() > 0) { std::vector lookup_columns_indices; @@ -559,11 +597,15 @@ int curve_dependent_main(std::string bytecode_file_name, max_lookup_rows ); } + auto pack_lookup_duration = std::chrono::duration_cast(std::chrono::high_resolution_clock::now() - pack_lookup_start); + BOOST_LOG_TRIVIAL(info) << "pack_lookup_duration: " << pack_lookup_duration.count() << "ms"; + auto overall_table_printing_start = std::chrono::high_resolution_clock::now(); constexpr std::uint32_t invalid_target_prover = std::numeric_limits::max(); // print assignment tables and circuits ASSERT_MSG(assigner_instance.assignments.size() == assigner_instance.circuits.size(), "Missmatch assignments circuits size"); if (assigner_instance.assignments.size() == 1 && (target_prover == 0 || target_prover == invalid_target_prover)) { + auto single_table_print_start = std::chrono::high_resolution_clock::now(); // print assignment table if (gen_mode.has_assignments()) { std::ofstream otable; @@ -578,6 +620,8 @@ int curve_dependent_main(std::string bytecode_file_name, ComponentSelectorColumns, otable); otable.close(); + auto single_table_print_duration = std::chrono::duration_cast(std::chrono::high_resolution_clock::now() - single_table_print_start); + BOOST_LOG_TRIVIAL(info) << "single_table_print_duration: " << single_table_print_duration.count() << "ms"; } // print circuit @@ -600,6 +644,7 @@ int curve_dependent_main(std::string bytecode_file_name, for (std::uint32_t idx = start_idx; idx < end_idx; idx++) { // print assignment table if (gen_mode.has_assignments()) { + auto multi_table_print_start = std::chrono::high_resolution_clock::now(); std::ofstream otable; otable.open(assignment_table_file_name + std::to_string(idx), std::ios_base::binary | std::ios_base::out); @@ -614,6 +659,8 @@ int curve_dependent_main(std::string bytecode_file_name, ComponentSelectorColumns, otable); otable.close(); + auto multi_table_print_duration = std::chrono::duration_cast(std::chrono::high_resolution_clock::now() - multi_table_print_start); + BOOST_LOG_TRIVIAL(info) << "multi_table_print_duration: " << multi_table_print_duration.count() << "ms"; } // print circuit @@ -637,7 +684,10 @@ int curve_dependent_main(std::string bytecode_file_name, << assigner_instance.assignments.size() << std::endl; return 1; } + auto overall_table_printing_duration = std::chrono::duration_cast(std::chrono::high_resolution_clock::now() - overall_table_printing_start); + BOOST_LOG_TRIVIAL(info) << "overall_table_printing_duration: " << overall_table_printing_duration.count() << "ms"; + auto check_validity_start = std::chrono::high_resolution_clock::now(); if (check_validity && gen_mode.has_assignments() && gen_mode.has_circuit()) { if (assigner_instance.assignments.size() == 1 && (target_prover == 0 || target_prover == invalid_target_prover)) { ASSERT_MSG(nil::blueprint::is_satisfied(assigner_instance.circuits[0].get(), assigner_instance.assignments[0].get()), @@ -660,6 +710,8 @@ int curve_dependent_main(std::string bytecode_file_name, return 1; } } + auto check_validity_duration = std::chrono::duration_cast(std::chrono::high_resolution_clock::now() - check_validity_start); + BOOST_LOG_TRIVIAL(info) << "check_validity_duration: " << check_validity_duration.count() << "ms"; return 0; }