You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

62 lines
1.8 KiB

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
}