LArSoft  v06_85_00
Liquid Argon Software toolkit - http://larsoft.org/
GFRecoHitFactory.h
Go to the documentation of this file.
1 /* Copyright 2008-2010, Technische Universitaet Muenchen,
2  Authors: Christian Hoeppner & Sebastian Neubert
3 
4  This file is part of GENFIT.
5 
6  GENFIT is free software: you can redistribute it and/or modify
7  it under the terms of the GNU Lesser General Public License as published
8  by the Free Software Foundation, either version 3 of the License, or
9  (at your option) any later version.
10 
11  GENFIT is distributed in the hope that it will be useful,
12  but WITHOUT ANY WARRANTY; without even the implied warranty of
13  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14  GNU Lesser General Public License for more details.
15 
16  You should have received a copy of the GNU Lesser General Public License
17  along with GENFIT. If not, see <http://www.gnu.org/licenses/>.
18 */
28 #ifndef GFRECOHITFACTORY_H
29 #define GFRECOHITFACTORY_H
30 
31 #include<vector>
32 #include<map>
33 
36 
37 
38 namespace genf {
39 
40 class GFAbsRecoHit;
41 
42 
55 private:
56  std::map<int,GFAbsRecoHitProducer*> fHitProdMap;
57 
58 
59 public:
61  virtual ~GFRecoHitFactory();
62 
69  void addProducer(int detID, GFAbsRecoHitProducer* hitProd);
70 
73  void clear();
74 
81  GFAbsRecoHit* createOne (int detID,int index);
82 
94  std::vector<GFAbsRecoHit*> createMany(const GFTrackCand& cand);
95 
96 
97 };
98 
99 } //namespace genf
100 #endif
101 
std::map< int, GFAbsRecoHitProducer * > fHitProdMap
Factory object to create RecoHits from digitized and clustered data.
GFAbsRecoHit * createOne(int detID, int index)
Create a RecoHit.
Generic Interface to magnetic fields in GENFIT.
std::vector< GFAbsRecoHit * > createMany(const GFTrackCand &cand)
Creat a collection of RecoHits.
void addProducer(int detID, GFAbsRecoHitProducer *hitProd)
Register a producer module to the factory.
Abstract interface class for GFRecoHitProducer.
void clear()
Clear all hit producers.