In this example, we are mapping a class to one of the Geant3 common blocks /gctrak/. In the real life, this common will be filled by Geant3 at each step and only the Tree Fill function should be called. The example emulates the Geant3 step routines.
Note that since IO is involved, ACLiC has to be invoked to create the dictionary of class Gctrak. 
 
 
 
public:
 
  Gctrak() {lmec=0; namec=0;}
 
};
 
 
{
  
   enum Evect {kX,kY,kZ,kPX,kPY,kPZ,kPP};
   vout[kPP] = vect[kPP];
   vout[kX]   = vect[kX]  + (
f1*vect[kPX] - f2*vect[kPY]);
   vout[kY]   = vect[kY]  + (
f1*vect[kPY] + f2*vect[kPX]);
   vout[kZ]   = vect[kZ]  + (
f1*vect[kPZ] + f3);
   vout[kPX]  = vect[kPX] + (f4*vect[kPX] - f5*vect[kPY]);
   vout[kPY]  = vect[kPY] + (f4*vect[kPY] + f5*vect[kPX]);
   vout[kPZ]  = vect[kPZ] + (f4*vect[kPZ] + f6);
}
 
void tree2aw()
{
   
 
   
   
   TFile f(
"tree2.root",
"recreate");
 
   TTree t2(
"t2",
"a Tree with data from a fake Geant3");
 
   Gctrak *gstep = new Gctrak;
   t2.Branch("track",&gstep,8000,1);
 
   
   gstep->lmec    = 
new Int_t[MAXMEC];
   gstep->namec   = 
new Int_t[MAXMEC];
   gstep->step    = 0.1;
   gstep->destep  = 0;
   gstep->nmec    = 0;
   gstep->pid     = 0;
 
   
   for (
Int_t i=0;i<10000;i++) {
 
      
      if (newParticle) {
         gstep->pid    += 1;
         gstep->vect[0] = 0;
         gstep->vect[1] = 0;
         gstep->vect[2] = 0;
         gstep->vect[3] = px/p;
         gstep->vect[4] = py/p;
         gstep->vect[5] = pz/p;
         gstep->vect[6] = p*charge;
         gstep->gekin   = gstep->getot - mass;
      }
 
      
      t2.Fill();
 
      
      helixStep(gstep->step, gstep->vect, vout); 
 
      
      gstep->destep = gstep->step*
gRandom->
Gaus(0.0002,0.00001);
      gstep->gekin -= gstep->destep;
      gstep->getot   = gstep->gekin + mass;
      gstep->vect[6] = charge*
TMath::Sqrt(gstep->getot*gstep->getot - mass*mass);
      gstep->vect[0] = vout[0];
      gstep->vect[1] = vout[1];
      gstep->vect[2] = vout[2];
      gstep->vect[3] = vout[3];
      gstep->vect[4] = vout[4];
      gstep->vect[5] = vout[5];
      }
      if (gstep->gekin < 0.001)            newParticle = 
kTRUE;
 
   }
 
   
   
   t2.Write();
}
 
void tree2ar()
{
   
   
 
   
   
   
   Gctrak *gstep = 0;
 
   
   TH1F *hdestep   = 
new TH1F(
"hdestep",
"destep in Mev",100,1
e-5,3
e-5);
 
 
   
      hdestep->
Fill(gstep->destep);
   }
 
   
   
   
   t2->
Draw(
"vect[0]:vect[1]:vect[2]");
   if (
gROOT->IsBatch()) 
return;
 
 
   
   gPad->GetViewer3D(
"x3d");
 
}
 
void tree2a() {
   tree2aw();
   tree2ar();
}
#define ClassDef(name, id)
R__EXTERN TRandom * gRandom
virtual void SetFillColor(Color_t fcolor)
Set the fill area color.
virtual void SetMarkerColor(Color_t mcolor=1)
Set the marker color.
A TTree is a list of TBranches.
virtual Int_t GetEntry(Long64_t entry=0, Int_t getall=0)
Read all leaves of entry and return total number of bytes read.
A ROOT file is a suite of consecutive data records (TKey instances) with a well defined format.
1-D histogram with a float per channel (see TH1 documentation)}
virtual TFitResultPtr Fit(const char *formula, Option_t *option="", Option_t *goption="", Double_t xmin=0, Double_t xmax=0)
Fit histogram with function fname.
virtual Int_t Fill(Double_t x)
Increment bin with abscissa X by 1.
Mother of all ROOT objects.
virtual Double_t Gaus(Double_t mean=0, Double_t sigma=1)
Samples a random number from the standard Normal (Gaussian) Distribution with the given mean and sigm...
virtual Double_t Rndm()
Machine independent random number generator.
A TTree represents a columnar dataset.
virtual TBranch * GetBranch(const char *name)
Return pointer to the branch with the given name in this tree or its friends.
virtual Int_t SetBranchAddress(const char *bname, void *add, TBranch **ptr=0)
Change branch address, dealing with clone trees properly.
virtual Long64_t GetEntries() const
virtual void Draw(Option_t *opt)
Default Draw method for all objects.
Double_t Sqrt(Double_t x)
#define snext(osub1, osub2)