1 |
loizides |
1.3 |
// $Id: HisInterface.cc,v 1.2 2008/09/04 13:55:29 loizides Exp $
|
2 |
loizides |
1.2 |
|
3 |
loizides |
1.3 |
#include "MitEdm/VertexFitInterface/interface/HisInterface.h"
|
4 |
loizides |
1.2 |
#include <TMath.h>
|
5 |
paus |
1.1 |
#include "MitEdm/DataFormats/interface/Types.h"
|
6 |
|
|
#include "MitEdm/VertexFitInterface/interface/TrackParameters.h"
|
7 |
|
|
|
8 |
|
|
using namespace reco;
|
9 |
|
|
using namespace mitedm;
|
10 |
loizides |
1.2 |
using namespace mithep;
|
11 |
paus |
1.1 |
|
12 |
loizides |
1.2 |
//--------------------------------------------------------------------------------------------------
|
13 |
paus |
1.1 |
HisInterface::HisInterface(const Track *trk1, const Track *trk2, const double bField) :
|
14 |
|
|
his_(0)
|
15 |
|
|
{
|
16 |
loizides |
1.3 |
// Constructor.
|
17 |
|
|
|
18 |
paus |
1.1 |
// Create the CMS track parameters
|
19 |
|
|
TrackParameters cmsTrk1(trk1);
|
20 |
|
|
TrackParameters cmsTrk2(trk2);
|
21 |
|
|
// Extract from them the MVF track parameters
|
22 |
|
|
TrackParameters hisTrk1 = cmsTrk1.mvfTrack();
|
23 |
|
|
TrackParameters hisTrk2 = cmsTrk2.mvfTrack();
|
24 |
|
|
// Initialize the corresponding momentum vector
|
25 |
|
|
const TVector3 momTrk1(trk1->px(),trk1->py(),trk1->pz());
|
26 |
|
|
const TVector3 momTrk2(trk2->px(),trk2->py(),trk2->pz());
|
27 |
|
|
// Finally setup the intersection object
|
28 |
|
|
his_ = new HelixIntersector(hisTrk1.pars(),&momTrk1, hisTrk2.pars(),&momTrk2);
|
29 |
|
|
}
|
30 |
|
|
|
31 |
|
|
HisInterface::~HisInterface()
|
32 |
|
|
{
|
33 |
loizides |
1.3 |
// Destructor.
|
34 |
|
|
|
35 |
paus |
1.1 |
delete his_;
|
36 |
|
|
}
|