183 virtual int kind() {
return 1; }
204 const Matrix **result_remainder,
205 const Matrix **result_quotient);
Abstract base for long-running, resumable engine computations (GBComputation, ResolutionComputation,...
Engine-side free module R^n over a Ring.
virtual const Matrix * get_change()
RingElement * compute_hilbert_function() const
void gb_geo_reduce(gbvector *&f, gbvector *&fsyz)
void gb_sort(int lo, int hi)
void gb_reduce(gbvector *&f, gbvector *&fsyz)
s_pair * new_ring_pair(gb_elem *p, const int *lcm)
virtual const Matrix * get_gb()
virtual M2_bool matrix_lift(const Matrix *m, const Matrix **result_remainder, const Matrix **result_quotient)
void remove_pair(s_pair *&p)
virtual const PolynomialRing * get_ring() const
void find_pairs(gb_elem *p)
static GB_comp * create(const Matrix *m, M2_bool collect_syz, int n_rows_to_keep, M2_arrayint gb_weights, int strategy, M2_bool use_max_degree, int max_degree)
virtual const Matrix * get_initial(int nparts)
void initialize0(const Matrix *m, int csyz, int nsyz, M2_arrayint gb_weights)
VECTOR(monideal_pair *) _monideals
virtual bool stop_conditions_ok()
virtual const Matrix * get_mingens()
void gb_insert(gbvector *f, gbvector *fsyz, int ismin)
virtual void text_out(buffer &o) const
virtual int complete_thru_degree() const
s_pair * new_var_pair(gb_elem *p, const int *lcm)
virtual int contains(const Matrix *m)
int gb_sort_partition(int lo, int hi)
const GBWeight * weightInfo_
s_pair * new_s_pair(gb_elem *p, gb_elem *q, const int *lcm)
void compute_s_pair(s_pair *p)
const PolynomialRing * originalR
void initialize(const Matrix *m, int csyz, int nsyz, M2_arrayint gb_weights, int strategy)
virtual const Matrix * get_syzygies()
virtual const Matrix * matrix_remainder(const Matrix *m)
virtual Computation * set_hilbert_function(const RingElement *h)
ComputationStatusCode computation_is_complete() const
virtual const Matrix * get_parallel_lead_terms(M2_arrayint w)
s_pair * new_gen(int i, gbvector *f, ring_elem denom)
void initialize_forced(const Matrix *m, const Matrix *gb, const Matrix *mchange)
static GB_comp * create_forced(const Matrix *m, const Matrix *gb, const Matrix *mchange)
void flush_pairs(int deg)
const RingElement * _hf_orig
void add_gens(int lo, int hi, const Matrix *m)
void debug_out(s_pair *q) const
A Groebner basis computation class for homogeneous input modules.
Polynomial-ring view tuned for the inner loop of classical Buchberger Groebner-basis computations.
Heuristic-weight evaluator for gbvectors, used during Groebner basis computation to drive the S-pair ...
Engine-side commutative monomial monoid: variable names, ordering, multidegree machinery,...
Abstract base for the engine's polynomial-ring hierarchy.
Front-end-visible "ring element" value: an engine ring_elem paired with the Ring* that gives it meani...
Computation of Hilbert functions.
GBComputation — abstract base of every Groebner-basis algorithm in the engine.
void gb(IntermediateBasis &F, int n)
const int GB_COMP_NEWPAIRS
const int GB_COMP_AUTO_REDUCE
const int GB_COMP_NEED_RESIZE
const int GB_COMP_S_PAIRS
const int GB_COMP_NEWDEGREE
GBWeight — packed-weight evaluator that drives S-pair selection.
Matrix — the engine's immutable homomorphism F -> G between free modules.
PolynomialRing — abstract polynomial-ring base, the engine's most-reused class.
RingElement — tagged (Ring*, ring_elem) pair, the engine's universal element type.
gb_elem / s_pair / s_pair_heap — basis-element record, S-pair work unit, and S-pair priority queue fo...