My Project  UNKNOWN_GIT_VERSION
Data Structures | Typedefs | Functions | Variables
p_Procs.h File Reference
#include "omalloc/omalloc.h"
#include "polys/monomials/ring.h"

Go to the source code of this file.

Data Structures

struct  p_Procs_s
 

Typedefs

typedef poly(* p_Copy_Proc_Ptr) (poly p, const ring r)
 
typedef void(* p_Delete_Proc_Ptr) (poly *p, const ring r)
 
typedef poly(* p_ShallowCopyDelete_Proc_Ptr) (poly p, const ring r, omBin dest_bin)
 
typedef poly(* p_Mult_nn_Proc_Ptr) (poly p, const number n, const ring r)
 
typedef poly(* pp_Mult_nn_Proc_Ptr) (poly p, const number n, const ring r)
 
typedef poly(* p_Mult_mm_Proc_Ptr) (poly p, const poly m, const ring r)
 
typedef poly(* pp_Mult_mm_Proc_Ptr) (poly p, const poly m, const ring r)
 
typedef poly(* pp_Mult_mm_Noether_Proc_Ptr) (poly p, const poly m, const poly spNoether, int &ll, const ring r)
 
typedef poly(* p_Add_q_Proc_Ptr) (poly p, poly q, int &shorter, const ring r)
 
typedef poly(* p_Minus_mm_Mult_qq_Proc_Ptr) (poly p, poly m, poly q, int &shorter, const poly spNoether, const ring r)
 
typedef poly(* p_Neg_Proc_Ptr) (poly p, const ring r)
 
typedef poly(* pp_Mult_Coeff_mm_DivSelect_Proc_Ptr) (poly p, const poly m, int &shorter, const ring r)
 
typedef poly(* pp_Mult_Coeff_mm_DivSelectMult_Proc_Ptr) (poly p, const poly m, const poly a, const poly b, int &shorter, const ring r)
 
typedef poly(* p_Merge_q_Proc_Ptr) (poly p, poly q, const ring r)
 
typedef void(* p_kBucketSetLm_Proc_Ptr) (kBucket_pt bucket)
 

Functions

void p_ProcsSet (ring r, p_Procs_s *p_Procs)
 
void p_Debug_GetSpecNames (const ring r, const char *&field, const char *&length, const char *&ord)
 
void p_Debug_GetProcNames (const ring r, p_Procs_s *p_Procs)
 

Variables

const BOOLEAN p_procs_dynamic
 

Data Structure Documentation

◆ p_Procs_s

struct p_Procs_s

Definition at line 41 of file p_Procs.h.

Data Fields
p_Add_q_Proc_Ptr p_Add_q
p_Copy_Proc_Ptr p_Copy
p_Delete_Proc_Ptr p_Delete
p_kBucketSetLm_Proc_Ptr p_kBucketSetLm
p_Merge_q_Proc_Ptr p_Merge_q
p_Minus_mm_Mult_qq_Proc_Ptr p_Minus_mm_Mult_qq
p_Mult_mm_Proc_Ptr p_mm_Mult
p_Mult_mm_Proc_Ptr p_Mult_mm
p_Mult_nn_Proc_Ptr p_Mult_nn
p_Neg_Proc_Ptr p_Neg
p_ShallowCopyDelete_Proc_Ptr p_ShallowCopyDelete
pp_Mult_mm_Proc_Ptr pp_mm_Mult
pp_Mult_Coeff_mm_DivSelect_Proc_Ptr pp_Mult_Coeff_mm_DivSelect
pp_Mult_Coeff_mm_DivSelectMult_Proc_Ptr pp_Mult_Coeff_mm_DivSelectMult
pp_Mult_mm_Proc_Ptr pp_Mult_mm
pp_Mult_mm_Noether_Proc_Ptr pp_Mult_mm_Noether
pp_Mult_nn_Proc_Ptr pp_Mult_nn

Typedef Documentation

