/** @file expair.h * * GiNaC Copyright (C) 1999 Johannes Gutenberg University Mainz, Germany * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */ #ifndef __GINAC_EXPAIR_H__ #define __GINAC_EXPAIR_H__ #include #include /** A pair of expressions. * This similar to, but slightly extended STL's pair<> but we need to account * for methods like .compare() */ class expair { public: expair() {} ~expair() {} expair(expair const & other) : rest(other.rest), coeff(other.coeff) { ASSERT(is_ex_exactly_of_type(coeff,numeric)); } expair const & operator=(expair const & other) { if (this != &other) { rest=other.rest; coeff=other.coeff; } return *this; } expair(ex const & r, ex const & c) : rest(r), coeff(c) { ASSERT(is_ex_exactly_of_type(coeff,numeric)); } bool is_numeric_with_coeff_1(void) const { ASSERT(is_ex_exactly_of_type(coeff,numeric)); return is_ex_exactly_of_type(rest,numeric) && (ex_to_numeric(coeff).compare(numONE())==0); } bool is_equal(expair const & other) const { return (rest.is_equal(other.rest) && coeff.is_equal(other.coeff)); } bool is_less(expair const & other) const { return (rest.compare(other.rest)<0) || (!(other.rest.compare(rest)<0) && (coeff.compare(other.coeff)<0)); } int compare(expair const & other) const { int cmpval=rest.compare(other.rest); if (cmpval!=0) return cmpval; cmpval=coeff.compare(other.coeff); return cmpval; } bool is_less_old2(expair const & other) const { /* bool this_numeric_with_coeff_1=is_numeric_with_coeff_1(); bool other_numeric_with_coeff_1=other.is_numeric_with_coeff_1(); if (this_numeric_with_coeff_1) { if (other_numeric_with_coeff_1) { // both have coeff 1: compare rests return rest.compare(other.rest)<0; } // only this has coeff 1: > return false; } else if (other_numeric_with_coeff_1) { // only other has coeff 1: < return true; } return (rest.compare(other.rest)<0) || (!(other.rest.compare(rest)<0) && (coeff.compare(other.coeff)<0)); */ if (is_ex_exactly_of_type(rest,numeric) && is_ex_exactly_of_type(other.rest,numeric)) { if (ex_to_numeric(coeff).compare(numONE())==0) { if (ex_to_numeric(other.coeff).compare(numONE())==0) { // both have coeff 1: compare rests return rest.compare(other.rest)<0; } // only this has coeff 1: > return false; } else if (ex_to_numeric(other.coeff).compare(numONE())==0) { // only other has coeff 1: < return true; } // neither has coeff 1: usual compare } return (rest.compare(other.rest)<0) || (!(other.rest.compare(rest)<0) && (coeff.compare(other.coeff)<0)); } int compare_old2(expair const & other) const { if (is_ex_exactly_of_type(rest,numeric) && is_ex_exactly_of_type(other.rest,numeric)) { if (ex_to_numeric(coeff).compare(numONE())==0) { if (ex_to_numeric(other.coeff).compare(numONE())==0) { // both have coeff 1: compare rests return rest.compare(other.rest); } // only this has coeff 1: > return 1; } else if (ex_to_numeric(other.coeff).compare(numONE())==0) { // only other has coeff 1: < return -1; } // neither has coeff 1: usual compare } /* bool this_numeric_with_coeff_1=is_numeric_with_coeff_1(); bool other_numeric_with_coeff_1=other.is_numeric_with_coeff_1(); if (this_numeric_with_coeff_1) { if (other_numeric_with_coeff_1) { // both have coeff 1: compare rests return rest.compare(other.rest); } // only this has coeff 1: > return 1; } else if (other_numeric_with_coeff_1) { // only other has coeff 1: < return -1; // neither has coeff 1: usual compare } */ int cmpval=rest.compare(other.rest); if (cmpval!=0) return cmpval; return coeff.compare(other.coeff); } bool is_less_old(expair const & other) const { return (rest.compare(other.rest)<0) || (!(other.rest.compare(rest)<0) && (coeff.compare(other.coeff)<0)); } int compare_old(expair const & other) const { int cmpval=rest.compare(other.rest); if (cmpval!=0) return cmpval; cmpval=coeff.compare(other.coeff); return cmpval; } void printraw(ostream & os) const { os << "expair("; rest.printraw(os); os << ","; coeff.printraw(os); os << ")"; } ex rest; ex coeff; }; class expair_is_less { public: bool operator()(expair const & lh, expair const & rh) const { return lh.is_less(rh); } }; class expair_is_less_old { public: bool operator()(expair const & lh, expair const & rh) const { return lh.is_less_old(rh); } }; #endif // ndef __GINAC_EXPAIR_H__