source: git/kernel/longalg.h @ 3580b7

spielwiese
Last change on this file since 3580b7 was 341696, checked in by Hans Schönemann <hannes@…>, 14 years ago
Adding Id property to all files git-svn-id: file:///usr/local/Singular/svn/trunk@12231 2c84dea3-7e68-4137-9b89-c4e89433aadc
  • Property mode set to 100644
File size: 3.2 KB
Line 
1#ifndef LONGALG_H
2#define LONGALG_H
3/****************************************
4*  Computer Algebra System SINGULAR     *
5****************************************/
6/* $Id$ */
7/*
8* ABSTRACT:   algebraic numbers
9*/
10#include "structs.h"
11#include "longrat.h"
12#include "polys-impl.h"
13
14struct slnumber;
15typedef struct slnumber * lnumber;
16
17struct slnumber
18{
19  napoly z;
20  napoly n;
21  BOOLEAN s;
22};
23
24extern napoly naMinimalPoly;
25extern ring nacRing;
26
27
28void naSetChar(int p, ring r);
29void    naDelete (number *p, const ring r);
30number  naInit(int i, const ring r);                /* z := i */
31number  naPar(int i);                               /* z := par(i) */
32int     naParDeg(number n);                         /* i := deg(n) */
33int     naSize(number n);                           /* size desc. */
34int     naInt(number &n, const ring r);
35void    naNew(number *z);
36BOOLEAN naIsZero(number za);                         /* za = 0 ? */
37BOOLEAN naIsOne(number  za);                         /* za = 1 ? */
38BOOLEAN naIsMOne(number  za);                        /* za = -1 ? */
39BOOLEAN naEqual(number a, number b);                  /* a = b ? */
40BOOLEAN naGreater(number a, number b);                  /* dummy */
41number  naNeg(number za);                           /* za := - za */
42number  naInvers(number a);
43void    naPower(number x, int exp, number *lo);
44BOOLEAN naGreaterZero(number a);
45number  naCopy(number p);                              /* erg:= p */
46number  na_Copy(number p, const ring r);               /* erg:= p */
47number  naAdd(number la, number li);               /* lu := la+li */
48number  naMult(number la, number li);              /* lo := la*li */
49number  naDiv(number la, number li);               /* lo := la/li */
50number  naIntDiv(number la, number li);            /* lo := la/li */
51//number  naIntMod(number la, number li);            /* lo := la/li */
52number  naSub(number la, number li);               /* lu := la-li */
53void    naNormalize(number &p);
54number  naGcd(number a, number b, const ring r);
55number  naLcm(number a, number b, const ring r);
56const char *  naRead(const char * s, number * p);
57void    naWrite(number &p);
58char *  naName(number n);
59nMapFunc naSetMap(ring src, ring dst);
60number naMap0P(number c);
61number naMap00(number c);
62#ifdef LDEBUG
63BOOLEAN naDBTest(number a, const char *f,const int l);
64#endif
65
66void    naSetIdeal(ideal I);
67
68// external access to the interna
69poly naPermNumber(number z, int * par_perm, int P, ring r);
70#define napAddExp(p,i,e)       (p_AddExp(p,i,e,currRing->algring))
71#define napLength(p)           pLength(p)
72#define napNeg(p)              (p_Neg(p,currRing->algring))
73#define napVariables           naNumbOfPar
74#define napGetCoeff(p)         pGetCoeff(p)
75#define napGetExpFrom(p,i,r)   (p_GetExp(p,i,r->algring))
76#define napSetExp(p,i,e)       (p_SetExp(p,i,e,currRing->algring))
77#define napNew()               (p_Init(currRing->algring))
78#define napAdd(p1,p2)          (p_Add_q(p1,p2,currRing->algring))
79#define napSetm(p)             p_Setm(p,currRing->algring)
80#define nanumber               lnumber
81napoly napRemainder(napoly f, const napoly  g);
82void napWrite(napoly l,const BOOLEAN denom=TRUE);
83number   naGetDenom(number &n, const ring r);
84number   naGetNumerator(number &n, const ring r);
85#endif
86
Note: See TracBrowser for help on using the repository browser.