39 lines
1.0 KiB
Go
39 lines
1.0 KiB
Go
|
package bn256
|
||
|
|
||
|
import (
|
||
|
"github.com/consensys/gnark-crypto/ecc/bn254"
|
||
|
)
|
||
|
|
||
|
// G2 is the affine representation of a G2 group element.
|
||
|
//
|
||
|
// Since this code is used for precompiles, using Jacobian
|
||
|
// points are not beneficial because there are no intermediate
|
||
|
// points and G2 in particular is only used for the pairing input.
|
||
|
//
|
||
|
// Note: We also use this struct so that we can conform to the existing API
|
||
|
// that the precompiles want.
|
||
|
type G2 struct {
|
||
|
inner bn254.G2Affine
|
||
|
}
|
||
|
|
||
|
// Unmarshal deserializes `buf` into `g`
|
||
|
//
|
||
|
// Note: whether the deserialization is of a compressed
|
||
|
// or an uncompressed point, is encoded in the bytes.
|
||
|
//
|
||
|
// For our purpose, the point will always be serialized
|
||
|
// as uncompressed, ie 128 bytes.
|
||
|
//
|
||
|
// This method also checks whether the point is on the
|
||
|
// curve and in the prime order subgroup.
|
||
|
func (g *G2) Unmarshal(buf []byte) (int, error) {
|
||
|
return g.inner.SetBytes(buf)
|
||
|
}
|
||
|
|
||
|
// Marshal serializes the point into a byte slice.
|
||
|
//
|
||
|
// Note: The point is serialized as uncompressed.
|
||
|
func (g *G2) Marshal() []byte {
|
||
|
return g.inner.Marshal()
|
||
|
}
|