cepgen is hosted by Hepforge, IPPP Durham
CepGen 1.2.5
Central exclusive processes event generator
Loading...
Searching...
No Matches
FortranFactorisedProcess.h
Go to the documentation of this file.
1/*
2 * CepGen: a central exclusive processes event generator
3 * Copyright (C) 2018-2024 Laurent Forthomme
4 *
5 * This program is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation, either version 3 of the License, or
8 * any later version.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License
16 * along with this program. If not, see <http://www.gnu.org/licenses/>.
17 */
18
19#ifndef CepGen_Process_FortranFactorisedProcess_h
20#define CepGen_Process_FortranFactorisedProcess_h
21
23
24namespace cepgen {
25 namespace proc {
28 public:
31 explicit FortranFactorisedProcess(const ParametersList&, const std::function<double(void)>& func);
32 ProcessPtr clone() const override { return ProcessPtr(new FortranFactorisedProcess(*this)); }
33
35
36 private:
37 void prepareFactorisedPhaseSpace() override final;
38 double computeFactorisedMatrixElement() override final;
39
40 const std::function<double(void)> func_;
41
42 // mapped variables
43 double m_y1_{0.};
44 double m_y2_{0.};
45 double m_pt_diff_{0.};
46 double m_phi_pt_diff_{0.};
47 };
48 } // namespace proc
49} // namespace cepgen
50
51#endif
Generic parton emission-factorised process.
Compute the matrix element for a generic factorised process defined in a Fortran weighting function.
ProcessPtr clone() const override
Copy all process attributes into a new object.
static ParametersList kProcParameters
List of parameters to steer the process.
std::unique_ptr< Process > ProcessPtr
Helper typedef for a Process unique pointer.
Definition Process.h:199
Common namespace for this Monte Carlo generator.