-
Notifications
You must be signed in to change notification settings - Fork 8
/
Copy pathQGroup.h
executable file
·48 lines (37 loc) · 1.3 KB
/
QGroup.h
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
#ifndef _QGroup
#define _QGroup
/* This class holds the data needed to represent
Gal/G_2
where G_2 is the decomposition group at 2 and Gal=(Z/mZ)^*
We hold it as a set of generators g[i] and orders d[i]
The group is created using a Hafner-McCurley style
generator/relation algorithm, then we apply the SNF.
The key thing is that we impose the relation 2=1 so
as to get the quotient group above
*/
#include <iostream>
#include <vector>
using namespace std;
class QGroup
{
int m; // the integer m defines the group (Z/mZ)^*/<2>
vector<int> g; // g is an array of generators
vector<int> d; /* d is an array of group orders, such that
* (Z/mZ)^* = C_d0 \times C_d1 \times ...
* and gi generates an order-di group
*******************************************/
int ngen; // the number of generators
int Gord;
mutable vector<int> elems;
public:
void assign(int mm,int seed); // initialize this instance for m=mm
QGroup() { ; }
~QGroup() { ; }
int num_gen() const { return ngen; }
int gen(int i) const { return g[i]; }
int gord(int i) const { return d[i]; }
int order() const { return Gord; }
// For 0 <= n < ord returns the nth element
int nth_element(int n) const;
};
#endif