{-# LANGUAGE UndecidableInstances #-}
{-# OPTIONS_GHC -Wno-orphans #-}
module ZkFold.Base.Protocol.Plonkup (
module ZkFold.Base.Protocol.Plonkup.Internal,
Plonkup (..)
) where
import Data.Functor.Rep (Rep, Representable)
import Data.Word (Word8)
import Prelude hiding (Num (..), div, drop, length, replicate,
sum, take, (!!), (/), (^))
import qualified Prelude as P hiding (length)
import ZkFold.Base.Algebra.Basic.Class
import ZkFold.Base.Algebra.Basic.Number
import ZkFold.Base.Algebra.EllipticCurve.Class (CompressedPoint, EllipticCurve (..), Pairing (..))
import ZkFold.Base.Protocol.NonInteractiveProof
import ZkFold.Base.Protocol.Plonkup.Input
import ZkFold.Base.Protocol.Plonkup.Internal
import ZkFold.Base.Protocol.Plonkup.Proof
import ZkFold.Base.Protocol.Plonkup.Prover
import ZkFold.Base.Protocol.Plonkup.Setup
import ZkFold.Base.Protocol.Plonkup.Verifier
import ZkFold.Base.Protocol.Plonkup.Witness
import ZkFold.Symbolic.Compiler.ArithmeticCircuit.Internal
import qualified ZkFold.Symbolic.Data.Ord as Sym
instance forall p i n l c1 c2 ts core.
( KnownNat n
, Representable p
, Representable i
, Representable l
, Foldable l
, Ord (Rep i)
, Sym.Ord (BooleanOf c1) (BaseField c1)
, AdditiveGroup (BaseField c1)
, Pairing c1 c2
, Arithmetic (ScalarField c1)
, ToTranscript ts Word8
, ToTranscript ts (ScalarField c1)
, ToTranscript ts (CompressedPoint c1)
, FromTranscript ts (ScalarField c1)
, CoreFunction c1 core
) => NonInteractiveProof (Plonkup p i n l c1 c2 ts) core where
type Transcript (Plonkup p i n l c1 c2 ts) = ts
type SetupProve (Plonkup p i n l c1 c2 ts) = PlonkupProverSetup p i n l c1 c2
type SetupVerify (Plonkup p i n l c1 c2 ts) = PlonkupVerifierSetup p i n l c1 c2
type Witness (Plonkup p i n l c1 c2 ts) = (PlonkupWitnessInput p i c1, PlonkupProverSecret c1)
type Input (Plonkup p i n l c1 c2 ts) = PlonkupInput l c1
type Proof (Plonkup p i n l c1 c2 ts) = PlonkupProof c1
setupProve :: Plonkup p i n l c1 c2 ts -> SetupProve (Plonkup p i n l c1 c2 ts)
setupProve :: Plonkup p i n l c1 c2 ts -> SetupProve (Plonkup p i n l c1 c2 ts)
setupProve Plonkup p i n l c1 c2 ts
plonk =
let PlonkupSetup {Vector (Point c1)
PolyVec (ScalarField c1) n
ScalarField c1
Point c2
PlonkupCircuitCommitments c1
PlonkupRelation p i n l (ScalarField c1)
PlonkupCircuitPolynomials n c1
omega :: ScalarField c1
k1 :: ScalarField c1
k2 :: ScalarField c1
gs :: Vector (Point c1)
h0 :: Point c2
h1 :: Point c2
sigma1s :: PolyVec (ScalarField c1) n
sigma2s :: PolyVec (ScalarField c1) n
sigma3s :: PolyVec (ScalarField c1) n
relation :: PlonkupRelation p i n l (ScalarField c1)
polynomials :: PlonkupCircuitPolynomials n c1
commitments :: PlonkupCircuitCommitments c1
omega :: forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2.
PlonkupSetup p i n l c1 c2 -> ScalarField c1
k1 :: forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2.
PlonkupSetup p i n l c1 c2 -> ScalarField c1
k2 :: forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2.
PlonkupSetup p i n l c1 c2 -> ScalarField c1
gs :: forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2.
PlonkupSetup p i n l c1 c2 -> Vector (Point c1)
h0 :: forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2.
PlonkupSetup p i n l c1 c2 -> Point c2
h1 :: forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2.
PlonkupSetup p i n l c1 c2 -> Point c2
sigma1s :: forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2.
PlonkupSetup p i n l c1 c2 -> PolyVec (ScalarField c1) n
sigma2s :: forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2.
PlonkupSetup p i n l c1 c2 -> PolyVec (ScalarField c1) n
sigma3s :: forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2.
PlonkupSetup p i n l c1 c2 -> PolyVec (ScalarField c1) n
relation :: forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2.
PlonkupSetup p i n l c1 c2
-> PlonkupRelation p i n l (ScalarField c1)
polynomials :: forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2.
PlonkupSetup p i n l c1 c2 -> PlonkupCircuitPolynomials n c1
commitments :: forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2.
PlonkupSetup p i n l c1 c2 -> PlonkupCircuitCommitments c1
..} = forall {k1} {k} (i :: Type -> Type) (p :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2 (ts :: k1) (core :: k).
(KnownNat n, Representable p, Representable i, Representable l,
Foldable l, Ord (Rep i), Arithmetic (ScalarField c1),
Pairing c1 c2, CoreFunction c1 core) =>
Plonkup p i n l c1 c2 ts -> PlonkupSetup p i n l c1 c2
forall (i :: Type -> Type) (p :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2 ts (core :: k).
(KnownNat n, Representable p, Representable i, Representable l,
Foldable l, Ord (Rep i), Arithmetic (ScalarField c1),
Pairing c1 c2, CoreFunction c1 core) =>
Plonkup p i n l c1 c2 ts -> PlonkupSetup p i n l c1 c2
plonkupSetup @_ @_ @_ @_ @c1 @_ @_ @core Plonkup p i n l c1 c2 ts
plonk
in PlonkupProverSetup {Vector (Point c1)
PolyVec (ScalarField c1) n
ScalarField c1
PlonkupRelation p i n l (ScalarField c1)
PlonkupCircuitPolynomials n c1
omega :: ScalarField c1
k1 :: ScalarField c1
k2 :: ScalarField c1
gs :: Vector (Point c1)
sigma1s :: PolyVec (ScalarField c1) n
sigma2s :: PolyVec (ScalarField c1) n
sigma3s :: PolyVec (ScalarField c1) n
relation :: PlonkupRelation p i n l (ScalarField c1)
polynomials :: PlonkupCircuitPolynomials n c1
omega :: ScalarField c1
k1 :: ScalarField c1
k2 :: ScalarField c1
gs :: Vector (Point c1)
sigma1s :: PolyVec (ScalarField c1) n
sigma2s :: PolyVec (ScalarField c1) n
sigma3s :: PolyVec (ScalarField c1) n
relation :: PlonkupRelation p i n l (ScalarField c1)
polynomials :: PlonkupCircuitPolynomials n c1
..}
setupVerify :: Plonkup p i n l c1 c2 ts -> SetupVerify (Plonkup p i n l c1 c2 ts)
setupVerify :: Plonkup p i n l c1 c2 ts -> SetupVerify (Plonkup p i n l c1 c2 ts)
setupVerify Plonkup p i n l c1 c2 ts
plonk =
let PlonkupSetup {Vector (Point c1)
PolyVec (ScalarField c1) n
ScalarField c1
Point c2
PlonkupCircuitCommitments c1
PlonkupRelation p i n l (ScalarField c1)
PlonkupCircuitPolynomials n c1
omega :: forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2.
PlonkupSetup p i n l c1 c2 -> ScalarField c1
k1 :: forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2.
PlonkupSetup p i n l c1 c2 -> ScalarField c1
k2 :: forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2.
PlonkupSetup p i n l c1 c2 -> ScalarField c1
gs :: forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2.
PlonkupSetup p i n l c1 c2 -> Vector (Point c1)
h0 :: forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2.
PlonkupSetup p i n l c1 c2 -> Point c2
h1 :: forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2.
PlonkupSetup p i n l c1 c2 -> Point c2
sigma1s :: forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2.
PlonkupSetup p i n l c1 c2 -> PolyVec (ScalarField c1) n
sigma2s :: forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2.
PlonkupSetup p i n l c1 c2 -> PolyVec (ScalarField c1) n
sigma3s :: forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2.
PlonkupSetup p i n l c1 c2 -> PolyVec (ScalarField c1) n
relation :: forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2.
PlonkupSetup p i n l c1 c2
-> PlonkupRelation p i n l (ScalarField c1)
polynomials :: forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2.
PlonkupSetup p i n l c1 c2 -> PlonkupCircuitPolynomials n c1
commitments :: forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2.
PlonkupSetup p i n l c1 c2 -> PlonkupCircuitCommitments c1
omega :: ScalarField c1
k1 :: ScalarField c1
k2 :: ScalarField c1
gs :: Vector (Point c1)
h0 :: Point c2
h1 :: Point c2
sigma1s :: PolyVec (ScalarField c1) n
sigma2s :: PolyVec (ScalarField c1) n
sigma3s :: PolyVec (ScalarField c1) n
relation :: PlonkupRelation p i n l (ScalarField c1)
polynomials :: PlonkupCircuitPolynomials n c1
commitments :: PlonkupCircuitCommitments c1
..} = forall {k1} {k} (i :: Type -> Type) (p :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2 (ts :: k1) (core :: k).
(KnownNat n, Representable p, Representable i, Representable l,
Foldable l, Ord (Rep i), Arithmetic (ScalarField c1),
Pairing c1 c2, CoreFunction c1 core) =>
Plonkup p i n l c1 c2 ts -> PlonkupSetup p i n l c1 c2
forall (i :: Type -> Type) (p :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2 ts (core :: k).
(KnownNat n, Representable p, Representable i, Representable l,
Foldable l, Ord (Rep i), Arithmetic (ScalarField c1),
Pairing c1 c2, CoreFunction c1 core) =>
Plonkup p i n l c1 c2 ts -> PlonkupSetup p i n l c1 c2
plonkupSetup @_ @_ @_ @_ @c1 @_ @_ @core Plonkup p i n l c1 c2 ts
plonk
in PlonkupVerifierSetup {PolyVec (ScalarField c1) n
ScalarField c1
Point c2
PlonkupCircuitCommitments c1
PlonkupRelation p i n l (ScalarField c1)
omega :: ScalarField c1
k1 :: ScalarField c1
k2 :: ScalarField c1
h1 :: Point c2
sigma1s :: PolyVec (ScalarField c1) n
sigma2s :: PolyVec (ScalarField c1) n
sigma3s :: PolyVec (ScalarField c1) n
relation :: PlonkupRelation p i n l (ScalarField c1)
commitments :: PlonkupCircuitCommitments c1
omega :: ScalarField c1
k1 :: ScalarField c1
k2 :: ScalarField c1
h1 :: Point c2
sigma1s :: PolyVec (ScalarField c1) n
sigma2s :: PolyVec (ScalarField c1) n
sigma3s :: PolyVec (ScalarField c1) n
relation :: PlonkupRelation p i n l (ScalarField c1)
commitments :: PlonkupCircuitCommitments c1
..}
prove :: SetupProve (Plonkup p i n l c1 c2 ts) -> Witness (Plonkup p i n l c1 c2 ts) -> (Input (Plonkup p i n l c1 c2 ts), Proof (Plonkup p i n l c1 c2 ts))
prove :: SetupProve (Plonkup p i n l c1 c2 ts)
-> Witness (Plonkup p i n l c1 c2 ts)
-> (Input (Plonkup p i n l c1 c2 ts),
Proof (Plonkup p i n l c1 c2 ts))
prove SetupProve (Plonkup p i n l c1 c2 ts)
setup Witness (Plonkup p i n l c1 c2 ts)
witness =
let (PlonkupInput l c1
input, PlonkupProof c1
proof, PlonkupProverTestInfo n c1
_) = forall (n :: Nat) {r}.
KnownNat n =>
(KnownNat ((4 * n) + 6) => r) -> r
with4n6 @n (forall {k1} {k2} (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 (c2 :: k1) ts (core :: k2).
(KnownNat n, KnownNat (PlonkupPolyExtendedLength n), Foldable l,
Ord (BooleanOf c1) (BaseField c1), AdditiveGroup (BaseField c1),
Arithmetic (ScalarField c1), ToTranscript ts Word8,
ToTranscript ts (ScalarField c1),
ToTranscript ts (CompressedPoint c1),
FromTranscript ts (ScalarField c1), CoreFunction c1 core) =>
PlonkupProverSetup p i n l c1 c2
-> (PlonkupWitnessInput p i c1, PlonkupProverSecret c1)
-> (PlonkupInput l c1, PlonkupProof c1, PlonkupProverTestInfo n c1)
forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2 ts (core :: k).
(KnownNat n, KnownNat (PlonkupPolyExtendedLength n), Foldable l,
Ord (BooleanOf c1) (BaseField c1), AdditiveGroup (BaseField c1),
Arithmetic (ScalarField c1), ToTranscript ts Word8,
ToTranscript ts (ScalarField c1),
ToTranscript ts (CompressedPoint c1),
FromTranscript ts (ScalarField c1), CoreFunction c1 core) =>
PlonkupProverSetup p i n l c1 c2
-> (PlonkupWitnessInput p i c1, PlonkupProverSecret c1)
-> (PlonkupInput l c1, PlonkupProof c1, PlonkupProverTestInfo n c1)
plonkupProve @p @i @n @l @c1 @c2 @ts @core PlonkupProverSetup p i n l c1 c2
SetupProve (Plonkup p i n l c1 c2 ts)
setup (PlonkupWitnessInput p i c1, PlonkupProverSecret c1)
Witness (Plonkup p i n l c1 c2 ts)
witness)
in (PlonkupInput l c1
Input (Plonkup p i n l c1 c2 ts)
input, PlonkupProof c1
Proof (Plonkup p i n l c1 c2 ts)
proof)
verify :: SetupVerify (Plonkup p i n l c1 c2 ts) -> Input (Plonkup p i n l c1 c2 ts) -> Proof (Plonkup p i n l c1 c2 ts) -> Bool
verify :: SetupVerify (Plonkup p i n l c1 c2 ts)
-> Input (Plonkup p i n l c1 c2 ts)
-> Proof (Plonkup p i n l c1 c2 ts)
-> Bool
verify = forall (n :: Nat) {r}.
KnownNat n =>
(KnownNat ((4 * n) + 6) => r) -> r
with4n6 @n ((KnownNat ((4 * n) + 6) =>
SetupVerify (Plonkup p i n l c1 c2 ts)
-> Input (Plonkup p i n l c1 c2 ts)
-> Proof (Plonkup p i n l c1 c2 ts)
-> Bool)
-> SetupVerify (Plonkup p i n l c1 c2 ts)
-> Input (Plonkup p i n l c1 c2 ts)
-> Proof (Plonkup p i n l c1 c2 ts)
-> Bool)
-> (KnownNat ((4 * n) + 6) =>
SetupVerify (Plonkup p i n l c1 c2 ts)
-> Input (Plonkup p i n l c1 c2 ts)
-> Proof (Plonkup p i n l c1 c2 ts)
-> Bool)
-> SetupVerify (Plonkup p i n l c1 c2 ts)
-> Input (Plonkup p i n l c1 c2 ts)
-> Proof (Plonkup p i n l c1 c2 ts)
-> Bool
forall a b. (a -> b) -> a -> b
$ forall (p :: Type -> Type) (i :: Type -> Type) (n :: Nat)
(l :: Type -> Type) c1 c2 ts.
(KnownNat n, KnownNat (PlonkupPolyExtendedLength n), Foldable l,
Pairing c1 c2, Ord (BooleanOf c1) (BaseField c1),
AdditiveGroup (BaseField c1), Arithmetic (ScalarField c1),
ToTranscript ts Word8, ToTranscript ts (ScalarField c1),
ToTranscript ts (CompressedPoint c1),
FromTranscript ts (ScalarField c1)) =>
PlonkupVerifierSetup p i n l c1 c2
-> PlonkupInput l c1 -> PlonkupProof c1 -> Bool
plonkupVerify @p @i @n @l @c1 @c2 @ts