◆ p_Add_q_Proc_Ptr

typedef poly(* p_Add_q_Proc_Ptr) (poly p, poly q, int &shorter, const ring r)

Definition at line 28 of file p_Procs.h.

◆ p_Copy_Proc_Ptr

typedef poly(* p_Copy_Proc_Ptr) (poly p, const ring r)

Definition at line 18 of file p_Procs.h.

◆ p_Delete_Proc_Ptr

typedef void(* p_Delete_Proc_Ptr) (poly *p, const ring r)

Definition at line 19 of file p_Procs.h.

◆ p_kBucketSetLm_Proc_Ptr

typedef void(* p_kBucketSetLm_Proc_Ptr) (kBucket_pt bucket)

Definition at line 39 of file p_Procs.h.

◆ p_Merge_q_Proc_Ptr

typedef poly(* p_Merge_q_Proc_Ptr) (poly p, poly q, const ring r)

Definition at line 38 of file p_Procs.h.

◆ p_Minus_mm_Mult_qq_Proc_Ptr

typedef poly(* p_Minus_mm_Mult_qq_Proc_Ptr) (poly p, poly m, poly q, int &shorter, const poly spNoether, const ring r)

Definition at line 29 of file p_Procs.h.

◆ p_Mult_mm_Proc_Ptr

typedef poly(* p_Mult_mm_Proc_Ptr) (poly p, const poly m, const ring r)

Definition at line 23 of file p_Procs.h.

◆ p_Mult_nn_Proc_Ptr

typedef poly(* p_Mult_nn_Proc_Ptr) (poly p, const number n, const ring r)

Definition at line 21 of file p_Procs.h.

◆ p_Neg_Proc_Ptr

typedef poly(* p_Neg_Proc_Ptr) (poly p, const ring r)

Definition at line 32 of file p_Procs.h.

◆ p_ShallowCopyDelete_Proc_Ptr

typedef poly(* p_ShallowCopyDelete_Proc_Ptr) (poly p, const ring r, omBin dest_bin)

Definition at line 20 of file p_Procs.h.

◆ pp_Mult_Coeff_mm_DivSelect_Proc_Ptr

typedef poly(* pp_Mult_Coeff_mm_DivSelect_Proc_Ptr) (poly p, const poly m, int &shorter, const ring r)

Definition at line 33 of file p_Procs.h.

◆ pp_Mult_Coeff_mm_DivSelectMult_Proc_Ptr

typedef poly(* pp_Mult_Coeff_mm_DivSelectMult_Proc_Ptr) (poly p, const poly m, const poly a, const poly b, int &shorter, const ring r)

Definition at line 36 of file p_Procs.h.

◆ pp_Mult_mm_Noether_Proc_Ptr

typedef poly(* pp_Mult_mm_Noether_Proc_Ptr) (poly p, const poly m, const poly spNoether, int &ll, const ring r)

Definition at line 25 of file p_Procs.h.

◆ pp_Mult_mm_Proc_Ptr

typedef poly(* pp_Mult_mm_Proc_Ptr) (poly p, const poly m, const ring r)

Definition at line 24 of file p_Procs.h.

◆ pp_Mult_nn_Proc_Ptr

typedef poly(* pp_Mult_nn_Proc_Ptr) (poly p, const number n, const ring r)

Definition at line 22 of file p_Procs.h.

Function Documentation

◆ p_Debug_GetProcNames()

void p_Debug_GetProcNames ( const ring  r,
p_Procs_s p_Procs 
)

Definition at line 213 of file p_Procs_Set.h.

214 {
215  set_names = 1;
216  p_ProcsSet(r, p_Procs); // changes p_Procs!!!
217  set_names = 0;
218 }

◆ p_Debug_GetSpecNames()

void p_Debug_GetSpecNames ( const ring  r,
const char *&  field,
const char *&  length,
const char *&  ord 
)

Definition at line 202 of file p_Procs_Set.h.

