1 | #ifndef RMODULON_H |
---|
2 | #define RMODULON_H |
---|
3 | /**************************************** |
---|
4 | * Computer Algebra System SINGULAR * |
---|
5 | ****************************************/ |
---|
6 | /* $Id: rmodulon.h,v 1.11 2009-05-22 16:57:41 Singular Exp $ */ |
---|
7 | /* |
---|
8 | * ABSTRACT: numbers modulo n |
---|
9 | */ |
---|
10 | #ifdef HAVE_RINGS |
---|
11 | #include "structs.h" |
---|
12 | |
---|
13 | #ifndef NATNUMBER |
---|
14 | #define NATNUMBER unsigned long |
---|
15 | #endif |
---|
16 | |
---|
17 | number nrnCopy (number a); |
---|
18 | number cfrnCopy (number a, const ring r); |
---|
19 | int nrnSize (number a); |
---|
20 | void nrnDelete (number *a, const ring r); |
---|
21 | BOOLEAN nrnGreaterZero (number k); |
---|
22 | number nrnMult (number a, number b); |
---|
23 | number nrnInit (int i); |
---|
24 | int nrnInt (number &n); |
---|
25 | number nrnAdd (number a, number b); |
---|
26 | number nrnSub (number a, number b); |
---|
27 | void nrnPower (number a, int i, number * result); |
---|
28 | BOOLEAN nrnIsZero (number a); |
---|
29 | BOOLEAN nrnIsOne (number a); |
---|
30 | BOOLEAN nrnIsMOne (number a); |
---|
31 | BOOLEAN nrnIsUnit (number a); |
---|
32 | number nrnGetUnit (number a); |
---|
33 | number nrnDiv (number a, number b); |
---|
34 | number nrnIntDiv (number a,number b); |
---|
35 | number nrnNeg (number c); |
---|
36 | number nrnInvers (number c); |
---|
37 | BOOLEAN nrnGreater (number a, number b); |
---|
38 | BOOLEAN nrnDivBy (number a, number b); |
---|
39 | int nrnDivComp (number a, number b); |
---|
40 | BOOLEAN nrnEqual (number a, number b); |
---|
41 | number nrnLcm (number a,number b, ring r); |
---|
42 | number nrnGcd (number a,number b,ring r); |
---|
43 | number nrnExtGcd (number a, number b, number *s, number *t); |
---|
44 | nMapFunc nrnSetMap (ring src, ring dst); |
---|
45 | void nrnWrite (number &a); |
---|
46 | const char * nrnRead (const char *s, number *a); |
---|
47 | char * nrnName (number n); |
---|
48 | #ifdef LDEBUG |
---|
49 | BOOLEAN nrnDBTest (number a, const char *f, const int l); |
---|
50 | #endif |
---|
51 | void nrnSetExp(int c, ring r); |
---|
52 | void nrnInitExp(int c, ring r); |
---|
53 | |
---|
54 | number nrnMapQ(number from); |
---|
55 | number nrnMapGMP(number from); |
---|
56 | #endif |
---|
57 | #endif |
---|