00001
00002
00003
00004 #ifndef GLAST_SPECTRUM_H
00005 #define GLAST_SPECTRUM_H
00006
00018 #include <string>
00019 #include <utility>
00020 #include <vector>
00021 #include "FluxSvc/ISpectrum.h"
00022
00023 class HepRandomEngine;
00024
00025
00028 class Spectrum : public ISpectrum {
00029 public:
00030
00031
00032
00033
00034
00035
00036
00037 virtual float operator()(float )const{return 0;};
00038
00039
00040
00041
00042
00043
00044
00045
00046
00048 virtual const char * particleName()const=0;
00049
00051 virtual double flux (double time ) const;
00052
00053
00055 virtual double solidAngle()const;
00056
00058 virtual std::string title()const=0;
00059
00062 float fraction(float energy);
00063
00064 virtual ~Spectrum();
00065
00067 virtual double interval (double time);
00068
00069 virtual std::pair<float,float> dir(float energy)const;
00070
00072 virtual double energySrc(HepRandomEngine* engine, double time=0);
00073
00078 virtual std::pair<double,double> dir(double energy, HepRandomEngine* engine);
00079
00080
00081
00082
00083 protected:
00084 Spectrum(const std::vector<float>& ){};
00085 Spectrum()
00086 {}
00087
00088
00089 virtual void parseParamList(std::string input, std::vector<float>& output) const;
00090
00091 double m_lat, m_lon;
00092 double m_currentInterval;
00093
00094 };
00095
00096 #endif