FWPFJet3DProxyBuilder

FWPFPatJet3DProxyBuilder

FWPFPatJet3DProxyBuilder

FWPatJet3DProxyBuilder

Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
#include "FWPFPatJet3DProxyBuilder.h"
#include "Fireworks/Core/interface/fwLog.h"

//______________________________________________________________________________
template <class T>
FWPFPatJet3DProxyBuilder<T>::FWPFPatJet3DProxyBuilder() {}
template <class T>
FWPFPatJet3DProxyBuilder<T>::~FWPFPatJet3DProxyBuilder() {}

//______________________________________________________________________________
template <class T>
void FWPFPatJet3DProxyBuilder<T>::build(const T& iData,
                                        unsigned int iIndex,
                                        TEveElement& oItemHolder,
                                        const FWViewContext*) {
  try {
    std::vector<reco::PFCandidatePtr> consts = iData.getPFConstituents();
    typedef std::vector<reco::PFCandidatePtr>::const_iterator IC;

    for (IC ic = consts.begin();  // If consts has no constituents then the loop simply won't execute
         ic != consts.end();
         ic++)  // and so no segmentation fault should occur
    {
      const reco::PFCandidatePtr& pfCandPtr = *ic;

      TEveRecTrack t;
      t.fBeta = 1;
      t.fP = TEveVector(pfCandPtr->px(), pfCandPtr->py(), pfCandPtr->pz());
      t.fV = TEveVector(pfCandPtr->vertex().x(), pfCandPtr->vertex().y(), pfCandPtr->vertex().z());
      t.fSign = pfCandPtr->charge();
      TEveTrack* trk = new TEveTrack(&t, FWProxyBuilderBase::context().getTrackPropagator());
      trk->MakeTrack();
      trk->SetLineWidth(3);

      fireworks::setTrackTypePF(*pfCandPtr, trk);

      FWProxyBuilderBase::setupAddElement(trk, &oItemHolder);
    }
  } catch (cms::Exception& iException) {
    fwLog(fwlog::kError) << "FWPFPatJet3DProxyBuilder::build() Caught exception " << iException.what() << std::endl;
  }
}

/* Classes have been created because 'concrete' types (i.e. reco::PFJet and not T) are required to register
a proxy builder. Each class must first register it's methods so that REGISTER_FWPROXYBUILDER macro knows
about them */
//_____________________________PF_______________________________________________
class FWPFJet3DProxyBuilder : public FWPFPatJet3DProxyBuilder<reco::PFJet> {
public:
  FWPFJet3DProxyBuilder() {}
  ~FWPFJet3DProxyBuilder() override {}

  REGISTER_PROXYBUILDER_METHODS();
};

//_____________________________PAT______________________________________________
class FWPatJet3DProxyBuilder : public FWPFPatJet3DProxyBuilder<pat::Jet> {
public:
  FWPatJet3DProxyBuilder() {}
  ~FWPatJet3DProxyBuilder() override {}

  REGISTER_PROXYBUILDER_METHODS();  // Register methods ready for macro
};

//______________________________________________________________________________
template class FWPFPatJet3DProxyBuilder<reco::PFJet>;
template class FWPFPatJet3DProxyBuilder<pat::Jet>;

//______________________________________________________________________________
REGISTER_FWPROXYBUILDER(FWPFJet3DProxyBuilder, reco::PFJet, "PF Jet", FWViewType::kAll3DBits | FWViewType::kAllRPZBits);
REGISTER_FWPROXYBUILDER(FWPatJet3DProxyBuilder, pat::Jet, "PF PatJet", FWViewType::kAll3DBits | FWViewType::kAllRPZBits);