ROOT logo
// $Id: g4ConfigCommon.C 30849 2009-02-01 11:42:22Z fca $
//
// AliRoot Configuration for running aliroot with Monte Carlo.
// ConfigCommon2() includes the common setting for all MCs
// which has to be called after MC is instantiated.
// Called from g4Config.C
//
// By I. Hrivnacova, IPN Orsay

// Functions
Float_t EtaToTheta(Float_t arg);
AliGenerator* GeneratorFactory();

void ConfigCommon2()
{
  cout << "Running ConfigCommon2.C ... " << endl;

  //=======================================================================
  // Steering parameters for ALICE simulation
  //=======================================================================

  gMC->SetProcess("DCAY",1);
  gMC->SetProcess("PAIR",1);
  gMC->SetProcess("COMP",1);
  gMC->SetProcess("PHOT",1);
  gMC->SetProcess("PFIS",0);
  gMC->SetProcess("DRAY",0);
  gMC->SetProcess("ANNI",1);
  gMC->SetProcess("BREM",1);
  gMC->SetProcess("MUNU",1);
  gMC->SetProcess("CKOV",1);
  gMC->SetProcess("HADR",1);
  gMC->SetProcess("LOSS",2);
  gMC->SetProcess("MULS",1);
  //gMC->SetProcess("RAYL",1);

  Float_t cut = 1.e-3;        // 1MeV cut by default
  Float_t tofmax = 1.e10;

  gMC->SetCut("CUTGAM", cut);
  gMC->SetCut("CUTELE", cut);
  gMC->SetCut("CUTNEU", cut);
  gMC->SetCut("CUTHAD", cut);
  gMC->SetCut("CUTMUO", cut);
  gMC->SetCut("BCUTE",  cut); 
  gMC->SetCut("BCUTM",  cut); 
  gMC->SetCut("DCUTE",  cut); 
  gMC->SetCut("DCUTM",  cut); 
  gMC->SetCut("PPCUTM", cut);
  gMC->SetCut("TOFMAX", tofmax); 

  //=======================================================================
  // External decayer
  //=======================================================================

  TVirtualMCDecayer *decayer = new AliDecayerPythia();
  decayer->SetForceDecay(kAll);
  decayer->Init();

  //forbid some decays
  AliPythia * py= AliPythia::Instance();
  py->SetMDME(737,1,0); //forbid D*+->D+ + pi0
  py->SetMDME(738,1,0);//forbid D*+->D+ + gamma

  for(Int_t d=747; d<=762; d++){ 
    py->SetMDME(d,1,0);
  }

  for(Int_t d=764; d<=807; d++){ 
    py->SetMDME(d,1,0);
  }

  gMC->SetExternalDecayer(decayer);
  
  //=======================================================================
  // Event generator
  //=======================================================================

  // Set Random Number seed
  gRandom->SetSeed(123456); // Set 0 to use the currecnt time
  AliLog::Message(AliLog::kInfo, Form("Seed for random number generation = %d",gRandom->GetSeed()), "Config.C", "Config.C", "Config()","Config.C", __LINE__);

  int nParticles = 100;
  if (gSystem->Getenv("CONFIG_NPARTICLES")) {
    nParticles = atoi(gSystem->Getenv("CONFIG_NPARTICLES"));
  }

  AliGenCocktail *gener = new AliGenCocktail();
  gener->SetPhiRange(0, 360);
  // Set pseudorapidity range from -8 to 8.
  Float_t thmin = EtaToTheta(8);   // theta min. <---> eta max
  Float_t thmax = EtaToTheta(-8);  // theta max. <---> eta min 
  gener->SetThetaRange(thmin,thmax);
  gener->SetOrigin(0, 0, 0);  //vertex position
  gener->SetSigma(0, 0, 0);   //Sigma in (X,Y,Z) (cm) on IP position

  AliGenHIJINGpara *hijingparam = new AliGenHIJINGpara(nParticles);
  hijingparam->SetMomentumRange(0.2, 999);
  gener->AddGenerator(hijingparam,"HIJING PARAM",1);
  gener->Init();

  // Activate this line if you want the vertex smearing to happen
  // track by track
  //
  //gener->SetVertexSmear(perTrack); 

/*
  // External generator configuration
  AliGenerator* gener = GeneratorFactory();
  gener->SetOrigin(0, 0, 0);    // vertex position
  gener->SetSigma(0, 0, 5.3);   // Sigma in (X,Y,Z) (cm) on IP position
  gener->SetCutVertexZ(1.);     // Truncate at 1 sigma
  gener->SetVertexSmear(kPerEvent); 
  gener->SetTrackingFlag(1);
  gener->Init();
*/    
  cout << "Running ConfigCommon2.C finished ... " << endl;
}

Float_t EtaToTheta(Float_t arg){
  return (180./TMath::Pi())*2.*atan(exp(-arg));
}

