CMS 3D CMS Logo

FWSiPixelDigiProxyBuilder.cc
Go to the documentation of this file.
1 // -*- C++ -*-
2 //
3 // Package: Tracks
4 // Class : FWSiPixelDigiProxyBuilder
5 //
6 //
7 // Original Author:
8 // Created: Thu Dec 6 18:01:21 PST 2007
9 //
10 
11 #include "TEveCompound.h"
12 #include "TEvePointSet.h"
13 
19 
22 
24 public:
26  ~FWSiPixelDigiProxyBuilder(void) override {}
27 
29 
30 private:
31  // Disable default copy constructor
33  // Disable default assignment operator
35 
37  void build(const FWEventItem* iItem, TEveElementList* product, const FWViewContext*) override;
38 };
39 
40 void FWSiPixelDigiProxyBuilder::build(const FWEventItem* iItem, TEveElementList* product, const FWViewContext*) {
41  const edm::DetSetVector<PixelDigi>* digis = nullptr;
42  iItem->get(digis);
43 
44  if (!digis) {
45  return;
46  }
47  const FWGeometry* geom = iItem->getGeom();
48 
49  for (edm::DetSetVector<PixelDigi>::const_iterator it = digis->begin(), end = digis->end(); it != end; ++it) {
50  edm::DetSet<PixelDigi> ds = *it;
51  unsigned int id = ds.id;
52 
53  const float* pars = geom->getParameters(id);
54 
55  for (edm::DetSet<PixelDigi>::const_iterator idigi = ds.data.begin(), idigiEnd = ds.data.end(); idigi != idigiEnd;
56  ++idigi) {
57  TEvePointSet* pointSet = new TEvePointSet;
58  pointSet->SetMarkerSize(2);
59  pointSet->SetMarkerStyle(2);
60  setupAddElement(pointSet, product);
61 
62  if (!geom->contains(id)) {
63  fwLog(fwlog::kWarning) << "failed get geometry of SiPixelDigi with detid: " << id << std::endl;
64  } else {
65  float localPoint[3] = {
66  fireworks::pixelLocalX((*idigi).row(), pars), fireworks::pixelLocalY((*idigi).column(), pars), 0.0};
67 
68  float globalPoint[3];
69  geom->localToGlobal(id, localPoint, globalPoint);
70 
71  pointSet->SetNextPoint(globalPoint[0], globalPoint[1], globalPoint[2]);
72  }
73  } // end of iteration over digis in range
74  } // end of iteration over the DetSetVector
75 }
76 
79  "SiPixelDigi",
edm::DetSetVector
Definition: DetSetVector.h:61
fwLog
#define fwLog(_level_)
Definition: fwLog.h:45
FWGeometry
Definition: FWGeometry.h:27
FWSiPixelDigiProxyBuilder::FWSiPixelDigiProxyBuilder
FWSiPixelDigiProxyBuilder(void)
Definition: FWSiPixelDigiProxyBuilder.cc:25
fireworks::pixelLocalX
float pixelLocalX(const double mpx, const float *)
Definition: TrackUtils.cc:159
edm::DetSetVector::end
iterator end()
Return the off-the-end iterator.
Definition: DetSetVector.h:325
edm::DetSet
Definition: DetSet.h:23
FWViewType::kAllRPZBits
static const int kAllRPZBits
Definition: FWViewType.h:67
REGISTER_FWPROXYBUILDER
#define REGISTER_FWPROXYBUILDER(_name_, _type_, _purpose_, _view_)
Definition: FWProxyBuilderFactory.h:33
edm::DetSet::id
det_id_type id
Definition: DetSet.h:79
FWEventItem::get
void get(const T *&oData) const
Definition: FWEventItem.h:78
FWProxyBuilderBase.h
REGISTER_PROXYBUILDER_METHODS
#define REGISTER_PROXYBUILDER_METHODS()
Definition: register_dataproxybuilder_macro.h:28
edm::DetSetVector::begin
iterator begin()
Return an iterator to the first DetSet.
Definition: DetSetVector.h:314
PixelDigi.h
TrackUtils.h
FWViewType::kAll3DBits
static const int kAll3DBits
Definition: FWViewType.h:68
mps_fire.end
end
Definition: mps_fire.py:242
FWSiPixelDigiProxyBuilder::operator=
const FWSiPixelDigiProxyBuilder & operator=(const FWSiPixelDigiProxyBuilder &)=delete
relativeConstraints.geom
geom
Definition: relativeConstraints.py:72
FWSiPixelDigiProxyBuilder::~FWSiPixelDigiProxyBuilder
~FWSiPixelDigiProxyBuilder(void) override
Definition: FWSiPixelDigiProxyBuilder.cc:26
fireworks::pixelLocalY
float pixelLocalY(const double mpy, const float *)
Definition: TrackUtils.cc:209
FWGeometry.h
edm::DetSetVector::const_iterator
collection_type::const_iterator const_iterator
Definition: DetSetVector.h:102
FWProxyBuilderBase::setupAddElement
void setupAddElement(TEveElement *el, TEveElement *parent, bool set_color=true) const
Definition: FWProxyBuilderBase.cc:350
FWSiPixelDigiProxyBuilder
Definition: FWSiPixelDigiProxyBuilder.cc:23
fwlog::kWarning
Definition: fwLog.h:35
fwLog.h
DetSetVector.h
FWProxyBuilderBase::build
void build()
Definition: FWProxyBuilderBase.cc:110
FWEventItem.h
FWViewContext
Definition: FWViewContext.h:32
FWEventItem::getGeom
const FWGeometry * getGeom() const
Definition: FWEventItem.cc:548
FWEventItem
Definition: FWEventItem.h:56
FWProxyBuilderBase
Definition: FWProxyBuilderBase.h:46
edm::DetSet::data
collection_type data
Definition: DetSet.h:80
edm::DetSet::const_iterator
collection_type::const_iterator const_iterator
Definition: DetSet.h:31