1 |
//--------------------------------------------------------------------------------------------------
|
2 |
// $Id: BeamSpot.h,v 1.4 2009/03/18 15:44:31 loizides Exp $
|
3 |
//
|
4 |
// BeamSpot
|
5 |
//
|
6 |
// BeamSpot class implemented as holding a 3d vector as a point in space with fit information.
|
7 |
//
|
8 |
// Authors: J.Bendavid
|
9 |
//--------------------------------------------------------------------------------------------------
|
10 |
|
11 |
#ifndef MITANA_DATATREE_BEAMSPOT_H
|
12 |
#define MITANA_DATATREE_BEAMSPOT_H
|
13 |
|
14 |
#include "MitAna/DataTree/interface/BaseVertex.h"
|
15 |
|
16 |
namespace mithep
|
17 |
{
|
18 |
class BeamSpot : public BaseVertex
|
19 |
{
|
20 |
public:
|
21 |
BeamSpot() :
|
22 |
fSigmaZ(0), fBeamWidthX(0), fBeamWidthY(0), fDxDz(0), fDyDz(0),
|
23 |
fSigmaZErr(0), fBeamWidthXErr(0), fBeamWidthYErr(0), fDxDzErr(0), fDyDzErr(0) {}
|
24 |
BeamSpot(Double_t x, Double_t y, Double_t z) :
|
25 |
BaseVertex(x,y,z), fSigmaZ(0), fBeamWidthX(0), fBeamWidthY(0), fDxDz(0), fDyDz(0),
|
26 |
fSigmaZErr(0), fBeamWidthXErr(0), fBeamWidthYErr(0), fDxDzErr(0), fDyDzErr(0) {}
|
27 |
BeamSpot(Double_t x, Double_t y, Double_t z, Double_t xErr, Double_t yErr, Double_t zErr) :
|
28 |
BaseVertex(x,y,z,xErr,yErr,zErr), fSigmaZ(0), fBeamWidthX(0), fBeamWidthY(0), fDxDz(0), fDyDz(0),
|
29 |
fSigmaZErr(0), fBeamWidthXErr(0), fBeamWidthYErr(0), fDxDzErr(0), fDyDzErr(0) {}
|
30 |
BeamSpot(const ThreeVector &pos) :
|
31 |
BaseVertex(pos), fSigmaZ(0), fBeamWidthX(0), fBeamWidthY(0), fDxDz(0), fDyDz(0),
|
32 |
fSigmaZErr(0), fBeamWidthXErr(0), fBeamWidthYErr(0), fDxDzErr(0), fDyDzErr(0) {}
|
33 |
|
34 |
Double_t BeamWidthX() const { return fBeamWidthX; }
|
35 |
Double_t BeamWidthY() const { return fBeamWidthY; }
|
36 |
Double_t BeamWidthXErr() const { return fBeamWidthXErr; }
|
37 |
Double_t BeamWidthYErr() const { return fBeamWidthYErr; }
|
38 |
Double_t DxDz() const { return fDxDz; }
|
39 |
Double_t DyDz() const { return fDyDz; }
|
40 |
Double_t DxDzErr() const { return fDxDzErr; }
|
41 |
Double_t DyDzErr() const { return fDyDzErr; }
|
42 |
EObjType ObjType() const { return kBeamSpot; }
|
43 |
Double_t SigmaZ() const { return fSigmaZ; }
|
44 |
Double_t SigmaZErr() const { return fSigmaZErr; }
|
45 |
void SetBeamWidthX(Double_t beamWidth) { fBeamWidthX = beamWidth; }
|
46 |
void SetBeamWidthY(Double_t beamWidth) { fBeamWidthY = beamWidth; }
|
47 |
void SetBeamWidthXErr(Double_t beamWErr) { fBeamWidthXErr = beamWErr; }
|
48 |
void SetBeamWidthYErr(Double_t beamWErr) { fBeamWidthYErr = beamWErr; }
|
49 |
void SetDxDz(Double_t dxDz) { fDxDz = dxDz; }
|
50 |
void SetDyDz(Double_t dyDz) { fDyDz = dyDz; }
|
51 |
void SetDxDzErr(Double_t dxDzErr) { fDxDzErr = dxDzErr; }
|
52 |
void SetDyDzErr(Double_t dyDzErr) { fDyDzErr = dyDzErr; }
|
53 |
void SetSigmaZ(Double_t sigmaZ) { fSigmaZ = sigmaZ; }
|
54 |
void SetSigmaZErr(Double_t sigmaZErr) { fSigmaZErr = sigmaZErr; }
|
55 |
|
56 |
protected:
|
57 |
Double32_t fSigmaZ; //[0,0,14]z width of beamspot
|
58 |
Double32_t fBeamWidthX; //[0,0,14]transverse width of beamspot (x-axis)
|
59 |
Double32_t fBeamWidthY; //[0,0,14]transverse width of beamspot (y-axis)
|
60 |
Double32_t fDxDz; //[0,0,14]x-z slope of beamline
|
61 |
Double32_t fDyDz; //[0,0,14]y-z slope of beamline
|
62 |
Double32_t fSigmaZErr; //[0,0,14]error of z width
|
63 |
Double32_t fBeamWidthXErr; //[0,0,14]error of transverse width (x-axis)
|
64 |
Double32_t fBeamWidthYErr; //[0,0,14]error of transverse width (y-axis)
|
65 |
Double32_t fDxDzErr; //[0,0,14]error of x-z slope
|
66 |
Double32_t fDyDzErr; //[0,0,14]error of y-z slope
|
67 |
|
68 |
ClassDef(BeamSpot, 2) // Beam spot class
|
69 |
};
|
70 |
}
|
71 |
#endif
|