Page Menu
Home
HEPForge
Search
Configure Global Search
Log In
Files
F19243942
RivetAnalysis.cc
No One
Temporary
Actions
View File
Edit File
Delete File
View Transforms
Subscribe
Award Token
Flag For Later
Size
4 KB
Referenced Files
None
Subscribers
None
RivetAnalysis.cc
View Options
/**
* \authors The HEJ collaboration (see AUTHORS for details)
* \date 2019
* \copyright GPLv2 or later
*/
#include
"HEJ/RivetAnalysis.hh"
#ifdef HEJ_BUILD_WITH_RIVET
#include
<ostream>
#include
<stddef.h>
#include
"yaml-cpp/yaml.h"
#include
"Rivet/AnalysisHandler.hh"
#include
"Rivet/Config/RivetConfig.hh"
#ifdef RIVET_ENABLE_HEPMC_3
#include
"HepMC3/GenEvent.h"
#include
"HEJ/HepMC3Interface.hh"
#else
// rivet with HepMC 2
#include
"HepMC/GenEvent.h"
#include
"HEJ/HepMC2Interface.hh"
#endif
#include
"HEJ/Event.hh"
#include
"HEJ/exceptions.hh"
#endif
namespace
HEJ
{
std
::
unique_ptr
<
Analysis
>
RivetAnalysis
::
create
(
YAML
::
Node
const
&
config
){
return
std
::
unique_ptr
<
Analysis
>
{
new
RivetAnalysis
{
config
}};
}
}
#ifdef HEJ_BUILD_WITH_RIVET
namespace
HEJ
{
#ifdef RIVET_ENABLE_HEPMC_3
using
HepMCInterface
=
HepMC3Interface
;
#else
using
HepMCInterface
=
HepMC2Interface
;
#endif
struct
RivetAnalysis
::
rivet_info
{
rivet_info
(
std
::
unique_ptr
<
Rivet
::
AnalysisHandler
>
&&
h
,
std
::
string
&&
s
,
HEJ
::
HepMCInterface
&&
m
)
:
handler
{
std
::
move
(
h
)},
name
{
std
::
move
(
s
)},
hepmc
{
std
::
move
(
m
)}
{}
// AnalysisHandler doesn't allow a copy constructor -> use ptr
std
::
unique_ptr
<
Rivet
::
AnalysisHandler
>
handler
;
std
::
string
name
;
HEJ
::
HepMCInterface
hepmc
;
};
RivetAnalysis
::
RivetAnalysis
(
YAML
::
Node
const
&
config
)
:
output_name_
{
config
[
"output"
].
as
<
std
::
string
>
()},
first_event_
(
true
)
{
// read in analyses
const
auto
&
name_node
=
config
[
"rivet"
];
switch
(
name_node
.
Type
()){
case
YAML
::
NodeType
::
Scalar
:
analyses_names_
.
push_back
(
name_node
.
as
<
std
::
string
>
());
break
;
case
YAML
::
NodeType
::
Sequence
:
for
(
YAML
::
const_iterator
it
=
name_node
.
begin
();
it
!=
name_node
.
end
();
++
it
){
analyses_names_
.
push_back
(
it
->
as
<
std
::
string
>
());
}
break
;
default
:
throw
std
::
invalid_argument
{
"No Analysis was provided to rivet. "
"Either give an analysis or deactivate rivet."
};
}
}
void
RivetAnalysis
::
initialise
(
LHEF
::
HEPRUP
const
&
heprup
){
heprup_
=
heprup
;
}
// it is a bit ugly that we can't do this directly in `initialise`
void
RivetAnalysis
::
init
(
Event
const
&
event
){
rivet_runs_
.
reserve
(
event
.
variations
().
size
()
+
1
);
rivet_runs_
.
emplace_back
(
std
::
make_unique
<
Rivet
::
AnalysisHandler
>
(),
std
::
string
(
""
),
HepMCInterface
(
heprup_
)
);
rivet_runs_
.
back
().
handler
->
addAnalyses
(
analyses_names_
);
if
(
!
event
.
variations
().
empty
()
){
for
(
auto
const
&
vari
:
event
.
variations
()){
rivet_runs_
.
emplace_back
(
std
::
make_unique
<
Rivet
::
AnalysisHandler
>
(),
"."
+
to_simple_string
(
*
vari
.
description
),
HepMCInterface
(
heprup_
)
);
rivet_runs_
.
back
().
handler
->
addAnalyses
(
analyses_names_
);
}
}
}
void
RivetAnalysis
::
fill
(
Event
const
&
event
,
Event
const
&
){
if
(
first_event_
){
first_event_
=
false
;
init
(
event
);
}
auto
hepmc_kin
(
rivet_runs_
[
0
].
hepmc
.
init_kinematics
(
event
));
rivet_runs_
[
0
].
hepmc
.
add_variation
(
hepmc_kin
,
event
.
variations
());
for
(
size_t
i
=
0
;
i
<
rivet_runs_
.
size
();
++
i
){
auto
&
run
=
rivet_runs_
[
i
];
run
.
hepmc
.
set_central
(
hepmc_kin
,
event
,
i
-
1
);
// -1: first = central
run
.
handler
->
analyze
(
hepmc_kin
);
}
}
void
RivetAnalysis
::
finalise
(){
for
(
auto
&
run
:
rivet_runs_
){
run
.
handler
->
finalize
();
run
.
handler
->
writeData
(
output_name_
+
run
.
name
+
std
::
string
(
".yoda"
));
}
}
}
// namespace HEJ
#else
// no rivet => create empty analysis
namespace
Rivet
{
class
AnalysisHandler
{};
}
namespace
HEJ
{
struct
RivetAnalysis
::
rivet_info
{};
RivetAnalysis
::
RivetAnalysis
(
YAML
::
Node
const
&
)
{
throw
std
::
invalid_argument
(
"Failed to create RivetAnalysis: "
"HEJ 2 was built without rivet support"
);
}
void
RivetAnalysis
::
initialise
(
LHEF
::
HEPRUP
const
&
){}
void
RivetAnalysis
::
init
(
Event
const
&
){}
void
RivetAnalysis
::
fill
(
Event
const
&
,
Event
const
&
){}
void
RivetAnalysis
::
finalise
(){}
}
// namespace HEJ
#endif
namespace
HEJ
{
RivetAnalysis
::~
RivetAnalysis
()
=
default
;
}
File Metadata
Details
Attached
Mime Type
text/x-c
Expires
Tue, Sep 30, 4:37 AM (4 h, 16 m)
Storage Engine
blob
Storage Format
Raw Data
Storage Handle
6559152
Default Alt Text
RivetAnalysis.cc (4 KB)
Attached To
Mode
rHEJ HEJ
Attached
Detach File
Event Timeline
Log In to Comment