Skip to content

Commit

Permalink
Saving the changes once again.
Browse files Browse the repository at this point in the history
  • Loading branch information
martun committed Sep 11, 2024
1 parent bb17c85 commit 4d7140a
Show file tree
Hide file tree
Showing 4 changed files with 254 additions and 64 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -268,47 +268,53 @@ namespace nil {
std::vector<round_proof_type> round_proofs;
};

struct round_proofs_batch {
bool operator==(const round_proofs_batch &rhs) const {
struct commitments_part_of_proof {
bool operator==(const commitments_part_of_proof& rhs) const {
return fri_roots == rhs.fri_roots &&
round_proofs == rhs.round_proofs &&
final_polynomial == rhs.final_polynomial;
}

bool operator!=(const round_proofs_batch &rhs) const {
bool operator!=(const commitments_part_of_proof& rhs) const {
return !(rhs == *this);
}

std::vector<commitment_type> fri_roots; // 0,..step_list.size()
std::vector<std::vector<round_proof_type>> round_proofs; // 0...lambda - 1
// Vector of size 'step_list.size()'.
std::vector<commitment_type> fri_roots;
math::polynomial<typename field_type::value_type> final_polynomial;
};

struct initial_proofs_batch {
initial_proofs_batch() = default;
struct round_proofs_batch {
bool operator==(const round_proofs_batch &rhs) const {
return round_proofs == rhs.round_proofs;
}

// Just pre-allocate the vector for a given size.
initial_proofs_batch(std::size_t lambda)
: initial_proofs(lambda) {
bool operator!=(const round_proofs_batch &rhs) const {
return !(rhs == *this);
}

bool operator==(const initial_proofs_batch &rhs) const {
// Vector of size 'lambda'.
std::vector<std::vector<round_proof_type>> round_proofs;
};

struct initial_proofs_batch_type {
bool operator==(const initial_proofs_batch_type &rhs) const {
return initial_proofs == rhs.initial_proofs;
}

bool operator!=(const initial_proofs_batch &rhs) const {
bool operator!=(const initial_proofs_batch_type &rhs) const {
return !(rhs == *this);
}

std::vector<std::map<std::size_t, initial_proof_type>> initial_proofs; // 0...lambda - 1
// Vector of size 'lambda'.
std::vector<std::map<std::size_t, initial_proof_type>> initial_proofs;
};

struct proof_type {
proof_type() = default;
proof_type(const proof_type&) = default;

proof_type(const round_proofs_batch& round_proofs,
const initial_proofs_batch& intial_proofs)
const initial_proofs_batch_type& intial_proofs)
: fri_roots(round_proofs.fri_roots)
, final_polynomial(round_proofs.final_polynomial) {
for (std::size_t i = 0; i < intial_proofs.initial_proofs.size(); ++i) {
Expand Down Expand Up @@ -337,36 +343,39 @@ namespace nil {
typename GrindingType::output_type proof_of_work;
};

// This represents and aggregated proofs of N provers with shared initial proof.
struct aggregated_proof {
// This represents and aggregated proofs of N provers with shared rounds proof.
struct aggregated_proof_type {
aggregated_proof() = default;
aggregated_proof(const aggregated_proof&) = default;

// Size of vector 'round_proofs_per_prover' is the number of provers.
// Size of vector 'intial_proofs_per_prover' is the number of provers.
aggregated_proof(
const std::vector<round_proofs_batch>& round_proofs_per_prover,
const initial_proofs_batch& intial_proofs)
: round_proofs_per_prover(round_proofs_per_prover)
, intial_proofs(intial_proofs) {
const round_proofs_batch& round_proofs,
const std::vector<initial_proofs_batch_type>& intial_proofs_per_prover)
: round_proofs(round_proofs)
, intial_proofs_per_prover(intial_proofs_per_prover) {
}

bool operator==(const aggregated_proof &rhs) const {
//if (FRI::use_grinding && proof_of_work != rhs.proof_of_work) {
// return false;
//}
return round_proofs_per_prover == rhs.round_proofs_per_prover &&
intial_proofs == rhs.intial_proofs;
return round_proofs == rhs.round_proofs &&
intial_proofs_per_prover == rhs.intial_proofs_per_prover;
}

bool operator!=(const aggregated_proof &rhs) const {
return !(rhs == *this);
}

// For each prover we have a rounds proof partial FRI proof for consistency checks.
std::vector<round_proofs_batch> round_proofs_per_prover;
// We have a single round proof for checking that F(X) is a low degree polynomial.
round_proofs_batch round_proofs;

// Contains fri_roots and final_polynomial that correspond to the polynomial F(x).
commitments_part_of_proof commitments_proof_part;

// We have a single intial proof for checking that F(X) is a low degree polynomial.
initial_proofs_batch intial_proofs;
// For each prover we have an initial proof for consistency checks.
std::vector<initial_proofs_batch_type> intial_proofs_per_prover;

typename GrindingType::output_type proof_of_work;
};
Expand Down Expand Up @@ -437,13 +446,10 @@ namespace nil {
FRI>::value,
bool>::type = true>
static typename FRI::precommitment_type
precommit(math::polynomial_dfs<typename FRI::field_type::value_type> &f,
precommit_inner(const math::polynomial_dfs<typename FRI::field_type::value_type> &f,
std::shared_ptr<math::evaluation_domain<typename FRI::field_type>> D,
const std::size_t fri_step) {

if (f.size() != D->size()) {
f.resize(D->size(), nullptr, D);
}
std::size_t domain_size = D->size();
std::size_t coset_size = 1 << fri_step;
std::size_t leafs_number = domain_size / coset_size;
Expand Down Expand Up @@ -483,6 +489,30 @@ namespace nil {
y_data.end());
}

template<typename FRI,
typename std::enable_if<
std::is_base_of<
commitments::detail::basic_batched_fri<
typename FRI::field_type,
typename FRI::merkle_tree_hash_type,
typename FRI::transcript_hash_type,
FRI::m, typename FRI::grinding_type
>,
FRI>::value,
bool>::type = true>
static typename FRI::precommitment_type
precommit(const math::polynomial_dfs<typename FRI::field_type::value_type> &f,
std::shared_ptr<math::evaluation_domain<typename FRI::field_type>> D,
const std::size_t fri_step) {

if (f.size() == D->size())
return precommit_inner<FRI>(f, D, fri_step);

math::polynomial_dfs<typename FRI::field_type::value_type> f_copy = f;
f_copy.resize(D->size(), nullptr, D);
return precommit_inner<FRI>(f_copy, D, fri_step);
}

template<typename FRI,
typename std::enable_if<
std::is_base_of<
Expand Down Expand Up @@ -741,8 +771,7 @@ namespace nil {
static std::tuple<
std::vector<PolynomialType>,
std::vector<typename FRI::precommitment_type>,
std::vector<typename FRI::commitment_type>,
math::polynomial<typename FRI::field_type::value_type>
typename FRI::commitments_part_of_proof
>
commit_phase(
const PolynomialType& combined_Q,
Expand All @@ -753,8 +782,7 @@ namespace nil {
PROFILE_SCOPE("Basic FRI commit phase");
std::vector<PolynomialType> fs;
std::vector<typename FRI::precommitment_type> fri_trees;
std::vector<typename FRI::commitment_type> fri_roots;
math::polynomial<typename FRI::field_type::value_type> final_polynomial;
typename FRI::commitments_part_of_proof commitments_proof;

auto f = combined_Q;
auto precommitment = combined_Q_precommitment;
Expand All @@ -763,7 +791,7 @@ namespace nil {
for (std::size_t i = 0; i < fri_params.step_list.size(); i++) {
fs.push_back(f);
fri_trees.push_back(precommitment);
fri_roots.push_back(commit<FRI>(precommitment));
commitments_proof.fri_roots.push_back(commit<FRI>(precommitment));
transcript(commit<FRI>(precommitment));
for (std::size_t step_i = 0; step_i < fri_params.step_list[i]; ++step_i, ++t) {
typename FRI::field_type::value_type alpha = transcript.template challenge<typename FRI::field_type>();
Expand All @@ -781,12 +809,12 @@ namespace nil {
}
fs.push_back(f);
if constexpr (std::is_same<math::polynomial_dfs<typename FRI::field_type::value_type>, PolynomialType>::value) {
final_polynomial = math::polynomial<typename FRI::field_type::value_type>(f.coefficients());
commitments_proof.final_polynomial = math::polynomial<typename FRI::field_type::value_type>(f.coefficients());
} else {
final_polynomial = f;
commitments_proof.final_polynomial = f;
}

return std::make_tuple(fs, fri_trees, fri_roots, final_polynomial);
return std::make_tuple(fs, fri_trees, commitments_proof);
}

/** @brief Convert a set of polynomials from DFS form into coefficients form */
Expand Down Expand Up @@ -988,7 +1016,7 @@ namespace nil {
}

template<typename FRI, typename PolynomialType>
static typename FRI::round_proofs_batch query_phase_round_proofs_with_challenges(
static typename FRI::round_proofs_batch query_phase_round_proofs(
const typename FRI::params_type &fri_params,
const std::vector<typename FRI::precommitment_type> &fri_trees,
const std::vector<PolynomialType> &fs,
Expand All @@ -1013,19 +1041,19 @@ namespace nil {
build_round_proofs<FRI, PolynomialType>(
fri_params, fri_trees, fs, final_polynomial, x_index);

proof.round_proofs[query_id] = std::move(round_proofs);
proof.round_proofs.emplace_back(std::move(round_proofs));
}
return proof;
}

template<typename FRI, typename PolynomialType>
static typename FRI::initial_proofs_batch query_phase_initial_proofs_with_challenges(
static typename FRI::initial_proofs_batch_type query_phase_initial_proofs(
const std::map<std::size_t, typename FRI::precommitment_type> &precommitments,
const typename FRI::params_type &fri_params,
const std::map<std::size_t, std::vector<PolynomialType>> &g,
const std::vector<typename FRI::field_type::value_type>& challenges)
{
typename FRI::initial_proofs_batch proof(fri_params.lambda);
typename FRI::initial_proofs_batch_type proof;

// If we have DFS polynomials, and we are going to resize them, better convert them to coefficients form,
// and compute their values in those 2 * FRI::lambda points each, which is normally 2 * 20.
Expand Down Expand Up @@ -1066,12 +1094,12 @@ namespace nil {
const std::vector<PolynomialType> &fs,
const math::polynomial<typename FRI::field_type::value_type> &final_polynomial)
{
typename FRI::initial_proofs_batch initial_proofs =
query_phase_initial_proofs_with_challenges<FRI, PolynomialType>(
typename FRI::initial_proofs_batch_type initial_proofs =
query_phase_initial_proofs<FRI, PolynomialType>(
precommitments, fri_params, g, challenges);

typename FRI::round_proofs_batch round_proofs =
query_phase_round_proofs_with_challenges<FRI, PolynomialType>(
query_phase_round_proofs<FRI, PolynomialType>(
fri_params, fri_trees, fs, final_polynomial, challenges);

// Join intial proofs and round proofs into a structure of query proofs.
Expand All @@ -1096,11 +1124,9 @@ namespace nil {
const math::polynomial<typename FRI::field_type::value_type> &final_polynomial)
{
PROFILE_SCOPE("Basic FRI query phase");
std::vector<typename FRI::field_type::value_type> challenges;
for (std::size_t query_id = 0; query_id < fri_params.lambda; query_id++) {
typename FRI::field_type::value_type x = transcript.template challenge<typename FRI::field_type>();
challenges.push_back(x);
}
std::vector<typename FRI::field_type::value_type> challenges =
transcript.template challenge<typename FRI::field_type>(fri_params.lambda);

return query_phase_with_challenges<FRI, PolynomialType>(
precommitments, fri_params, challenges, g, fri_trees, fs, final_polynomial);
}
Expand Down Expand Up @@ -1133,9 +1159,12 @@ namespace nil {
std::vector<typename FRI::precommitment_type> fri_trees;
std::vector<typename FRI::commitment_type> fri_roots;
std::vector<PolynomialType> fs;
math::polynomial<typename FRI::field_type::value_type> final_polynomial;
math::polynomial<typename FRI::field_type::value_type> final_polynomial;

// Contains fri_roots and final_polynomial.
typename FRI::commitments_part_of_proof commitments_proof;

std::tie(fs, fri_trees, fri_roots, final_polynomial) =
std::tie(fs, fri_trees, commitments_proof) =
commit_phase<FRI, PolynomialType>(
combined_Q,
combined_Q_precommitment,
Expand All @@ -1150,10 +1179,10 @@ namespace nil {
// Query phase
proof.query_proofs = query_phase<FRI, PolynomialType>(
precommitments, fri_params, transcript,
g, fri_trees, fs, final_polynomial);
g, fri_trees, fs, commitments_proof.final_polynomial);

proof.fri_roots = std::move(fri_roots);
proof.final_polynomial = std::move(final_polynomial);
proof.fri_roots = std::move(commitments_proof.fri_roots);
proof.final_polynomial = std::move(commitments_proof.final_polynomial);

return proof;
}
Expand Down
Loading

0 comments on commit 4d7140a

Please sign in to comment.