ROOT logo
// $Id$
//
// AliRoot Configuration for running aliroot with Monte Carlo.
// Called from g4Config.C
//
// By I. Hrivnacova, IPN Orsay

enum PprGeo_t
  {
    kHoles, kNoHoles
  };
static PprGeo_t geo = kHoles;

Float_t EtaToTheta(Float_t arg);
void    LoadPythia();
static Int_t    eventsPerRun = 50;

void ConfigCommon(Bool_t setRootGeometry = kTRUE)
{
  cout << "Running ConfigCommon.C ... " << endl;

  // Load Pythia libraries
  LoadPythia();

  // Create the output file
  AliRunLoader* rl = 0;
  rl = AliRunLoader::Open("galice.root",
			   AliConfig::GetDefaultEventFolderName(),
			   "recreate");
  if (!rl) {
    gAlice->Fatal("Config.C","Can not instatiate the Run Loader");
    return;
  }
  rl->SetCompressionLevel(2);
  rl->SetNumberOfEventsPerFile(3);
  gAlice->SetRunLoader(rl);
  
  // Set Root geometry file
  //
  if ( setRootGeometry ) {
    gAlice->SetRootGeometry();
    gAlice->SetGeometryFromFile("geometry.root");
  }

  // Set the trigger configuration
  AliSimulation::Instance()->SetTriggerConfig("Pb-Pb");
  cout<<"Trigger configuration is set to  Pb-Pb"<<endl;

    // 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); 

  // ============================= 
  // Magnetic field
  // ============================= 

    // Field (L3 0.4 T)
    TGeoGlobalMagField::Instance()->SetField(new AliMagF("Maps","Maps", 1., 1., AliMagF::k5kG));

    Int_t   iABSO  =  1;
    Int_t   iDIPO  =  1;
    Int_t   iFMD   =  1;
    Int_t   iFRAME =  1;
    Int_t   iHALL  =  1;
    Int_t   iITS   =  1;
    Int_t   iMAG   =  1;
    Int_t   iMUON  =  1;
    Int_t   iPHOS  =  1;
    Int_t   iPIPE  =  1;
    Int_t   iPMD   =  1;
    Int_t   iHMPID =  1;
    Int_t   iSHIL  =  1;
    Int_t   iT0    =  1;
    Int_t   iTOF   =  1;
    Int_t   iTPC   =  1;
    Int_t   iTRD   =  1;
    Int_t   iZDC   =  1;
    Int_t   iEMCAL =  1;
    Int_t   iACORDE = 0;
    Int_t   iVZERO =  1;
/*
    Int_t   iABSO  =  0;
    Int_t   iDIPO  =  0;
    Int_t   iFMD   =  0;
    Int_t   iFRAME =  0;
    Int_t   iHALL  =  0;
    Int_t   iITS   =  0;
    Int_t   iMAG   =  0;
    Int_t   iMUON  =  0;
    Int_t   iPHOS  =  0;
    Int_t   iPIPE  =  0;
    Int_t   iPMD   =  0;
    Int_t   iHMPID =  0;
    Int_t   iSHIL  =  0;
    Int_t   iT0    =  0;
    Int_t   iTOF   =  0;
    Int_t   iTPC   =  1;
    Int_t   iTRD   =  0;
    Int_t   iZDC   =  0;
    Int_t   iEMCAL =  0;
    Int_t   iACORDE = 0;
    Int_t   iVZERO =  0;
*/   
// Exluded for problems

    rl->CdGAFile();
    //=================== Alice BODY parameters =============================
    AliBODY *BODY = new AliBODY("BODY", "Alice envelop");

    if (iMAG)
    {
        //=================== MAG parameters ============================
        // --- Start with Magnet since detector layouts may be depending ---
        // --- on the selected Magnet dimensions ---
        AliMAG *MAG = new AliMAG("MAG", "Magnet");
    }


    if (iABSO)
    {
        //=================== ABSO parameters ============================
        AliABSO *ABSO = new AliABSOv3("ABSO", "Muon Absorber");
    }

    if (iDIPO)
    {
        //=================== DIPO parameters ============================

        AliDIPO *DIPO = new AliDIPOv3("DIPO", "Dipole version 3");
    }

    if (iHALL)
    {
        //=================== HALL parameters ============================

        AliHALL *HALL = new AliHALLv3("HALL", "Alice Hall");
    }


    if (iFRAME)
    {
        //=================== FRAME parameters ============================

        AliFRAMEv2 *FRAME = new AliFRAMEv2("FRAME", "Space Frame");
        if (geo == kHoles) {
	  FRAME->SetHoles(1);
	} else {
	  FRAME->SetHoles(0);
	}
    }

    if (iSHIL)
    {
        //=================== SHIL parameters ============================

        AliSHIL *SHIL = new AliSHILv3("SHIL", "Shielding Version 3");
    }


    if (iPIPE)
    {
        //=================== PIPE parameters ============================

        AliPIPE *PIPE = new AliPIPEv3("PIPE", "Beam Pipe");
    }
 
    if (iITS)
    {
        //=================== ITS parameters ============================

	AliITS *ITS  = new AliITSv11("ITS","ITS v11");
    }

    if (iTPC)
    {
        //============================ TPC parameters ===================
        AliTPC *TPC = new AliTPCv2("TPC", "Default");
    }


    if (iTOF) {
        //=================== TOF parameters ============================
	AliTOF *TOF = new AliTOFv6T0("TOF", "normal TOF");
    }


    if (iHMPID)
    {
        //=================== HMPID parameters ===========================
        AliHMPID *HMPID = new AliHMPIDv3("HMPID", "normal HMPID");

    }


    if (iZDC)
    {
        //=================== ZDC parameters ============================

        AliZDC *ZDC = new AliZDCv3("ZDC", "normal ZDC");
    }

    if (iTRD)
    {
        //=================== TRD parameters ============================

        AliTRD *TRD = new AliTRDv1("TRD", "TRD slow simulator");
    }

    if (iFMD)
    {
        //=================== FMD parameters ============================
	AliFMD *FMD = new AliFMDv1("FMD", "normal FMD");
   }

    if (iMUON)
    {
        //=================== MUON parameters ===========================
        // New MUONv1 version (geometry defined via builders)
        AliMUON *MUON = new AliMUONv1("MUON", "default");
    }
    //=================== PHOS parameters ===========================

    if (iPHOS)
    {
        AliPHOS *PHOS = new AliPHOSv1("PHOS", "IHEP");
    }


    if (iPMD)
    {
        //=================== PMD parameters ============================
        AliPMD *PMD = new AliPMDv1("PMD", "normal PMD");
    }

    if (iT0)
    {
        //=================== T0 parameters ============================
        AliT0 *T0 = new AliT0v1("T0", "T0 Detector");
    }

    if (iEMCAL)
    {
        //=================== EMCAL parameters ============================
        AliEMCAL *EMCAL = new AliEMCALv2("EMCAL", "EMCAL_COMPLETE");
    }

     if (iACORDE)
    {
        //=================== ACORDE parameters ============================
        AliACORDE *ACORDE = new AliACORDEv1("ACORDE", "normal ACORDE");
    }

     if (iVZERO)
    {
        //=================== ACORDE parameters ============================
        AliVZERO *VZERO = new AliVZEROv7("VZERO", "normal VZERO");
    }

     AliLog::Message(AliLog::kInfo, "End of Config", "Config.C", "Config.C", "Config()"," Config.C", __LINE__);

     cout << "Running ConfigCommon.C finished ... " << endl;

}

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

