diff --git a/Phys/ParticleMaker/doc/release.notes b/Phys/ParticleMaker/doc/release.notes index d5a19aaccd6e0e82be33aa96fec3a22dd3bec71e..23807c9726cf3420805970e4378137ee590fb4e9 100755 --- a/Phys/ParticleMaker/doc/release.notes +++ b/Phys/ParticleMaker/doc/release.notes @@ -3,6 +3,9 @@ ! Responsible : DaVinci coordinator !============================================================================== +! 2016-07-14 - Chris Jones + - Skip empty input locations in ParticleMakerBase + !======================= ParticleMaker v6r17 2015-11-27 ======================= ! 2015-11-01 - Gerhard Raven diff --git a/Phys/ParticleMaker/src/ParticleMakerBase.cpp b/Phys/ParticleMaker/src/ParticleMakerBase.cpp index 44f46358c01f9a374039afd45ecc5ebd28ea2597..d73bc6387ae7a8f9d3b5109404e0160d24770b3d 100644 --- a/Phys/ParticleMaker/src/ParticleMakerBase.cpp +++ b/Phys/ParticleMaker/src/ParticleMakerBase.cpp @@ -20,18 +20,15 @@ ParticleMakerBase::ParticleMakerBase( const std::string& name, ISvcLocator* pSvcLocator) : DaVinciAlgorithm ( name , pSvcLocator ) - , m_apid ( ) - , m_pp ( 0 ) - , m_app ( 0 ) - , m_brem ( NULL ) { - declareProperty ( "Input" , m_input = LHCb::ProtoParticleLocation::Charged ) ; - declareProperty ( "Particle" , m_pid = "UNDEFINED" , + declareProperty( "Input", m_input = LHCb::ProtoParticleLocation::Charged ) ; + declareProperty( "Particle" , m_pid = "UNDEFINED" , "Particle to create : pion, kaon, muon..." ) ; declareProperty( "AddBremPhotonTo", m_addBremPhoton, "ParticleIDs to be Brem-corrected (default : electrons only)"); m_addBremPhoton.push_back( "e+" ); } + //========================================================================= // //======================================================================== @@ -47,7 +44,7 @@ StatusCode ParticleMakerBase::initialize ( ) if ( this->inputLocations().empty() ) { - this->inputLocations().push_back(m_input); + if ( !m_input.empty() ) { this->inputLocations().push_back(m_input); } } else { @@ -72,17 +69,19 @@ StatusCode ParticleMakerBase::execute() StatusCode sc = makeParticles(newParts); if ( sc.isFailure() ) return sc; - LHCb::Particle::ConstVector constParts ; /// @todo this is a hack due to CaloParticle... - constParts.reserve(newParts.size()); + // CRJ Seems not needed any more + //LHCb::Particle::ConstVector constParts ; /// @todo this is a hack due to CaloParticle... + //constParts.reserve(newParts.size()); - for ( LHCb::Particle::Vector::const_iterator i = newParts.begin() ; - i != newParts.end() ; ++i ) + for ( auto * p : newParts ) { - constParts.push_back(*i); - addBrem( *i ); + //constParts.push_back(p); + addBrem(p); } - this->markNewTrees(constParts); + const bool ok = !newParts.empty(); + + this->markNewTrees(newParts); if ( msgLevel(MSG::DEBUG) ) { @@ -97,7 +96,7 @@ StatusCode ParticleMakerBase::execute() else { debug() << "No primary vertices" << endmsg; } } - setFilterPassed( !newParts.empty() ); + setFilterPassed( ok ); return sc; } @@ -106,7 +105,7 @@ StatusCode ParticleMakerBase::execute() StatusCode ParticleMakerBase::loadEventInput() { - if (msgLevel(MSG::VERBOSE)) + if ( msgLevel(MSG::VERBOSE) ) { verbose() << ">>> ProtoParticleMakerBase::loadEventInput: load ProtoParticles from " << this->inputLocations() << endmsg; @@ -114,27 +113,21 @@ StatusCode ParticleMakerBase::loadEventInput() m_protos.clear(); - for ( std::vector<std::string>::const_iterator iLoc = this->inputLocations().begin(); - iLoc != this->inputLocations().end(); ++iLoc ) + for ( const auto& loc : this->inputLocations() ) { - const LHCb::ProtoParticle::Container* pp = - getIfExists< LHCb::ProtoParticle::Container > ( *iLoc) ; + const auto * pp = getIfExists< LHCb::ProtoParticle::Container >(loc) ; if ( pp ) { if (msgLevel(MSG::VERBOSE)) { verbose() << "load " << pp->size() << " ProtoParticles from " - << *iLoc << endmsg; - } - for ( LHCb::ProtoParticle::Container::const_iterator iPP = pp->begin(); - iPP != pp->end(); ++iPP ) - { - m_protos.push_back(*iPP); + << loc << endmsg; } + for ( const auto * proto : *pp ) { m_protos.push_back(proto); } } else { - Info("No ProtoParticles at " + *iLoc); + Info("No ProtoParticles at " + loc); continue; } } @@ -144,21 +137,16 @@ StatusCode ParticleMakerBase::loadEventInput() //============================================================================= -void ParticleMakerBase::addBrem( LHCb::Particle* particle ) +void ParticleMakerBase::addBrem( LHCb::Particle * particle ) { bool ok = false; - for ( std::vector<std::string>::iterator p = m_addBremPhoton.begin() ; - m_addBremPhoton.end() != p; ++p ) + for ( const auto & p : m_addBremPhoton ) { - if ( *p == m_pid ) - { - ok = true; - break; - } + if ( p == m_pid ) { ok = true; break; } } - + if ( !ok ) return; - if ( !m_brem->addBrem( particle ) ) return; + if ( !bremAdder()->addBrem( particle ) ) return; if (msgLevel(MSG::DEBUG)) debug() << " ------- BremStrahlung has been added to the particle " diff --git a/Phys/ParticleMaker/src/ParticleMakerBase.h b/Phys/ParticleMaker/src/ParticleMakerBase.h index 38384356cf1721c7cfcc217ad1e7cc0e4ca1c57f..8f8b7cc5c4c357003b86cfb4b29830b77fb79164 100644 --- a/Phys/ParticleMaker/src/ParticleMakerBase.h +++ b/Phys/ParticleMaker/src/ParticleMakerBase.h @@ -54,6 +54,9 @@ protected: std::transform( in.begin() , in.end() , out.begin () , ::toupper ) ; return out ; } + + /// Access the Brem Adder + IBremAdder* bremAdder() const { return m_brem; } private: @@ -67,10 +70,10 @@ protected: /// ID of the anti-particle std::string m_apid ; /// properties of particle - const LHCb::ParticleProperty* m_pp ; + const LHCb::ParticleProperty* m_pp = nullptr; /// properties of anti-particle - const LHCb::ParticleProperty* m_app ; + const LHCb::ParticleProperty* m_app = nullptr; /// Input Location of protoparticles std::string m_input ; @@ -78,15 +81,14 @@ protected: // list of PIDs for which BremStrahlung correction is activated std::vector<std::string> m_addBremPhoton; - IBremAdder* bremAdder(){return m_brem;} - private: /// Local ProtoParticle container. LHCb::ProtoParticle::ConstVector m_protos; /// Track selector tool - IBremAdder* m_brem; + IBremAdder* m_brem = nullptr; }; + #endif // PARTICLEMAKERBASE