00001
00002
00003
00004
00005
00006
00007
00008
00009 #ifndef EllipticIntegral_h
00010 #define EllipticIntegral_h 1
00011 #include "CLHEP/GenericFunctions/AbsFunction.hh"
00012 #include "CLHEP/GenericFunctions/Parameter.hh"
00013
00014 namespace Genfun {
00015 namespace EllipticIntegral {
00016
00017 class FirstKind : public AbsFunction {
00018
00019 FUNCTION_OBJECT_DEF(FirstKind)
00020
00021 public:
00022
00023
00024 FirstKind ();
00025
00026
00027 FirstKind(const FirstKind &right);
00028
00029
00030 virtual ~FirstKind();
00031
00032
00033 virtual double operator ()(double argument) const;
00034 virtual double operator ()(const Argument & a) const {return operator() (a[0]);}
00035
00036
00037 Parameter & k();
00038 const Parameter & k() const;
00039
00040 private:
00041
00042
00043 const FirstKind & operator=(const FirstKind &right);
00044
00045 Parameter _k;
00046
00047 };
00048
00049 class SecondKind : public AbsFunction {
00050
00051 FUNCTION_OBJECT_DEF(SecondKind)
00052
00053 public:
00054
00055
00056 SecondKind ();
00057
00058
00059 SecondKind(const SecondKind &right);
00060
00061
00062 virtual ~SecondKind();
00063
00064
00065 virtual double operator ()(double argument) const;
00066 virtual double operator ()(const Argument & a) const {return operator() (a[0]);}
00067
00068
00069 Parameter & k();
00070 const Parameter & k() const;
00071
00072 private:
00073
00074
00075 const SecondKind & operator=(const SecondKind &right);
00076
00077 Parameter _k;
00078
00079 };
00080
00081 class ThirdKind : public AbsFunction {
00082
00083 FUNCTION_OBJECT_DEF(ThirdKind)
00084
00085 public:
00086
00087
00088 ThirdKind ();
00089
00090
00091 ThirdKind(const ThirdKind &right);
00092
00093
00094 virtual ~ThirdKind();
00095
00096
00097 virtual double operator ()(double argument) const;
00098 virtual double operator ()(const Argument & a) const {return operator() (a[0]);}
00099
00100
00101 Parameter & k();
00102 const Parameter & k() const;
00103
00104
00105 Parameter & n();
00106 const Parameter & n() const;
00107
00108 private:
00109
00110
00111 const ThirdKind & operator=(const ThirdKind &right);
00112
00113 Parameter _k;
00114 Parameter _n;
00115
00116 };
00117
00118 }
00119 }
00120
00121 #include "CLHEP/GenericFunctions/EllipticIntegral.icc"
00122 #endif