mirror of
https://github.com/allemangD/toddcox-visualize.git
synced 2025-11-10 12:02:47 -05:00
split "cosets" and "solver" data. "solver.cpp" now only for solution logic.
This commit is contained in:
33
include/cosets.h
Normal file
33
include/cosets.h
Normal file
@@ -0,0 +1,33 @@
|
||||
#pragma once
|
||||
|
||||
#include "groups.h"
|
||||
#include <vector>
|
||||
|
||||
struct Cosets {
|
||||
int ngens;
|
||||
std::vector<int> data;
|
||||
int len;
|
||||
|
||||
Cosets(int ngens, const std::vector<int> &data);
|
||||
|
||||
void add_row();
|
||||
|
||||
void put(int coset, int gen, int target);
|
||||
|
||||
void put(int idx, int target);
|
||||
|
||||
[[nodiscard]] int get(int coset, int gen) const;
|
||||
|
||||
[[nodiscard]] int get(int idx) const;
|
||||
};
|
||||
|
||||
struct RelTable {
|
||||
int gens[2]{};
|
||||
int mult;
|
||||
std::vector<int *> lst_ptr;
|
||||
std::vector<int> gen;
|
||||
|
||||
explicit RelTable(tc::Mult m);
|
||||
|
||||
int add_row();
|
||||
};
|
||||
@@ -1,37 +1,7 @@
|
||||
#pragma once
|
||||
|
||||
#include "groups.h"
|
||||
#include <vector>
|
||||
#include "cosets.h"
|
||||
|
||||
namespace tc {
|
||||
struct Cosets {
|
||||
int ngens;
|
||||
std::vector<int> data;
|
||||
int len;
|
||||
|
||||
Cosets(int ngens, const std::vector<int> &data);
|
||||
|
||||
void add_row();
|
||||
|
||||
void put(int coset, int gen, int target);
|
||||
|
||||
void put(int idx, int target);
|
||||
|
||||
[[nodiscard]] int get(int coset, int gen) const;
|
||||
|
||||
[[nodiscard]] int get(int idx) const;
|
||||
};
|
||||
|
||||
struct RelTable {
|
||||
int gens[2]{};
|
||||
int mult;
|
||||
std::vector<int *> lst_ptr;
|
||||
std::vector<int> gen;
|
||||
|
||||
explicit RelTable(Mult m);
|
||||
|
||||
int add_row();
|
||||
};
|
||||
|
||||
Cosets solve(const Group &g, const std::vector<int> &sub_gens = {});
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user