1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17
// This Source Code Form is subject to the terms of the Mozilla Public // License, v. 2.0. If a copy of the MPL was not distributed with this // file, You can obtain one at http://mozilla.org/MPL/2.0/. // // Copyright (c) DUSK NETWORK. All rights reserved. //! Ideally we should cleanly abstract away the polynomial commitment scheme //! We note that PLONK makes use of the linearisation technique //! conceived in SONIC [Mary Maller]. This technique implicitly requires the //! commitment scheme to be homomorphic. `Merkle Tree like` techniques such as FRI are not homomorphic //! and therefore for PLONK to be usable with all commitment schemes without modification, one would need to remove the lineariser // XXX: This empty trait is left here so that Rust docs does not complain that we are documenting nothing. It is also a reminder that we ideally should find a good abstraction. trait CommitmentScheme { type Proof; } pub mod kzg10;