X-Git-Url: https://www.ginac.de/ginac.git//ginac.git?p=ginac.git;a=blobdiff_plain;f=ginac%2Frelational.h;h=9f58e0c7125e0a2aae73e50e4822d014181eddd3;hp=c9c0eb68700e2029eea28c87bcb4f0eacd1e44ba;hb=a053768864556ce627f958a38fb1169ab00b8229;hpb=19c8f943c15dcc0d946fb4d5fef11e487d34857a diff --git a/ginac/relational.h b/ginac/relational.h index c9c0eb68..9f58e0c7 100644 --- a/ginac/relational.h +++ b/ginac/relational.h @@ -3,7 +3,7 @@ * Interface to relations between expressions. */ /* - * GiNaC Copyright (C) 1999-2000 Johannes Gutenberg University Mainz, Germany + * GiNaC Copyright (C) 1999-2003 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 @@ -26,9 +26,7 @@ #include "basic.h" #include "ex.h" -#ifndef NO_NAMESPACE_GINAC namespace GiNaC { -#endif // ndef NO_NAMESPACE_GINAC /** This class holds a relation consisting of two expressions and a logical * relation between them. */ @@ -47,39 +45,26 @@ public: greater_or_equal }; -// member functions - - // default constructor, destructor, copy constructor assignment operator and helpers -public: - relational(); - ~relational(); - relational(const relational & other); - const relational & operator=(const relational & other); -protected: - void copy(const relational & other); - void destroy(bool call_parent); - - // other constructors + // other ctors public: relational(const ex & lhs, const ex & rhs, operators oper=equal); - // functions overriding virtual functions from bases classes + // functions overriding virtual functions from base classes public: - basic * duplicate() const; - void print(std::ostream & os, unsigned upper_precedence=0) const; - void printraw(std::ostream & os) const; - void printcsrc(std::ostream & os, unsigned type, unsigned upper_precedence=0) const; + void print(const print_context & c, unsigned level = 0) const; + unsigned precedence(void) const {return 20;} bool info(unsigned inf) const; unsigned nops() const; ex & let_op(int i); ex eval(int level=0) const; - ex evalf(int level=0) const; - ex normal(lst &sym_lst, lst &repl_lst, int level=0) const; + ex subs(const lst & ls, const lst & lr, bool no_pattern = false) const; ex simplify_ncmul(const exvector & v) const; + protected: - int compare_same_type(const basic & other) const; + bool match_same_type(const basic & other) const; unsigned return_type(void) const; unsigned return_type_tinfo(void) const; + unsigned calchash(void) const; // new virtual functions which can be overridden by derived classes public: @@ -96,22 +81,16 @@ protected: ex lh; ex rh; operators o; - static unsigned precedence; }; -// global constants - -extern const relational some_relational; -extern const type_info & typeid_relational; - // utility functions -inline const relational &ex_to_relational(const ex &e) + +/** Specialization of is_exactly_a(obj) for relational objects. */ +template<> inline bool is_exactly_a(const basic & obj) { - return static_cast(*e.bp); + return obj.tinfo()==TINFO_relational; } -#ifndef NO_NAMESPACE_GINAC } // namespace GiNaC -#endif // ndef NO_NAMESPACE_GINAC #endif // ndef __GINAC_RELATIONAL_H__