evtgen is hosted by Hepforge, IPPP Durham
EvtGen  2.0.0
Monte Carlo generator of particle decays, in particular the weak decays of heavy flavour particles such as B mesons.
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 ( *_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> _coeffs1;
58  std::vector<double> _coeffs2;
59  std::vector<double> _coeffs3;
60  std::vector<double> _coeffs4;
61 };
62 
63 #endif // EvtITGPTRFUNCTION_HH
double myFunction(double x) const override
double getCoeff(int, int) override
std::vector< double > _coeffs4
void setCoeff(int, int, double) override
double lowerRange() const
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 upperRange() const
std::vector< double > _coeffs1
std::vector< double > _coeffs2
double(* _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 > _coeffs3