17 #include "nusimdata/SimulationBase/MCParticle.h" 
   18 #include "nusimdata/SimulationBase/MCTruth.h" 
   21 #include "art/Framework/Core/ModuleMacros.h" 
   22 #include "canvas/Persistency/Common/FindManyP.h" 
   23 #include "art/Framework/Principal/Event.h" 
   24 #include "art/Framework/Principal/View.h" 
   25 #include "fhiclcpp/ParameterSet.h" 
   26 #include "art/Framework/Principal/Handle.h" 
   27 #include "messagefacility/MessageLogger/MessageLogger.h" 
   28 #include "canvas/Persistency/Common/FindOneP.h" 
   29 #include "art/Framework/Core/EDProducer.h" 
   53     fCheatedVertexLabel = pset.get< std::string >(
"CheatedVertexLabel", 
"prong" );
 
   54     fG4ModuleLabel      = pset.get< std::string >(
"G4ModuleLabel",      
"largeant");
 
   56     produces< std::vector<recob::Event> >();
 
   57     produces< art::Assns<recob::Event, recob::Vertex> >();
 
   58     produces< art::Assns<recob::Event, recob::Hit> >();
 
   65     art::View<simb::MCParticle> pcol;
 
   72     std::map<int, int> trackIDToPColEntry;
 
   73     for(
size_t p = 0; 
p < pcol.vals().size(); ++
p) trackIDToPColEntry[pcol.vals().at(
p)->TrackId()] = 
p;
 
   76     art::Handle< std::vector<recob::Vertex> > vertexcol;
 
   83     std::vector< art::Ptr<recob::Vertex> > vertices;
 
   84     art::fill_ptr_vector(vertices, vertexcol);
 
   87     std::vector< art::Ptr<recob::Vertex> >::iterator vertexitr = vertices.begin();
 
   90     std::map<art::Ptr<simb::MCTruth>, std::vector< art::Ptr<recob::Vertex> > > vertexMap;
 
   91     std::map<art::Ptr<simb::MCTruth>, std::vector< art::Ptr<recob::Vertex> > >::iterator vertexMapItr = vertexMap.begin();
 
   94     while( vertexitr != vertices.end() ){
 
   96       size_t pcolEntry = trackIDToPColEntry.find((*vertexitr)->ID())->
second;
 
   97       const art::Ptr<simb::MCTruth> primary = fo.at(pcolEntry);
 
   99       vertexMap[primary].push_back(*vertexitr);
 
  104     std::unique_ptr< std::vector<recob::Event> >               eventcol(
new std::vector<recob::Event>);
 
  105     std::unique_ptr< art::Assns<recob::Event, recob::Vertex> > evassn(
new art::Assns<recob::Event, recob::Vertex>);
 
  106     std::unique_ptr< art::Assns<recob::Event, recob::Hit> >    ehassn(
new art::Assns<recob::Event, recob::Hit>);
 
  109     for(vertexMapItr = vertexMap.begin(); vertexMapItr != vertexMap.end(); vertexMapItr++){
 
  111       art::PtrVector<recob::Vertex> ptrvs;
 
  113       std::vector< art::Ptr<recob::Vertex> > verts( (*vertexMapItr).second );
 
  122       for(
size_t p = 0; 
p < ptrvs.size(); ++
p){
 
  123         std::vector< art::Ptr<recob::Hit> > hits = fm.at(
p);
 
  128       mf::LogInfo(
"EventCheater") << 
"adding event: \n" 
  130                                   << 
"\nto collection";
 
  134     evt.put(std::move(eventcol));
 
  135     evt.put(std::move(evassn));
 
  136     evt.put(std::move(ehassn));
 
  146   DEFINE_ART_MODULE(EventCheater)
 
std::string fCheatedVertexLabel
label for module creating recob::Vertex objects 
Declaration of signal hit object. 
void produce(art::Event &evt)
std::string fG4ModuleLabel
label for module running G4 and making particles, etc 
bool CreateAssn(art::Event &evt, std::vector< T > const &a, art::Ptr< U > const &b, art::Assns< U, T > &assn, std::string a_instance, size_t index=UINT_MAX)
Creates a single one-to-one association. 
Represents the Event implemented as a self balancing binary search tree. 
EventCheater(fhicl::ParameterSet const &pset)