void LoadPythia()
{
    // Load Pythia related libraries
    gSystem->Load("liblhapdf.so");      // Parton density functions
    gSystem->Load("libEGPythia6.so");   // TGenerator interface
    gSystem->Load("libpythia6.so");     // Pythia
    gSystem->Load("libAliPythia6.so");  // ALICE specific implementations
}
 g4ConfigCommon.C:1
 g4ConfigCommon.C:2
 g4ConfigCommon.C:3
 g4ConfigCommon.C:4
 g4ConfigCommon.C:5
 g4ConfigCommon.C:6
 g4ConfigCommon.C:7
 g4ConfigCommon.C:8
 g4ConfigCommon.C:9
 g4ConfigCommon.C:10
 g4ConfigCommon.C:11
 g4ConfigCommon.C:12
 g4ConfigCommon.C:13
 g4ConfigCommon.C:14
 g4ConfigCommon.C:15
 g4ConfigCommon.C:16
 g4ConfigCommon.C:17
 g4ConfigCommon.C:18
 g4ConfigCommon.C:19
 g4ConfigCommon.C:20
 g4ConfigCommon.C:21
 g4ConfigCommon.C:22
 g4ConfigCommon.C:23
 g4ConfigCommon.C:24
 g4ConfigCommon.C:25
 g4ConfigCommon.C:26
 g4ConfigCommon.C:27
 g4ConfigCommon.C:28
 g4ConfigCommon.C:29
 g4ConfigCommon.C:30
 g4ConfigCommon.C:31
 g4ConfigCommon.C:32
 g4ConfigCommon.C:33
 g4ConfigCommon.C:34
 g4ConfigCommon.C:35
 g4ConfigCommon.C:36
 g4ConfigCommon.C:37
 g4ConfigCommon.C:38
 g4ConfigCommon.C:39
 g4ConfigCommon.C:40
 g4ConfigCommon.C:41
 g4ConfigCommon.C:42
 g4ConfigCommon.C:43
 g4ConfigCommon.C:44
 g4ConfigCommon.C:45
 g4ConfigCommon.C:46
 g4ConfigCommon.C:47
 g4ConfigCommon.C:48
 g4ConfigCommon.C:49
 g4ConfigCommon.C:50
 g4ConfigCommon.C:51
 g4ConfigCommon.C:52
 g4ConfigCommon.C:53
 g4ConfigCommon.C:54
 g4ConfigCommon.C:55
 g4ConfigCommon.C:56
 g4ConfigCommon.C:57
 g4ConfigCommon.C:58
 g4ConfigCommon.C:59
 g4ConfigCommon.C:60
 g4ConfigCommon.C:61
 g4ConfigCommon.C:62
 g4ConfigCommon.C:63
 g4ConfigCommon.C:64
 g4ConfigCommon.C:65
 g4ConfigCommon.C:66
 g4ConfigCommon.C:67
 g4ConfigCommon.C:68
 g4ConfigCommon.C:69
 g4ConfigCommon.C:70
 g4ConfigCommon.C:71
 g4ConfigCommon.C:72
 g4ConfigCommon.C:73
 g4ConfigCommon.C:74
 g4ConfigCommon.C:75
 g4ConfigCommon.C:76
 g4ConfigCommon.C:77
 g4ConfigCommon.C:78
 g4ConfigCommon.C:79
 g4ConfigCommon.C:80
 g4ConfigCommon.C:81
 g4ConfigCommon.C:82
 g4ConfigCommon.C:83
 g4ConfigCommon.C:84
 g4ConfigCommon.C:85
 g4ConfigCommon.C:86
 g4ConfigCommon.C:87
 g4ConfigCommon.C:88
 g4ConfigCommon.C:89
 g4ConfigCommon.C:90
 g4ConfigCommon.C:91
 g4ConfigCommon.C:92
 g4ConfigCommon.C:93
 g4ConfigCommon.C:94
 g4ConfigCommon.C:95
 g4ConfigCommon.C:96
 g4ConfigCommon.C:97
 g4ConfigCommon.C:98
 g4ConfigCommon.C:99
 g4ConfigCommon.C:100
 g4ConfigCommon.C:101
 g4ConfigCommon.C:102
 g4ConfigCommon.C:103
 g4ConfigCommon.C:104
 g4ConfigCommon.C:105
 g4ConfigCommon.C:106
 g4ConfigCommon.C:107
 g4ConfigCommon.C:108
 g4ConfigCommon.C:109
 g4ConfigCommon.C:110
 g4ConfigCommon.C:111
 g4ConfigCommon.C:112
 g4ConfigCommon.C:113
 g4ConfigCommon.C:114
 g4ConfigCommon.C:115
 g4ConfigCommon.C:116
 g4ConfigCommon.C:117
 g4ConfigCommon.C:118
 g4ConfigCommon.C:119
 g4ConfigCommon.C:120
 g4ConfigCommon.C:121
 g4ConfigCommon.C:122
 g4ConfigCommon.C:123
 g4ConfigCommon.C:124
 g4ConfigCommon.C:125
 g4ConfigCommon.C:126
 g4ConfigCommon.C:127
 g4ConfigCommon.C:128
 g4ConfigCommon.C:129
 g4ConfigCommon.C:130
 g4ConfigCommon.C:131
 g4ConfigCommon.C:132
 g4ConfigCommon.C:133
 g4ConfigCommon.C:134
 g4ConfigCommon.C:135
 g4ConfigCommon.C:136
 g4ConfigCommon.C:137
 g4ConfigCommon.C:138
 g4ConfigCommon.C:139
 g4ConfigCommon.C:140
 g4ConfigCommon.C:141
 g4ConfigCommon.C:142
 g4ConfigCommon.C:143
 g4ConfigCommon.C:144
 g4ConfigCommon.C:145
 g4ConfigCommon.C:146
 g4ConfigCommon.C:147
 g4ConfigCommon.C:148
 g4ConfigCommon.C:149
 g4ConfigCommon.C:150
 g4ConfigCommon.C:151
 g4ConfigCommon.C:152
 g4ConfigCommon.C:153
 g4ConfigCommon.C:154
 g4ConfigCommon.C:155
 g4ConfigCommon.C:156
 g4ConfigCommon.C:157
 g4ConfigCommon.C:158
 g4ConfigCommon.C:159
 g4ConfigCommon.C:160
 g4ConfigCommon.C:161
 g4ConfigCommon.C:162
 g4ConfigCommon.C:163
 g4ConfigCommon.C:164
 g4ConfigCommon.C:165
 g4ConfigCommon.C:166
 g4ConfigCommon.C:167
 g4ConfigCommon.C:168
 g4ConfigCommon.C:169
 g4ConfigCommon.C:170
 g4ConfigCommon.C:171
 g4ConfigCommon.C:172
 g4ConfigCommon.C:173
 g4ConfigCommon.C:174
 g4ConfigCommon.C:175
 g4ConfigCommon.C:176
 g4ConfigCommon.C:177
 g4ConfigCommon.C:178
 g4ConfigCommon.C:179
 g4ConfigCommon.C:180
 g4ConfigCommon.C:181
 g4ConfigCommon.C:182
 g4ConfigCommon.C:183
 g4ConfigCommon.C:184
 g4ConfigCommon.C:185
 g4ConfigCommon.C:186
 g4ConfigCommon.C:187
 g4ConfigCommon.C:188
 g4ConfigCommon.C:189
 g4ConfigCommon.C:190
 g4ConfigCommon.C:191
 g4ConfigCommon.C:192
 g4ConfigCommon.C:193
 g4ConfigCommon.C:194
 g4ConfigCommon.C:195
 g4ConfigCommon.C:196
 g4ConfigCommon.C:197
 g4ConfigCommon.C:198
 g4ConfigCommon.C:199
 g4ConfigCommon.C:200
 g4ConfigCommon.C:201
 g4ConfigCommon.C:202
 g4ConfigCommon.C:203
 g4ConfigCommon.C:204
 g4ConfigCommon.C:205
 g4ConfigCommon.C:206
 g4ConfigCommon.C:207
 g4ConfigCommon.C:208
 g4ConfigCommon.C:209
 g4ConfigCommon.C:210
 g4ConfigCommon.C:211
 g4ConfigCommon.C:212
 g4ConfigCommon.C:213
 g4ConfigCommon.C:214
 g4ConfigCommon.C:215
 g4ConfigCommon.C:216
 g4ConfigCommon.C:217
 g4ConfigCommon.C:218
 g4ConfigCommon.C:219
 g4ConfigCommon.C:220
 g4ConfigCommon.C:221
 g4ConfigCommon.C:222
 g4ConfigCommon.C:223
 g4ConfigCommon.C:224
 g4ConfigCommon.C:225
 g4ConfigCommon.C:226
 g4ConfigCommon.C:227
 g4ConfigCommon.C:228
 g4ConfigCommon.C:229
 g4ConfigCommon.C:230
 g4ConfigCommon.C:231
 g4ConfigCommon.C:232
 g4ConfigCommon.C:233
 g4ConfigCommon.C:234
 g4ConfigCommon.C:235
 g4ConfigCommon.C:236
 g4ConfigCommon.C:237
 g4ConfigCommon.C:238
 g4ConfigCommon.C:239
 g4ConfigCommon.C:240
 g4ConfigCommon.C:241
 g4ConfigCommon.C:242
 g4ConfigCommon.C:243
 g4ConfigCommon.C:244
 g4ConfigCommon.C:245
 g4ConfigCommon.C:246
 g4ConfigCommon.C:247
 g4ConfigCommon.C:248
 g4ConfigCommon.C:249
 g4ConfigCommon.C:250
 g4ConfigCommon.C:251
 g4ConfigCommon.C:252
 g4ConfigCommon.C:253
 g4ConfigCommon.C:254
 g4ConfigCommon.C:255
 g4ConfigCommon.C:256
 g4ConfigCommon.C:257
 g4ConfigCommon.C:258
 g4ConfigCommon.C:259
 g4ConfigCommon.C:260
 g4ConfigCommon.C:261
 g4ConfigCommon.C:262
 g4ConfigCommon.C:263
 g4ConfigCommon.C:264
 g4ConfigCommon.C:265
 g4ConfigCommon.C:266
 g4ConfigCommon.C:267
 g4ConfigCommon.C:268
 g4ConfigCommon.C:269
 g4ConfigCommon.C:270
 g4ConfigCommon.C:271
 g4ConfigCommon.C:272
 g4ConfigCommon.C:273
 g4ConfigCommon.C:274
 g4ConfigCommon.C:275
 g4ConfigCommon.C:276
 g4ConfigCommon.C:277
 g4ConfigCommon.C:278
 g4ConfigCommon.C:279
 g4ConfigCommon.C:280
 g4ConfigCommon.C:281
 g4ConfigCommon.C:282
 g4ConfigCommon.C:283
 g4ConfigCommon.C:284
 g4ConfigCommon.C:285
 g4ConfigCommon.C:286
 g4ConfigCommon.C:287
 g4ConfigCommon.C:288
 g4ConfigCommon.C:289
 g4ConfigCommon.C:290
 g4ConfigCommon.C:291
 g4ConfigCommon.C:292
 g4ConfigCommon.C:293
 g4ConfigCommon.C:294
 g4ConfigCommon.C:295
 g4ConfigCommon.C:296
 g4ConfigCommon.C:297
 g4ConfigCommon.C:298
 g4ConfigCommon.C:299
 g4ConfigCommon.C:300
 g4ConfigCommon.C:301
 g4ConfigCommon.C:302