00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012 #include "AtlfastAlgs/DefaultSmearer.h"
00013
00014 #include "CLHEP/Vector/LorentzVector.h"
00015 #include "CLHEP/Random/JamesRandom.h"
00016 #include "CLHEP/Random/RandGauss.h"
00017
00018
00019
00020
00021
00022 namespace Atlfast {
00023
00024 DefaultSmearer::DefaultSmearer(const int aseed) {
00025
00026 HepRandomEngine* randomEngine = new HepJamesRandom( aseed );
00027 m_randGauss = new RandGauss( randomEngine );
00028 m_randSeed = aseed;
00029 }
00030
00031
00032 DefaultSmearer::~DefaultSmearer() {
00033
00034
00035
00036
00037 if (m_randGauss) {
00038 delete m_randGauss;
00039 }
00040 }
00041
00042 HepLorentzVector DefaultSmearer::smear( const HepLorentzVector& avec) {
00043
00044
00045
00046 HepLorentzVector bvec;
00047
00048 bvec.setE( m_randGauss->fire(avec.e(), 1.0) );
00049 bvec.setPx(m_randGauss->fire(avec.px(),1.0) );
00050 bvec.setPy(m_randGauss->fire(avec.py(),1.0) );
00051 bvec.setPz(m_randGauss->fire(avec.pz(),1.0) );
00052
00053 return bvec;
00054 }
00055
00056
00057
00058 }