Wire Sysio Wire Sysion 1.0.0
Loading...
Searching...
No Matches
mnt6_g2.hpp
Go to the documentation of this file.
1
12#ifndef MNT6_G2_HPP_
13#define MNT6_G2_HPP_
14
15#include <vector>
16
19
20namespace libff {
21
22class mnt6_G2;
23std::ostream& operator<<(std::ostream &, const mnt6_G2&);
24std::istream& operator>>(std::istream &, mnt6_G2&);
25
26class mnt6_G2 {
27public:
28#ifdef PROFILE_OP_COUNTS
29 static long long add_cnt;
30 static long long dbl_cnt;
31#endif
32 static std::vector<size_t> wnaf_window_table;
33 static std::vector<size_t> fixed_base_exp_window_table;
36 static bool initialized;
40
44
46
47 // using projective coordinates
48 mnt6_G2();
49 mnt6_G2(const mnt6_Fq3& X, const mnt6_Fq3& Y, const mnt6_Fq3& Z) : X(X), Y(Y), Z(Z) {}
50
51 static mnt6_Fq3 mul_by_a(const mnt6_Fq3 &elt);
52 static mnt6_Fq3 mul_by_b(const mnt6_Fq3 &elt);
53
54 void print() const;
55 void print_coordinates() const;
56
58 void to_special();
59 bool is_special() const;
60
61 bool is_zero() const;
62
63 bool operator==(const mnt6_G2 &other) const;
64 bool operator!=(const mnt6_G2 &other) const;
65
66 mnt6_G2 operator+(const mnt6_G2 &other) const;
67 mnt6_G2 operator-() const;
68 mnt6_G2 operator-(const mnt6_G2 &other) const;
69
70 mnt6_G2 add(const mnt6_G2 &other) const;
71 mnt6_G2 mixed_add(const mnt6_G2 &other) const;
72 mnt6_G2 dbl() const;
73 mnt6_G2 mul_by_q() const;
74
75 bool is_well_formed() const;
76
77 static mnt6_G2 zero();
78 static mnt6_G2 one();
79 static mnt6_G2 random_element();
80
81 static size_t size_in_bits() { return twist_field::size_in_bits() + 1; }
84
85 friend std::ostream& operator<<(std::ostream &out, const mnt6_G2 &g);
86 friend std::istream& operator>>(std::istream &in, mnt6_G2 &g);
87
88 static void batch_to_special_all_non_zeros(std::vector<mnt6_G2> &vec);
89};
90
91template<mp_size_t m>
92mnt6_G2 operator*(const bigint<m> &lhs, const mnt6_G2 &rhs)
93{
94 return scalar_mul<mnt6_G2, m>(rhs, lhs);
95}
96
97template<mp_size_t m, const bigint<m>& modulus_p>
99{
100 return scalar_mul<mnt6_G2, m>(rhs, lhs.as_bigint());
101}
102
103} // libff
104
105#endif // MNT6_G2_HPP_
bigint< n > as_bigint() const
void to_special()
Definition mnt6_g2.cpp:110
static std::vector< size_t > wnaf_window_table
Definition mnt6_g2.hpp:32
mnt6_Fq3 Z
Definition mnt6_g2.hpp:45
static bigint< scalar_field::num_limbs > order()
Definition mnt6_g2.hpp:83
mnt6_G2(const mnt6_Fq3 &X, const mnt6_Fq3 &Y, const mnt6_Fq3 &Z)
Definition mnt6_g2.hpp:49
mnt6_G2 operator+(const mnt6_G2 &other) const
Definition mnt6_g2.cpp:160
static void batch_to_special_all_non_zeros(std::vector< mnt6_G2 > &vec)
Definition mnt6_g2.cpp:487
static bool initialized
Definition mnt6_g2.hpp:36
mnt6_G2 operator-() const
Definition mnt6_g2.cpp:235
mnt6_G2 add(const mnt6_G2 &other) const
Definition mnt6_g2.cpp:246
bool is_zero() const
Definition mnt6_g2.cpp:120
friend std::ostream & operator<<(std::ostream &out, const mnt6_G2 &g)
Definition mnt6_g2.cpp:424
bool is_well_formed() const
Definition mnt6_g2.cpp:381
static mnt6_Fq3 mul_by_b(const mnt6_Fq3 &elt)
Definition mnt6_g2.cpp:47
mnt6_Fq3 X
Definition mnt6_g2.hpp:45
mnt6_Fr scalar_field
Definition mnt6_g2.hpp:43
static mnt6_G2 random_element()
Definition mnt6_g2.cpp:419
bool is_special() const
Definition mnt6_g2.cpp:115
mnt6_Fq base_field
Definition mnt6_g2.hpp:41
static mnt6_G2 G2_one
Definition mnt6_g2.hpp:35
mnt6_G2 dbl() const
Definition mnt6_g2.cpp:341
static mnt6_Fq3 twist
Definition mnt6_g2.hpp:37
static mnt6_G2 G2_zero
Definition mnt6_g2.hpp:34
bool operator==(const mnt6_G2 &other) const
Definition mnt6_g2.cpp:126
static size_t size_in_bits()
Definition mnt6_g2.hpp:81
friend std::istream & operator>>(std::istream &in, mnt6_G2 &g)
Definition mnt6_g2.cpp:440
mnt6_G2 mixed_add(const mnt6_G2 &other) const
Definition mnt6_g2.cpp:291
static mnt6_Fq3 mul_by_a(const mnt6_Fq3 &elt)
Definition mnt6_g2.cpp:42
void print() const
Definition mnt6_g2.cpp:52
static mnt6_G2 one()
Definition mnt6_g2.cpp:414
mnt6_G2 mul_by_q() const
Definition mnt6_g2.cpp:374
mnt6_Fq3 Y
Definition mnt6_g2.hpp:45
static mnt6_G2 zero()
Definition mnt6_g2.cpp:409
static mnt6_Fq3 coeff_a
Definition mnt6_g2.hpp:38
mnt6_Fq3 twist_field
Definition mnt6_g2.hpp:42
static mnt6_Fq3 coeff_b
Definition mnt6_g2.hpp:39
bool operator!=(const mnt6_G2 &other) const
Definition mnt6_g2.cpp:155
static bigint< base_field::num_limbs > base_field_char()
Definition mnt6_g2.hpp:82
void to_affine_coordinates()
Definition mnt6_g2.cpp:93
void print_coordinates() const
Definition mnt6_g2.cpp:72
static std::vector< size_t > fixed_base_exp_window_table
Definition mnt6_g2.hpp:33
std::istream & operator>>(std::istream &in, alt_bn128_G1 &g)
GroupT scalar_mul(const GroupT &base, const bigint< m > &scalar)
std::ostream & operator<<(std::ostream &out, const alt_bn128_G1 &g)
alt_bn128_G1 operator*(const bigint< m > &lhs, const alt_bn128_G1 &rhs)
Definition lib.h:43