// -*- C++ -*- // $Id: SphericalBessel.hh,v 1.2 2003/09/06 14:04:13 boudreau Exp $ //---------------------SphericalBessel--------------------------------------// // // // Class SphericalBessel. An spherical bessel function of integral order // // Joe Boudreau, Petar Maksimovic, January 2000 // // // //--------------------------------------------------------------------------// #ifndef SphericalBessel_h #define SphericalBessel_h 1 #include "CLHEP/GenericFunctions/AbsFunction.hh" #include "CLHEP/GenericFunctions/Parameter.hh" namespace Genfun { /** * @author * @ingroup genfun */ class SphericalBessel : public AbsFunction { FUNCTION_OBJECT_DEF(SphericalBessel) public: // Constructor SphericalBessel(unsigned int l); // Copy constructor SphericalBessel(const SphericalBessel &right); // Destructor virtual ~SphericalBessel(); // Retreive function value virtual double operator ()(double argument) const; virtual double operator ()(const Argument & a) const {return operator() (a[0]);} // Get the integer variable l unsigned int l() const; private: // It is illegal to assign a spherical bessel const SphericalBessel & operator=(const SphericalBessel &right); // Here is the index unsigned int _l; }; } // namespace Genfun #include "CLHEP/GenericFunctions/SphericalBessel.icc" #endif