package plonky2_verifier import ( "fmt" . "gnark-plonky2-verifier/field" ) // Ideally, this should be serialized in the plonky2 repo const d = 2 type ArithmeticExtensionGate struct { numOps uint64 } func NewArithmeticExtensionGate(numOps uint64) *ArithmeticExtensionGate { return &ArithmeticExtensionGate{ numOps: numOps, } } func (g *ArithmeticExtensionGate) Id() string { return fmt.Sprintf("ArithmeticExtensionGate { num_ops: %d }", g.numOps) } func (g *ArithmeticExtensionGate) wiresIthMultiplicand0(i uint64) Range { return Range{4 * d * i, 4*d*i + d} } func (g *ArithmeticExtensionGate) wiresIthMultiplicand1(i uint64) Range { return Range{4*d*i + d, 4*d*i + 2*d} } func (g *ArithmeticExtensionGate) wiresIthAddend(i uint64) Range { return Range{4*d*i + 2*d, 4*d*i + 3*d} } func (g *ArithmeticExtensionGate) wiresIthOutput(i uint64) Range { return Range{4*d*i + 3*d, 4*d*i + 4*d} } func (g *ArithmeticExtensionGate) EvalUnfiltered(p *PlonkChip, vars EvaluationVars) []QuadraticExtension { const0 := vars.localConstants[0] const1 := vars.localConstants[1] constraints := []QuadraticExtension{} for i := uint64(0); i < g.numOps; i++ { multiplicand0 := vars.GetLocalExtAlgebra(g.wiresIthMultiplicand0(i)) multiplicand1 := vars.GetLocalExtAlgebra(g.wiresIthMultiplicand1(i)) addend := vars.GetLocalExtAlgebra(g.wiresIthAddend(i)) output := vars.GetLocalExtAlgebra(g.wiresIthOutput(i)) mul := p.qeAPI.MulExtensionAlgebra(multiplicand0, multiplicand1) scaled_mul := p.qeAPI.ScalarMulExtensionAlgebra(const0, mul) computed_output := p.qeAPI.ScalarMulExtensionAlgebra(const1, addend) computed_output = p.qeAPI.AddExtensionAlgebra(computed_output, scaled_mul) diff := p.qeAPI.SubExtensionAlgebra(output, computed_output) constraints = append(constraints, diff[0], diff[1]) } return constraints }