NuclearInteraction< T > Class Template Reference

#include <NuclearInteraction.h>

Inheritance diagram for NuclearInteraction< T >:
EnergyLossProcess

List of all members.

Public Member Functions

 NuclearInteraction ()
 NuclearInteraction (const Material &material)
 ~NuclearInteraction ()
double dE_dx (double E) const
double Threshold (void) const

Private Attributes

T * fModel

Detailed Description

template<class T>
class NuclearInteraction< T >

________________________________________________________________________________________

Id
NuclearInteraction.cxx,v 1.3 2005/02/03 11:56:04 tagg Exp

________________________________________________________________________________________

Id
NuclearInteraction.h,v 1.2 2004/01/05 16:11:13 costas Exp

Definition at line 21 of file NuclearInteraction.h.


Constructor & Destructor Documentation

template<class T >
NuclearInteraction< T >::NuclearInteraction (  )  [inline]

Definition at line 25 of file NuclearInteraction.cxx.

00025                                                              :
00026 EnergyLossProcess()
00027 {
00028   fModel = new T();
00029 }
//_________________________________________________________________________________________

template<class T >
NuclearInteraction< T >::NuclearInteraction ( const Material material  )  [inline]

Definition at line 31 of file NuclearInteraction.cxx.

References Process::eAll, Process::eNuclearInteraction, and NuclearInteraction< T >::fModel.

00031                                                                                       :
00032 EnergyLossProcess()
00033 {
00034   fModel = new T(material);
00035 
00036   Process::Process_t proc = fModel->ModeledProcess();
00037 
00038   assert( proc == Process::eNuclearInteraction || proc == Process::eAll );
00039 }
//_________________________________________________________________________________________

template<class T >
NuclearInteraction< T >::~NuclearInteraction (  )  [inline]

Definition at line 41 of file NuclearInteraction.cxx.

References NuclearInteraction< T >::fModel.

00042 {
00043   if(fModel) delete fModel;
00044 }


Member Function Documentation

template<class T >
double NuclearInteraction< T >::dE_dx ( double  E  )  const [inline, virtual]

Implements EnergyLossProcess.

Definition at line 46 of file NuclearInteraction.cxx.

References ValidityRange::Emax, ValidityRange::Emin, NuclearInteraction< T >::fModel, and NuclearInteraction< T >::Threshold().

00047 {
00048   if(E > Threshold() ) {
00049 
00050      ValidityRange_t vldrange = fModel->ValidityRange();
00051 
00052      if(E >= vldrange.Emin && E <= vldrange.Emax)  return fModel->dE_dx(E);
00053   }
00054 
00055   return 0;
00056 }

template<class T >
double NuclearInteraction< T >::Threshold ( void   )  const [inline, virtual]

Implements EnergyLossProcess.

Definition at line 29 of file NuclearInteraction.h.

Referenced by NuclearInteraction< T >::dE_dx().

00029 { return 0; }


Member Data Documentation

template<class T >
T* NuclearInteraction< T >::fModel [private]

The documentation for this class was generated from the following files:

Generated on 22 Nov 2017 for loon by  doxygen 1.6.1