|
|
package r1csqapFloat
import ( "fmt" "math/big" "testing"
"github.com/stretchr/testify/assert" )
func TestTranspose(t *testing.T) { b0 := big.NewFloat(float64(0)) b1 := big.NewFloat(float64(1)) bFive := big.NewFloat(float64(5)) a := [][]*big.Float{ []*big.Float{b0, b1, b0, b0, b0, b0}, []*big.Float{b0, b0, b0, b1, b0, b0}, []*big.Float{b0, b1, b0, b0, b1, b0}, []*big.Float{bFive, b0, b0, b0, b0, b1}, } aT := Transpose(a) assert.Equal(t, aT, [][]*big.Float{ []*big.Float{b0, b0, b0, bFive}, []*big.Float{b1, b0, b1, b0}, []*big.Float{b0, b0, b0, b0}, []*big.Float{b0, b1, b0, b0}, []*big.Float{b0, b0, b1, b0}, []*big.Float{b0, b0, b0, b1}, }) }
func TestPol(t *testing.T) { b0 := big.NewFloat(float64(0)) b1 := big.NewFloat(float64(1)) // b1neg := big.NewFloat(float64(-1))
// b2 := big.NewFloat(float64(2))
b2neg := big.NewFloat(float64(-2)) b3 := big.NewFloat(float64(3)) b4 := big.NewFloat(float64(4)) b5 := big.NewFloat(float64(5)) b6 := big.NewFloat(float64(6)) b16 := big.NewFloat(float64(16))
a := []*big.Float{b1, b0, b5} b := []*big.Float{b3, b0, b1}
// polynomial multiplication
c := PolMul(a, b) assert.Equal(t, c, []*big.Float{b3, b0, b16, b0, b5})
// polynomial addition
c = PolAdd(a, b) assert.Equal(t, c, []*big.Float{b4, b0, b6})
// polynomial subtraction
c = PolSub(a, b) assert.Equal(t, c, []*big.Float{b2neg, b0, b4})
// FloatPow
p := FloatPow(big.NewFloat(float64(5)), 3) assert.Equal(t, p, big.NewFloat(float64(125))) p = FloatPow(big.NewFloat(float64(5)), 0) assert.Equal(t, p, big.NewFloat(float64(1)))
// NewPolZeroAt
r := NewPolZeroAt(3, 4, b4) assert.Equal(t, PolEval(r, big.NewFloat(3)), b4) r = NewPolZeroAt(2, 4, b3) assert.Equal(t, PolEval(r, big.NewFloat(2)), b3) }
func TestLagrangeInterpolation(t *testing.T) { b0 := big.NewFloat(float64(0)) b5 := big.NewFloat(float64(5)) a := []*big.Float{b0, b0, b0, b5} alpha := LagrangeInterpolation(a)
assert.Equal(t, PolEval(alpha, big.NewFloat(4)), b5) aux, _ := PolEval(alpha, big.NewFloat(3)).Int64() assert.Equal(t, aux, int64(0))
}
func TestR1CSToQAP(t *testing.T) { b0 := big.NewFloat(float64(0)) b1 := big.NewFloat(float64(1)) b3 := big.NewFloat(float64(3)) b5 := big.NewFloat(float64(5)) b9 := big.NewFloat(float64(9)) b27 := big.NewFloat(float64(27)) b30 := big.NewFloat(float64(30)) b35 := big.NewFloat(float64(35)) a := [][]*big.Float{ []*big.Float{b0, b1, b0, b0, b0, b0}, []*big.Float{b0, b0, b0, b1, b0, b0}, []*big.Float{b0, b1, b0, b0, b1, b0}, []*big.Float{b5, b0, b0, b0, b0, b1}, } b := [][]*big.Float{ []*big.Float{b0, b1, b0, b0, b0, b0}, []*big.Float{b0, b1, b0, b0, b0, b0}, []*big.Float{b1, b0, b0, b0, b0, b0}, []*big.Float{b1, b0, b0, b0, b0, b0}, } c := [][]*big.Float{ []*big.Float{b0, b0, b0, b1, b0, b0}, []*big.Float{b0, b0, b0, b0, b1, b0}, []*big.Float{b0, b0, b0, b0, b0, b1}, []*big.Float{b0, b0, b1, b0, b0, b0}, } // alphas, betas, gammas
alphas, betas, gammas, zx := R1CSToQAP(a, b, c) fmt.Println(alphas) fmt.Println(betas) fmt.Println(gammas) fmt.Print("Z(x): ") fmt.Println(zx) zexpected := []*big.Float{big.NewFloat(float64(24)), big.NewFloat(float64(-50)), big.NewFloat(float64(35)), big.NewFloat(float64(-10)), big.NewFloat(float64(1))} assert.Equal(t, zx, zexpected)
// witness
w := []*big.Float{b1, b3, b35, b9, b27, b30} fmt.Print("w: ") fmt.Println(w) // QAP A(x), B(x), C(x)
ax, bx, cx, px := CombinePolynomials(w, alphas, betas, gammas) fmt.Print("A(x), B(x), C(x), P(x): ") fmt.Println(ax) fmt.Println(bx) fmt.Println(cx) fmt.Println(px)
hx := DivisorPolinomial(px, zx) fmt.Print("H(x): ") fmt.Println(hx)
}
|