File: term.cpp

package info (click to toggle)
gfan 0.5%2Bdfsg-5
  • links: PTS
  • area: main
  • in suites: jessie, jessie-kfreebsd
  • size: 8,296 kB
  • ctags: 5,612
  • sloc: cpp: 39,675; makefile: 453; sh: 1
file content (27 lines) | stat: -rw-r--r-- 580 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
#include "term.h"

#include "printer.h"

Term::Term(FieldElement const &c_, Monomial const &m_):m(m_),c(c_),theRing(m_.getRing())
{
  //  fprintf(Stderr,"TermConstructor :");
  //  AsciiPrinter(Stderr).printFieldElement(c);
  //  AsciiPrinter(Stderr).printMonomial(m);
}

void Term::operator*=(const Term &t)
{
  m.exponent+=t.m.exponent;
  c*=t.c;
}

Term Term::operator/(const Term &b)const
{
  return Term(c*b.c.inverse(),Monomial(theRing,m.exponent-b.m.exponent));
}

Term Term::operator/(const Monomial &b)const
{
  return Term(c,Monomial(theRing,m.exponent-b.exponent));
}