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
#include "TEveJetCone.h"
#include "DataFormats/JetReco/interface/Jet.h"
#include "Fireworks/Core/interface/Context.h"

namespace fireworks {
  TEveJetCone* makeEveJetCone(const reco::Jet& iData, const fireworks::Context& context) {
    TEveJetCone* jet = new TEveJetCone();
    jet->SetApex(TEveVector(iData.vertex().x(), iData.vertex().y(), iData.vertex().z()));

    reco::Jet::Constituents c = iData.getJetConstituents();
    bool haveData = true;
    for (reco::Jet::Constituents::const_iterator itr = c.begin(); itr != c.end(); ++itr) {
      if (!itr->isAvailable()) {
        haveData = false;
        break;
      }
    }

    double eta_size = 0.2;
    double phi_size = 0.2;
    if (haveData) {
      eta_size = sqrt(iData.etaetaMoment());
      phi_size = sqrt(iData.phiphiMoment());
    }

    static const float offr = 5;
    static const float offz = offr / tan(context.caloTransAngle());
    if (iData.eta() < context.caloMaxEta())
      jet->SetCylinder(context.caloR1(false) - offr, context.caloZ1(false) - offz);
    else
      jet->SetCylinder(context.caloR2(false) - offr, context.caloZ2(false) - offz);

    jet->AddEllipticCone(iData.eta(), iData.phi(), eta_size, phi_size);
    jet->SetPickable(kTRUE);
    return jet;
  }
}  // namespace fireworks