X-Git-Url: https://www.ginac.de/ginac.git//ginac.git?p=ginac.git;a=blobdiff_plain;f=ginac%2Fconstant.h;h=c43465ae6f732485d0fcf12b82f62e371bf494df;hp=e772ada848566a796b9e307f48748a6f2cdd5bb6;hb=fbdd5eefb7188778ca9c04b5bee08223609b880f;hpb=a8507b8af1c08d9b27d98d57f95c7ca1a8671e27 diff --git a/ginac/constant.h b/ginac/constant.h index e772ada8..c43465ae 100644 --- a/ginac/constant.h +++ b/ginac/constant.h @@ -1,8 +1,9 @@ /** @file constant.h * - * Interface to GiNaC's constant types and some special constants. - * - * GiNaC Copyright (C) 1999 Johannes Gutenberg University Mainz, Germany + * Interface to GiNaC's constant types and some special constants. */ + +/* + * GiNaC Copyright (C) 1999-2001 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 @@ -23,67 +24,69 @@ #define __GINAC_CONSTANT_H__ #include +#include "basic.h" +#include "ex.h" + +namespace GiNaC { +typedef ex (*evalffunctype)(void); + /** This class holds constants, symbols with specific numerical value. Each * object of this class must either provide their own function to evaluate it * to class numeric or provide the constant as a numeric (if it's an exact * number). */ class constant : public basic { - + GINAC_DECLARE_REGISTERED_CLASS(constant, basic) + // member functions - - // default constructor, destructor, copy constructor assignment operator and helpers + + // other ctors public: - ~constant(); - constant(constant const & other); - // constant const & operator=(constant const & other); /* it's pervert! */ -protected: - void copy(constant const & other); - void destroy(bool call_parent); - - // other constructors -public: - constant(string const & initname, ex (*efun)()=0); - constant(string const & initname, numeric const & initnumber); - - // functions overriding virtual functions from bases classes + constant(const std::string & initname, evalffunctype efun = 0, const std::string & texname = std::string()); + constant(const std::string & initname, const numeric & initnumber, const std::string & texname = std::string()); + + // functions overriding virtual functions from base classes public: - basic * duplicate() const; - void printraw(ostream & os) const; - void print(ostream & os, unsigned upper_precedence=0) const; - void printcsrc(ostream & os, unsigned type, unsigned upper_precedence=0) const; - ex evalf(int level=0) const; - ex diff(symbol const & s) const; + void print(const print_context & c, unsigned level = 0) const; + int degree(const ex & s) const; + int ldegree(const ex & s) const; + ex coeff(const ex & s, int n = 1) const; + ex evalf(int level = 0) const; protected: - int compare_same_type(basic const & other) const; - bool is_equal_same_type(basic const & other) const; - - // new virtual functions which can be overridden by derived classes - // none - - // non-virtual functions in this class - // none - + ex derivative(const symbol & s) const; + bool is_equal_same_type(const basic & other) const; + unsigned calchash(void) const; + + // new virtual functions which can be overridden by derived classes + // none + + // non-virtual functions in this class + // none + // member variables - + private: - string name; - ex (*ef)(); - numeric * number; - bool fct_assigned; - unsigned serial; //!< unique serial number for comparision - static unsigned next_serial; + std::string name; ///< printname of this constant + std::string TeX_name; ///< LaTeX name + evalffunctype ef; + numeric *number; ///< numerical value this constant evalf()s to + unsigned serial; ///< unique serial number for comparison + static unsigned next_serial; }; -// global constants - -extern const constant some_constant; -extern type_info const & typeid_constant; - -// extern const numeric I; extern const constant Pi; extern const constant Catalan; -extern const constant EulerGamma; +extern const constant Euler; + +// utility functions + +/** Specialization of is_exactly_a(obj) for constant objects. */ +template<> inline bool is_exactly_a(const basic & obj) +{ + return obj.tinfo()==TINFO_constant; +} + +} // namespace GiNaC #endif // ndef __GINAC_CONSTANT_H__