203 {
204  /*p_Field e_field =*/ (void) p_FieldIs(r);
205  /*p_Length e_length =*/ (void) p_LengthIs(r);
206  /*p_Ord e_ord =*/ (void) p_OrdIs(r);
207 
208  field = p_FieldEnum_2_String(p_FieldIs(r));
210  ord = p_OrdEnum_2_String(p_OrdIs(r));
211 }

◆ p_ProcsSet()

void p_ProcsSet ( ring  r,
p_Procs_s p_Procs 
)

Definition at line 138 of file p_Procs_Set.h.

139 {
140  p_Field field = p_FieldIs(r);
142  p_Ord ord = p_OrdIs(r);
143 
144  assume(p_Procs != NULL);
145  memset(p_Procs, 0, sizeof(p_Procs_s));
146  _p_procs = p_Procs;
147 
148  SetProcs(field, length, ord);
149  extern poly p_Mult_nn_pthread(poly p, const number n, const ring r);
150  #ifdef NV_OPS
151  if ((field==FieldZp) && (r->cf->ch>NV_MAX_PRIME))
152  {
153  // set all (mult/div.) routines to FieldGeneral-variants
154  SetProcs(FieldGeneral, length,ord); // p_Mult_nn, ...
155  // set all non-mult/div. routines to FieldZp-variants
156  SetProcs_nv(FieldZp, length,ord); // p_Delete, p_ShallowCopyDelete...
157  }
158  if (field==RingGeneral)
159  {
160  if (nCoeff_is_Domain(r->cf))
162  // FieldGeneral vs. RingGeneral: HAVE_ZERODIVISORS
163  else
165  }
166  #endif
169  CheckProc(p_Copy);
177  CheckProc(pp_Mult_mm_Noether);
179  CheckProc(p_Neg);
181  CheckProc(pp_Mult_Coeff_mm_DivSelectMult);
183  CheckProc(p_kBucketSetLm);
184 
185 /*
186  assume(p_Procs->pp_Mult_mm_Noether != pp_Mult_mm_Noether__FieldGeneral_LengthGeneral_OrdGeneral ||
187  p_Procs->p_Minus_mm_Mult_qq == p_Minus_mm_Mult_qq__FieldGeneral_LengthGeneral_OrdGeneral ||
188  r->OrdSgn == 1 || r->LexOrder);
189 */
190 #ifdef HAVE_PLURAL
191 #ifndef SING_NDEBUG
192  if (rIsPluralRing(r))
193  {
194  dReportError("Setting pProcs in p_ProcsSet (rDebugPrint!?)!!!");
195  nc_p_ProcsSet(r, _p_procs); // Setup non-commutative p_Procs table!
196  }
197 #endif
198 #endif
199 }

Variable Documentation

◆ p_procs_dynamic

const BOOLEAN p_procs_dynamic

Definition at line 30 of file p_Procs_Dynamic.cc.

FieldGeneral
@ FieldGeneral
Definition: p_Procs_Impl.h:112
p_Procs_s::p_mm_Mult
p_Mult_mm_Proc_Ptr p_mm_Mult
Definition: p_Procs.h:52
dReportError
int dReportError(const char *fmt,...)
Definition: dError.cc:45
p_ProcsSet
void p_ProcsSet(ring r, p_Procs_s *p_Procs)
Definition: p_Procs_Set.h:138
p_FieldIs
static p_Field p_FieldIs(ring r)
Definition: p_Procs_Set.h:20
p_Merge_q
static poly p_Merge_q(poly p, poly q, const ring r)
Definition: p_polys.h:1149
p_Procs_s
Definition: p_Procs.h:41
p_Ord
p_Ord
Definition: p_Procs_Impl.h:135
p_LengthIs
static p_Length p_LengthIs(ring r)
Definition: p_Procs_Set.h:37
p_Mult_mm
static poly p_Mult_mm(poly p, poly m, const ring r)
Definition: p_polys.h:998
p_Neg
static poly p_Neg(poly p, const ring r)
Definition: p_polys.h:1044
p_Minus_mm_Mult_qq
static poly p_Minus_mm_Mult_qq(poly p, const poly m, const poly q, int &lp, int lq, const poly spNoether, const ring r)
Definition: p_polys.h:1007
length
static BOOLEAN length(leftv result, leftv arg)
Definition: interval.cc:263
p_ShallowCopyDelete
static poly p_ShallowCopyDelete(poly p, const ring r, omBin bin)
Definition: p_polys.h:885
CheckProc
#define CheckProc(which)
Definition: p_Procs_Set.h:121
p_LengthEnum_2_String
static const char * p_LengthEnum_2_String(p_Length length)
Definition: p_Procs_Impl.h:219
pp_Mult_mm
static poly pp_Mult_mm(poly p, poly m, const ring r)
Definition: p_polys.h:988
p_OrdEnum_2_String
static const char * p_OrdEnum_2_String(p_Ord ord)
Definition: p_Procs_Impl.h:237
p_Field
p_Field
Definition: p_Procs_Impl.h:106
pp_Mult_Coeff_mm_DivSelect
static poly pp_Mult_Coeff_mm_DivSelect(poly p, const poly m, const ring r)
Definition: p_polys.h:1027
rIsPluralRing
static BOOLEAN rIsPluralRing(const ring r)
we must always have this test!
Definition: ring.h:398
set_names
static int set_names
Definition: p_Procs_Set.h:117
p_Copy
static poly p_Copy(poly p, const ring r)
returns a copy of p
Definition: p_polys.h:813
p_OrdIs
static p_Ord p_OrdIs(ring r)
Definition: p_Procs_Set.h:70
SetProcs
#define SetProcs(field, length, ord)
Definition: p_Procs_Impl.h:662
p_Procs_s::pp_mm_Mult
pp_Mult_mm_Proc_Ptr pp_mm_Mult
Definition: p_Procs.h:49
p_Procs_s::pp_Mult_mm
pp_Mult_mm_Proc_Ptr pp_Mult_mm
Definition: p_Procs.h:48
p_Delete
static void p_Delete(poly *p, const ring r)
Definition: p_polys.h:858
p_Add_q
static poly p_Add_q(poly p, poly q, const ring r)
Definition: p_polys.h:893
NV_MAX_PRIME
#define NV_MAX_PRIME
Definition: modulop.h:29
p_Length
p_Length
Definition: p_Procs_Impl.h:122
SetProcs_ring
#define SetProcs_ring(field, length, ord)
Definition: p_Procs_Impl.h:698
p_Procs_s::p_Mult_mm
p_Mult_mm_Proc_Ptr p_Mult_mm
Definition: p_Procs.h:51
assume
#define assume(x)
Definition: mod2.h:390
NULL
#define NULL
Definition: omList.c:10
pp_Mult_nn
static poly pp_Mult_nn(poly p, number n, const ring r)
Definition: p_polys.h:949
p
int p
Definition: cfModGcd.cc:4019
p_FieldEnum_2_String
static const char * p_FieldEnum_2_String(p_Field field)
Definition: p_Procs_Impl.h:198
RingGeneral
@ RingGeneral
Definition: p_Procs_Impl.h:123
_p_procs
static p_Procs_s * _p_procs
Definition: p_Procs_Set.h:113
p_Mult_nn
static poly p_Mult_nn(poly p, number n, const ring r)
Definition: p_polys.h:915
nc_p_ProcsSet
void nc_p_ProcsSet(ring rGR, p_Procs_s *p_Procs)
Definition: old.gring.cc:3205
FieldZp
@ FieldZp
Definition: p_Procs_Impl.h:113
nCoeff_is_Domain
static FORCE_INLINE BOOLEAN nCoeff_is_Domain(const coeffs r)
returns TRUE, if r is a field or r has no zero divisors (i.e is a domain)
Definition: coeffs.h:761