Documentation ¶
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func ChallengeNames ¶
func ProofSize ¶
ProofSize computes how large the proof for a circuit would be. It needs nbUniqueOutputs to be set
func Verify ¶
func Verify(c Circuit, assignment WireAssignment, proof Proof, transcriptSettings fiatshamir.Settings, options ...Option) error
Verify the consistency of the claimed output with the claimed input Unlike in Prove, the assignment argument need not be complete
Types ¶
type Circuit ¶
type Circuit []Wire
func (Circuit) MemoryRequirements ¶ added in v0.9.1
MemoryRequirements returns an increasing vector of memory allocation sizes required for proving a GKR statement
type Gate ¶
type Gate interface { Evaluate(...small_rational.SmallRational) small_rational.SmallRational Degree() int }
Gate must be a low-degree polynomial
type IdentityGate ¶
type IdentityGate struct{}
func (IdentityGate) Degree ¶
func (IdentityGate) Degree() int
func (IdentityGate) Evaluate ¶
func (IdentityGate) Evaluate(input ...small_rational.SmallRational) small_rational.SmallRational
type Option ¶
type Option func(*settings)
func WithPool ¶
func WithPool(pool *polynomial.Pool) Option
func WithSortedCircuit ¶
func WithWorkers ¶ added in v0.9.1
func WithWorkers(workers *utils.WorkerPool) Option
type Proof ¶
type Proof []sumcheck.Proof // for each layer, for each wire, a sumcheck (for each variable, a polynomial)
func Prove ¶
func Prove(c Circuit, assignment WireAssignment, transcriptSettings fiatshamir.Settings, options ...Option) (Proof, error)
Prove consistency of the claimed assignment
func (Proof) SerializeToBigInts ¶ added in v0.9.1
SerializeToBigInts flattens a proof object into the given slice of big.Ints useful in gnark hints. TODO: Change propagation: Once this is merged, it will duplicate some code in std/gkr/bn254Prover.go. Remove that in favor of this
type Wire ¶
type Wire struct { Gate Gate Inputs []*Wire // if there are no Inputs, the wire is assumed an input wire // contains filtered or unexported fields }
func TopologicalSort ¶
TopologicalSort sorts the wires in order of dependence. Such that for any wire, any one it depends on occurs before it. It tries to stick to the input order as much as possible. An already sorted list will remain unchanged. It also sets the nbOutput flags, and a dummy IdentityGate for input wires. Worst-case inefficient O(n^2), but that probably won't matter since the circuits are small. Furthermore, it is efficient with already-close-to-sorted lists, which are the expected input
type WireAssignment ¶
type WireAssignment map[*Wire]polynomial.MultiLin
WireAssignment is assignment of values to the same wire across many instances of the circuit
func (WireAssignment) Complete ¶
func (a WireAssignment) Complete(c Circuit) WireAssignment
Complete the circuit evaluation from input values
func (WireAssignment) NumInstances ¶
func (a WireAssignment) NumInstances() int
func (WireAssignment) NumVars ¶
func (a WireAssignment) NumVars() int