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
src
EvtGenBase
EvtMTRandomEngine.cpp
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
#include "
EvtGenBase/EvtMTRandomEngine.hh
"
22
23
#include "
EvtGenBase/EvtReport.hh
"
24
25
#include <iostream>
26
27
EvtMTRandomEngine::EvtMTRandomEngine
(
unsigned
long
int
seed ) :
28
m_engine
{ seed },
m_distribution
{ 0.0, 1.0 },
m_lastSeed
{ seed }
29
{
30
EvtGenReport
(
EVTGEN_INFO
,
"EvtMTRandomEngine"
)
31
<<
"Mersenne-Twister random number generator with seed = "
<< seed
32
<< std::endl;
33
}
34
35
double
EvtMTRandomEngine::random
()
36
{
37
return
m_distribution
(
m_engine
);
38
}
39
40
void
EvtMTRandomEngine::setSeed
(
unsigned
long
int
seed )
41
{
42
m_engine
.seed( seed );
43
m_lastSeed
= seed;
44
}
EvtMTRandomEngine.hh
EvtReport.hh
EvtGenReport
std::ostream & EvtGenReport(EvtGenSeverity severity, const char *facility=nullptr)
Definition
EvtReport.cpp:32
EVTGEN_INFO
@ EVTGEN_INFO
Definition
EvtReport.hh:52
EvtMTRandomEngine::m_lastSeed
unsigned long int m_lastSeed
Definition
EvtMTRandomEngine.hh:41
EvtMTRandomEngine::EvtMTRandomEngine
EvtMTRandomEngine(unsigned long int seed=1430957218)
Definition
EvtMTRandomEngine.cpp:27
EvtMTRandomEngine::setSeed
void setSeed(unsigned long int seed) override
Definition
EvtMTRandomEngine.cpp:40
EvtMTRandomEngine::m_engine
std::mt19937 m_engine
Definition
EvtMTRandomEngine.hh:39
EvtMTRandomEngine::random
double random() override
Definition
EvtMTRandomEngine.cpp:35
EvtMTRandomEngine::m_distribution
std::uniform_real_distribution< double > m_distribution
Definition
EvtMTRandomEngine.hh:40
Generated by
1.16.1