EvtGen 2.2.0
Monte Carlo generator of particle decays, in particular the weak decays of heavy flavour particles such as B mesons.
Loading...
Searching...
No Matches
EvtItgFourCoeffFcn.hh
Go to the documentation of this file.
1
2/***********************************************************************
3* Copyright 1998-2020 CERN for the benefit of the EvtGen authors *
4* *
5* This file is part of EvtGen. *
6* *
7* EvtGen is free software: you can redistribute it and/or modify *
8* it under the terms of the GNU General Public License as published by *
9* the Free Software Foundation, either version 3 of the License, or *
10* (at your option) any later version. *
11* *
12* EvtGen is distributed in the hope that it will be useful, *
13* but WITHOUT ANY WARRANTY; without even the implied warranty of *
14* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
15* GNU General Public License for more details. *
16* *
17* You should have received a copy of the GNU General Public License *
18* along with EvtGen. If not, see <https://www.gnu.org/licenses/>. *
19***********************************************************************/
20
21#ifndef EVTITFOURCOEFFFCN_HH
22#define EVTITFOURCOEFFFCN_HH
23
25
26#include <vector>
27
28// Description:
29// Class describing a function with Four vectors of coefficients.
30
32 public:
33 EvtItgFourCoeffFcn( double ( *theFunction )( double,
34 const std::vector<double>&,
35 const std::vector<double>&,
36 const std::vector<double>&,
37 const std::vector<double>& ),
38 double lowerRange, double upperRange,
39 const std::vector<double>& coeffs1,
40 const std::vector<double>& coeffs2,
41 const std::vector<double>& coeffs3,
42 const std::vector<double>& coeffs4 );
43
44 void setCoeff( int, int, double ) override;
45 double getCoeff( int, int ) override;
46
47 protected:
48 double myFunction( double x ) const override;
49
50 private:
51 // Data members
52 double ( *m_myFunction )( double x, const std::vector<double>& coeffs1,
53 const std::vector<double>& coeffs2,
54 const std::vector<double>& coeffs3,
55 const std::vector<double>& coeffs4 );
56
57 std::vector<double> m_coeffs1;
58 std::vector<double> m_coeffs2;
59 std::vector<double> m_coeffs3;
60 std::vector<double> m_coeffs4;
61};
62
63#endif // EvtITGPTRFUNCTION_HH
EvtItgAbsFunction(double lowerRange, double upperRange)
double lowerRange() const
double upperRange() const
double getCoeff(int, int) override
void setCoeff(int, int, double) override
double myFunction(double x) const override
EvtItgFourCoeffFcn(double(*theFunction)(double, const std::vector< double > &, const std::vector< double > &, const std::vector< double > &, const std::vector< double > &), double lowerRange, double upperRange, const std::vector< double > &coeffs1, const std::vector< double > &coeffs2, const std::vector< double > &coeffs3, const std::vector< double > &coeffs4)
double(* m_myFunction)(double x, const std::vector< double > &coeffs1, const std::vector< double > &coeffs2, const std::vector< double > &coeffs3, const std::vector< double > &coeffs4)
std::vector< double > m_coeffs2
std::vector< double > m_coeffs3
std::vector< double > m_coeffs1
std::vector< double > m_coeffs4