CLHEP/GenericFunctions/Gaussian.hh

// -*- C++ -*-
// $Id: Gaussian.hh,v 1.2 2001/05/16 05:10:34 joeb Exp $
//---------------------Gaussian---------------------------------------------//
//                                                                          //
// Class Gaussian                                                           //
// Joe Boudreau, Petar Maksimovic, November 1999                            //
//                                                                          //
//--------------------------------------------------------------------------//
#ifndef Gaussian_h
#define Gaussian_h 1
#include "CLHEP/GenericFunctions/AbsFunction.hh"
#include "CLHEP/GenericFunctions/Parameter.hh"

HEP_BEGIN_NAMESPACE(Genfun)

  class Gaussian : public AbsFunction  {

    FUNCTION_OBJECT_DEF(Gaussian)

      public:

    // Constructor
    Gaussian();

    // Copy constructor
    Gaussian(const Gaussian &right);
  
    // Destructor
    virtual ~Gaussian();
  
    // Retreive function value
    virtual double operator ()(double argument) const;
    virtual double operator ()(const Argument & a) const {return operator() (a[0]);}
  
    // Get the mean of the Gaussian
    Parameter & mean(); 
    const Parameter & mean() const; 

    // Get the sigma of the Gaussian
    Parameter & sigma();
    const Parameter & sigma() const;

    // Derivative.  
    Derivative partial (unsigned int) const;

    // Does this function have an analytic derivative?
    virtual bool hasAnalyticDerivative() const {return true;}

  
  private:

    // It is illegal to assign an adjustable constant
    const Gaussian & operator=(const Gaussian &right);

    // Here is the decay constant
    Parameter _mean;

    // Here is the sigma
    Parameter _sigma;
  };
HEP_END_NAMESPACE(Genfun)

#endif

Generated by GNU enscript 1.6.1.