Loading [MathJax]/extensions/tex2jax.js
 |
ATLAS Offline Software
|
#include <McEventCollectionCnv_p7.h>
|
| McEventCollectionCnv_p7 () |
| Default constructor: More...
|
|
| McEventCollectionCnv_p7 (const McEventCollectionCnv_p7 &rhs) |
| Copy constructor. More...
|
|
McEventCollectionCnv_p7 & | operator= (const McEventCollectionCnv_p7 &rhs) |
| Assignement operator. More...
|
|
virtual | ~McEventCollectionCnv_p7 () |
| Destructor. More...
|
|
void | setPileup () |
|
virtual void | persToTrans (const McEventCollection_p7 *persObj, McEventCollection *transObj, MsgStream &log) |
| Method creating the transient representation of McEventCollection from its persistent representation McEventCollection_p7 . More...
|
|
virtual void | transToPers (const McEventCollection *transObj, McEventCollection_p7 *persObj, MsgStream &log) |
| Method creating the persistent representation McEventCollection_p7 from its transient representation McEventCollection . More...
|
|
virtual TPObjRef | virt_toPersistent (const TRANS *trans, MsgStream &log) |
| Internal interface method that is used to invoke the real conversion method (toPersistent_impl) in the derived converter. More...
|
|
virtual TPObjRef | virt_toPersistentWithKey (const TRANS *trans, const std::string &key, MsgStream &log) |
| Internal interface method that is used to invoke the real conversion method (toPersistent_impl) in the derived converter. More...
|
|
virtual void | pstoreToTrans (unsigned index, TRANS *trans, MsgStream &log) |
| Convert persistent representation stored in the storage vector of the top-level object to transient. More...
|
|
virtual TRANS * | createTransient (const PERS *persObj, MsgStream &log) |
| Create transient representation of a persistent object. More...
|
|
virtual TRANS * | createTransientWithKey (const PERS *persObj, const std::string &key, MsgStream &log) |
| Create transient representation of a persistent object, with SG key. More...
|
|
virtual TRANS * | virt_createTransFromPStore (unsigned index, MsgStream &log) |
| Internal interface method that is used to invoke the real conversion method (createTransient) More...
|
|
virtual TRANS * | virt_createTransFromPStoreWithKey (unsigned index, const std::string &key, MsgStream &log) |
| Internal interface method that is used to invoke the real conversion method (createTransient) More...
|
|
virtual void | persToTrans (const PERS *persObj, TRANS *transObj, MsgStream &log)=0 |
| Convert persistent representation to transient one. More...
|
|
virtual void | transToPers (const TRANS *transObj, PERS *persObj, MsgStream &log)=0 |
| Convert transient representation to persistent one. More...
|
|
virtual void | persToTransWithKey (const PERS *persObj, TRANS *transObj, const std::string &, MsgStream &log) |
| Convert persistent representation to transient one. More...
|
|
virtual void | transToPersWithKey (const TRANS *transObj, PERS *persObj, const std::string &, MsgStream &log) |
| Convert transient representation to persistent one. More...
|
|
virtual void | persToTransUntyped (const void *pers, void *trans, MsgStream &log) |
| Convert persistent object representation to transient. More...
|
|
virtual void | transToPersUntyped (const void *trans, void *pers, MsgStream &log) |
| Convert transient object representation to persistent. More...
|
|
virtual void | persToTransWithKeyUntyped (const void *pers, void *trans, const std::string &key, MsgStream &log) |
| Convert persistent object representation to transient. More...
|
|
virtual void | transToPersWithKeyUntyped (const void *trans, void *pers, const std::string &key, MsgStream &log) |
| Convert transient object representation to persistent. More...
|
|
virtual PERS * | createPersistent (const TRANS *transObj, MsgStream &log) |
| Create persistent representation of a transient object. More...
|
|
virtual PERS * | createPersistentWithKey (const TRANS *transObj, const std::string &key, MsgStream &log) |
| Create persistent representation of a transient object, with SG key. More...
|
|
TPObjRef | toPersistentWithKey_impl (const TRANS *trans, const std::string &key, MsgStream &log) |
| Convert transient object to persistent representation. More...
|
|
virtual const std::type_info & | transientTInfo () const |
| return C++ type id of the transient class this converter is for More...
|
|
virtual const std::type_info & | transientTInfo () const |
| return C++ type id of the transient class this converter is for More...
|
|
virtual const std::type_info & | persistentTInfo () const |
| return C++ type id of the persistent class this converter is for More...
|
|
virtual const std::type_info & | persistentTInfo () const =0 |
| return C++ type id of the persistent class this converter is for More...
|
|
void | setPStorage (std::vector< PERS > *storage) |
| Tell this converter which storage vector it should use to store or retrieve persistent representations. More...
|
|
void | setRecursive (bool flag=true) |
| Tell the converter if it should work in recursive mode slower but it can safely handle recursion. More...
|
|
void | ignoreRecursion (bool flag=false) |
| Tell the converter to ignore recursion (do not throw errors) even when recurion is detected. More...
|
|
virtual void | reservePStorage (size_t size) |
| Reserve 'size' elements for persistent storage. More...
|
|
template<class CNV > |
CNV * | converterForType (CNV *cnv, const std::type_info &t_info, MsgStream &log) const |
| Find converter for a given C++ type ID, that is or ihnerits from CNV type. More...
|
|
template<class CNV > |
CNV * | converterForRef (CNV *cnv, const TPObjRef &ref, MsgStream &log) const |
| Find converter for a TP type ID (passed in a TP Ref), that is or ihnerits from CNV type. More...
|
|
template<class CNV > |
TPObjRef | baseToPersistent (CNV **cnv, const typename CNV::Trans_t *transObj, MsgStream &log) const |
| Persistify bass class of a given object and store the persistent represenation in the storage vector of the top-level persistent object. More...
|
|
template<class CNV > |
TPObjRef | toPersistent (CNV **cnv, const typename CNV::TransBase_t *transObj, MsgStream &log) const |
| Persistify an object and store the persistent represenation in the storage vector of the top-level persistent object. More...
|
|
template<class CNV , class TRANS_T > |
void | fillTransFromPStore (CNV **cnv, const TPObjRef &ref, TRANS_T *trans, MsgStream &log) const |
| Convert persistent object, stored in the the top-level persistent object and referenced by the TP Ref, to transient representation. More...
|
|
template<class CNV > |
CNV::Trans_t * | createTransFromPStore (CNV **cnv, const TPObjRef &ref, MsgStream &log) const |
| Create transient representation of a persistent object, stored in the the top-level persistent object and referenced by the TP Ref. More...
|
|
virtual void | initPrivateConverters (TopLevelTPCnvBase *) |
|
virtual TopLevelTPCnvBase * | topConverter () |
| return the top-level converter for this elemental TP converter More...
|
|
virtual const TopLevelTPCnvBase * | topConverter () const |
| return the top-level converter for this elemental TP converter More...
|
|
const std::type_info & | transBaseTInfo () const |
| return C++ type id of the common base transient type for all converters for a group of polymorphic types More...
|
|
virtual const TPObjRef::typeID_t & | typeID () const |
| Return TP typeID for persistent objects produced by this converter. More...
|
|
unsigned | typeIDvalue () const |
| inlined non-virtual version to get the typeID value fast More...
|
|
virtual void | setRuntimeTopConverter (TopLevelTPCnvBase *topConverter) |
| Set runtime top-level converter - usually it is the owning TL converter, but in case of extended objects it will be the TL converter of the extended object. More...
|
|
virtual void | setTopConverter (TopLevelTPCnvBase *topConverter, const TPObjRef::typeID_t &TPtypeID) |
| Set which top-level converter owns this elemental converter, and what TPtypeID was assigned to the persistent objects it produces. More...
|
|
void | setReadingFlag () |
|
void | clearReadingFlag () |
|
bool | wasUsedForReading () |
|
virtual void | converterNotFound (const std::type_info &converterType, ITPConverter *c, const std::string &typeName, MsgStream &log) const |
| method called when the right TP converter was not found during writing More...
|
|
virtual void | converterNotFound (unsigned typeID, ITPConverter *c, const std::string &typeName, MsgStream &log) const |
| method called when the right TP converter was not found during reading More...
|
|
|
HepMC::GenVertexPtr | createGenVertex (const McEventCollection_p7 &persEvts, const GenVertex_p7 &vtx, ParticlesMap_t &bcToPart, HepMC::DataPool &datapools, HepMC::GenEvent *parent=nullptr) const |
| Create a transient GenVertex from a persistent one (version 1) It returns the new GenVertex . More...
|
|
HepMC::GenParticlePtr | createGenParticle (const GenParticle_p7 &p, ParticlesMap_t &partToEndVtx, HepMC::DataPool &datapools, const HepMC::GenVertexPtr &parent=nullptr, bool add_to_output=true) const |
| Create a transient GenParticle from a persistent one (vers.1) It returns the new GenParticle . More...
|
|
void | writeGenVertex (const HepMC::GenVertex &vtx, McEventCollection_p7 &persEvt) const |
| Method to write a persistent GenVertex object. More...
|
|
int | writeGenParticle (const HepMC::GenParticle &p, McEventCollection_p7 &persEvt) const |
| Method to write a persistent GenParticle object It returns the index of the persistent GenParticle into the collection of persistent of GenParticles from the persistent GenEvent . More...
|
|
Definition at line 54 of file McEventCollectionCnv_p7.h.
◆ Base_t
◆ Factory
◆ ParticlesMap_t
◆ Pers_t
◆ PersBase_t
◆ PolyCnvBase_t
◆ Trans_t
◆ TransBase_t
◆ McEventCollectionCnv_p7() [1/2]
McEventCollectionCnv_p7::McEventCollectionCnv_p7 |
( |
| ) |
|
◆ McEventCollectionCnv_p7() [2/2]
◆ ~McEventCollectionCnv_p7()
McEventCollectionCnv_p7::~McEventCollectionCnv_p7 |
( |
| ) |
|
|
virtualdefault |
◆ baseToPersistent()
template<class TRANS >
template<class CNV >
Persistify bass class of a given object and store the persistent represenation in the storage vector of the top-level persistent object.
The converter is located using the transient type from the CNV parameter, not from the object itself (because we need the base type, not the actual type)
- Parameters
-
cnv | [IN/OUT] type of this parameter decides which converter will be used. Once the converter is found, this pointer will be set so the search is done only once |
transObj | [IN] transient object |
log | [IN] output message stream |
- Returns
- TPObjRef TP reference to the persistent representation stored in the storage vector of the top-level persistent object
Definition at line 97 of file TPConverter.h.
98 if( !*cnv || (*cnv)->wasUsedForReading() ) {
102 (*cnv)->clearReadingFlag();
105 return (**cnv).virt_toPersistent(transObj,
log);
◆ clearReadingFlag()
◆ converterForRef()
template<class TRANS >
template<class CNV >
Find converter for a TP type ID (passed in a TP Ref), that is or ihnerits from CNV type.
- Parameters
-
cnv | [IN] parameter specifying the converter type |
ref | [IN] TP Ref to an object for which a converter is sought |
log | [IN] output message stream |
- Returns
- CNV* pointer to the converter, if found
Definition at line 74 of file TPConverter.h.
76 cnv =
dynamic_cast<CNV*
>(
c);
◆ converterForType()
template<class TRANS >
template<class CNV >
CNV* ITPConverterFor< TRANS >::converterForType |
( |
CNV * |
cnv, |
|
|
const std::type_info & |
t_info, |
|
|
MsgStream & |
log |
|
) |
| const |
|
inlineinherited |
Find converter for a given C++ type ID, that is or ihnerits from CNV type.
- Parameters
-
cnv | [IN] parameter specifying the converter type |
t_info | [IN] C++ type id for which a converter is sought |
log | [IN] output message stream |
- Returns
- CNV* pointer to the converter, if found
Definition at line 58 of file TPConverter.h.
60 cnv =
dynamic_cast< CNV*
>(
c );
◆ converterNotFound() [1/2]
void ITPConverter::converterNotFound |
( |
const std::type_info & |
converterType, |
|
|
ITPConverter * |
c, |
|
|
const std::string & |
typeName, |
|
|
MsgStream & |
log |
|
) |
| const |
|
virtualinherited |
method called when the right TP converter was not found during writing
- useful as a debugging hook, prints a detailed error message
- Parameters
-
converterType | [IN] converterType that was requested |
c | [IN] converter that was actually found (0 if not) |
typeName | [IN] the C++ type name of the type for which converter was searched for |
log | [IN] output message stream |
Definition at line 22 of file ITPConverter.cxx.
27 log << MSG::ERROR <<
">>>>>> in parent TP converter " <<
typeid(*this).name()
28 <<
": could not find matching TP converter for type " <<
typeName <<
endmsg;
30 log << MSG::ERROR <<
" - found incompatible converter of type "
31 <<
typeid(*c).name() <<
endmsg;
33 log << MSG::ERROR <<
" Converter handle type was " << converterType.name() <<
endmsg;
◆ converterNotFound() [2/2]
void ITPConverter::converterNotFound |
( |
unsigned |
typeID, |
|
|
ITPConverter * |
c, |
|
|
const std::string & |
typeName, |
|
|
MsgStream & |
log |
|
) |
| const |
|
virtualinherited |
method called when the right TP converter was not found during reading
- useful as a debugging hook, prints a detailed error message
- Parameters
-
typeID | [IN] converter ID that was requested |
c | [IN] converter that was actually found (0 if not) |
typeName | [IN] the C++ type name of the type for which converter was searched for |
log | [IN] output message stream |
Definition at line 40 of file ITPConverter.cxx.
45 log << MSG::ERROR <<
">>>>>> in parent TP converter " <<
typeid(*this).name()
46 <<
" requested TP converter for TP type ID " <<
typeID <<
" not found " <<
endmsg;
48 log << MSG::ERROR <<
" - found converter " <<
typeid(*c).name()
49 <<
" for " <<
c->transientTInfo().name()
50 <<
" with an incompatible base type " <<
c->transBaseTInfo().name()
53 log << MSG::ERROR <<
" Converter handle type was " << reqCnvTypeName <<
endmsg;
◆ createGenParticle()
Create a transient GenParticle
from a persistent one (vers.1) It returns the new GenParticle
.
Note that the map being passed as an argument is to hold the association of barcodes to particle so that we can reconnect all the particles to their decay vertex (if any).
Definition at line 698 of file McEventCollectionCnv_p7.cxx.
709 p->set_pdg_id( persPart.m_pdgId);
710 p->set_status( persPart.m_status);
711 p->add_attribute(
"phi",std::make_shared<HepMC3::DoubleAttribute>(persPart.m_phiPolarization));
712 p->add_attribute(
"theta",std::make_shared<HepMC3::DoubleAttribute>(persPart.m_thetaPolarization));
714 p->set_generated_mass(persPart.m_generated_mass);
721 if ( 0 == persPart.m_recoMethod ) {
722 double temp_e = std::sqrt( (
long double)(persPart.m_px)*persPart.m_px +
723 (
long double)(persPart.m_py)*persPart.m_py +
724 (
long double)(persPart.m_pz)*persPart.m_pz +
725 (
long double)(persPart.m_m) *persPart.m_m );
726 p->set_momentum( HepMC::FourVector(persPart.m_px,persPart.m_py,persPart.m_pz,temp_e));
728 const int signM2 = ( persPart.m_m >= 0. ? 1 : -1 );
729 const double persPart_ene =
730 std::sqrt( std::abs((
long double)(persPart.m_px)*persPart.m_px +
731 (
long double)(persPart.m_py)*persPart.m_py +
732 (
long double)(persPart.m_pz)*persPart.m_pz +
733 signM2* (
long double)(persPart.m_m)* persPart.m_m));
734 const int signEne = ( persPart.m_recoMethod == 1 ? 1 : -1 );
735 p->set_momentum(HepMC::FourVector( persPart.m_px,
738 signEne * persPart_ene ));
742 std::vector<int> flows;
743 const unsigned int nFlow = persPart.m_flow.size();
744 for (
unsigned int iFlow= 0; iFlow != nFlow; ++iFlow ) {
745 flows.push_back(persPart.m_flow[iFlow].second );
748 p->add_attribute(
"flows", std::make_shared<HepMC3::VectorIntAttribute>(flows));
750 p->m_pdg_id = persPart.m_pdgId;
751 p->m_status = persPart.m_status;
752 p->m_polarization.m_theta=
static_cast<double>(persPart.m_thetaPolarization);
753 p->m_polarization.m_phi =
static_cast<double>(persPart.m_phiPolarization );
754 p->m_production_vertex = 0;
756 p->m_barcode = persPart.m_barcode;
757 p->m_generated_mass =
static_cast<double>(persPart.m_generated_mass);
764 if ( 0 == persPart.m_recoMethod ) {
766 p->m_momentum.setPx( persPart.m_px);
767 p->m_momentum.setPy( persPart.m_py);
768 p->m_momentum.setPz( persPart.m_pz);
769 double temp_e = std::sqrt( (
long double)(persPart.m_px)*persPart.m_px +
770 (
long double)(persPart.m_py)*persPart.m_py +
771 (
long double)(persPart.m_pz)*persPart.m_pz +
772 (
long double)(persPart.m_m) *persPart.m_m );
773 p->m_momentum.setE( temp_e);
775 const int signM2 = ( persPart.m_m >= 0. ? 1 : -1 );
776 const double persPart_ene =
777 std::sqrt( std::abs((
long double)(persPart.m_px)*persPart.m_px +
778 (
long double)(persPart.m_py)*persPart.m_py +
779 (
long double)(persPart.m_pz)*persPart.m_pz +
780 signM2* (
long double)(persPart.m_m)* persPart.m_m));
781 const int signEne = ( persPart.m_recoMethod == 1 ? 1 : -1 );
782 p->m_momentum.set( persPart.m_px,
785 signEne * persPart_ene );
789 const unsigned int nFlow = persPart.m_flow.size();
791 for (
unsigned int iFlow= 0; iFlow != nFlow; ++iFlow ) {
792 p->m_flow.set_icode( persPart.m_flow[iFlow].first,
793 persPart.m_flow[iFlow].second );
797 if ( persPart.m_endVtx != 0 ) {
798 partToEndVtx[
p] = persPart.m_endVtx;
◆ createGenVertex()
Create a transient GenVertex
from a persistent one (version 1) It returns the new GenVertex
.
This method calls createGenParticle
for each of the out-going particles and only for the in-going particle which are orphans (no production vertex): for optimisation purposes. Note that the map being passed as an argument is to hold the association of barcodes to particle so that we can reconnect all the (non-orphan) particles to their decay vertex (if any).
Definition at line 631 of file McEventCollectionCnv_p7.cxx.
645 vtx->set_position(HepMC::FourVector( persVtx.m_x , persVtx.m_y , persVtx.m_z ,persVtx.m_t ));
647 vtx->set_status(persVtx.m_id);
649 std::vector<double>
weights( persVtx.m_weights.begin(), persVtx.m_weights.end() );
650 vtx->add_attribute(
"weights",std::make_shared<HepMC3::VectorDoubleAttribute>(
weights));
653 const unsigned int nPartsIn = persVtx.m_particlesIn.size();
654 for (
unsigned int i = 0;
i != nPartsIn; ++
i ) {
655 createGenParticle( persEvt.m_genParticles[persVtx.m_particlesIn[
i]], partToEndVtx, datapools, vtx,
false );
659 const unsigned int nPartsOut = persVtx.m_particlesOut.size();
660 for (
unsigned int i = 0;
i != nPartsOut; ++
i ) {
661 createGenParticle( persEvt.m_genParticles[persVtx.m_particlesOut[
i]], partToEndVtx, datapools, vtx );
664 vtx->m_position.setX( persVtx.m_x );
665 vtx->m_position.setY( persVtx.m_y );
666 vtx->m_position.setZ( persVtx.m_z );
667 vtx->m_position.setT( persVtx.m_t );
668 vtx->m_particles_in.clear();
669 vtx->m_particles_out.clear();
670 vtx->
m_id = persVtx.m_id;
671 vtx->
m_weights.m_weights.reserve( persVtx.m_weights.size() );
672 vtx->
m_weights.m_weights.assign ( persVtx.m_weights.begin(),
673 persVtx.m_weights.end() );
678 const unsigned int nPartsIn = persVtx.m_particlesIn.size();
679 for (
unsigned int i = 0;
i != nPartsIn; ++
i ) {
686 const unsigned int nPartsOut = persVtx.m_particlesOut.size();
687 for (
unsigned int i = 0;
i != nPartsOut; ++
i ) {
688 vtx->add_particle_out(
createGenParticle( persEvt.m_genParticles[persVtx.m_particlesOut[
i]],
◆ createPersistent()
Create persistent representation of a transient object.
Simply creates a new persistent object and calls transToPers()
- Parameters
-
transObj | [IN] transient object |
log | [IN] output message stream |
- Returns
- the created persistent representation
◆ createPersistentWithKey()
Create persistent representation of a transient object, with SG key.
Simply creates a new persistent object and calls transToPersWithKey()
- Parameters
-
transObj | [IN] transient object |
key | [IN] SG key of object being written |
log | [IN] output message stream |
- Returns
- the created persistent representation
◆ createTransFromPStore()
template<class TRANS >
template<class CNV >
Create transient representation of a persistent object, stored in the the top-level persistent object and referenced by the TP Ref.
If a TP converter is not specified, it will be found based on the Ref type.
- Parameters
-
cnv | [IN][OUT] pointer to the converter, usually 0 at the start. Once the right converter is found, this pointer will be set so the search is done only once |
ref | [IN] TP Ref to the persistent object to be converted |
log | [IN] output message stream |
- Returns
- pointer to the created transient represention
Definition at line 172 of file TPConverter.h.
173 if(
ref.isNull() )
return 0;
175 if( !cnv ) cnv = &temp_cnv_p;
177 if( !*cnv || (*cnv)->typeID().value() !=
ref.typeID() ) {
180 if( !*cnv )
return 0;
181 (*cnv)->setReadingFlag();
183 return (**cnv).virt_createTransFromPStore(
ref.index(),
log );
◆ createTransient()
Create transient representation of a persistent object.
Simply creates a new transient object and calls persToTrans()
- Parameters
-
persObj | [IN] persistent object |
log | [IN] output message stream |
- Returns
- the created transient object
◆ createTransientWithKey()
Create transient representation of a persistent object, with SG key.
Simply creates a new transient object and calls persToTransWithKey()
- Parameters
-
persObj | [IN] persistent object |
key | [IN] SG key of object being read |
log | [IN] output message stream |
- Returns
- the created transient object
◆ fillTransFromPStore()
template<class TRANS >
template<class CNV , class TRANS_T >
Convert persistent object, stored in the the top-level persistent object and referenced by the TP Ref, to transient representation.
An empty transient object to be filled in is provided. If converter is not given, it will be found based on the Ref type.
- Parameters
-
cnv | [IN][OUT] pointer to the converter, usually 0 at the start. Once the right converter is found, this pointer will be set so the search is done only once |
ref | [IN] TP Ref to the persistent object to be converted |
trans | [IN] pointer to the empty transient object |
log | [IN] output message stream |
Definition at line 145 of file TPConverter.h.
146 if(
ref.isNull() )
return;
148 if( !cnv ) cnv = &temp_cnv_p;
150 if( !*cnv || (*cnv)->typeID().value() !=
ref.typeID() ) {
154 (*cnv)->setReadingFlag();
156 (**cnv).pstoreToTrans(
ref.index(), trans,
log );
◆ ignoreRecursion()
Tell the converter to ignore recursion (do not throw errors) even when recurion is detected.
UNSAFE! use only if you are sure you preallocated enough persistent storage
Definition at line 568 of file TPConverter.h.
◆ initPrivateConverters()
Reimplemented in JetConverterBase< Jet_p5 >, JetConverterBase< Jet_p6 >, JetCnv_p4, TauPi0DetailsCnv_p2, TauPi0ClusterCnv_p1, TauPi0DetailsCnv_p1, TauPi0CandidateCnv_p1, TrackParticleBaseCnv_p1, TrigVertexCnv_p1, TrigVertexCnv_p2, TrigInDetTrackCollectionCnv_p1, MeasuredNeutralAtaSurfaceCnv_p1< SURFACE_CNV, ATA_SURFACE >, MeasuredNeutralAtaSurfaceCnv_p1< NeutralAtaStraightLineCnv_p1, Trk::NeutralAtaStraightLine >, MeasuredNeutralAtaSurfaceCnv_p1< NeutralAtaPlaneCnv_p1, Trk::NeutralAtaPlane >, MeasuredNeutralAtaSurfaceCnv_p1< NeutralAtaDiscCnv_p1, Trk::NeutralAtaDisc >, MeasuredNeutralAtaSurfaceCnv_p1< NeutralAtaCylinderCnv_p1, Trk::NeutralAtaCylinder >, SegmentCnv_p1, VxCandidateCnv_p1, MeasuredAtaSurfaceCnv_p1< SURFACE_CNV, ATA_SURFACE >, TrackCnv_p3, MeasuredAtaSurfaceCnv_p1< AtaDiscCnv_p1, Trk::AtaDisc >, MeasuredAtaSurfaceCnv_p1< AtaPlaneCnv_p1, Trk::AtaPlane >, MeasuredAtaSurfaceCnv_p1< AtaCylinderCnv_p1, Trk::AtaCylinder >, MeasuredAtaSurfaceCnv_p1< CurvilinearParametersCnv_p1, Trk::CurvilinearParameters >, MeasuredAtaSurfaceCnv_p1< AtaStraightLineCnv_p1, Trk::AtaStraightLine >, TrackParticleCnv_p2, TrackCnv_p1, TrackCnv_p2, TrackCnv_p4, TrackCnv_p12, V0CandidateCnv_p1, VxCandidateCnv_p2, and TrackParticleCnv_p3.
Definition at line 187 of file TPConverter.h.
◆ operator=()
◆ persistentTInfo() [1/2]
return C++ type id of the persistent class this converter is for
- Returns
- std::type_info&
Definition at line 482 of file TPConverter.h.
482 {
return typeid(
PERS); }
◆ persistentTInfo() [2/2]
virtual const std::type_info& ITPCnvBase::persistentTInfo |
( |
| ) |
const |
|
pure virtualinherited |
◆ persToTrans() [1/2]
Method creating the transient representation of McEventCollection
from its persistent representation McEventCollection_p7
.
Definition at line 66 of file McEventCollectionCnv_p7.cxx.
70 const EventContext& ctx = Gaudi::Hive::currentContext();
72 msg <<
MSG::DEBUG <<
"Loading McEventCollection from persistent state..."
83 datapools.
part.prepareToAdd(nParts);
84 const unsigned int nEvts = persObj->
m_genEvents.size();
85 datapools.
evt.prepareToAdd(nEvts);
88 for ( std::vector<GenEvent_p7>::const_iterator
94 HepMC::GenEvent * genEvt(
nullptr);
96 genEvt =
new HepMC::GenEvent();
101 genEvt->add_attribute (
"barcodes", std::make_shared<HepMC::GenEventBarcodes>());
108 genEvt->add_attribute(
"signal_process_id", std::make_shared<HepMC3::IntAttribute>(persEvt.
m_signalProcessId));
110 genEvt->add_attribute(
"mpi", std::make_shared<HepMC3::IntAttribute>(persEvt.
m_mpi));
111 genEvt->add_attribute(
"event_scale", std::make_shared<HepMC3::DoubleAttribute>(persEvt.
m_eventScale));
112 genEvt->add_attribute(
"alphaQCD", std::make_shared<HepMC3::DoubleAttribute>(persEvt.
m_alphaQCD));
113 genEvt->add_attribute(
"alphaQED", std::make_shared<HepMC3::DoubleAttribute>(persEvt.
m_alphaQED));
114 genEvt->add_attribute(
"filterWeight", std::make_shared<HepMC3::DoubleAttribute>(persEvt.
m_filterWeight));
115 genEvt->add_attribute(
"filterHT", std::make_shared<HepMC3::DoubleAttribute>(persEvt.m_filterHT));
116 genEvt->add_attribute(
"filterMET", std::make_shared<HepMC3::DoubleAttribute>(persEvt.m_filterMET));
118 genEvt->add_attribute(
"random_states", std::make_shared<HepMC3::VectorLongIntAttribute>(persEvt.
m_randomStates));
120 genEvt->set_units(
static_cast<HepMC3::Units::MomentumUnit
>(persEvt.
m_momentumUnit),
121 static_cast<HepMC3::Units::LengthUnit
>(persEvt.
m_lengthUnit));
124 if(!genEvt->run_info()) {
125 HepMC3::GenRunInfoData ri_read;
132 auto ri = std::make_shared<HepMC3::GenRunInfo>();
133 ri->read_data(ri_read);
134 genEvt->set_run_info(ri);
139 auto cs = std::make_shared<HepMC3::GenCrossSection>();
141 if(
static_cast<bool>(xsection[0]) )
142 cs->set_cross_section(xsection[2],xsection[1]);
144 cs->set_cross_section(-1.0, -1.0);
145 genEvt->set_cross_section(cs);
150 auto hi = std::make_shared<HepMC3::GenHeavyIon>();
151 const std::vector<float>& hIon = persEvt.
m_heavyIon;
154 static_cast<int>(hIon[12]),
155 static_cast<int>(hIon[11]),
156 static_cast<int>(hIon[10]),
157 static_cast<int>(hIon[9]),
158 static_cast<int>(hIon[8]),
159 static_cast<int>(hIon[7]),
160 static_cast<int>(hIon[6]),
161 static_cast<int>(hIon[5]),
162 static_cast<int>(hIon[4]),
167 genEvt->set_heavy_ion(hi);
177 pi->set(
static_cast<int>(
pdf[8]),
178 static_cast<int>(
pdf[7]),
184 static_cast<int>(
pdf[6]),
185 static_cast<int>(
pdf[5]));
186 genEvt->set_pdf_info(
pi);
196 std::map<int, HepMC::GenVertexPtr> brc_to_vertex;
200 for (
unsigned int iVtx = persEvt.
m_verticesBegin; iVtx != endVtx; ++iVtx ) {
207 if ( sigProcVtx != 0 && brc_to_vertex.count(sigProcVtx) ) {
212 for (
auto &
p : partToEndVtx) {
213 if ( brc_to_vertex.count(
p.second) ) {
214 auto decayVtx = brc_to_vertex[
p.second];
215 decayVtx->add_particle_in(
p.first );
217 msg << MSG::ERROR <<
"GenParticle points to null end vertex !!" <<
endmsg;
223 if ( beamPart1 != 0 && beamPart2 != 0 ) {
231 genEvt->m_mpi = persEvt.
m_mpi;
235 genEvt->m_signal_process_vertex = 0;
236 genEvt->m_beam_particle_1 = 0;
237 genEvt->m_beam_particle_2 = 0;
240 genEvt->m_vertex_barcodes.clear();
241 genEvt->m_particle_barcodes.clear();
242 genEvt->m_momentum_unit =
static_cast<HepMC::Units::MomentumUnit
>(persEvt.
m_momentumUnit);
243 genEvt->m_position_unit =
static_cast<HepMC::Units::LengthUnit
>(persEvt.
m_lengthUnit);
249 if( genEvt->m_cross_section )
250 delete genEvt->m_cross_section;
251 genEvt->m_cross_section = 0;
254 genEvt->m_cross_section =
new HepMC::GenCrossSection();
256 if(
static_cast<bool>(xsection[0]) )
257 genEvt->m_cross_section->set_cross_section(xsection[2],xsection[1]);
261 if(genEvt->m_heavy_ion )
262 delete genEvt->m_heavy_ion;
263 genEvt->m_heavy_ion = 0;
265 const std::vector<float>& hIon = persEvt.
m_heavyIon;
266 genEvt->m_heavy_ion =
new HepMC::HeavyIon
268 static_cast<int>(hIon[12]),
269 static_cast<int>(hIon[11]),
270 static_cast<int>(hIon[10]),
271 static_cast<int>(hIon[9]),
272 static_cast<int>(hIon[8]),
273 static_cast<int>(hIon[7]),
274 static_cast<int>(hIon[6]),
275 static_cast<int>(hIon[5]),
276 static_cast<int>(hIon[4]),
286 if(genEvt->m_pdf_info)
287 delete genEvt->m_pdf_info;
288 genEvt->m_pdf_info = 0;
291 genEvt->m_pdf_info =
new HepMC::PdfInfo
293 static_cast<int>(
pdf[8]),
294 static_cast<int>(
pdf[7]),
300 static_cast<int>(
pdf[6]),
301 static_cast<int>(
pdf[5])
316 for (
unsigned int iVtx= persEvt.
m_verticesBegin; iVtx != endVtx; ++iVtx ) {
325 if ( sigProcVtx != 0 ) {
326 genEvt->set_signal_process_vertex( genEvt->barcode_to_vertex( sigProcVtx ) );
331 p = partToEndVtx.begin(),
332 endItr = partToEndVtx.end();
337 decayVtx->add_particle_in(
p->first );
340 <<
"GenParticle points to null end vertex !!"
348 if ( beamPart1 != 0 && beamPart2 !=0 ) {
349 genEvt->set_beam_particles(genEvt->barcode_to_particle(beamPart1),
350 genEvt->barcode_to_particle(beamPart2));
358 msg <<
MSG::DEBUG <<
"Loaded McEventCollection from persistent state [OK]"
◆ persToTrans() [2/2]
Convert persistent representation to transient one.
Copies data members from persistent object to an existing transient one. Needs to be implemented by the developer on the actual converter.
- Parameters
-
persObj | [IN] persistent object |
transObj | [IN] transient object |
log | [IN] output message stream |
Implemented in TPCnvIDContFromIdentifier< TRANS, PERS, CONV >, TPCnvIDCont< TRANS, PERS, CONV >, TPCnvStdVector< TRANS, PERS, CONV >, TPCnvVector< TRANS, PERS, CONV >, TPValVectorCnv< TRANS, PERS, CONV >, TPPtrVectorCnv< TRANS, PERS, CONV >, TPConverterConstBase< TRANS, PERS >, T_AtlasHitsVectorCnv< TRANS, PERS, CONV >, and T_AthenaHitsVectorCnv< TRANS, PERS, CONV >.
◆ persToTransUntyped()
Convert persistent object representation to transient.
- Parameters
-
pers | [IN] void* pointer to the persistent object |
trans | [OUT] void* pointer to the empty transient object |
log | [IN] output message stream |
Implements ITPCnvBase.
Definition at line 400 of file TPConverter.h.
405 reinterpret_cast<TRANS*
> (trans),
◆ persToTransWithKey()
Convert persistent representation to transient one.
Copies data members from persistent object to an existing transient one. Needs to be implemented by the developer on the actual converter.
- Parameters
-
persObj | [IN] persistent object |
transObj | [IN] transient object |
log | [IN] output message stream |
Reimplemented in TPConverterWithKeyBase< TRANS, PERS >.
Definition at line 376 of file TPConverter.h.
◆ persToTransWithKeyUntyped()
Convert persistent object representation to transient.
- Parameters
-
pers | [IN] void* pointer to the persistent object |
trans | [OUT] void* pointer to the empty transient object |
key | [IN] SG key of object being read. |
log | [IN] output message stream |
Reimplemented from ITPCnvBase.
Definition at line 420 of file TPConverter.h.
426 reinterpret_cast<TRANS*
> (trans),
◆ pstoreToTrans()
template<class TRANS , class PERS >
virtual void TPConverterBase< TRANS, PERS >::pstoreToTrans |
( |
unsigned |
index, |
|
|
TRANS * |
trans, |
|
|
MsgStream & |
log |
|
) |
| |
|
inlinevirtualinherited |
Convert persistent representation stored in the storage vector of the top-level object to transient.
Internal.
- Parameters
-
index | [IN] index of the persistent representation in the storage vector |
trans | [IN] empty transient object |
log | [IN] output message stream
|
Reimplemented from TPAbstractPolyCnvBase< TRANS, TRANS, PERS >.
Definition at line 760 of file TPConverter.h.
◆ reservePStorage()
◆ setPileup()
void McEventCollectionCnv_p7::setPileup |
( |
| ) |
|
◆ setPStorage()
Tell this converter which storage vector it should use to store or retrieve persistent representations.
- Parameters
-
storage | [IN] the address of the storage vector |
Definition at line 551 of file TPConverter.h.
◆ setReadingFlag()
◆ setRecursive()
Tell the converter if it should work in recursive mode slower but it can safely handle recursion.
Definition at line 559 of file TPConverter.h.
◆ setRuntimeTopConverter()
Set runtime top-level converter - usually it is the owning TL converter, but in case of extended objects it will be the TL converter of the extended object.
- Parameters
-
topConverter | [IN] runtime top-level converter for this converter |
Implements ITPConverter.
Definition at line 215 of file TPConverter.h.
◆ setTopConverter()
Set which top-level converter owns this elemental converter, and what TPtypeID was assigned to the persistent objects it produces.
- Parameters
-
topConverter | [IN] the top-level converter owning this converter |
TPtypeID | [IN] TP type id for persistent objects (used in TP refs) |
Implements ITPConverter.
Definition at line 221 of file TPConverter.h.
◆ topConverter() [1/2]
return the top-level converter for this elemental TP converter
- Returns
- TopLevelTPCnvBas
Reimplemented from ITPConverter.
Definition at line 191 of file TPConverter.h.
◆ topConverter() [2/2]
return the top-level converter for this elemental TP converter
- Returns
- TopLevelTPCnvBas
Reimplemented from ITPConverter.
Definition at line 196 of file TPConverter.h.
◆ toPersistent()
template<class TRANS >
template<class CNV >
Persistify an object and store the persistent represenation in the storage vector of the top-level persistent object.
The correct converter is located using the actual object type.
- Parameters
-
cnv | [IN/OUT] pointer to the converter, usually 0 at the start. Once the right converter is found, this pointer will be set so the search is done only once |
transObj | [IN] transient object |
log | [IN] output message stream |
- Returns
- TPObjRef TP reference to the persistent representation stored in the storage vector of the top-level persistent object
Definition at line 119 of file TPConverter.h.
122 if( !cnv ) cnv = &temp_cnv_p;
123 if( !*cnv || (*cnv)->wasUsedForReading() ) {
127 (*cnv)->clearReadingFlag();
129 return (**cnv).virt_toPersistent(transObj,
log);
◆ toPersistentWithKey_impl()
Convert transient object to persistent representation.
Stores the result in the storage vector of the top-level object and returns a TP Ref to it.
- Parameters
-
trans | [IN] transient object |
key | [IN] SG key of object being converted |
log | [IN] output message stream |
- Returns
- TP reference to the persistent representation
◆ transBaseTInfo()
return C++ type id of the common base transient type for all converters for a group of polymorphic types
- Returns
- std::type_info& this method is not overwritten in the subclasses like transientTInfo()
Implements ITPConverter.
Definition at line 205 of file TPConverter.h.
205 {
return typeid(TRANS); }
◆ transientTInfo() [1/2]
return C++ type id of the transient class this converter is for
- Returns
- std::type_info&
Implements ITPCnvBase.
Reimplemented in TPAbstractPolyCnvBase< Analysis::MuonContainer, Analysis::MuonContainer, MuonContainer_p3 >, TPAbstractPolyCnvBase< TileTrackMuFeatureContainer, TileTrackMuFeatureContainer, TileTrackMuFeatureContainer_p3 >, TPAbstractPolyCnvBase< std::vector< Analysis::TauPi0Cluster * >, std::vector< Analysis::TauPi0Cluster * >, std::vector< TPObjRef > >, TPAbstractPolyCnvBase< IsoMuonFeatureContainer, IsoMuonFeatureContainer, IsoMuonFeatureContainer_p2 >, TPAbstractPolyCnvBase< MuonFeatureContainer, MuonFeatureContainer, MuonFeatureContainer_p3 >, TPAbstractPolyCnvBase< MuonFeatureDetailsContainer, MuonFeatureDetailsContainer, MuonFeatureDetailsContainer_p2 >, TPAbstractPolyCnvBase< std::vector< Trk::VxCandidate * >, std::vector< Trk::VxCandidate * >, std::vector< TPObjRef > >, TPAbstractPolyCnvBase< std::vector< TrigConfAlg >, std::vector< TrigConfAlg >, std::vector< TrigConfAlg_p1 > >, TPAbstractPolyCnvBase< TrigT2MbtsBitsContainer, TrigT2MbtsBitsContainer, TrigT2MbtsBitsContainer_p3 >, TPAbstractPolyCnvBase< TrigCompositeContainer, TrigCompositeContainer, TrigCompositeContainer_p1 >, TPAbstractPolyCnvBase< LumiBlockCollection, LumiBlockCollection, LumiBlockCollection_p2 >, TPAbstractPolyCnvBase< TrigTauClusterContainer, TrigTauClusterContainer, TrigTauClusterContainer_p5 >, TPAbstractPolyCnvBase< TrigRNNOutputContainer, TrigRNNOutputContainer, TrigRNNOutputContainer_p2 >, TPAbstractPolyCnvBase< TrigRoiDescriptorCollection, TrigRoiDescriptorCollection, TrigRoiDescriptorCollection_p3 >, TPAbstractPolyCnvBase< TrigTauClusterContainer, TrigTauClusterContainer, TrigTauClusterContainer_p4 >, TPAbstractPolyCnvBase< TrigT2JetContainer, TrigT2JetContainer, TrigT2JetContainer_p3 >, TPAbstractPolyCnvBase< TrigPassBitsCollection, TrigPassBitsCollection, TrigPassBitsCollection_p1 >, TPAbstractPolyCnvBase< TrigRoiDescriptorCollection, TrigRoiDescriptorCollection, TrigRoiDescriptorCollection_p2 >, TPAbstractPolyCnvBase< std::vector< const JetTagInfoBase * >, std::vector< const JetTagInfoBase * >, std::vector< TPObjRef > >, TPAbstractPolyCnvBase< TrigTauClusterContainer, TrigTauClusterContainer, TrigTauClusterContainer_p3 >, TPAbstractPolyCnvBase< TrigMuonEFIsolationContainer, TrigMuonEFIsolationContainer, TrigMuonEFIsolationContainer_p1 >, TPAbstractPolyCnvBase< MultiComponentStateOnSurfaceDV, MultiComponentStateOnSurfaceDV, std::vector< TPObjRef > >, TPAbstractPolyCnvBase< RingerRingsContainer, RingerRingsContainer, RingerRingsContainer_p2 >, TPAbstractPolyCnvBase< std::vector< Trk::VxTrackAtVertex * >, std::vector< Trk::VxTrackAtVertex * >, std::vector< TPObjRef > >, TPAbstractPolyCnvBase< std::vector< TrigMonTE >, std::vector< TrigMonTE >, std::vector< TrigMonTE_p1 > >, TPAbstractPolyCnvBase< Analysis::MuonContainer, Analysis::MuonContainer, MuonContainer_p6 >, TPAbstractPolyCnvBase< TrigMissingETContainer, TrigMissingETContainer, TrigMissingETContainer_p3 >, TPAbstractPolyCnvBase< TileHitVector, TileHitVector, TileHitVector_p1 >, TPAbstractPolyCnvBase< DataVector< eflowObject >, DataVector< eflowObject >, std::vector< eflowObject_p2 > >, TPAbstractPolyCnvBase< std::vector< TrigConfSeq >, std::vector< TrigConfSeq >, std::vector< TrigConfSeq_p1 > >, TPAbstractPolyCnvBase< TrigTrtHitCountsCollection, TrigTrtHitCountsCollection, TrigTrtHitCountsCollection_p2 >, TPAbstractPolyCnvBase< JetCollection, JetCollection, ParticleJetContainer_p1 >, TPAbstractPolyCnvBase< TrigL2BjetContainer, TrigL2BjetContainer, TrigL2BjetContainer_p3 >, TPAbstractPolyCnvBase< TrigMuonEFIsolationContainer, TrigMuonEFIsolationContainer, TrigMuonEFIsolationContainer_p2 >, TPAbstractPolyCnvBase< TrigPassFlagsCollection, TrigPassFlagsCollection, TrigPassFlagsCollection_p1 >, TPAbstractPolyCnvBase< DataVector< const Trk::MeasurementBase >, DataVector< const Trk::MeasurementBase >, std::vector< TPObjRef > >, TPAbstractPolyCnvBase< DataVector< eflowObject >, DataVector< eflowObject >, std::vector< eflowObject_p3 > >, TPAbstractPolyCnvBase< TrigTauTracksInfoCollection, TrigTauTracksInfoCollection, TrigTauTracksInfoCollection_p2 >, TPAbstractPolyCnvBase< TrackInVertexVector, TrackInVertexVector, std::vector< TPObjRef > >, TPAbstractPolyCnvBase< TrigTauClusterDetailsContainer, TrigTauClusterDetailsContainer, TrigTauClusterDetailsContainer_p2 >, TPAbstractPolyCnvBase< std::vector< Analysis::TauShot * >, std::vector< Analysis::TauShot * >, std::vector< TPObjRef > >, TPAbstractPolyCnvBase< TrigEMClusterContainer, TrigEMClusterContainer, TrigEMClusterContainer_p4 >, TPAbstractPolyCnvBase< DataVector< eflowObject >, DataVector< eflowObject >, std::vector< eflowObject_p4 > >, TPAbstractPolyCnvBase< std::vector< TrigMonRoi >, std::vector< TrigMonRoi >, std::vector< TrigMonRoi_p1 > >, TPAbstractPolyCnvBase< TrigMuonEFContainer, TrigMuonEFContainer, TrigMuonEFContainer_p2 >, TPAbstractPolyCnvBase< DataVector< eflowObject >, DataVector< eflowObject >, std::vector< eflowObject_p5 > >, TPAbstractPolyCnvBase< TrigTauContainer, TrigTauContainer, TrigTauContainer_p3 >, TPAbstractPolyCnvBase< TrigEMClusterContainer, TrigEMClusterContainer, TrigEMClusterContainer_p3 >, TPAbstractPolyCnvBase< ElectronMuonTopoInfoContainer, ElectronMuonTopoInfoContainer, ElectronMuonTopoInfoContainer_p1 >, TPAbstractPolyCnvBase< TrigInDetTrackCollection, TrigInDetTrackCollection, std::vector< TPObjRef > >, TPAbstractPolyCnvBase< std::vector< const Trk::TrackParameters * >, std::vector< const Trk::TrackParameters * >, std::vector< TPObjRef > >, TPAbstractPolyCnvBase< EventBookkeeperCollection, EventBookkeeperCollection, EventBookkeeperCollection_p2 >, TPAbstractPolyCnvBase< SkimDecisionCollection, SkimDecisionCollection, SkimDecisionCollection_p1 >, TPAbstractPolyCnvBase< std::vector< TrigConfChain >, std::vector< TrigConfChain >, std::vector< TrigConfChain_p1 > >, TPAbstractPolyCnvBase< Trk::TrackStates, Trk::TrackStates, std::vector< TPObjRef > >, TPAbstractPolyCnvBase< CombinedMuonFeatureContainer, CombinedMuonFeatureContainer, CombinedMuonFeatureContainer_p4 >, TPAbstractPolyCnvBase< TrigPhotonContainer, TrigPhotonContainer, TrigPhotonContainer_p3 >, TPAbstractPolyCnvBase< std::vector< TrigMonSeq >, std::vector< TrigMonSeq >, std::vector< TrigMonSeq_p1 > >, TPAbstractPolyCnvBase< EventBookkeeperCollection, EventBookkeeperCollection, EventBookkeeperCollection_p1 >, TPAbstractPolyCnvBase< std::vector< TrigMonAlg >, std::vector< TrigMonAlg >, std::vector< TrigMonAlg_p1 > >, TPAbstractPolyCnvBase< CombinedMuonFeatureContainer, CombinedMuonFeatureContainer, CombinedMuonFeatureContainer_p3 >, TPAbstractPolyCnvBase< DataVector< eflowObject >, DataVector< eflowObject >, std::vector< eflowObject_p1 > >, TPAbstractPolyCnvBase< std::vector< Analysis::TauPi0Candidate * >, std::vector< Analysis::TauPi0Candidate * >, std::vector< TPObjRef > >, TPAbstractPolyCnvBase< CombinedMuonFeatureContainer, CombinedMuonFeatureContainer, CombinedMuonFeatureContainer_p2 >, TPAbstractPolyCnvBase< TrigElectronContainer, TrigElectronContainer, TrigElectronContainer_p3 >, TPAbstractPolyCnvBase< TrigSpacePointCountsCollection, TrigSpacePointCountsCollection, TrigSpacePointCountsCollection_p4 >, TPAbstractPolyCnvBase< Analysis::MuonContainer, Analysis::MuonContainer, MuonContainer_p5 >, TPAbstractPolyCnvBase< std::vector< TrigMonROBData >, std::vector< TrigMonROBData >, std::vector< TrigMonROBData_p1 > >, TPAbstractPolyCnvBase< TileMuFeatureContainer, TileMuFeatureContainer, TileMuFeatureContainer_p2 >, TPAbstractPolyCnvBase< std::vector< TrigConfSig >, std::vector< TrigConfSig >, std::vector< TrigConfSig_p1 > >, TPAbstractPolyCnvBase< Analysis::MuonContainer, Analysis::MuonContainer, MuonContainer_p4 >, TPAbstractPolyCnvBase< LumiBlockCollection, LumiBlockCollection, LumiBlockCollection_p1 >, TPAbstractPolyCnvBase< std::vector< const JetAssociationBase * >, std::vector< const JetAssociationBase * >, std::vector< TPObjRef > >, TPAbstractPolyCnvBase< IsoMuonFeatureContainer, IsoMuonFeatureContainer, IsoMuonFeatureContainer_p3 >, TPAbstractPolyCnvBase< TrigCaloClusterContainer, TrigCaloClusterContainer, TrigCaloClusterContainer_p3 >, and TPAbstractPolyCnvBase< std::vector< TrigMonROB >, std::vector< TrigMonROB >, std::vector< TrigMonROB_p1 > >.
Definition at line 201 of file TPConverter.h.
201 {
return typeid(TRANS); }
◆ transientTInfo() [2/2]
return C++ type id of the transient class this converter is for
- Returns
- std::type_info&
Definition at line 479 of file TPConverter.h.
479 {
return typeid(TRANS); }
◆ transToPers() [1/2]
Method creating the persistent representation McEventCollection_p7
from its transient representation McEventCollection
.
Definition at line 362 of file McEventCollectionCnv_p7.cxx.
366 const EventContext& ctx = Gaudi::Hive::currentContext();
368 msg <<
MSG::DEBUG <<
"Creating persistent state of McEventCollection..."
372 const std::pair<unsigned int,unsigned int>
stats = nbrParticlesAndVertices( transObj );
382 const HepMC::GenEvent* genEvt = *itr;
384 auto ri = genEvt->run_info();
386 HepMC3::GenRunInfoData ri_data;
388 ri->write_data(ri_data);
389 if (!ri_data.weight_names.empty()) {
390 m_hepMCWeightSvc->setWeightNames( names_to_name_index_map(ri_data.weight_names), ctx ).ignore();
398 auto A_mpi=genEvt->attribute<HepMC3::IntAttribute>(
"mpi");
399 auto A_signal_process_id=genEvt->attribute<HepMC3::IntAttribute>(
"signal_process_id");
400 auto A_event_scale=genEvt->attribute<HepMC3::DoubleAttribute>(
"event_scale");
401 auto A_alphaQCD=genEvt->attribute<HepMC3::DoubleAttribute>(
"alphaQCD");
402 auto A_alphaQED=genEvt->attribute<HepMC3::DoubleAttribute>(
"alphaQED");
403 auto A_filterWeight=genEvt->attribute<HepMC3::DoubleAttribute>(
"filterWeight");
404 auto A_filterHT=genEvt->attribute<HepMC3::DoubleAttribute>(
"filterHT");
405 auto A_filterMET=genEvt->attribute<HepMC3::DoubleAttribute>(
"filterMET");
407 auto A_random_states=genEvt->attribute<HepMC3::VectorLongIntAttribute>(
"random_states");
408 auto beams=genEvt->beams();
410 emplace_back(A_signal_process_id?(A_signal_process_id->value()):-1,
411 genEvt->event_number(),
412 A_mpi?(A_mpi->value()):-1,
413 A_event_scale?(A_event_scale->value()):0.0,
414 A_alphaQCD?(A_alphaQCD->value()):0.0,
415 A_alphaQED?(A_alphaQED->value()):0.0,
416 A_filterWeight?(A_filterWeight->value()):1.0,
417 A_filterHT?(A_filterHT->value()):-13.,
418 A_filterMET?(A_filterMET->value()):-13.0,
423 A_random_states?(A_random_states->value()):std::vector<long>(),
424 std::vector<double>(),
425 std::vector<float>(),
426 std::vector<double>(),
427 genEvt->momentum_unit(),
428 genEvt->length_unit(),
430 nPersVtx + genEvt->vertices().size(),
432 nPersParts + genEvt->particles().size() );
435 std::map< std::string, std::map<int, std::shared_ptr<HepMC3::Attribute> > > e_atts = genEvt->attributes();
439 for (
auto& attmap: e_atts) {
440 if (attributes_to_ignore.count(attmap.first))
continue;
441 if (attmap.first ==
"ShadowParticle")
continue;
442 if (attmap.first ==
"ShadowParticleId")
continue;
443 for (
auto& att: attmap.second) {
447 att.second->to_string(st);
470 if (genEvt->cross_section()) {
471 auto cs=genEvt->cross_section();
491 if (genEvt->heavy_ion()) {
492 auto hi=genEvt->heavy_ion();
494 std::vector<float>& heavyIon = persEvt.
m_heavyIon;
496 heavyIon[12] =
static_cast<float>(hi->Ncoll_hard);
497 heavyIon[11] =
static_cast<float>(hi->Npart_proj);
498 heavyIon[10] =
static_cast<float>(hi->Npart_targ);
499 heavyIon[9] =
static_cast<float>(hi->Ncoll);
500 heavyIon[8] =
static_cast<float>(hi->spectator_neutrons);
501 heavyIon[7] =
static_cast<float>(hi->spectator_protons);
502 heavyIon[6] =
static_cast<float>(hi->N_Nwounded_collisions);
503 heavyIon[5] =
static_cast<float>(hi->Nwounded_N_collisions);
504 heavyIon[4] =
static_cast<float>(hi->Nwounded_Nwounded_collisions);
505 heavyIon[3] = hi->impact_parameter;
506 heavyIon[2] = hi->event_plane_angle;
507 heavyIon[1] = hi->eccentricity;
508 heavyIon[0] = hi->sigma_inel_NN;
512 if (genEvt->pdf_info()) {
513 auto pi=genEvt->pdf_info();
515 std::vector<double>& pdfinfo = persEvt.
m_pdfinfo;
517 pdfinfo[8] =
static_cast<double>(
pi->parton_id[0]);
518 pdfinfo[7] =
static_cast<double>(
pi->parton_id[1]);
519 pdfinfo[6] =
static_cast<double>(
pi->pdf_id[0]);
520 pdfinfo[5] =
static_cast<double>(
pi->pdf_id[1]);
521 pdfinfo[4] =
pi->x[0];
522 pdfinfo[3] =
pi->x[1];
523 pdfinfo[2] =
pi->scale;
524 pdfinfo[1] =
pi->xf[0];
525 pdfinfo[0] =
pi->xf[1];
529 for (
const auto&
v: genEvt->vertices()) {
533 const int signalProcessVtx = genEvt->m_signal_process_vertex
534 ? genEvt->m_signal_process_vertex->barcode()
536 const int beamParticle1Barcode = genEvt->m_beam_particle_1
537 ? genEvt->m_beam_particle_1->barcode()
539 const int beamParticle2Barcode = genEvt->m_beam_particle_2
540 ? genEvt->m_beam_particle_2->barcode()
544 m_hepMCWeightSvc->setWeightNames( genEvt->m_weights.m_names, ctx ).ignore();
548 push_back(
GenEvent_p7( genEvt->m_signal_process_id,
549 genEvt->m_event_number,
551 genEvt->m_event_scale,
556 beamParticle1Barcode,
557 beamParticle2Barcode,
558 genEvt->m_weights.m_weights,
559 genEvt->m_random_states,
560 std::vector<double>(),
561 std::vector<float>(),
562 std::vector<double>(),
563 genEvt->m_momentum_unit,
564 genEvt->m_position_unit,
566 nPersVtx + genEvt->vertices_size(),
568 nPersParts + genEvt->particles_size() ) );
570 if (genEvt->m_cross_section) {
574 crossSection[2] = genEvt->m_cross_section->m_cross_section;
575 crossSection[1] = genEvt->m_cross_section->m_cross_section_error;
576 crossSection[0] =
static_cast<double>(genEvt->m_cross_section->m_is_set);
580 if (genEvt->m_heavy_ion) {
582 std::vector<float>& heavyIon = persEvt.
m_heavyIon;
584 heavyIon[12] =
static_cast<float>(genEvt->m_heavy_ion->m_Ncoll_hard);
585 heavyIon[11] =
static_cast<float>(genEvt->m_heavy_ion->m_Npart_proj);
586 heavyIon[10] =
static_cast<float>(genEvt->m_heavy_ion->m_Npart_targ);
587 heavyIon[9] =
static_cast<float>(genEvt->m_heavy_ion->m_Ncoll);
588 heavyIon[8] =
static_cast<float>(genEvt->m_heavy_ion->m_spectator_neutrons);
589 heavyIon[7] =
static_cast<float>(genEvt->m_heavy_ion->m_spectator_protons);
590 heavyIon[6] =
static_cast<float>(genEvt->m_heavy_ion->m_N_Nwounded_collisions);
591 heavyIon[5] =
static_cast<float>(genEvt->m_heavy_ion->m_Nwounded_N_collisions);
592 heavyIon[4] =
static_cast<float>(genEvt->m_heavy_ion->m_Nwounded_Nwounded_collisions);
593 heavyIon[3] = genEvt->m_heavy_ion->m_impact_parameter;
594 heavyIon[2] = genEvt->m_heavy_ion->m_event_plane_angle;
595 heavyIon[1] = genEvt->m_heavy_ion->m_eccentricity;
596 heavyIon[0] = genEvt->m_heavy_ion->m_sigma_inel_NN;
600 if (genEvt->m_pdf_info) {
602 std::vector<double>& pdfinfo = persEvt.
m_pdfinfo;
604 pdfinfo[8] =
static_cast<double>(genEvt->m_pdf_info->m_id1);
605 pdfinfo[7] =
static_cast<double>(genEvt->m_pdf_info->m_id2);
606 pdfinfo[6] =
static_cast<double>(genEvt->m_pdf_info->m_pdf_id1);
607 pdfinfo[5] =
static_cast<double>(genEvt->m_pdf_info->m_pdf_id2);
608 pdfinfo[4] = genEvt->m_pdf_info->m_x1;
609 pdfinfo[3] = genEvt->m_pdf_info->m_x2;
610 pdfinfo[2] = genEvt->m_pdf_info->m_scalePDF;
611 pdfinfo[1] = genEvt->m_pdf_info->m_pdf1;
612 pdfinfo[0] = genEvt->m_pdf_info->m_pdf2;
616 const HepMC::GenEvent::vertex_const_iterator endVtx=genEvt->vertices_end();
617 for ( HepMC::GenEvent::vertex_const_iterator
i = genEvt->vertices_begin();
◆ transToPers() [2/2]
Convert transient representation to persistent one.
Copies data members from transient object to an existing persistent one. Needs to be implemented by the developer on the actual converter.
- Parameters
-
transObj | [IN] transient object |
persObj | [IN] persistent object |
log | [IN] output message stream |
Implemented in TPCnvIDContFromIdentifier< TRANS, PERS, CONV >, TPCnvIDCont< TRANS, PERS, CONV >, TPCnvStdVector< TRANS, PERS, CONV >, TPCnvVector< TRANS, PERS, CONV >, TPValVectorCnv< TRANS, PERS, CONV >, TPPolyVectorCnv< TRANS, PERS, CONV >, TPPtrVectorCnv< TRANS, PERS, CONV >, TPConverterConstBase< TRANS, PERS >, T_AtlasHitsVectorCnv< TRANS, PERS, CONV >, and T_AthenaHitsVectorCnv< TRANS, PERS, CONV >.
◆ transToPersUntyped()
Convert transient object representation to persistent.
- Parameters
-
trans | [IN] void* pointer to the transient object |
pers | [OUT] void* pointer to the empty persistent object |
log | [IN] output message stream |
Implements ITPCnvBase.
Definition at line 410 of file TPConverter.h.
414 transToPers (
reinterpret_cast<const TRANS*
> (trans),
415 reinterpret_cast<PERS*
> (pers),
◆ transToPersWithKey()
Convert transient representation to persistent one.
Copies data members from transient object to an existing persistent one. Needs to be implemented by the developer on the actual converter.
- Parameters
-
transObj | [IN] transient object |
persObj | [IN] persistent object |
key | [IN] SG key of object being written. |
log | [IN] output message stream |
Reimplemented in TPConverterWithKeyBase< TRANS, PERS >.
Definition at line 392 of file TPConverter.h.
◆ transToPersWithKeyUntyped()
Convert transient object representation to persistent.
- Parameters
-
trans | [IN] void* pointer to the transient object |
pers | [OUT] void* pointer to the empty persistent object |
key | [IN] SG key of object being written. |
log | [IN] output message stream |
Reimplemented from ITPCnvBase.
Definition at line 432 of file TPConverter.h.
438 reinterpret_cast<PERS*
> (pers),
◆ typeID()
◆ typeIDvalue()
inlined non-virtual version to get the typeID value fast
Definition at line 211 of file TPConverter.h.
◆ virt_createTransFromPStore()
virtual TRANS* TPPolyCnvBase< TRANS , TRANS, PERS >::virt_createTransFromPStore |
( |
unsigned |
index, |
|
|
MsgStream & |
log |
|
) |
| |
|
inlinevirtualinherited |
Internal interface method that is used to invoke the real conversion method (createTransient)
- Parameters
-
index | [IN] index of the persistent object in the storage vector |
log | [IN] output message stream |
- Returns
- Created transient object (by pointer)
Reimplemented from TPAbstractPolyCnvBase< TRANS, TRANS, PERS >.
Definition at line 706 of file TPConverter.h.
◆ virt_createTransFromPStoreWithKey()
virtual TRANS* TPPolyCnvBase< TRANS , TRANS, PERS >::virt_createTransFromPStoreWithKey |
( |
unsigned |
index, |
|
|
const std::string & |
key, |
|
|
MsgStream & |
log |
|
) |
| |
|
inlinevirtualinherited |
Internal interface method that is used to invoke the real conversion method (createTransient)
- Parameters
-
index | [IN] index of the persistent object in the storage vector |
key | [IN] SG key of the object being converted |
log | [IN] output message stream |
- Returns
- Created transient object (by pointer)
Reimplemented from TPAbstractPolyCnvBase< TRANS, TRANS, PERS >.
Definition at line 718 of file TPConverter.h.
◆ virt_toPersistent()
template<class TRANS , class PERS >
Internal interface method that is used to invoke the real conversion method (toPersistent_impl) in the derived converter.
- Parameters
-
trans | [IN] transient object |
log | [IN] output message stream |
- Returns
- TPObjRef TP reference to the persistent representation stored in the storage vector of the top-level persistent object Here toPersistent_impl is invoked with the dynamic cast of the transient type pointer to it's actual type
Reimplemented from TPAbstractPolyCnvBase< TRANS, TRANS, PERS >.
Definition at line 747 of file TPConverter.h.
◆ virt_toPersistentWithKey()
template<class TRANS , class PERS >
Internal interface method that is used to invoke the real conversion method (toPersistent_impl) in the derived converter.
- Parameters
-
trans | [IN] transient object |
key | [IN] SG key of the object being converted. |
log | [IN] output message stream |
- Returns
- TPObjRef TP reference to the persistent representation stored in the storage vector of the top-level persistent object Here toPersistentWithKey_impl is invoked with the dynamic cast of the transient type pointer to it's actual type
Reimplemented from TPAbstractPolyCnvBase< TRANS, TRANS, PERS >.
Definition at line 752 of file TPConverter.h.
◆ wasUsedForReading()
◆ writeGenParticle()
Method to write a persistent GenParticle
object It returns the index of the persistent GenParticle
into the collection of persistent of GenParticles
from the persistent GenEvent
.
Definition at line 922 of file McEventCollectionCnv_p7.cxx.
925 const HepMC::FourVector&
mom =
p.m_momentum;
926 const double ene =
mom.e();
927 const double m2 =
mom.m2();
930 const bool useP2M2 = !(
m2 > 0) &&
932 !(std::abs(
m2) < 2.0*DBL_EPSILON*ene*ene);
934 const short recoMethod = ( !useP2M2
948 p.m_polarization.theta(),
949 p.m_polarization.phi(),
950 p.m_production_vertex
951 ?
p.m_production_vertex->barcode()
954 ?
p.m_end_vertex->barcode()
◆ writeGenVertex()
Method to write a persistent GenVertex
object.
The persistent vertex is added to the persistent is added to the persistent GenEvent
.
Definition at line 841 of file McEventCollectionCnv_p7.cxx.
844 const HepMC::FourVector& position = vtx.m_position;
851 vtx.m_weights.m_weights.begin(),
852 vtx.m_weights.m_weights.end(),
857 const std::vector<HepMC::GenParticlePtr>::const_iterator endInVtx = vtx.m_particles_in.end();
859 for ( std::vector<HepMC::GenParticlePtr>::const_iterator
p = vtx.m_particles_in.begin();
862 if ( 0 == (*p)->production_vertex() ) {
867 const std::vector<HepMC::GenParticlePtr>::const_iterator endOutVtx = vtx.m_particles_out.end();
869 for ( std::vector<HepMC::GenParticlePtr>::const_iterator
p = vtx.m_particles_out.begin();
◆ m_curRecLevel
count recursive invocations, to detect recursion
Definition at line 582 of file TPConverter.h.
◆ m_hepMCWeightSvc
◆ m_ignoreRecursion
if true, do not throw errors in case of recursion.
Definition at line 588 of file TPConverter.h.
◆ m_isPileup
bool McEventCollectionCnv_p7::m_isPileup |
|
protected |
◆ m_pStorage
the address of the storage vector for persistent representations
Definition at line 579 of file TPConverter.h.
◆ m_pStorageTID
TP Ref typeID for the persistent objects this converter is creating.
Definition at line 292 of file TPConverter.h.
◆ m_pStorageTIDvalue
m_pStorageTID converted to integer value
Definition at line 295 of file TPConverter.h.
◆ m_recursive
if true, work in recursion-safe way (slower)
Definition at line 585 of file TPConverter.h.
◆ m_topConverter
top level converter that owns this elemental TP converter it also holds the storage object
Definition at line 299 of file TPConverter.h.
◆ m_topConverterRuntime
top level converter "owning" this TP converter at runtime (different from m_topConverter in case the top-level converter and object have extensions)
Definition at line 302 of file TPConverter.h.
◆ m_wasUsedForReading
flag set when using this converter for reading triggers search for a new converter before writing, to prevent possible use of old version
Definition at line 306 of file TPConverter.h.
The documentation for this class was generated from the following files:
void reserve(size_type n)
Attempt to preallocate enough memory for a specified number of elements.
HepMC::GenVertex * GenVertexPtr
JetConstituentVector::iterator iterator
virtual const TPObjRef::typeID_t & typeID() const =0
Return TP typeID for persistent objects produced by this converter.
bool suggest_barcode(T &p, int i)
ITPConverter * converterForType(const std::type_info &info) const
Find and return a TP converter for a given C++ type info.
std::vector< PERS > * m_pStorage
the address of the storage vector for persistent representations
double m_alphaQCD
value of the QCD coupling.
std::vector< double > m_crossSection
Container of HepMC::GenCrossSection object translated to vector<double>
Const iterator class for DataVector/DataList.
unsigned int m_verticesBegin
Begin position in the vector of vertices composing this event.
std::vector< float > m_heavyIon
Container of HepMC::HeavyIon object translated to vector<double>
int nVertices(const Polygon &p)
TopLevelTPCnvBase * m_topConverter
top level converter that owns this elemental TP converter it also holds the storage object
HepMC::GenVertexPtr createGenVertex(const McEventCollection_p7 &persEvts, const GenVertex_p7 &vtx, ParticlesMap_t &bcToPart, HepMC::DataPool &datapools, HepMC::GenEvent *parent=nullptr) const
Create a transient GenVertex from a persistent one (version 1) It returns the new GenVertex.
TPObjRef toPersistentWithKey_impl(const TRANS *trans, const std::string &key, MsgStream &log)
Convert transient object to persistent representation.
@ VIEW_ELEMENTS
this data object is a view, it does not own its elmts
AccessorTemplate & operator=(AccessorTemplate &&that)
unsigned value() const
Returns the type ID as an integer.
HepMC::GenParticlePtr createGenParticle(const GenParticle_p7 &p, ParticlesMap_t &partToEndVtx, HepMC::DataPool &datapools, const HepMC::GenVertexPtr &parent=nullptr, bool add_to_output=true) const
Create a transient GenParticle from a persistent one (vers.1) It returns the new GenParticle.
int m_signalProcessVtx
Barcode of the GenVertex holding the signal process.
virtual TRANS * createTransient(const PERS *persObj, MsgStream &log)
Create transient representation of a persistent object.
int m_barcode
barcode of this vertex (uniquely identifying a vertex within an event)
GenParticle * GenParticlePtr
HepMC::PdfInfo * GenPdfInfoPtr
ITPConverter * converterForRef(const TPObjRef &ref) const
Find and return a TP converter for persistent type referenced by ref.
std::vector< GenParticle_p7 > m_genParticles
The vector of persistent representation of GenParticles.
virtual TRANS * createTransientWithKey(const PERS *persObj, const std::string &key, MsgStream &log)
Create transient representation of a persistent object, with SG key.
std::vector< double > m_weights
Weights for this event.
int m_momentumUnit
HepMC::Units::MomentumUnit casted to int.
int m_lengthUnit
HepMC::Units::LengthUnit casted to int.
std::vector< std::string > m_e_attribute_name
Attribute name for event.
bool m_ignoreRecursion
if true, do not throw errors in case of recursion.
virtual TopLevelTPCnvBase * topConverter()
return the top-level converter for this elemental TP converter
unsigned int m_verticesEnd
End position in the vector of vertices composing this event.
T_AthenaPoolTPCnvBase< McEventCollection, McEventCollection_p7 > Base_t
std::vector< GenEvent_p7 > m_genEvents
The vector of persistent representation of GenEvents.
HepMC::GenParticlePtr getGenParticle()
virtual void transToPers(const TRANS *transObj, PERS *persObj, MsgStream &log)=0
Convert transient representation to persistent one.
bool m_wasUsedForReading
flag set when using this converter for reading triggers search for a new converter before writing,...
double m_eventScale
Energy scale.
void set_signal_process_vertex(GenEvent *e, T v)
unsigned int m_particlesEnd
End position in the vector of particles composing this event.
CNV * converterForType(CNV *cnv, const std::type_info &t_info, MsgStream &log) const
Find converter for a given C++ type ID, that is or ihnerits from CNV type.
std::vector< std::string > m_r_tool_version
Version of the used tool.
GenParticle * barcode_to_particle(const GenEvent *e, int id)
GenEvtPool_t evt
an arena of HepMC::GenEvent for efficient object instantiation
GenVertexPtr newGenVertexPtr(const HepMC::FourVector &pos=HepMC::FourVector(0.0, 0.0, 0.0, 0.0), const int i=0)
int m_beamParticle1
Barcode of the beam particle 1.
unsigned int m_particlesBegin
Begin position in the vector of particles composing this event.
TPObjRef::typeID_t m_pStorageTID
TP Ref typeID for the persistent objects this converter is creating.
std::vector< std::string > m_e_attribute_string
Attribute serialized as string for event.
virtual void persToTransWithKey(const PERS *persObj, TRANS *transObj, const std::string &, MsgStream &log)
Convert persistent representation to transient one.
std::vector< GenVertex_p7 > m_genVertices
The vector of persistent representation of GenVertices.
GenVtxPool_t vtx
an arena of HepMC::GenVertex for efficient object instantiation
TopLevelTPCnvBase * m_topConverterRuntime
top level converter "owning" this TP converter at runtime (different from m_topConverter in case the ...
double m_alphaQED
value of the QED coupling.
std::vector< int > m_particlesOut
collection of barcodes of out-going particles connected to this vertex
void clear()
Erase all the elements in the collection.
double m_filterWeight
value of the extra weight introduced during reweighting events in filter and value of some variables ...
CNV * converterForRef(CNV *cnv, const TPObjRef &ref, MsgStream &log) const
Find converter for a TP type ID (passed in a TP Ref), that is or ihnerits from CNV type.
std::unordered_map< HepMC::GenParticlePtr, int > ParticlesMap_t
RpcSectorLogicContainer_p1 PERS
int m_beamParticle2
Barcode of the beam particle 2.
value_type push_back(value_type pElem)
Add an element to the end of the collection.
std::vector< long int > m_randomStates
Container of random numbers for the generator states.
std::vector< int > m_e_attribute_id
We define those exactly as in the HepMC3::GenEvent.
int m_id
Id of this vertex.
virtual void transToPersWithKey(const TRANS *transObj, PERS *persObj, const std::string &, MsgStream &log)
Convert transient representation to persistent one.
virtual void initPrivateConverters(TopLevelTPCnvBase *)
bool m_recursive
if true, work in recursion-safe way (slower)
int m_mpi
Number of multi particle interactions.
const_iterator end() const noexcept
Return a const_iterator pointing past the end of the collection.
int writeGenParticle(const HepMC::GenParticle &p, McEventCollection_p7 &persEvt) const
Method to write a persistent GenParticle object It returns the index of the persistent GenParticle in...
GenParticlePtr newGenParticlePtr(const HepMC::FourVector &mom=HepMC::FourVector(0.0, 0.0, 0.0, 0.0), int pid=0, int status=0)
unsigned m_pStorageTIDvalue
m_pStorageTID converted to integer value
ServiceHandle< IHepMCWeightSvc > m_hepMCWeightSvc
const boost::regex ref(r_ef)
void writeGenVertex(const HepMC::GenVertex &vtx, McEventCollection_p7 &persEvt) const
Method to write a persistent GenVertex object.
virtual void persToTrans(const PERS *persObj, TRANS *transObj, MsgStream &log)=0
Convert persistent representation to transient one.
int m_signalProcessId
Id of the processus being generated.
std::vector< float > m_weights
Weights for this vertex.
std::vector< int > m_particlesIn
collection of barcodes of in-going particles connected to this vertex
HepMC::GenEvent * getGenEvent()
GenVertex * barcode_to_vertex(const GenEvent *e, int id)
std::vector< std::string > m_r_attribute_string
Attribute serialized as string for run info.
std::vector< std::string > m_r_attribute_name
Attribute name for run info.
virtual void converterNotFound(const std::type_info &converterType, ITPConverter *c, const std::string &typeName, MsgStream &log) const
method called when the right TP converter was not found during writing
unsigned typeID() const
returns the type ID (as integer) of the referenced object
int m_eventNbr
Event number.
HepMC::GenVertexPtr getGenVertex()
std::vector< std::string > m_r_tool_name
Name of the used tool.
std::vector< std::string > m_r_tool_description
Description of the used tool.
size_type size() const noexcept
Returns the number of elements in the collection.
std::vector< std::string > m_r_weight_names
The weight names.
std::vector< double > m_pdfinfo
Container of HepMC::PdfInfo object translated to vector<double> for simplicity.
int m_curRecLevel
count recursive invocations, to detect recursion
const_iterator begin() const noexcept
Return a const_iterator pointing at the beginning of the collection.
GenPartPool_t part
an arena of HepMC::GenParticle for efficient object instantiation
GenVertex * signal_process_vertex(const GenEvent *e)