#include "TEveCaloData.h"
#include "TEveCalo.h"
#include "TAxis.h"
#include "THStack.h"
#include "TH2.h"
#include "TMath.h"
#include "TList.h"
#include <cassert>
#include <algorithm>
void TEveCaloData::CellGeom_t::Dump() const
{
printf("%f, %f %f, %f \n", fEtaMin, fEtaMax, fPhiMin, fPhiMax);
}
Float_t TEveCaloData::CellData_t::Value(Bool_t isEt) const
{
if (isEt)
return fValue;
else
return TMath::Abs(fValue/TMath::Cos(Theta()));
}
void TEveCaloData::CellData_t::Dump() const
{
printf("%f, %f %f, %f \n", fEtaMin, fEtaMax, fPhiMin, fPhiMax);
}
Float_t* TEveCaloData::RebinData_t::GetSliceVals(Int_t bin)
{
if (fBinData[bin] == -1)
{
fBinData[bin] = fSliceData.size();
for (Int_t i=0; i<fNSlices; i++)
fSliceData.push_back(0.f);
}
return &fSliceData[fBinData[bin]];
}
ClassImp(TEveCaloData);
TEveCaloData::TEveCaloData():
TEveRefBackPtr(),
fEtaAxis(0),
fPhiAxis(0),
fMaxValEt(0),
fMaxValE(0),
fEps(0)
{
}
void TEveCaloData::SetSliceThreshold(Int_t slice, Float_t val)
{
fSliceInfos[slice].fThreshold = val;
InvalidateUsersCellIdCache();
}
Float_t TEveCaloData::GetSliceThreshold(Int_t slice) const
{
return fSliceInfos[slice].fThreshold;
}
void TEveCaloData::SetSliceColor(Int_t slice, Color_t col)
{
fSliceInfos[slice].fColor = col;
StampBackPtrElements(TEveElement::kCBObjProps);
}
Color_t TEveCaloData::GetSliceColor(Int_t slice) const
{
return fSliceInfos[slice].fColor;
}
void TEveCaloData::InvalidateUsersCellIdCache()
{
TEveCaloViz* calo;
std::list<TEveElement*>::iterator i = fBackRefs.begin();
while (i != fBackRefs.end())
{
calo = dynamic_cast<TEveCaloViz*>(*i);
calo->InvalidateCellIdCache();
calo->StampObjProps();
++i;
}
}
void TEveCaloData::DataChanged()
{
TEveCaloViz* calo;
std::list<TEveElement*>::iterator i = fBackRefs.begin();
while (i != fBackRefs.end())
{
calo = dynamic_cast<TEveCaloViz*>(*i);
calo->DataChanged();
calo->StampObjProps();
++i;
}
}
Float_t TEveCaloData::EtaToTheta(Float_t eta)
{
using namespace TMath;
if (eta < 0)
return Pi() - 2*ATan(Exp(- Abs(eta)));
else
return 2*ATan(Exp(- Abs(eta)));
}
void TEveCaloData::CellGeom_t::Configure(Float_t etaMin, Float_t etaMax, Float_t phiMin, Float_t phiMax)
{
fEtaMin = etaMin;
fEtaMax = etaMax;
fPhiMin = phiMin;
fPhiMax = phiMax;
fThetaMin = EtaToTheta(fEtaMax);
fThetaMax = EtaToTheta(fEtaMin);
}
ClassImp(TEveCaloDataVec);
TEveCaloDataVec::TEveCaloDataVec(Int_t nslices):
TEveCaloData(),
fTower(0),
fEtaMin( 10),
fEtaMax(-10),
fPhiMin( 10),
fPhiMax(-10)
{
fSliceInfos.assign(nslices, SliceInfo_t());
fSliceVec.assign(nslices, std::vector<Float_t> ());
}
TEveCaloDataVec::~TEveCaloDataVec()
{
if (fEtaAxis) delete fEtaAxis;
if (fPhiAxis) delete fPhiAxis;
}
Int_t TEveCaloDataVec::AddTower(Float_t etaMin, Float_t etaMax, Float_t phiMin, Float_t phiMax)
{
assert (etaMin < etaMax);
assert (phiMin < phiMax);
fGeomVec.push_back(CellGeom_t(etaMin, etaMax, phiMin, phiMax));
for (vvFloat_i it=fSliceVec.begin(); it!=fSliceVec.end(); ++it)
(*it).push_back(0);
if (etaMin < fEtaMin) fEtaMin = etaMin;
if (etaMax > fEtaMax) fEtaMax = etaMax;
if (phiMin < fPhiMin) fPhiMin = phiMin;
if (phiMax > fPhiMax) fPhiMax = phiMax;
fTower = fGeomVec.size() - 1;
return fTower;
}
void TEveCaloDataVec::FillSlice(Int_t slice, Float_t val)
{
fSliceVec[slice][fTower] = val;
}
void TEveCaloDataVec::FillSlice(Int_t slice, Int_t tower, Float_t val)
{
fSliceVec[slice][tower] = val;
}
void TEveCaloDataVec::GetCellList(Float_t eta, Float_t etaD,
Float_t phi, Float_t phiD,
TEveCaloData::vCellId_t &out) const
{
using namespace TMath;
Float_t etaMin = eta - etaD*0.5;
Float_t etaMax = eta + etaD*0.5;
Float_t phiMin = phi - phiD*0.5;
Float_t phiMax = phi + phiD*0.5;
Int_t nS = fSliceVec.size();
Int_t tower = 0;
Float_t fracx=0, fracy=0, frac;
Float_t minQ, maxQ;
for(vCellGeom_ci i=fGeomVec.begin(); i!=fGeomVec.end(); i++)
{
const CellGeom_t &cg = *i;
fracx = TEveUtil::GetFraction(etaMin, etaMax, cg.fEtaMin, cg.fEtaMax);
if (fracx > 1e-3)
{
minQ = cg.fPhiMin;
maxQ = cg.fPhiMax;
if (maxQ < phiMin)
{
minQ += TwoPi(); maxQ += TwoPi();
}
else if (minQ > phiMax)
{
minQ -= TwoPi(); maxQ -= TwoPi();
}
if (maxQ >= phiMin && minQ <= phiMax)
{
fracy = TEveUtil::GetFraction(phiMin, phiMax, minQ, maxQ);
if (fracy > 1e-3)
{
frac = fracx*fracy;
for (Int_t s=0; s<nS; s++)
{
if (fSliceVec[s][tower] > fSliceInfos[s].fThreshold)
out.push_back(CellId_t(tower, s, frac));
}
}
}
}
tower++;
}
}
void TEveCaloDataVec::Rebin(TAxis* ax, TAxis* ay, vCellId_t &ids, Bool_t et, RebinData_t& rdata) const
{
rdata.fNSlices = GetNSlices();
rdata.fBinData.assign((ax->GetNbins()+2)*(ay->GetNbins()+2), -1);
CellData_t cd;
Float_t left, right, up, down;
for (TEveCaloData::vCellId_t::iterator it=ids.begin(); it!=ids.end(); ++it)
{
GetCellData(*it, cd);
Int_t iMin = ax->FindBin(cd.EtaMin());
Int_t iMax = ax->FindBin(cd.EtaMax());
Int_t jMin = ay->FindBin(cd.PhiMin());
Int_t jMax = ay->FindBin(cd.PhiMax());
for (Int_t i = iMin; i <= iMax; ++i)
{
if (i < 0 || i > ax->GetNbins()) continue;
left = (i == iMin) ? cd.EtaMin() : ax->GetBinLowEdge(i);
right = (i == iMax) ? cd.EtaMax() : ax->GetBinUpEdge(i);
for (Int_t j = jMin; j <= jMax; ++j)
{
if (j < 0 || j > ay->GetNbins()) continue;
down = (j == jMin) ? cd.PhiMin() : ay->GetBinLowEdge(j);
up = (j == jMax) ? cd.PhiMax() : ay->GetBinUpEdge(j);
Float_t ratio = ((right-left)*(up-down))/(ax->GetBinWidth(i)*ay->GetBinWidth(j));
if (ratio > 1e-6)
{
Float_t* slices = rdata.GetSliceVals(i+j*(ax->GetNbins()+2));
slices[(*it).fSlice] += ratio* cd.Value(et);
}
}
}
}
}
void TEveCaloDataVec::GetCellData(const TEveCaloData::CellId_t &id,
TEveCaloData::CellData_t& cellData) const
{
cellData.CellGeom_t::operator=( fGeomVec[id.fTower] );
cellData.fValue = fSliceVec[id.fSlice][id.fTower]*id.fFraction;
}
void TEveCaloDataVec::DataChanged()
{
using namespace TMath;
fMaxValE = 0;
fMaxValEt = 0;
Float_t sum=0, cos=0;
for (UInt_t tw=0; tw<fGeomVec.size(); tw++)
{
sum=0;
for (vvFloat_i it=fSliceVec.begin(); it!=fSliceVec.end(); ++it)
sum += (*it)[tw];
if (sum > fMaxValEt ) fMaxValEt=sum;
cos = Cos(2*ATan(Exp( -Abs(fGeomVec[tw].Eta()))));
sum /= Abs(cos);
if (sum > fMaxValE) fMaxValE=sum;
}
TEveCaloData::DataChanged();
}
void TEveCaloDataVec::SetAxisFromBins(Double_t epsX, Double_t epsY)
{
std::vector<Double_t> binX;
std::vector<Double_t> binY;
for(vCellGeom_ci i=fGeomVec.begin(); i!=fGeomVec.end(); i++)
{
const CellGeom_t &ch = *i;
binX.push_back(ch.EtaMin());
binX.push_back(ch.EtaMax());
binY.push_back(ch.PhiMin());
binY.push_back(ch.PhiMax());
}
std::sort(binX.begin(), binX.end());
std::sort(binY.begin(), binY.end());
Int_t cnt = 0;
Double_t sum = 0;
Double_t val;
Double_t dx = binX.back() - binX.front();
epsX *= dx;
std::vector<Double_t> newX;
newX.push_back(binX.front());
Int_t nX = binX.size()-1;
for(Int_t i=0; i<nX; i++)
{
val = (sum +binX[i])/(cnt+1);
if (binX[i+1] -val > epsX)
{
newX.push_back(val);
cnt = 0;
sum = 0;
}
else
{
sum += binX[i];
cnt++;
}
}
newX.push_back(binX.back());
cnt = 0;
sum = 0;
std::vector<Double_t> newY;
Double_t dy = binY.back() - binY.front();
epsY *= dy;
newY.push_back(binY.front());
Int_t nY = binY.size()-1;
for(Int_t i=0 ; i<nY; i++)
{
val = (sum +binY[i])/(cnt+1);
if (binY[i+1] -val > epsY )
{
newY.push_back(val);
cnt = 0;
sum = 0;
}
else
{
sum += binY[i];
cnt++;
}
}
newY.push_back(binY.back());
if (fEtaAxis) delete fEtaAxis;
if (fPhiAxis) delete fPhiAxis;
fEtaAxis = new TAxis(newX.size()-1, &newX[0]);
fPhiAxis = new TAxis(newY.size()-1, &newY[0]);
fEtaAxis->SetNdivisions(510);
fPhiAxis->SetNdivisions(510);
}
ClassImp(TEveCaloDataHist);
TEveCaloDataHist::TEveCaloDataHist():
TEveCaloData(),
fHStack(0)
{
fHStack = new THStack();
fEps = 1e-5;
}
TEveCaloDataHist::~TEveCaloDataHist()
{
delete fHStack;
}
void TEveCaloDataHist::DataChanged()
{
using namespace TMath;
fMaxValE = 0;
fMaxValEt = 0;
if (GetNSlices() < 1) return;
TH2 *ah = (TH2*) RefSliceInfo(0).fHist;
fEtaAxis = ah->GetXaxis();
fPhiAxis = ah->GetYaxis();
for (Int_t ieta = 1; ieta <= fEtaAxis->GetNbins(); ++ieta)
{
Double_t eta = fEtaAxis->GetBinCenter(ieta);
for (Int_t iphi = 1; iphi <= fPhiAxis->GetNbins(); ++iphi)
{
Double_t value = 0;
for (Int_t i = 0; i < GetNSlices(); ++i)
{
Int_t bin = RefSliceInfo(i).fHist->GetBin(ieta, iphi);
value += RefSliceInfo(i).fHist->GetBinContent(bin);
}
if (value > fMaxValEt ) fMaxValEt = value;
Double_t cos = Cos(2*ATan(Exp(-Abs(eta))));
value /= Abs(cos);
if (value > fMaxValE) fMaxValE = value;
}
}
TEveCaloData::DataChanged();
}
void TEveCaloDataHist::GetCellList(Float_t eta, Float_t etaD,
Float_t phi, Float_t phiD,
TEveCaloData::vCellId_t &out) const
{
using namespace TMath;
Float_t etaMin = eta - etaD*0.5 -fEps;
Float_t etaMax = eta + etaD*0.5 +fEps;
Float_t phiMin = phi - phiD*0.5 -fEps;
Float_t phiMax = phi + phiD*0.5 +fEps;
Int_t nEta = fEtaAxis->GetNbins();
Int_t nPhi = fPhiAxis->GetNbins();
Int_t nSlices = GetNSlices();
TH2 *h0 = fSliceInfos[0].fHist;
Int_t bin = 0;
for (Int_t ieta = 1; ieta <= nEta; ++ieta)
{
if (fEtaAxis->GetBinLowEdge(ieta) >= etaMin && fEtaAxis->GetBinUpEdge(ieta) <= etaMax)
{
for (Int_t iphi = 1; iphi <= nPhi; ++iphi)
{
if (TEveUtil::IsU1IntervalContainedByMinMax
(phiMin, phiMax, fPhiAxis->GetBinLowEdge(iphi), fPhiAxis->GetBinUpEdge(iphi)))
{
bin = h0->GetBin(ieta, iphi);
for (Int_t s = 0; s < nSlices; ++s)
{
if (fSliceInfos[s].fHist->GetBinContent(bin) > fSliceInfos[s].fThreshold )
out.push_back(TEveCaloData::CellId_t(bin, s));
}
}
}
}
}
}
void TEveCaloDataHist::Rebin(TAxis* ax, TAxis* ay, TEveCaloData::vCellId_t &ids, Bool_t et, RebinData_t &rdata) const
{
rdata.fNSlices = GetNSlices();
rdata.fBinData.assign((ax->GetNbins()+2)*(ay->GetNbins()+2), -1);
TEveCaloData::CellData_t cd;
Float_t *val;
Int_t i, j, w;
Int_t binx, biny;
Int_t bin;
for (vCellId_i it=ids.begin(); it!=ids.end(); ++it)
{
GetCellData(*it, cd);
fSliceInfos[(*it).fSlice].fHist->GetBinXYZ((*it).fTower, i, j, w);
binx = ax->FindBin(fEtaAxis->GetBinCenter(i));
biny = ay->FindBin(fPhiAxis->GetBinCenter(j));
bin = biny*(ax->GetNbins()+2)+binx;
val = rdata.GetSliceVals(bin);
Double_t ratio = (fEtaAxis->GetBinWidth(i)*fPhiAxis->GetBinWidth(j))/(ax->GetBinWidth(binx)*ay->GetBinWidth(biny));
val[(*it).fSlice] += cd.Value(et)*ratio;
}
}
void TEveCaloDataHist::GetCellData(const TEveCaloData::CellId_t &id,
TEveCaloData::CellData_t& cellData) const
{
TH2F* hist = fSliceInfos[id.fSlice].fHist;
Int_t x, y, z;
hist->GetBinXYZ(id.fTower, x, y, z);
cellData.fValue = hist->GetBinContent(id.fTower);
cellData.Configure(hist->GetXaxis()->GetBinLowEdge(x),
hist->GetXaxis()->GetBinUpEdge(x),
hist->GetYaxis()->GetBinLowEdge(y),
hist->GetYaxis()->GetBinUpEdge(y));
}
Int_t TEveCaloDataHist::AddHistogram(TH2F* hist)
{
fHStack->Add(hist);
Int_t id = fSliceInfos.size();
fSliceInfos.push_back(SliceInfo_t(hist));
fSliceInfos[id].fName = hist->GetName();
fSliceInfos[id].fColor = hist->GetLineColor();
fSliceInfos[id].fID = id;
DataChanged();
return id;
}
void TEveCaloDataHist::GetEtaLimits(Double_t &min, Double_t &max) const
{
min = fEtaAxis->GetXmin();
max = fEtaAxis->GetXmax();
}
void TEveCaloDataHist::GetPhiLimits(Double_t &min, Double_t &max) const
{
min = fPhiAxis->GetXmin();
max = fPhiAxis->GetXmax();
}
Last change: Tue Dec 2 08:45:46 2008
Last generated: 2008-12-02 08:45
This page has been automatically generated. If you have any comments or suggestions about the page layout send a mail to ROOT support, or contact the developers with any questions or problems regarding ROOT.