math

package
v0.4.4 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: Mar 22, 2022 License: AGPL-3.0 Imports: 10 Imported by: 0

Documentation

Index

Constants

This section is empty.

Variables

This section is empty.

Functions

func EvalsCircuitR1CS added in v0.4.0

func EvalsCircuitR1CS(hashSeed string, numVoters int, numCandidates int) (frontend.CompiledConstraintSystem, error)

func HashSeedFromSeedParts added in v0.4.0

func HashSeedFromSeedParts(seedParts [][]byte) string

func LagrangeEvalAtZero added in v0.4.0

func LagrangeEvalAtZero(points []Point) *fr.Element

uses https://en.wikipedia.org/wiki/Lagrange_polynomial#Definition but returns the evaluation at zero (the only one we care about)

func SumCircuitR1CS added in v0.4.0

func SumCircuitR1CS(hashSeed string, numVoters int) (frontend.CompiledConstraintSystem, error)

Types

type EvalsCircuit added in v0.4.0

type EvalsCircuit struct {
	HashSeed     string
	Inputs       []frontend.Variable `gnark:",public"`
	OutputHashes []frontend.Variable `gnark:",public"`

	// must be created with length numCandidates^2
	BallotBits []frontend.Variable `gnark:",secret"`
	// must be created with length numVoters - 1
	Coeffs   []frontend.Variable `gnark:",secret"`
	Constant frontend.Variable   `gnark:",secret"`
}

func (*EvalsCircuit) Define added in v0.4.0

func (circuit *EvalsCircuit) Define(curveID ecc.ID, api frontend.API) error

type Point added in v0.4.0

type Point [2]*fr.Element

p[0] is x coordinate, p[1] is y coordinate

type Poly

type Poly struct {
	Ballot   [][]byte      `json:"ballot"`
	Coeffs   []*fr.Element `json:"coeffs"`
	HashSeed string        `json:"hash_seed"`
	Inputs   []*fr.Element `json:"inputs"`
	// contains filtered or unexported fields
}

func NewRandomPoly

func NewRandomPoly(ballot [][]byte, hashSeed string, inputs []*fr.Element) *Poly

NewRandomPoly generates a random polynomial of degree numVoters-1, using `ballot' as the constant term

func (*Poly) EvalAndProve added in v0.4.0

func (p *Poly) EvalAndProve(input *fr.Element, provingKey groth16.ProvingKey) (*fr.Element, []byte, groth16.Proof)

type SumCircuit added in v0.4.0

type SumCircuit struct {
	HashSeed     string
	HashSelects  []frontend.Variable `gnark:",public"`
	OutputHashes []frontend.Variable `gnark:",public"`
	Sum          frontend.Variable   `gnark:",public"`

	Outputs []frontend.Variable `gnark:",secret"`
}

func (*SumCircuit) Define added in v0.4.0

func (circuit *SumCircuit) Define(curveID ecc.ID, api frontend.API) error

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL