27#include <NTL/config.h>
32# define OSTREAM std::ostream
33# define ISTREAM std::istream
34# elif defined(HAVE_IOSTREAM_H)
36# define OSTREAM ostream
37# define ISTREAM istream
41#include <NTL/mat_ZZ.h>
42#include <NTL/mat_lzz_p.h>
51#define TRANSEXT_PRIVATES
66#define MAX_CHAR_FACTORY 536870909
86 #if __FLINT_RELEASE >= 20503
90 if (!convSingRFlintR(ctx,r))
100 if (!convSingRFlintR(ctx,r))
111 fmpz_mpoly_ctx_t ctx;
112 if (!convSingRFlintR(ctx,r))
136 else if ( r->cf->extRing!=
NULL )
142 if (r->cf->extRing->qideal!=
NULL)
258 else if ( r->cf->extRing )
264 if (r->cf->extRing->qideal!=
NULL)
363 WerrorS(
"3rd argument must be a ring variable");
364 goto resultant_returns_res;
367 goto resultant_returns_res;
380 goto resultant_returns_res;
383 else if (r->cf->extRing!=
NULL)
390 if (r->cf->extRing->qideal!=
NULL)
435 goto resultant_returns_res;
439resultant_returns_res:
535 else if ( r->cf->extRing!=
NULL )
542 if (r->cf->extRing->qideal!=
NULL)
611 else if (r->cf->extRing!=
NULL)
617 if (r->cf->extRing->qideal!=
NULL)
640 res = convFactoryGFSingGF( F *
G );
654 #if __FLINT_RELEASE >= 20503
661 nmod_mpoly_ctx_t ctx;
662 if (!convSingRFlintR(ctx,r))
664 res = Flint_Divide_MP(
f,0,
g,0,ctx,r);
672 fmpq_mpoly_ctx_t ctx;
673 if (!convSingRFlintR(ctx,r))
675 res = Flint_Divide_MP(
f,0,
g,0,ctx,r);
694 else if (r->cf->extRing!=
NULL)
700 if (r->cf->extRing->qideal!=
NULL)
723 res = convFactoryGFSingGF( F /
G );
749 else if (r->cf->extRing!=
NULL)
755 if (r->cf->extRing->qideal!=
NULL)
784 res = convFactoryGFSingGF( F /
G );
795void singclap_divide_content ( poly
f,
const ring r )
824 int sz1=
n_Size(g1, r->cf);
825 int sz2=
n_Size(g2, r->cf);
858 while ( (
p !=
NULL) && (
g != 1) && (
g != 0))
867 if ((
g == 1 ) || (
g == 0))
900#ifdef FACTORIZE2_DEBUG
913 else if (r->cf->extRing!=
NULL)
915 if (r->cf->extRing->qideal!=
NULL)
947 else if (r->cf->extRing!=
NULL)
949 if (r->cf->extRing->qideal!=
NULL)
965 if (r->cf->extRing!=
NULL)
966 if (r->cf->extRing->qideal!=
NULL)
987#ifdef FACTORIZE2_DEBUG
1015 if (with_exps==0) n++;
1048 if (with_exps!=1) (**v)[n]=e;
1117 else if (r->cf->extRing!=
NULL)
1124 if (r->cf->extRing->qideal!=
NULL)
1164 if ((with_exps==2)&&(n>1))
1185 else if (r->cf->extRing!=
NULL)
1191 if (r->cf->extRing->qideal==
NULL)
1219 if (r->cf->extRing!=
NULL)
1220 if (r->cf->extRing->qideal!=
NULL)
1229#ifdef FACTORIZE2_DEBUG
1230 printf(
"factorize_retry\n");
1236 int l=(*v)->length();
1238 for(jj=0;jj<ww->
length();jj++)
1239 (**
v)[jj+
l]=(*ww)[jj];
1244 hh->m[jj]=
res->m[jj];
1260 WarnS(
"problem with factorize");
1324 (**v)[
j]=(*w)[
i];
j++;
1340 if (with_exps!=0) stop=0;
1346 else n_Delete(&old_lead_coeff,r->cf);
1356 if ((
v!=
NULL) && ((*
v)!=
NULL) &&(with_exps==2))
1380#ifdef FACTORIZE2_DEBUG
1394 if (with_exps!=1 && with_exps!=3)
1408 if (with_exps==0 || with_exps==3) n++;
1433 if (with_exps!=1) (**v)[n]=e;
1453 number n0=
n_Copy(old_lead_coeff,r->cf);
1454 if (with_exps==0 || with_exps==3)
1461 if (with_exps==0 || with_exps==3)
1472 number n0=
n_Copy(old_lead_coeff,r->cf);
1473 if (with_exps==0 || with_exps==3)
1479 if (with_exps==0 || with_exps==3)
1495 else if (r->cf->extRing!=
NULL)
1501 if (r->cf->extRing->qideal!=
NULL)
1543 if ((with_exps==2)&&(n>1))
1558 if (with_exps!=1 && with_exps!=3) (**v)[
j] = J.
getItem().
exp();
1562 else if (r->cf->extRing!=
NULL)
1564 if (r->cf->extRing->qideal==
NULL)
1581 if (r->cf->extRing!=
NULL)
1582 if (r->cf->extRing->qideal!=
NULL)
1588 if (with_exps!=0 || with_exps==3) stop=0;
1593 if (with_exps==0 || with_exps==3)
p_SetCoeff(
res->m[0],old_lead_coeff,r);
1594 else n_Delete(&old_lead_coeff,r->cf);
1678 for ( LLi = LL; LLi.
hasItem(); LLi++ )
1682 if ((
m!=0) && (n!=0))
break;
1684 if (tries>=5)
break;
1686 if ((
m==0) || (n==0))
1688 Warn(
"char_series returns %d x %d matrix from %d input polys (%d)",
1696 for (
m=1, LLi = LL; LLi.
hasItem(); LLi++,
m++ )
1766 int cnt=
rVar(r)+offs;
1807 if (
s[strlen(
s)-1]==
',')
s[strlen(
s)-1]=
'\0';
1816 Werror(
"det of %d x %d matrix",r,
m->cols());
1841 for(
i=
m->rows();
i>0;
i--)
1843 for(
j=
m->cols();
j>0;
j--)
1858 for(
i=
m->rows();
i>0;
i--)
1860 for(
j=
m->cols();
j>0;
j--)
1870#if defined(HAVE_NTL) || defined(HAVE_FLINT)
1876 Werror(
"HNF of %d x %d matrix",r,
m->cols());
1912 Werror(
"HNF of %d x %d matrix",r,
m->cols());
1943 Werror(
"HNF of %d x %d matrix",r,
b->cols());
2060 mat_zz_p *NTLM=
new mat_zz_p;
2075 WerrorS(
"smatrix for rref is not constant");
2086 number n=
n_Init(rep((*NTLM)(
i,
j)),
R->cf);
2098 WerrorS(
"not implemented for these coefficients");
2114 mat_zz_p *NTLM=
new mat_zz_p;
2126 WerrorS(
"smatrix for rref is not constant");
2137 number n=
n_Init(rep((*NTLM)(
i,
j)),
R->cf);
2150 WerrorS(
"not implemented for these coefficients");
2156#if defined(HAVE_NTL) || defined(HAVE_FLINT)
2182 int n= absFactors.
length();
2196 if (
iter.getItem().factor().inCoeffDomain())
2203 (**exps)[
i]=
iter.getItem().exp();
2205 if (
iter.getItem().minpoly().isOne())
2210 if (
iter.getItem().minpoly().isOne())
2220 if (!
iter.getItem().minpoly().isOne())
2222 numFactors +=
count;
2236 WerrorS(
"NTL/FLINT missing: absFactorize");
static int si_max(const int a, const int b)
static int si_min(const int a, const int b)
bigintmat * bimCopy(const bigintmat *b)
same as copy constructor - apart from it being able to accept NULL as input
#define BIMATELEM(M, I, J)
ListCFList irrCharSeries(const CFList &PS)
irreducible characteristic series
IntList neworderint(const CFList &PolyList)
const CanonicalForm CFMap CFMap & N
CanonicalForm extgcd(const CanonicalForm &f, const CanonicalForm &g, CanonicalForm &a, CanonicalForm &b)
CanonicalForm extgcd ( const CanonicalForm & f, const CanonicalForm & g, CanonicalForm & a,...
CanonicalForm bCommonDen(const CanonicalForm &f)
void psqr ( const CanonicalForm & f, const CanonicalForm & g, CanonicalForm & q, CanonicalForm & r,...
CanonicalForm FACTORY_PUBLIC determinant(const CFMatrix &M, int n)
CFFList FACTORY_PUBLIC sqrFree(const CanonicalForm &f, bool sort=false)
squarefree factorization
CFFList FACTORY_PUBLIC factorize(const CanonicalForm &f, bool issqrfree=false)
factorization over or
CanonicalForm FACTORY_PUBLIC resultant(const CanonicalForm &f, const CanonicalForm &g, const Variable &x)
CanonicalForm resultant ( const CanonicalForm & f, const CanonicalForm & g, const Variable & x ).
static const int SW_USE_QGCD
set to 1 to use Encarnacion GCD over Q(a)
static const int SW_USE_EZGCD_P
set to 1 to use EZGCD over F_q
static const int SW_RATIONAL
set to 1 for computations over Q
static const int SW_SYMMETRIC_FF
set to 1 for symmetric representation over F_q
CFMatrix * cf_LLL(CFMatrix &A)
performs LLL reduction.
CFMatrix * cf_HNF(CFMatrix &A)
The input matrix A is an n x m matrix of rank m (so n >= m), and D is a multiple of the determinant o...
CanonicalForm convSingPFactoryP(poly p, const ring r)
BOOLEAN convSingTrP(poly p, const ring r)
poly convFactoryPSingTrP(const CanonicalForm &f, const ring r)
poly convFactoryAPSingAP(const CanonicalForm &f, const ring r)
CanonicalForm convSingAPFactoryAP(poly p, const Variable &a, const ring r)
poly convFactoryPSingP(const CanonicalForm &f, const ring r)
int convFactoryISingI(const CanonicalForm &f)
CanonicalForm convSingTrPFactoryP(poly p, const ring r)
poly singclap_resultant(poly f, poly g, poly x, const ring r)
BOOLEAN count_Factors(ideal I, intvec *v, int j, poly &f, poly fac, const ring r)
matrix singntl_HNF(matrix m, const ring s)
poly singclap_pmod(poly f, poly g, const ring r)
ideal singclap_factorize(poly f, intvec **v, int with_exps, const ring r)
matrix singclap_irrCharSeries(ideal I, const ring r)
int pGetExp_Var(poly p, int i, const ring r)
VAR int singclap_factorize_retry
poly singclap_pdivide(poly f, poly g, const ring r)
int * Zp_roots(poly p, const ring r)
void out_cf(const char *s1, const CanonicalForm &f, const char *s2)
BOOLEAN singclap_extgcd(poly f, poly g, poly &res, poly &pa, poly &pb, const ring r)
matrix singntl_rref(matrix m, const ring R)
poly singclap_det(const matrix m, const ring s)
poly singclap_gcd_and_divide(poly &f, poly &g, const ring r)
clears denominators of f and g, divides by gcd(f,g)
matrix singntl_LLL(matrix m, const ring s)
number singclap_det_bi(bigintmat *m, const coeffs cf)
poly singclap_pmult(poly f, poly g, const ring r)
poly singclap_gcd_r(poly f, poly g, const ring r)
int singclap_det_i(intvec *m, const ring)
ideal singclap_absFactorize(poly f, ideal &mipos, intvec **exps, int &numFactors, const ring r)
ideal singclap_sqrfree(poly f, intvec **v, int with_exps, const ring r)
char * singclap_neworder(ideal I, const ring r)
factory's class for variables
Coefficient rings, fields and other domains suitable for Singular polynomials.
static FORCE_INLINE number n_Copy(number n, const coeffs r)
return a copy of 'n'
static FORCE_INLINE number n_convFactoryNSingN(const CanonicalForm n, const coeffs r)
static FORCE_INLINE number n_Invers(number a, const coeffs r)
return the multiplicative inverse of 'a'; raise an error if 'a' is not invertible
static FORCE_INLINE BOOLEAN n_GreaterZero(number n, const coeffs r)
ordered fields: TRUE iff 'n' is positive; in Z/pZ: TRUE iff 0 < m <= roundedBelow(p/2),...
static FORCE_INLINE number n_Div(number a, number b, const coeffs r)
return the quotient of 'a' and 'b', i.e., a/b; raises an error if 'b' is not invertible in r exceptio...
static FORCE_INLINE CanonicalForm n_convSingNFactoryN(number n, BOOLEAN setChar, const coeffs r)
static FORCE_INLINE BOOLEAN n_IsZero(number n, const coeffs r)
TRUE iff 'n' represents the zero element.
static FORCE_INLINE int n_Size(number n, const coeffs r)
return a non-negative measure for the complexity of n; return 0 only when n represents zero; (used fo...
static FORCE_INLINE void n_Delete(number *p, const coeffs r)
delete 'p'
static FORCE_INLINE number n_Init(long i, const coeffs r)
a number representing i in the given coeff field/ring r
static FORCE_INLINE BOOLEAN n_IsOne(number n, const coeffs r)
TRUE iff 'n' represents the one element.
static FORCE_INLINE BOOLEAN nCoeff_is_transExt(const coeffs r)
TRUE iff r represents a transcendental extension field.
static BOOLEAN pa(leftv res, leftv args)
static BOOLEAN pb(leftv res, leftv args)
CFAFList absFactorize(const CanonicalForm &G)
absolute factorization of a multivariate poly over Q
const CanonicalForm int s
const Variable & v
< [in] a sqrfree bivariate poly
factory.h' is the user interface to Factory.
Variable FACTORY_PUBLIC rootOf(const CanonicalForm &, char name='@')
returns a symbolic root of polynomial with name name Use it to define algebraic variables
void FACTORY_PUBLIC prune(Variable &alpha)
void WerrorS(const char *s)
STATIC_VAR int nfMinPoly[16]
This file is work in progress and currently not part of the official Singular.
BOOLEAN idIs0(ideal h)
returns true if h is the zero ideal
intvec * ivCopy(const intvec *o)
#define IMATELEM(M, I, J)
matrix mpNew(int r, int c)
create a r x c zero-matrix
void iiWriteMatrix(matrix im, const char *n, int dim, const ring r, int spaces)
set spaces to zero by default
#define MATELEM(mat, i, j)
1-based access to matrix
static number & pGetCoeff(poly p)
return an alias to the leading coefficient of p assumes that p != NULL NOTE: not copy
The main handler for Singular numbers which are suitable for Singular polynomials.
CanonicalForm ndConvSingNFactoryN(number, BOOLEAN, const coeffs)
int p_IsPurePower(const poly p, const ring r)
return i, if head depends only on var(i)
void p_Cleardenom_n(poly ph, const ring r, number &c)
poly p_GcdMon(poly f, poly g, const ring r)
polynomial gcd for f=mon
void p_Content(poly ph, const ring r)
void p_Norm(poly p1, const ring r)
poly p_Div_mm(poly p, const poly m, const ring r)
divide polynomial by monomial
poly p_Cleardenom(poly p, const ring r)
poly p_Sub(poly p1, poly p2, const ring r)
poly p_NSet(number n, const ring r)
returns the poly representing the number n, destroys n
static poly p_Neg(poly p, const ring r)
static int pLength(poly a)
static poly p_Add_q(poly p, poly q, const ring r)
static poly p_Mult_q(poly p, poly q, const ring r)
void p_Write(poly p, ring lmRing, ring tailRing)
static unsigned long p_SetExp(poly p, const unsigned long e, const unsigned long iBitmask, const int VarOffset)
set a single variable exponent @Note: VarOffset encodes the position in p->exp
static unsigned long p_SetComp(poly p, unsigned long c, ring r)
static void p_Setm(poly p, const ring r)
static number p_SetCoeff(poly p, number n, ring r)
static long p_GetExp(const poly p, const unsigned long iBitmask, const int VarOffset)
get a single variable exponent @Note: the integer VarOffset encodes:
static BOOLEAN p_IsConstant(const poly p, const ring r)
static void p_Delete(poly *p, const ring r)
void p_Write0(poly p, ring lmRing, ring tailRing)
static poly pp_Mult_qq(poly p, poly q, const ring r)
static poly p_Copy(poly p, const ring r)
returns a copy of p
static long p_Totaldegree(poly p, const ring r)
#define __p_Mult_nn(p, n, r)
void p_wrp(poly p, ring lmRing, ring tailRing)
VAR ring currRing
Widely used global variable which specifies the current polynomial ring for Singular interpreter and ...
static long pTotaldegree(poly p)
std::pair< int, int > mark
void StringSetS(const char *st)
void StringAppendS(const char *st)
const char feNotImplemented[]
void PrintS(const char *s)
void Werror(const char *fmt,...)
static BOOLEAN rField_is_Zp_a(const ring r)
static BOOLEAN rField_is_Z(const ring r)
static BOOLEAN rField_is_Zp(const ring r)
static BOOLEAN rField_is_Zn(const ring r)
static int rPar(const ring r)
(r->cf->P)
static int rInternalChar(const ring r)
static BOOLEAN rField_is_Q_a(const ring r)
static BOOLEAN rField_is_Q(const ring r)
static BOOLEAN rField_is_GF(const ring r)
static short rVar(const ring r)
define rVar(r) (r->N)
int status int void size_t count
ideal idInit(int idsize, int rank)
initialise an ideal / module
void id_Delete(ideal *h, ring r)
deletes an ideal/module/matrix
void idShow(const ideal id, const ring lmRing, const ring tailRing, const int debugPrint)
void idSkipZeroes(ideal ide)
gives an ideal/module the minimal possible size