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
EvtExternalGenFactory.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 EVTEXTERNALGENFACTORY_HH
22#define EVTEXTERNALGENFACTORY_HH
23
25
26#include <map>
27#include <memory>
28
29// Description: A factory type method to create engines for external physics
30// generators like Pythia.
31
33 public:
34 enum class GenId
35 {
38 };
39
41
42 EvtAbsExternalGen* getGenerator( const GenId genId );
43
45
46 void definePythiaGenerator( std::string xmlDir, bool convertPhysCodes,
47 bool useEvtGenRandom = true );
48 void defineTauolaGenerator( bool useEvtGenRandom = true,
49 bool seedTauolaFortran = true );
50
51 //methods to add configuration commands to the pythia generators
52 //void addPythiaCommand( std::string generator, std::string module, std::string param, std::string value);
53 //void addPythia6Command(std::string generator, std::string module, std::string param, std::string value);
54
55 private:
62
63 typedef std::map<GenId, std::unique_ptr<EvtAbsExternalGen>> ExtGenMap;
64 //typedef std::map<GenId, std::map<std::string, std::vector<std::string>>> ExtGenCommandMap;
65
67 //ExtGenCommandMap m_extGenCommandMap;
68};
69
70#endif
EvtExternalGenFactory & operator=(const EvtExternalGenFactory &)=delete
static EvtExternalGenFactory & getInstance()
~EvtExternalGenFactory()=default
EvtExternalGenFactory(EvtExternalGenFactory &&)=delete
EvtExternalGenFactory()=default
EvtExternalGenFactory(const EvtExternalGenFactory &)=delete
EvtAbsExternalGen * getGenerator(const GenId genId)
void defineTauolaGenerator(bool useEvtGenRandom=true, bool seedTauolaFortran=true)
EvtExternalGenFactory & operator=(EvtExternalGenFactory &&)=delete
void definePythiaGenerator(std::string xmlDir, bool convertPhysCodes, bool useEvtGenRandom=true)
std::map< GenId, std::unique_ptr< EvtAbsExternalGen > > ExtGenMap