cepgen is hosted by Hepforge, IPPP Durham
CepGen N/A
Central exclusive processes event generator
FortranFactorisedProcess.h
Go to the documentation of this file.
1/*
2 * CepGen: a central exclusive processes event generator
3 * Copyright (C) 2018-2025 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::proc {
27 public:
30 explicit FortranFactorisedProcess(const ParametersList&, const std::function<double()>& func);
31 ProcessPtr clone() const override { return std::make_unique<FortranFactorisedProcess>(*this); }
32
34
35 private:
36 void prepareFactorisedPhaseSpace() final;
37 double computeFactorisedMatrixElement() final;
38
39 const std::function<double()> func_;
40
41 // mapped variables
42 double m_y1_{0.};
43 double m_y2_{0.};
44 double m_pt_diff_{0.};
45 double m_phi_pt_diff_{0.};
46 };
47} // namespace cepgen::proc
48
49#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.
FortranFactorisedProcess(const ParametersList &, const std::function< double()> &func)
Construct a Fortran-CepGen interface object using a double precision argument-less F77 function.
Location for all physics processes to be generated.
std::unique_ptr< Process > ProcessPtr
Helper for a Process unique pointer.
Definition Process.h:193