[35aab3] | 1 | #ifndef NUMBERS_H |
---|
| 2 | #define NUMBERS_H |
---|
| 3 | /**************************************** |
---|
| 4 | * Computer Algebra System SINGULAR * |
---|
| 5 | ****************************************/ |
---|
[3332cc6] | 6 | /* $Id: numbers.h,v 1.6 2007-05-07 16:23:04 Singular Exp $ */ |
---|
[35aab3] | 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) |
---|
[0ab374] | 30 | #define n_Div(a, b, r) (r)->cf->nDiv(a,b) |
---|
| 31 | #define n_ExactDiv(a, b, r) (r)->cf->nExactDiv(a,b) |
---|
[3332cc6] | 32 | #define n_Test(a,r) (r)->cf->nDBTest(a,__FILE__,__LINE__) |
---|
[0ab374] | 33 | |
---|
[35aab3] | 34 | #define n_InpMult(a, b, r) (r)->cf->nInpMult(a,b,r) |
---|
[c329af] | 35 | #define n_Power(a, b, res, r) (r)->cf->nPower(a,b,res) |
---|
[6b4fbf7] | 36 | #define n_Size(n,r) (r)->cf->nSize(n) |
---|
[0ab374] | 37 | |
---|
[35aab3] | 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); |
---|
[c3db61] | 49 | // always use in the form n=nNeg(n) ! |
---|
[35aab3] | 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 |
---|