AliGenerator* GeneratorFactory() {

  AliGenExtFile *gener = new AliGenExtFile(-1);
  AliGenReaderTreeK * reader = new AliGenReaderTreeK();

  reader->SetFileName("galice.root");
  reader->AddDir("gen");
  gener->SetReader(reader);
     
  return gener; 
}

 g4ConfigCommon2.C:1
 g4ConfigCommon2.C:2
 g4ConfigCommon2.C:3
 g4ConfigCommon2.C:4
 g4ConfigCommon2.C:5
 g4ConfigCommon2.C:6
 g4ConfigCommon2.C:7
 g4ConfigCommon2.C:8
 g4ConfigCommon2.C:9
 g4ConfigCommon2.C:10
 g4ConfigCommon2.C:11
 g4ConfigCommon2.C:12
 g4ConfigCommon2.C:13
 g4ConfigCommon2.C:14
 g4ConfigCommon2.C:15
 g4ConfigCommon2.C:16
 g4ConfigCommon2.C:17
 g4ConfigCommon2.C:18
 g4ConfigCommon2.C:19
 g4ConfigCommon2.C:20
 g4ConfigCommon2.C:21
 g4ConfigCommon2.C:22
 g4ConfigCommon2.C:23
 g4ConfigCommon2.C:24
 g4ConfigCommon2.C:25
 g4ConfigCommon2.C:26
 g4ConfigCommon2.C:27
 g4ConfigCommon2.C:28
 g4ConfigCommon2.C:29
 g4ConfigCommon2.C:30
 g4ConfigCommon2.C:31
 g4ConfigCommon2.C:32
 g4ConfigCommon2.C:33
 g4ConfigCommon2.C:34
 g4ConfigCommon2.C:35
 g4ConfigCommon2.C:36
 g4ConfigCommon2.C:37
 g4ConfigCommon2.C:38
 g4ConfigCommon2.C:39
 g4ConfigCommon2.C:40
 g4ConfigCommon2.C:41
 g4ConfigCommon2.C:42
 g4ConfigCommon2.C:43
 g4ConfigCommon2.C:44
 g4ConfigCommon2.C:45
 g4ConfigCommon2.C:46
 g4ConfigCommon2.C:47
 g4ConfigCommon2.C:48
 g4ConfigCommon2.C:49
 g4ConfigCommon2.C:50
 g4ConfigCommon2.C:51
 g4ConfigCommon2.C:52
 g4ConfigCommon2.C:53
 g4ConfigCommon2.C:54
 g4ConfigCommon2.C:55
 g4ConfigCommon2.C:56
 g4ConfigCommon2.C:57
 g4ConfigCommon2.C:58
 g4ConfigCommon2.C:59
 g4ConfigCommon2.C:60
 g4ConfigCommon2.C:61
 g4ConfigCommon2.C:62
 g4ConfigCommon2.C:63
 g4ConfigCommon2.C:64
 g4ConfigCommon2.C:65
 g4ConfigCommon2.C:66
 g4ConfigCommon2.C:67
 g4ConfigCommon2.C:68
 g4ConfigCommon2.C:69
 g4ConfigCommon2.C:70
 g4ConfigCommon2.C:71
 g4ConfigCommon2.C:72
 g4ConfigCommon2.C:73
 g4ConfigCommon2.C:74
 g4ConfigCommon2.C:75
 g4ConfigCommon2.C:76
 g4ConfigCommon2.C:77
 g4ConfigCommon2.C:78
 g4ConfigCommon2.C:79
 g4ConfigCommon2.C:80
 g4ConfigCommon2.C:81
 g4ConfigCommon2.C:82
 g4ConfigCommon2.C:83
 g4ConfigCommon2.C:84
 g4ConfigCommon2.C:85
 g4ConfigCommon2.C:86
 g4ConfigCommon2.C:87
 g4ConfigCommon2.C:88
 g4ConfigCommon2.C:89
 g4ConfigCommon2.C:90
 g4ConfigCommon2.C:91
 g4ConfigCommon2.C:92
 g4ConfigCommon2.C:93
 g4ConfigCommon2.C:94
 g4ConfigCommon2.C:95
 g4ConfigCommon2.C:96
 g4ConfigCommon2.C:97
 g4ConfigCommon2.C:98
 g4ConfigCommon2.C:99
 g4ConfigCommon2.C:100
 g4ConfigCommon2.C:101
 g4ConfigCommon2.C:102
 g4ConfigCommon2.C:103
 g4ConfigCommon2.C:104
 g4ConfigCommon2.C:105
 g4ConfigCommon2.C:106
 g4ConfigCommon2.C:107
 g4ConfigCommon2.C:108
 g4ConfigCommon2.C:109
 g4ConfigCommon2.C:110
 g4ConfigCommon2.C:111
 g4ConfigCommon2.C:112
 g4ConfigCommon2.C:113
 g4ConfigCommon2.C:114
 g4ConfigCommon2.C:115
 g4ConfigCommon2.C:116
 g4ConfigCommon2.C:117
 g4ConfigCommon2.C:118
 g4ConfigCommon2.C:119
 g4ConfigCommon2.C:120
 g4ConfigCommon2.C:121
 g4ConfigCommon2.C:122
 g4ConfigCommon2.C:123
 g4ConfigCommon2.C:124
 g4ConfigCommon2.C:125
 g4ConfigCommon2.C:126
 g4ConfigCommon2.C:127
 g4ConfigCommon2.C:128
 g4ConfigCommon2.C:129
 g4ConfigCommon2.C:130
 g4ConfigCommon2.C:131
 g4ConfigCommon2.C:132
 g4ConfigCommon2.C:133
 g4ConfigCommon2.C:134
 g4ConfigCommon2.C:135
 g4ConfigCommon2.C:136