// @(#)root/vmc:$Name: $:$Id: TMCVerbose.cxx,v 1.2 2003/09/23 14:03:15 brun Exp $
// Author: Ivana Hrivnacova, 27/03/2002
#include "Riostream.h"
#include "TVirtualMC.h"
#include "TVirtualMCStack.h"
#include "TDatabasePDG.h"
#include "TParticlePDG.h"
#include "TArrayI.h"
#include "TMCVerbose.h"
//______________________________________________________________________________
//
// Class for printing detailed info from MC application.
// Defined levels:
// 0 no output
// 1 info up to event level
// 2 info up to tracking level
// 3 detailed info for each step
//______________________________________________________________________________
ClassImp(TMCVerbose)
//_____________________________________________________________________________
TMCVerbose::TMCVerbose(Int_t level)
: TObject(),
fLevel(level),
fStepNumber(0)
{
// Standard constructor
// ---
}
//_____________________________________________________________________________
TMCVerbose::TMCVerbose()
: TObject(),
fLevel(0),
fStepNumber(0)
{
// Default constructor
// ---
}
//_____________________________________________________________________________
TMCVerbose::~TMCVerbose()
{
// Destructor
// ---
}
//
// private methods
//
//_____________________________________________________________________________
void TMCVerbose::PrintBanner() const
{
// Prints banner for track information
// ---
cout << endl;
for (Int_t i=0; i<10; i++) cout << "**********";
cout << endl;
}
//_____________________________________________________________________________
void TMCVerbose::PrintTrackInfo() const
{
// Prints track information
// ---
// Particle
//
cout << " Particle = ";
TParticlePDG* particle
= TDatabasePDG::Instance()->GetParticle(gMC->TrackPid());
if (particle)
cout << particle->GetName() << " ";
else
cout << "unknown" << " ";
// Track ID
//
cout << " Track ID = " << gMC->GetStack()->GetCurrentTrackNumber() << " ";
// Parent ID
//
cout << " Parent ID = " << gMC->GetStack()->GetCurrentParentTrackNumber();
}
//_____________________________________________________________________________
void TMCVerbose::PrintStepHeader() const
{
// Prints the header for stepping information
// ---
cout << "Step# "
<< "X(cm) "
<< "Y(cm) "
<< "Z(cm) "
<< "KinE(MeV) "
<< "dE(MeV) "
<< "Step(cm) "
<< "TrackL(cm) "
<< "Volume "
<< "Process "
<< endl;
}
//
// public methods
//
//_____________________________________________________________________________
void TMCVerbose::InitMC()
{
// Initialize MC info.
// ---
if (fLevel>0)
cout << "--- Init MC " << endl;
}
//_____________________________________________________________________________
void TMCVerbose::RunMC(Int_t nofEvents)
{
// MC run info.
// ---
if (fLevel>0)
cout << "--- Run MC for " << nofEvents << " events" << endl;
}
//_____________________________________________________________________________
void TMCVerbose::FinishRun()
{
// Finish MC run info.
// ---
if (fLevel>0)
cout << "--- Finish Run MC " << endl;
}
//_____________________________________________________________________________
void TMCVerbose::ConstructGeometry()
{
// Construct geometry info
// ---
if (fLevel>0)
cout << "--- Construct geometry " << endl;
}
//_____________________________________________________________________________
void TMCVerbose::InitGeometry()
{
// Initialize geometry info
// ---
if (fLevel>0)
cout << "--- Init geometry " << endl;
}
//_____________________________________________________________________________
void TMCVerbose::GeneratePrimaries()
{
// Generate primaries info
// ---
if (fLevel>0)
cout << "--- Generate primaries " << endl;
}
//_____________________________________________________________________________
void TMCVerbose::BeginEvent()
{
// Begin event info
// ---
if (fLevel>0)
cout << "--- Begin event " << endl;
}
//_____________________________________________________________________________
void TMCVerbose::BeginPrimary()
{
// Begin of a primary track info
// ---
if (fLevel>1)
cout << "--- Begin primary " << endl;
}
//_____________________________________________________________________________
void TMCVerbose::PreTrack()
{
// Begin of each track info
// ---
if (fLevel>2) {
PrintBanner();
PrintTrackInfo();
PrintBanner();
PrintStepHeader();
fStepNumber = 0;
return;
}
if (fLevel>1)
cout << "--- Pre track " << endl;
}
//_____________________________________________________________________________
void TMCVerbose::Stepping()
{
// Stepping info
// ---
if (fLevel>2) {
#if __GNUC__ >= 3
cout << std::fixed;
#endif
// Step number
//
cout << "#" << setw(4) << fStepNumber++ << " ";
// Position
//
Double_t x, y, z;
gMC->TrackPosition(x, y, z);
cout << setw(8) << setprecision(3) << x << " "
<< setw(8) << setprecision(3) << y << " "
<< setw(8) << setprecision(3) << z << " ";
// Kinetic energy
//
Double_t px, py, pz, etot;
gMC->TrackMomentum(px, py, pz, etot);
Double_t ekin = etot - gMC->TrackMass();
cout << setw(9) << setprecision(4) << ekin*1e03 << " ";
// Energy deposit
//
cout << setw(9) << setprecision(4) << gMC->Edep()*1e03 << " ";
// Step length
//
cout << setw(8) << setprecision(3) << gMC->TrackStep() << " ";
// Track length
//
cout << setw(8) << setprecision(3) << gMC->TrackLength() << " ";
// Volume
//
cout << setw(4) << gMC->CurrentVolName() << " ";
// Process
//
TArrayI processes;
Int_t nofProcesses = gMC->StepProcesses(processes);
if (nofProcesses > 0)
cout << TMCProcessName[processes[nofProcesses-1]];
cout << endl;
}
}
//_____________________________________________________________________________
void TMCVerbose::PostTrack()
{
// Finish of each track info
// ---
if (fLevel==2)
cout << "--- Post track " << endl;
}
//_____________________________________________________________________________
void TMCVerbose::FinishPrimary()
{
// Finish of a primary track info
// ---
if (fLevel==2)
cout << "--- Finish primary " << endl;
}
//_____________________________________________________________________________
void TMCVerbose::FinishEvent()
{
// Finish of an event info
// ---
if (fLevel>0)
cout << "--- Finish event " << endl;
}
ROOT page - Class index - Class Hierarchy - Top of the page
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.