X-Git-Url: https://www.ginac.de/ginac.git//ginac.git?p=ginac.git;a=blobdiff_plain;f=ginac%2Fexpair.h;h=4b1a42e859a8f52544806d1d5ce7227405e37b49;hp=a170ae8649ba994b621ebc6ef15d51bde99c528f;hb=bb0f99d6298fccb8cf1421fa0c7463c647f543a7;hpb=dbd9c306a74f1cb258c0d15a346b973b39deaad2 diff --git a/ginac/expair.h b/ginac/expair.h index a170ae86..4b1a42e8 100644 --- a/ginac/expair.h +++ b/ginac/expair.h @@ -3,7 +3,7 @@ * Definition of expression pairs (building blocks of expairseq). */ /* - * GiNaC Copyright (C) 1999-2003 Johannes Gutenberg University Mainz, Germany + * GiNaC Copyright (C) 1999-2011 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 @@ -17,11 +17,11 @@ * * 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 + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA */ -#ifndef __GINAC_EXPAIR_H__ -#define __GINAC_EXPAIR_H__ +#ifndef GINAC_EXPAIR_H +#define GINAC_EXPAIR_H #include "ex.h" #include "numeric.h" @@ -38,20 +38,7 @@ class expair { public: expair() : rest(0), coeff(1) { } - ~expair() { } - expair(const expair & other) : rest(other.rest), coeff(other.coeff) - { - GINAC_ASSERT(is_exactly_a(coeff)); - } - const expair & operator=(const expair & other) - { - if (this != &other) { - rest = other.rest; - coeff = other.coeff; - } - return *this; - } - + /** Construct an expair from two ex. */ expair(const ex & r, const ex & c) : rest(r), coeff(c) { @@ -85,7 +72,7 @@ public: void print(std::ostream & os) const; /** True if this is of the form (numeric,ex(1)). */ - bool is_canonical_numeric(void) const + bool is_canonical_numeric() const { GINAC_ASSERT(is_exactly_a(coeff)); return (is_exactly_a(rest) && (coeff.is_equal(1))); @@ -97,7 +84,9 @@ public: rest.swap(other.rest); coeff.swap(other.coeff); } - + + const expair conjugate() const; + ex rest; ///< first member of pair, an arbitrary expression ex coeff; ///< second member of pair, must be numeric }; @@ -128,4 +117,4 @@ inline void iter_swap(std::vector::iterator i1, std::vector::ite } // namespace GiNaC -#endif // ndef __GINAC_EXPAIR_H__ +#endif // ndef GINAC_EXPAIR_H