248 lines
5.6 KiB
248 lines
5.6 KiB
|
|
|
|
%module ModRationalFunction
|
|
%{
|
|
#include <carl/core/RationalFunction.h>
|
|
#include <carl/core/MultivariatePolynomial.h>
|
|
#include <carl/core/FactorizedPolynomial.h>
|
|
|
|
|
|
|
|
typedef mpq_class Rational;
|
|
|
|
|
|
typedef carl::Term<Rational> Term;
|
|
typedef carl::MultivariatePolynomial<Rational> Polynomial;
|
|
typedef carl::FactorizedPolynomial<Polynomial> FactorizedPolynomial;
|
|
typedef carl::RationalFunction<Polynomial> RationalFunction;
|
|
typedef carl::RationalFunction<FactorizedPolynomial> FactorizedRationalFunction;
|
|
|
|
|
|
typedef unsigned int uint;
|
|
|
|
%}
|
|
|
|
|
|
|
|
%include "std_string.i"
|
|
//TODO: for 32 bit support this has to be changed..
|
|
//%import <stddef> //for size_t maybe?
|
|
typedef long unsigned int size_t; //this should be okay for 64 bits at least
|
|
|
|
|
|
%import "rational.i"
|
|
%import "variable.i"
|
|
%import "monomial.i"
|
|
%import "term.i"
|
|
%import "polynomial.i"
|
|
%import "factorizedpolynomial.i"
|
|
|
|
typedef carl::Term<Rational> Term;
|
|
typedef carl::MultivariatePolynomial<Rational> Polynomial;
|
|
typedef carl::FactorizedPolynomial<Polynomial> FactorizedPolynomial;
|
|
|
|
typedef carl::RationalFunction<FactorizedPolynomial> FactorizedRationalFunction;
|
|
|
|
|
|
%rename(RationalFunction) carl::RationalFunction<Polynomial>;
|
|
%rename(FactorizedRationalFunction) carl::RationalFunction<FactorizedPolynomial>;
|
|
namespace carl {
|
|
|
|
|
|
|
|
class RationalFunction<Polynomial>
|
|
{
|
|
public:
|
|
typedef typename Rational CoeffType;
|
|
explicit RationalFunction(const Polynomial& nom, const Polynomial& denom):
|
|
mPolynomialQuotient(nullptr),
|
|
mNumberQuotient(),
|
|
mIsSimplified(false)
|
|
{
|
|
}
|
|
|
|
CoeffType evaluate(const std::map<Variable, CoeffType>& substitutions) const;
|
|
|
|
inline Polynomial nominator() const;
|
|
|
|
inline Polynomial denominator() const;
|
|
|
|
|
|
%extend {
|
|
std::string toString() {
|
|
std::stringstream ss;
|
|
ss << *$self;
|
|
return ss.str();
|
|
}
|
|
|
|
Polynomial numerator() const {
|
|
return $self->nominator();
|
|
}
|
|
|
|
std::vector<carl::Variable> gatherVariables() const {
|
|
std::set<carl::Variable> asSet = $self->gatherVariables();
|
|
return std::vector<carl::Variable>(asSet.begin(),asSet.end());
|
|
}
|
|
|
|
|
|
bool equals(const carl::RationalFunction<Polynomial>& other) {
|
|
return *$self == other;
|
|
}
|
|
bool notEquals(const carl::RationalFunction<Polynomial>& other) {
|
|
return *$self != other;
|
|
}
|
|
|
|
|
|
|
|
|
|
carl::RationalFunction<Polynomial> add(const Polynomial& rhs) {
|
|
return *($self)+rhs;
|
|
}
|
|
|
|
|
|
carl::RationalFunction<Polynomial> add(const Term& rhs) {
|
|
return *($self)+rhs;
|
|
}
|
|
|
|
carl::RationalFunction<Polynomial> add(const Monomial::Arg& rhs) {
|
|
return *($self)+rhs;
|
|
}
|
|
|
|
carl::RationalFunction<Polynomial> add(carl::Variable::Arg rhs) {
|
|
return *($self)+rhs;
|
|
}
|
|
|
|
carl::RationalFunction<Polynomial> add(Rational rhs) {
|
|
return *($self)+rhs;
|
|
}
|
|
|
|
|
|
carl::RationalFunction<Polynomial> sub(const Polynomial& rhs) {
|
|
return *($self)-rhs;
|
|
}
|
|
|
|
carl::RationalFunction<Polynomial> sub(const Term& rhs) {
|
|
return *($self)-rhs;
|
|
}
|
|
|
|
carl::RationalFunction<Polynomial> sub(const Monomial::Arg& rhs) {
|
|
return *($self)-rhs;
|
|
}
|
|
|
|
carl::RationalFunction<Polynomial> sub(carl::Variable::Arg rhs) {
|
|
return *($self)-rhs;
|
|
}
|
|
|
|
carl::RationalFunction<Polynomial> sub(Rational rhs) {
|
|
return *($self)-rhs;
|
|
}
|
|
|
|
|
|
|
|
carl::RationalFunction<Polynomial> mul(const Polynomial& rhs) {
|
|
return *($self)*rhs;
|
|
}
|
|
|
|
carl::RationalFunction<Polynomial>mul(const Term& rhs) {
|
|
return *($self)*rhs;
|
|
}
|
|
|
|
carl::RationalFunction<Polynomial> mul(const Monomial::Arg& rhs) {
|
|
return *($self)*rhs;
|
|
}
|
|
|
|
carl::RationalFunction<Polynomial> mul(carl::Variable::Arg rhs) {
|
|
return *($self)*rhs;
|
|
}
|
|
|
|
carl::RationalFunction<Polynomial> mul(Rational rhs) {
|
|
return *($self)*rhs;
|
|
}
|
|
|
|
carl::RationalFunction<Polynomial> div(const Polynomial& rhs) {
|
|
return *($self)/rhs;
|
|
}
|
|
|
|
carl::RationalFunction<Polynomial> div(const Term& rhs) {
|
|
return *($self)/rhs;
|
|
}
|
|
|
|
carl::RationalFunction<Polynomial> div(const Monomial::Arg& rhs) {
|
|
return *($self)/rhs;
|
|
}
|
|
|
|
carl::RationalFunction<Polynomial> div(carl::Variable::Arg rhs) {
|
|
return *($self)/rhs;
|
|
}
|
|
|
|
carl::RationalFunction<Polynomial> div(Rational rhs) {
|
|
return *($self)/rhs;
|
|
}
|
|
|
|
carl::RationalFunction<Polynomial> div(const RationalFunction& rhs) {
|
|
return *($self)/rhs;
|
|
}
|
|
|
|
|
|
carl::RationalFunction<Polynomial> pow(uint exp) {
|
|
return carl::pow(*($self),exp);
|
|
}
|
|
|
|
carl::RationalFunction<Polynomial> neg() {
|
|
return *$self*Rational(-1);
|
|
}
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
class RationalFunction<FactorizedPolynomial> {
|
|
public:
|
|
typedef typename Rational CoeffType;
|
|
explicit RationalFunction(const FactorizedPolynomial& nom, const FactorizedPolynomial& denom):
|
|
mPolynomialQuotient(nullptr),
|
|
mNumberQuotient(),
|
|
mIsSimplified(false)
|
|
{
|
|
}
|
|
|
|
CoeffType evaluate(const std::map<Variable, CoeffType>& substitutions) const;
|
|
|
|
inline FactorizedPolynomial nominator() const;
|
|
|
|
inline FactorizedPolynomial denominator() const;
|
|
|
|
|
|
%extend {
|
|
std::string toString() {
|
|
std::stringstream ss;
|
|
ss << *$self;
|
|
return ss.str();
|
|
}
|
|
|
|
FactorizedPolynomial numerator() const {
|
|
return $self->nominator();
|
|
}
|
|
|
|
std::vector<carl::Variable> gatherVariables() const {
|
|
std::set<carl::Variable> asSet = $self->gatherVariables();
|
|
return std::vector<carl::Variable>(asSet.begin(),asSet.end());
|
|
}
|
|
|
|
bool equals(const carl::RationalFunction<FactorizedPolynomial>& other) {
|
|
return *$self == other;
|
|
}
|
|
|
|
}
|
|
};
|
|
|
|
}
|
|
|
|
typedef carl::RationalFunction<Polynomial> RationalFunction;
|
|
|
|
|
|
/*
|
|
%template(RationalFunctionPoly) carl::RationalFunction<Polynomial>;
|
|
%template(FactorizedRationalFunction) carl::RationalFunction<carl::FactorizedPolynomial<Polynomial>,false>; */
|
|
|