1 | #ifndef NUMBERS_H |
---|
2 | #define NUMBERS_H |
---|
3 | /**************************************** |
---|
4 | * Computer Algebra System SINGULAR * |
---|
5 | ****************************************/ |
---|
6 | /* $Id: numbers.h,v 1.6 2007-05-07 16:23:04 Singular Exp $ */ |
---|
7 | /* |
---|
8 | * ABSTRACT: interface to coefficient aritmetics |
---|
9 | */ |
---|
10 | #include "structs.h" |
---|
11 | |
---|
12 | #define n_Copy(n, r) (r)->cf->cfCopy(n,r) |
---|
13 | #define n_Delete(n, r) (r)->cf->cfDelete(n,r) |
---|
14 | #define n_Mult(n1, n2, r) (r)->cf->nMult(n1, n2) |
---|
15 | #define n_Add(n1, n2, r) (r)->cf->nAdd(n1, n2) |
---|
16 | #define n_IsZero(n, r) (r)->cf->nIsZero(n) |
---|
17 | #define n_Equal(n1, n2, r) (r)->cf->nEqual(n1, n2) |
---|
18 | #define n_Neg(n, r) (r)->cf->nNeg(n) |
---|
19 | #define n_Sub(n1, n2, r) (r)->cf->nSub(n1, n2) |
---|
20 | //#define n_GetChar(r) ((r)->cf->nChar) |
---|
21 | #define n_GetChar(r) ((r)->ch) |
---|
22 | #define n_Init(i, r) (r)->cf->nInit(i) |
---|
23 | #define n_IsOne(n, r) (r)->cf->nIsOne(n) |
---|
24 | #define n_IsMOne(n, r) (r)->cf->nIsMOne(n) |
---|
25 | #define n_GreaterZero(n, r) (r)->cf->nGreaterZero(n) |
---|
26 | #define n_Write(n, r) (r)->cf->nWrite(n) |
---|
27 | #define n_Normalize(n, r) (r)->cf->nNormalize(n) |
---|
28 | #define n_Gcd(a, b, r) (r)->cf->nGcd(a,b,r) |
---|
29 | #define n_IntDiv(a, b, r) (r)->cf->nIntDiv(a,b) |
---|
30 | #define n_Div(a, b, r) (r)->cf->nDiv(a,b) |
---|
31 | #define n_ExactDiv(a, b, r) (r)->cf->nExactDiv(a,b) |
---|
32 | #define n_Test(a,r) (r)->cf->nDBTest(a,__FILE__,__LINE__) |
---|
33 | |
---|
34 | #define n_InpMult(a, b, r) (r)->cf->nInpMult(a,b,r) |
---|
35 | #define n_Power(a, b, res, r) (r)->cf->nPower(a,b,res) |
---|
36 | #define n_Size(n,r) (r)->cf->nSize(n) |
---|
37 | |
---|
38 | /* variables */ |
---|
39 | extern short fftable[]; |
---|
40 | |
---|
41 | /* prototypes */ |
---|
42 | extern numberfunc nMult, nSub ,nAdd ,nDiv, nIntDiv, nIntMod, nExactDiv; |
---|
43 | extern void (*nNew)(number * a); |
---|
44 | extern number (*nInit)(int i); |
---|
45 | extern number (*nPar)(int i); |
---|
46 | extern int (*nParDeg)(number n); |
---|
47 | extern int (*nSize)(number n); |
---|
48 | extern int (*nInt)(number &n); |
---|
49 | // always use in the form n=nNeg(n) ! |
---|
50 | extern number (*nNeg)(number a); |
---|
51 | extern number (*nInvers)(number a); |
---|
52 | extern number (*nCopy)(number a); |
---|
53 | extern number (*nRePart)(number a); |
---|
54 | extern number (*nImPart)(number a); |
---|
55 | extern void (*nWrite)(number &a); |
---|
56 | extern char * (*nRead)(char * s, number * a); |
---|
57 | extern void (*nNormalize)(number &a); |
---|
58 | extern BOOLEAN (*nGreater)(number a,number b), |
---|
59 | (*nEqual)(number a,number b), |
---|
60 | (*nIsZero)(number a), |
---|
61 | (*nIsOne)(number a), |
---|
62 | (*nIsMOne)(number a), |
---|
63 | (*nGreaterZero)(number a); |
---|
64 | extern void (*nPower)(number a, int i, number * result); |
---|
65 | extern number (*nGcd)(number a, number b, const ring r); |
---|
66 | extern number (*nLcm)(number a, number b, const ring r); |
---|
67 | |
---|
68 | extern number nNULL; /* the 0 as constant */ |
---|
69 | |
---|
70 | extern void (*n__Delete)(number * a, const ring r); |
---|
71 | #define nTest(a) (1) |
---|
72 | #define nDelete(A) (currRing)->cf->cfDelete(A,currRing) |
---|
73 | #define nGetDenom(N) (currRing->cf->n_GetDenom((N),currRing)) |
---|
74 | |
---|
75 | #define nSetMap(R) (currRing->cf->cfSetMap(R,currRing)) |
---|
76 | extern char * (*nName)(number n); |
---|
77 | |
---|
78 | void nDummy1(number* d); |
---|
79 | void ndDelete(number* d, const ring r); |
---|
80 | void nDummy2(number &d); |
---|
81 | number ndGcd(number a, number b, const ring); |
---|
82 | number ndCopy(number a); |
---|
83 | void ndInpMult(number &a, number b, const ring r); |
---|
84 | |
---|
85 | #ifdef LDEBUG |
---|
86 | void nDBDummy1(number* d,char *f, int l); |
---|
87 | #endif |
---|
88 | #define nGetChar() n_GetChar(currRing) |
---|
89 | |
---|
90 | void nInitChar(ring r); |
---|
91 | void nKillChar(ring r); |
---|
92 | void nSetChar(ring r); |
---|
93 | |
---|
94 | #endif |
---|