aboutsummaryrefslogblamecommitdiffstats
path: root/crypto/bn256/bn256_fast.go
blob: 702521c324a1aad9e94311e022da664655217708 (plain) (tree)
1
2
3
4
5
6
7
8
9


                                                                               
 
                     



                                                                                         
                                                                  


                                                                            
                  


                                                                            
                  


                                                                       
                                       
 
// Copyright 2018 Péter Szilágyi. All rights reserved.
// Use of this source code is governed by a BSD-style license that can be found
// in the LICENSE file.

// +build amd64 arm64

// Package bn256 implements the Optimal Ate pairing over a 256-bit Barreto-Naehrig curve.
package bn256

import "github.com/dexon-foundation/dexon/crypto/bn256/cloudflare"

// G1 is an abstract cyclic group. The zero value is suitable for use as the
// output of an operation, but cannot be used as an input.
type G1 = bn256.G1

// G2 is an abstract cyclic group. The zero value is suitable for use as the
// output of an operation, but cannot be used as an input.
type G2 = bn256.G2

// PairingCheck calculates the Optimal Ate pairing for a set of points.
func PairingCheck(a []*G1, b []*G2) bool {
    return bn256.PairingCheck(a, b)
}