Public Member Functions | Private Attributes
CShiftSpecialPairMultiplier Class Reference

#include <ncSAMult.h>

Public Member Functions

 CShiftSpecialPairMultiplier (ring r, int i, int j, int s, number c)
 
virtual ~CShiftSpecialPairMultiplier ()
 
virtual poly MultiplyEE (const int expLeft, const int expRight)
 
- Public Member Functions inherited from CSpecialPairMultiplier
 CSpecialPairMultiplier (ring r, int i, int j)
 
virtual ~CSpecialPairMultiplier ()
 
int GetI () const
 
int GetJ () const
 
virtual poly MultiplyME (const poly pMonom, const CExponent expRight)
 
virtual poly MultiplyEM (const CExponent expLeft, const poly pMonom)
 
- Public Member Functions inherited from CMultiplier< int >
 CMultiplier (ring rBaseRing)
 
virtual ~CMultiplier ()
 
ring GetBasering () const
 
int NVars () const
 
poly LM (const poly pTerm, const ring r, int i=1) const
 
poly MultiplyTE (const poly pTerm, const int expRight)
 
poly MultiplyET (const int expLeft, const poly pTerm)
 

Private Attributes

const number m_shiftCoef
 
const int m_shiftVar
 

Additional Inherited Members

- Public Types inherited from CSpecialPairMultiplier
typedef int CExponent
 
- Protected Attributes inherited from CMultiplier< int >
const ring m_basering
 
const int m_NVars
 

Detailed Description

Definition at line 575 of file ncSAMult.h.

Constructor & Destructor Documentation

§ CShiftSpecialPairMultiplier()

CShiftSpecialPairMultiplier::CShiftSpecialPairMultiplier ( ring  r,
int  i,
int  j,
int  s,
number  c 
)

Definition at line 697 of file ncSAMult.cc.

697  :
699 {
700 #if OUTPUT
701  Print("CShiftSpecialPairMultiplier::CShiftSpecialPairMultiplier(ring, i: %d, j: %d, s: %d, c)!", i, j, s);
702  PrintLn();
703  PrintS("Parameter c: "); n_Write(c, r);
704 #endif
705 }
const CanonicalForm int s
Definition: facAbsFact.cc:55
void PrintLn()
Definition: reporter.cc:310
#define Print
Definition: emacs.cc:83
CSpecialPairMultiplier(ring r, int i, int j)
Definition: ncSAMult.cc:1061
const ring r
Definition: syzextra.cc:208
int j
Definition: myNF.cc:70
static FORCE_INLINE void n_Write(number &n, const coeffs r, const BOOLEAN bShortOut=TRUE)
Definition: coeffs.h:595
int i
Definition: cfEzgcd.cc:123
void PrintS(const char *s)
Definition: reporter.cc:284
const number m_shiftCoef
Definition: ncSAMult.h:578

§ ~CShiftSpecialPairMultiplier()

CShiftSpecialPairMultiplier::~CShiftSpecialPairMultiplier ( )
virtual

Definition at line 708 of file ncSAMult.cc.

709 {
710 #if OUTPUT
711  PrintS("CShiftSpecialPairMultiplier::~CShiftSpecialPairMultiplier()");
712  PrintLn();
713 #endif
714 }
void PrintLn()
Definition: reporter.cc:310
void PrintS(const char *s)
Definition: reporter.cc:284

Member Function Documentation

§ MultiplyEE()

poly CShiftSpecialPairMultiplier::MultiplyEE ( const int  expLeft,
const int  expRight 
)
virtual

Implements CSpecialPairMultiplier.

Definition at line 717 of file ncSAMult.cc.

718 {
719 #if OUTPUT
720  Print("CShiftSpecialPairMultiplier::MultiplyEE(var(%d)^{%d}, var(%d)^{%d})!", GetJ(), expLeft, GetI(), expRight);
721  PrintLn();
722 #endif
723  // Char == 0, otherwise - problem!
724 
725  assume( expLeft*expRight > 0 );
726 
727  const ring r = GetBasering();
728 
729  if( m_shiftVar != GetI() ) // YX = XY + b*Y?
730  return CFormulaPowerMultiplier::ncSA_1xy0xBy0(GetI(), GetJ(), expRight, expLeft, m_shiftCoef, r); // case: (1, 0, beta, 0, 0)
731  else
732  return CFormulaPowerMultiplier::ncSA_1xyAx0y0(GetI(), GetJ(), expRight, expLeft, m_shiftCoef, r); // case: (1, alpha, 0, 0)
733 
734 }
ring GetBasering() const
Definition: ncSAMult.h:40
void PrintLn()
Definition: reporter.cc:310
#define Print
Definition: emacs.cc:83
static poly ncSA_1xyAx0y0(const int i, const int j, const int n, const int m, const number m_shiftCoef, const ring r)
Definition: ncSAFormula.cc:740
int GetI() const
Definition: ncSAMult.h:113
static poly ncSA_1xy0xBy0(const int i, const int j, const int n, const int m, const number m_shiftCoef, const ring r)
Definition: ncSAFormula.cc:745
int GetJ() const
Definition: ncSAMult.h:114
const ring r
Definition: syzextra.cc:208
#define assume(x)
Definition: mod2.h:403
const number m_shiftCoef
Definition: ncSAMult.h:578

Field Documentation

§ m_shiftCoef

const number CShiftSpecialPairMultiplier::m_shiftCoef
private

Definition at line 578 of file ncSAMult.h.

§ m_shiftVar

const int CShiftSpecialPairMultiplier::m_shiftVar
private

Definition at line 579 of file ncSAMult.h.


The documentation for this class was generated from the following files: