nforder_ideal.cc
Go to the documentation of this file.
1 #include <coeffs/bigintmat.h>
2 #include "nforder.h"
3 #include <reporter/reporter.h>
4 #include <coeffs/numbers.h>
5 #include <coeffs/coeffs.h>
6 #include "Singular/ipid.h"
7 #include "nforder_ideal.h"
8 
9 
10 
11 
12 ////////////////////////////////////
13 //// Konstruktoren/Destruktoren ////
14 ////////////////////////////////////
15 
16 /*________________0_______________*/
18  memset(this, 0, sizeof(nforder_ideal));
19 }
20 
22  init();
23  ord = O;
24  basis = new bigintmat(_basis);
25 }
26 
28  init();
29  ord = I->ord;
30  coeffs C = ((nforder *)ord->data)->basecoeffs();
31  basis = new bigintmat(I->basis);
32  if (I->den) {
33  den = n_Copy(I->den, C);
34  }
35  if (I->norm) {
36  norm = n_Copy(I->norm, C);
37  norm_den = n_Copy(I->norm_den, C);
38  }
39  if (I->min) {
40  min = n_Copy(I->min, C);
41  min_den = n_Copy(I->min_den, C);
42  }
43 }
44 
46  coeffs C = ((nforder *)ord->data)->basecoeffs();
47  if (isFractional()) {
48  StringAppendS("Fractional ");
49  }
50  StringAppend("Ideal with basis:\n");
51  basis->Write();
52  if (isFractional()) {
53  number d;
54  StringAppend(" / ");
55  n_Write((d = viewBasisDen()), C);
56  }
57  StringAppendS("\n");
58  if (norm) {
59  StringAppendS("and norm ");
60  n_Write(norm, C);
61  StringAppendS(" / ");
62  n_Write(norm_den, C);
63  StringAppendS(" ");
64  }
65  if (min) {
66  StringAppendS("and min ");
67  n_Write(min, C);
68  StringAppendS(" / ");
69  n_Write(min_den, C);
70  StringAppendS(" ");
71  }
72 }
73 
75  StringSetS("");
76  Write();
77  return StringEndS();
78 }
80  char * s = String();
81  PrintS(s);
82  PrintS("\n");
83  omFree(s);
84 }
85 
87  if (basis) delete basis;
88  coeffs C = ((nforder *)ord->data)->basecoeffs();
89  if (den) n_Delete(&den, C);
90  if (norm) {
91  n_Delete(&norm, C);
92  n_Delete(&norm_den, C);
93  }
94  if (min) {
95  n_Delete(&min, C);
96  n_Delete(&min_den, C);
97  }
98 }
99 
101 {
102  assume(A->order() == B->order());
103  nforder * O = (nforder*) A->order()->data;
104  coeffs C = O->basecoeffs();
105  bigintmat * r = new bigintmat(O->getDim(), 2*O->getDim(), C),
106  *s1, *s2;
107  number den = NULL;
108  if (B->isFractional()) {
109  s1 = A->getBasis();
110  s1->skalmult(B->viewBasisDen(), C);
111  den = n_Copy(B->viewBasisDen(), C);
112  } else {
113  s1 = A->viewBasis();
114  }
115  if (A->isFractional()) {
116  s2 = B->getBasis();
117  s2->skalmult(A->viewBasisDen(), C);
118  if (den) {
119  number d = n_Mult(den, A->viewBasisDen(), C);
120  n_Delete(&den, C);
121  den = d;
122  } else {
123  den = n_Copy(A->viewBasisDen(), C);
124  }
125  } else {
126  s2 = B->viewBasis();
127  }
128  r->concatcol(s1, s2);
129 
130  if (A->isFractional())
131  delete s2;
132  if (B->isFractional())
133  delete s1;
134 
135  number modA = NULL, modB = NULL;
136  if (!(modA = A->viewMin())) {
137  modA = A->viewNorm();
138  }
139  if (!(modB = B->viewMin())) {
140  modB = B->viewNorm();
141  }
142  bigintmat *t2;
143  if (modA && modB) {
144  number mod = n_Gcd(modA, modB, C);
145  t2 = r->modhnf(mod, C);
146  n_Delete(&mod, C);
147  } else {
148  r->hnf();
149  t2 = new bigintmat(O->getDim(), O->getDim(), C);
150  t2->copySubmatInto(r, 1, O->getDim()+1, O->getDim(), O->getDim(), 1,1);
151  }
152  delete r;
153  if (den) {
154  t2->simplifyContentDen(&den);
155  }
156  nforder_ideal *D = new nforder_ideal(t2, A->order());
157  if (den)
158  D->setBasisDenTransfer(den);
159 
160  if (O->oneIsOne())
161  D->setMinTransfer(t2->get(1,1), den ? n_Copy(den, C) : n_Init(1, C));
162  D->setNormTransfer(t2->det(), den ? n_Copy(den, C) : n_Init(1, C));
163  delete t2;
164  return D;
165 }
166 
167 
169 {
170  assume(A->order() == B->order());
171  nforder * O = (nforder*) A->order()->data;
172  coeffs C = O->basecoeffs();
173  number den = NULL;
174 
175  bigintmat * r= NULL;
176  bigintmat * c = new bigintmat(O->getDim(), 1, C),
177  *rep = new bigintmat(O->getDim(), O->getDim(), C);
178  for(int i=0; i<O->getDim(); i++) {
179  A->viewBasis()->getcol(i+1, c);
180  O->multmap(c, rep);
181  bigintmat * cc = bimMult(rep, B->viewBasis());
182  if (r) {
183  bigintmat * s = new bigintmat(O->getDim(), r->cols()+O->getDim(), C);
184  s->concatcol(r, cc);
185  delete r;
186  delete cc;
187  r = s;
188  } else {
189  r = cc;
190  }
191  }
192  delete c;
193 
194  number modA = NULL, modB = NULL;
195  if (!(modA = A->viewMin())) {
196  modA = A->viewNorm();
197  }
198  if (!(modB = B->viewMin())) {
199  modB = B->viewNorm();
200  }
201 
202 
203  bigintmat * t1;
204  if (modA && modB) {
205  number mod = n_Mult(modA, modB, C);
206  t1 = r->modhnf(mod, C);
207  n_Delete(&mod, C);
208  } else {
209  r->hnf();
210  t1 = new bigintmat(O->getDim(), O->getDim(), C);
211  r->getColRange(r->cols()-O->getDim()+1, O->getDim(), t1);
212  }
213  delete r;
214 
215  if (A->isFractional()) {
216  den = A->viewBasisDen();
217  }
218  if (B->isFractional()) {
219  if (den)
220  den = n_Mult(den, B->viewBasisDen(), C);
221  else
222  den = n_Copy(B->viewBasisDen(), C);
223  }
224  if (den) {
225  t1->simplifyContentDen(&den);
226  }
227  nforder_ideal *D = new nforder_ideal(t1, A->order());
228  if (den)
229  D->setBasisDenTransfer(den);
230 
231  if (O->oneIsOne())
232  D->setMinTransfer(t1->get(1,1), den ? n_Copy(den, C) : n_Init(1, C));
233  D->setNormTransfer(t1->det(), den ? n_Copy(den, C) : n_Init(1, C));
234  delete t1;
235  return D;
236 }
237 
239 {
240  nforder * O = (nforder*) A->order()->data;
241  coeffs C = O->basecoeffs();
242  bigintmat * r = O->elRepMat((bigintmat*) b);
243  bigintmat * s = bimMult(r, A->viewBasis());
244  delete r;
245  if (A->isFractional()) {
246  number d = n_Copy(A->viewBasisDen(), C);
247  s->simplifyContentDen(&d);
248  nforder_ideal * res = new nforder_ideal(s, A->order());
249  res->setBasisDenTransfer(d);
250  return res;
251  } else {
252  return new nforder_ideal(s, A->order());
253  }
254 }
255 
257 {
258  nforder *ord = (nforder*) O->data;
259  coeffs C = ord->basecoeffs();
260  bigintmat * r = new bigintmat(ord->getDim(), ord->getDim(), C);
261  r->one();
262  number I = n_Init(i, C);
263  r->skalmult(I, C);
264  nforder_ideal * A = new nforder_ideal(r, O);
265  delete r;
266  number n;
267  n_Power(I, ord->getDim(), &n, C);
268  A->setNormTransfer(n, n_Init(1, C));
269  A->setMinTransfer(I, n_Init(1, C));
270  return A;
271 }
272 
274 {
275  nforder *ord = (nforder*) O->data;
276  bigintmat * r = ord->elRepMat((bigintmat*)I);
277  nforder_ideal * A = new nforder_ideal(r, O);
278  delete r;
279  return A;
280 }
281 
283 {
284  nforder * O = (nforder*) A->order()->data;
285  coeffs C = O->basecoeffs();
286  bigintmat * s = new bigintmat(A->viewBasis());
287  number bb = n_Init(b, C);
288  s->skalmult(bb, C);
289  n_Delete(&bb, C);
290 
291  if (A->isFractional()) {
292  number d = n_Copy(A->viewBasisDen(), C);
293  s->simplifyContentDen(&d);
294  nforder_ideal * res = new nforder_ideal(s, A->order());
295  res->setBasisDenTransfer(d);
296  return res;
297  } else {
298  return new nforder_ideal(s, A->order());
299  }
300 }
301 
303 {
304  if (i==0) {
305  return nf_idInit(1, A->order());
306  } else if (i==1) {
307  return new nforder_ideal(A, 1);
308  } else if (i<0) {
309  Werror("not done yet");
310  } else {
311  nforder_ideal *B = nf_idPower(A, i/2);
312  nforder_ideal *res = nf_idMult(B, B);
313  delete B;
314  if (i&1) {
315  nforder_ideal * C = nf_idMult(res, B);
316  delete res;
317  return C;
318  } else {
319  return res;
320  }
321  }
322 }
void concatcol(bigintmat *a, bigintmat *b)
Definition: bigintmat.cc:1047
number viewMin()
Definition: nforder_ideal.h:53
static FORCE_INLINE number n_Gcd(number a, number b, const coeffs r)
in Z: return the gcd of 'a' and 'b' in Z/nZ, Z/2^kZ: computed as in the case Z in Z/pZ...
Definition: coeffs.h:683
const CanonicalForm int s
Definition: facAbsFact.cc:55
nforder_ideal()
0 Konstruktoren/Destruktoren ///
CF_NO_INLINE CanonicalForm mod(const CanonicalForm &, const CanonicalForm &)
Definition: cf_inline.cc:564
number det()
det (via LaPlace in general, hnf for euc. rings)
Definition: bigintmat.cc:1412
bigintmat * viewBasis()
Definition: nforder_ideal.h:46
void simplifyContentDen(number *den)
ensures that Gcd(den, content)=1 < enden hier wieder
Definition: bigintmat.cc:2486
void setMinTransfer(number a, number b)
Definition: nforder_ideal.h:50
nforder_ideal * nf_idMult(nforder_ideal *A, nforder_ideal *B)
Matrices of numbers.
Definition: bigintmat.h:32
static FORCE_INLINE number n_Init(long i, const coeffs r)
a number representing i in the given coeff field/ring r
Definition: coeffs.h:537
const CanonicalForm CFMap CFMap int &both_non_zero int n
Definition: cfEzgcd.cc:52
coeffs order() const
Definition: nforder_ideal.h:45
number viewBasisDen()
Definition: nforder_ideal.h:48
nforder_ideal * nf_idInit(int i, coeffs O)
void getColRange(int j, int no, bigintmat *a)
copies the no-columns staring by j (so j...j+no-1) into the pre-allocated a
Definition: bigintmat.cc:768
void setNormTransfer(number a, number b)
Definition: nforder_ideal.h:51
char * StringEndS()
Definition: reporter.cc:151
bigintmat * getBasis()
Definition: nforder_ideal.h:47
void Write()
IO: writes the matrix into the current internal string buffer which must be started/ allocated before...
Definition: bigintmat.cc:411
bigintmat * elRepMat(bigintmat *a)
Definition: nforder.cpp:395
poly res
Definition: myNF.cc:322
static FORCE_INLINE number n_Mult(number a, number b, const coeffs r)
return the product of 'a' and 'b', i.e., a*b
Definition: coeffs.h:633
nforder_ideal * nf_idPower(nforder_ideal *A, int i)
const ring r
Definition: syzextra.cc:208
Coefficient rings, fields and other domains suitable for Singular polynomials.
void copySubmatInto(bigintmat *, int sr, int sc, int nr, int nc, int tr, int tc)
copy the submatrix of b, staring at (a,b) having n rows, m cols into the given matrix at pos...
Definition: bigintmat.cc:1202
bigintmat * bimMult(bigintmat *a, bigintmat *b)
Definition: bigintmat.cc:251
#define omFree(addr)
Definition: omAllocDecl.h:261
#define assume(x)
Definition: mod2.h:405
The main handler for Singular numbers which are suitable for Singular polynomials.
int isFractional()
Definition: nforder_ideal.h:49
void StringSetS(const char *st)
Definition: reporter.cc:128
void StringAppendS(const char *st)
Definition: reporter.cc:107
#define A
Definition: sirandom.c:23
bool skalmult(number b, coeffs c)
Multipliziert zur Matrix den Skalar b hinzu.
Definition: bigintmat.cc:904
D(ideal gnc_gr_bba(const ideal, const ideal, const intvec *, const intvec *, kStrategy, const ring _currRing)) D(ideal gnc_gr_mora(const ideal
Modified Plural's Buchberger's algorithmus.
static FORCE_INLINE void n_Write(number &n, const coeffs r, const BOOLEAN bShortOut=TRUE)
Definition: coeffs.h:590
void setBasisDenTransfer(number a)
Definition: nforder_ideal.h:54
void hnf()
transforms INPLACE to HNF
Definition: bigintmat.cc:1560
#define StringAppend
Definition: emacs.cc:82
int i
Definition: cfEzgcd.cc:123
void PrintS(const char *s)
Definition: reporter.cc:294
bigintmat * basis
Definition: nforder_ideal.h:19
int cols() const
Definition: bigintmat.h:128
void getcol(int j, bigintmat *a)
copies the j-th column into the matrix a - which needs to be pre-allocated with the correct size...
Definition: bigintmat.cc:741
bigintmat * modhnf(number p, coeffs c)
computes HNF(this | p*I)
Definition: bigintmat.cc:1715
static FORCE_INLINE void n_Power(number a, int b, number *res, const coeffs r)
fill res with the power a^b
Definition: coeffs.h:629
coeffs basecoeffs() const
Definition: nforder.h:76
#define NULL
Definition: omList.c:10
static FORCE_INLINE number n_Copy(number n, const coeffs r)
return a copy of 'n'
Definition: coeffs.h:451
CanonicalForm den(const CanonicalForm &f)
b *CanonicalForm B
Definition: facBivar.cc:51
char * String()
static FORCE_INLINE void n_Delete(number *p, const coeffs r)
delete 'p'
Definition: coeffs.h:455
nforder_ideal * nf_idAdd(nforder_ideal *A, nforder_ideal *B)
number viewNorm()
Definition: nforder_ideal.h:52
int getDim()
Definition: nforder.cpp:235
const poly b
Definition: syzextra.cc:213
void Werror(const char *fmt,...)
Definition: reporter.cc:199
void one()
Macht Matrix (Falls quadratisch) zu Einheitsmatrix.
Definition: bigintmat.cc:1236
number get(int i, int j) const
get a copy of an entry. NOTE: starts at [1,1]
Definition: bigintmat.cc:115