1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
use crate::{
bls12_377::{
g1::Bls12_377G1Parameters,
g2::Bls12_377G2Parameters,
Fq,
Fq12,
Fq12Parameters,
Fq2Parameters,
Fq6Parameters,
},
templates::bls12::{
Bls12,
Bls12Parameters,
G1Affine as Bls12G1Affine,
G1Prepared,
G1Projective as Bls12G1Projective,
G2Affine as Bls12G2Affine,
G2Prepared,
G2Projective as Bls12G2Projective,
TwistType,
},
traits::{PairingCurve, PairingEngine},
};
#[derive(Copy, Clone, Debug, PartialEq, Eq, Hash)]
pub struct Bls12_377Parameters;
impl Bls12Parameters for Bls12_377Parameters {
type Fp = Fq;
type Fp12Params = Fq12Parameters;
type Fp2Params = Fq2Parameters;
type Fp6Params = Fq6Parameters;
type G1Parameters = Bls12_377G1Parameters;
type G2Parameters = Bls12_377G2Parameters;
const TWIST_TYPE: TwistType = TwistType::D;
const X: &'static [u64] = &[0x8508c00000000001];
const X_IS_NEGATIVE: bool = false;
}
pub type Bls12_377 = Bls12<Bls12_377Parameters>;
pub type G1Affine = Bls12G1Affine<Bls12_377Parameters>;
pub type G1Projective = Bls12G1Projective<Bls12_377Parameters>;
impl PairingCurve for G1Affine {
type Engine = Bls12_377;
type PairWith = G2Affine;
type PairingResult = Fq12;
type Prepared = G1Prepared<Bls12_377Parameters>;
fn prepare(&self) -> Self::Prepared {
Self::Prepared::from_affine(*self)
}
fn pairing_with(&self, other: &Self::PairWith) -> Self::PairingResult {
Bls12_377::pairing(*self, *other)
}
}
pub type G2Affine = Bls12G2Affine<Bls12_377Parameters>;
pub type G2Projective = Bls12G2Projective<Bls12_377Parameters>;
impl PairingCurve for G2Affine {
type Engine = Bls12_377;
type PairWith = G1Affine;
type PairingResult = Fq12;
type Prepared = G2Prepared<Bls12_377Parameters>;
fn prepare(&self) -> Self::Prepared {
Self::Prepared::from_affine(*self)
}
fn pairing_with(&self, other: &Self::PairWith) -> Self::PairingResult {
Bls12_377::pairing(*other, *self)
}
}