ROOT logo
// One can use the configuration macro in compiled mode by
// root [0] gSystem->Load("libgeant321");
// root [0] gSystem->SetIncludePath("-I$ROOTSYS/include -I$ALICE_ROOT/include\
//                   -I$ALICE_ROOT -I$ALICE/geant3/TGeant3");
// root [0] .x grun.C(1,"Config.C++")

#if !defined(__CINT__) || defined(__MAKECINT__)
#include <Riostream.h>
#include <TPDGCode.h>
#include <TRandom.h>
#include <TSystem.h>
#include <TVirtualMC.h>
#include <TGeant3TGeo.h>
#include "STEER/AliRunLoader.h"
#include "STEER/AliRun.h"
#include "STEER/AliConfig.h"
#include "PYTHIA6/AliDecayerPythia.h"
#include "EVGEN/AliGenCocktail.h"
#include "EVGEN/AliGenHIJINGpara.h"
#include "EVGEN/AliGenFixed.h"
#include "EVGEN/AliGenBox.h"
#include "STEER/AliMagF.h"
#include "STRUCT/AliBODY.h"
#include "STRUCT/AliMAG.h"
#include "STRUCT/AliABSOv3.h"
#include "STRUCT/AliDIPOv3.h"
#include "STRUCT/AliHALLv3.h"
#include "STRUCT/AliFRAMEv2.h"
#include "STRUCT/AliSHILv3.h"
#include "STRUCT/AliPIPEv3.h"
#include "ITS/AliITSv11.h"
#include "TPC/AliTPCv2.h"
#include "TOF/AliTOFv6T0.h"
#include "HMPID/AliHMPIDv3.h"
#include "ZDC/AliZDCv3.h"
#include "TRD/AliTRDv1.h"
#include "TRD/AliTRDgeometry.h"
#include "FMD/AliFMDv1.h"
#include "MUON/AliMUONv1.h"
#include "PHOS/AliPHOSv1.h"
#include "PMD/AliPMDv1.h"
#include "T0/AliT0v1.h"
#include "EMCAL/AliEMCALv2.h"
#include "ACORDE/AliACORDEv1.h"
#include "VZERO/AliVZEROv7.h"
#endif

enum PprTrigConf_t
{
    kDefaultPPTrig, kDefaultPbPbTrig
};

const char * pprTrigConfName[] = {
    "p-p","Pb-Pb"
};

Float_t EtaToTheta(Float_t arg);

static PprTrigConf_t strig = kDefaultPPTrig;// default PP trigger configuration

void Config()
{
    // ThetaRange is (0., 180.). It was (0.28,179.72) 7/12/00 09:00
    // Theta range given through pseudorapidity limits 22/6/2001

    // Set Random Number seed
  gRandom->SetSeed(123456); // Set 0 to use the currecnt time


   // libraries required by geant321
#if defined(__CINT__)
    gSystem->Load("liblhapdf");
    gSystem->Load("libEGPythia6");
    gSystem->Load("libpythia6");
    gSystem->Load("libAliPythia6");
    gSystem->Load("libgeant321");
#endif

    new     TGeant3TGeo("C++ Interface to Geant3");

    AliRunLoader* rl=0x0;


    rl = AliRunLoader::Open("galice.root",
			    AliConfig::GetDefaultEventFolderName(),
			    "recreate");
    if (rl == 0x0)
      {
	gAlice->Fatal("Config.C","Can not instatiate the Run Loader");
	return;
      }
    rl->SetCompressionLevel(2);
    rl->SetNumberOfEventsPerFile(3);
    gAlice->SetRunLoader(rl);

    // Set the trigger configuration
    gAlice->SetTriggerDescriptor(pprTrigConfName[strig]);
    cout<<"Trigger configuration is set to  "<<pprTrigConfName[strig]<<endl;

    //
    // Set External decayer
    TVirtualMCDecayer *decayer = new AliDecayerPythia();

    decayer->SetForceDecay(kAll);
    decayer->Init();
    gMC->SetExternalDecayer(decayer);
    //=======================================================================
    // ************* STEERING parameters FOR ALICE SIMULATION **************
    // --- Specify event type to be tracked through the ALICE setup
    // --- All positions are in cm, angles in degrees, and P and E in GeV


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

    // Special generation for Valgrind tests
    // Each detector is fired by few particles selected 
    // to cover specific cases


    // The cocktail iitself

    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



    // PHOS

    AliGenBox *gphos = new AliGenBox(1);
    gphos->SetMomentumRange(10.0,10.1);
    gphos->SetPhiRange(265.,275.);
    gphos->SetThetaRange(EtaToTheta(-0.10),EtaToTheta(0.10));
    gphos->SetPart(kElectron);
    gener->AddGenerator(gphos,"GENBOX ELECTRON for PHOS",1);

    // EMCAL

    AliGenBox *gemcal = new AliGenBox(1);
    gemcal->SetMomentumRange(10.0,10.1);
    gemcal->SetPhiRange(95.,100.);
    gemcal->SetThetaRange(EtaToTheta(0.10),EtaToTheta(0.20));
    gemcal->SetPart(kElectron);
    gener->AddGenerator(gemcal,"GENBOX ELECTRON for EMCAL",1);

    
    gener->Init();


    // 
    // Activate this line if you want the vertex smearing to happen
    // track by track
    //
    //gener->SetVertexSmear(perTrack); 
    // Field (L3 0.5 T)
    TGeoGlobalMagField::Instance()->SetField(new AliMagF("Maps","Maps", -1., -1., AliMagF::k5kG));

    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  =  1;
    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   =  0;
    Int_t   iTRD   =  0;
    Int_t   iZDC   =  0;
    Int_t   iEMCAL =  1;
    Int_t   iACORDE   =  0;
    Int_t   iVZERO =  0;
    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");
	FRAME->SetHoles(1);
    }

    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");
        AliTRDgeometry *geoTRD = TRD->GetGeometry();
	// Partial geometry: modules at 2,3,4,6,11,12,14,15
	// starting at 6h in positive direction
	geoTRD->SetSMstatus(0,0);
        geoTRD->SetSMstatus(1,0);
        geoTRD->SetSMstatus(5,0);
        geoTRD->SetSMstatus(7,0);
        geoTRD->SetSMstatus(8,0);
        geoTRD->SetSMstatus(9,0);
        geoTRD->SetSMstatus(10,0);
        geoTRD->SetSMstatus(13,0);
        geoTRD->SetSMstatus(16,0);
        geoTRD->SetSMstatus(17,0);
    }

    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)
    {
        //=================== VZERO parameters ============================
        AliVZERO *VZERO = new AliVZEROv7("VZERO", "normal VZERO");
    }


}

Float_t EtaToTheta(Float_t arg){
  return (180./TMath::Pi())*2.*atan(exp(-arg));
}
 ConfigPi0.C:1
 ConfigPi0.C:2
 ConfigPi0.C:3
 ConfigPi0.C:4
 ConfigPi0.C:5
 ConfigPi0.C:6
 ConfigPi0.C:7
 ConfigPi0.C:8
 ConfigPi0.C:9
 ConfigPi0.C:10
 ConfigPi0.C:11
 ConfigPi0.C:12
 ConfigPi0.C:13
 ConfigPi0.C:14
 ConfigPi0.C:15
 ConfigPi0.C:16
 ConfigPi0.C:17
 ConfigPi0.C:18
 ConfigPi0.C:19
 ConfigPi0.C:20
 ConfigPi0.C:21
 ConfigPi0.C:22
 ConfigPi0.C:23
 ConfigPi0.C:24
 ConfigPi0.C:25
 ConfigPi0.C:26
 ConfigPi0.C:27
 ConfigPi0.C:28
 ConfigPi0.C:29
 ConfigPi0.C:30
 ConfigPi0.C:31
 ConfigPi0.C:32
 ConfigPi0.C:33
 ConfigPi0.C:34
 ConfigPi0.C:35
 ConfigPi0.C:36
 ConfigPi0.C:37
 ConfigPi0.C:38
 ConfigPi0.C:39
 ConfigPi0.C:40
 ConfigPi0.C:41
 ConfigPi0.C:42
 ConfigPi0.C:43
 ConfigPi0.C:44
 ConfigPi0.C:45
 ConfigPi0.C:46
 ConfigPi0.C:47
 ConfigPi0.C:48
 ConfigPi0.C:49
 ConfigPi0.C:50
 ConfigPi0.C:51
 ConfigPi0.C:52
 ConfigPi0.C:53
 ConfigPi0.C:54
 ConfigPi0.C:55
 ConfigPi0.C:56
 ConfigPi0.C:57
 ConfigPi0.C:58
 ConfigPi0.C:59
 ConfigPi0.C:60
 ConfigPi0.C:61
 ConfigPi0.C:62
 ConfigPi0.C:63
 ConfigPi0.C:64
 ConfigPi0.C:65
 ConfigPi0.C:66
 ConfigPi0.C:67
 ConfigPi0.C:68
 ConfigPi0.C:69
 ConfigPi0.C:70
 ConfigPi0.C:71
 ConfigPi0.C:72
 ConfigPi0.C:73
 ConfigPi0.C:74
 ConfigPi0.C:75
 ConfigPi0.C:76
 ConfigPi0.C:77
 ConfigPi0.C:78
 ConfigPi0.C:79
 ConfigPi0.C:80
 ConfigPi0.C:81
 ConfigPi0.C:82
 ConfigPi0.C:83
 ConfigPi0.C:84
 ConfigPi0.C:85
 ConfigPi0.C:86
 ConfigPi0.C:87
 ConfigPi0.C:88
 ConfigPi0.C:89
 ConfigPi0.C:90
 ConfigPi0.C:91
 ConfigPi0.C:92
 ConfigPi0.C:93
 ConfigPi0.C:94
 ConfigPi0.C:95
 ConfigPi0.C:96
 ConfigPi0.C:97
 ConfigPi0.C:98
 ConfigPi0.C:99
 ConfigPi0.C:100
 ConfigPi0.C:101
 ConfigPi0.C:102
 ConfigPi0.C:103
 ConfigPi0.C:104
 ConfigPi0.C:105
 ConfigPi0.C:106
 ConfigPi0.C:107
 ConfigPi0.C:108
 ConfigPi0.C:109
 ConfigPi0.C:110
 ConfigPi0.C:111
 ConfigPi0.C:112
 ConfigPi0.C:113
 ConfigPi0.C:114
 ConfigPi0.C:115
 ConfigPi0.C:116
 ConfigPi0.C:117
 ConfigPi0.C:118
 ConfigPi0.C:119
 ConfigPi0.C:120
 ConfigPi0.C:121
 ConfigPi0.C:122
 ConfigPi0.C:123
 ConfigPi0.C:124
 ConfigPi0.C:125
 ConfigPi0.C:126
 ConfigPi0.C:127
 ConfigPi0.C:128
 ConfigPi0.C:129
 ConfigPi0.C:130
 ConfigPi0.C:131
 ConfigPi0.C:132
 ConfigPi0.C:133
 ConfigPi0.C:134
 ConfigPi0.C:135
 ConfigPi0.C:136
 ConfigPi0.C:137
 ConfigPi0.C:138
 ConfigPi0.C:139
 ConfigPi0.C:140
 ConfigPi0.C:141
 ConfigPi0.C:142
 ConfigPi0.C:143
 ConfigPi0.C:144
 ConfigPi0.C:145
 ConfigPi0.C:146
 ConfigPi0.C:147
 ConfigPi0.C:148
 ConfigPi0.C:149
 ConfigPi0.C:150
 ConfigPi0.C:151
 ConfigPi0.C:152
 ConfigPi0.C:153
 ConfigPi0.C:154
 ConfigPi0.C:155
 ConfigPi0.C:156
 ConfigPi0.C:157
 ConfigPi0.C:158
 ConfigPi0.C:159
 ConfigPi0.C:160
 ConfigPi0.C:161
 ConfigPi0.C:162
 ConfigPi0.C:163
 ConfigPi0.C:164
 ConfigPi0.C:165
 ConfigPi0.C:166
 ConfigPi0.C:167
 ConfigPi0.C:168
 ConfigPi0.C:169
 ConfigPi0.C:170
 ConfigPi0.C:171
 ConfigPi0.C:172
 ConfigPi0.C:173
 ConfigPi0.C:174
 ConfigPi0.C:175
 ConfigPi0.C:176
 ConfigPi0.C:177
 ConfigPi0.C:178
 ConfigPi0.C:179
 ConfigPi0.C:180
 ConfigPi0.C:181
 ConfigPi0.C:182
 ConfigPi0.C:183
 ConfigPi0.C:184
 ConfigPi0.C:185
 ConfigPi0.C:186
 ConfigPi0.C:187
 ConfigPi0.C:188
 ConfigPi0.C:189
 ConfigPi0.C:190
 ConfigPi0.C:191
 ConfigPi0.C:192
 ConfigPi0.C:193
 ConfigPi0.C:194
 ConfigPi0.C:195
 ConfigPi0.C:196
 ConfigPi0.C:197
 ConfigPi0.C:198
 ConfigPi0.C:199
 ConfigPi0.C:200
 ConfigPi0.C:201
 ConfigPi0.C:202
 ConfigPi0.C:203
 ConfigPi0.C:204
 ConfigPi0.C:205
 ConfigPi0.C:206
 ConfigPi0.C:207
 ConfigPi0.C:208
 ConfigPi0.C:209
 ConfigPi0.C:210
 ConfigPi0.C:211
 ConfigPi0.C:212
 ConfigPi0.C:213
 ConfigPi0.C:214
 ConfigPi0.C:215
 ConfigPi0.C:216
 ConfigPi0.C:217
 ConfigPi0.C:218
 ConfigPi0.C:219
 ConfigPi0.C:220
 ConfigPi0.C:221
 ConfigPi0.C:222
 ConfigPi0.C:223
 ConfigPi0.C:224
 ConfigPi0.C:225
 ConfigPi0.C:226
 ConfigPi0.C:227
 ConfigPi0.C:228
 ConfigPi0.C:229
 ConfigPi0.C:230
 ConfigPi0.C:231
 ConfigPi0.C:232
 ConfigPi0.C:233
 ConfigPi0.C:234
 ConfigPi0.C:235
 ConfigPi0.C:236
 ConfigPi0.C:237
 ConfigPi0.C:238
 ConfigPi0.C:239
 ConfigPi0.C:240
 ConfigPi0.C:241
 ConfigPi0.C:242
 ConfigPi0.C:243
 ConfigPi0.C:244
 ConfigPi0.C:245
 ConfigPi0.C:246
 ConfigPi0.C:247
 ConfigPi0.C:248
 ConfigPi0.C:249
 ConfigPi0.C:250
 ConfigPi0.C:251
 ConfigPi0.C:252
 ConfigPi0.C:253
 ConfigPi0.C:254
 ConfigPi0.C:255
 ConfigPi0.C:256
 ConfigPi0.C:257
 ConfigPi0.C:258
 ConfigPi0.C:259
 ConfigPi0.C:260
 ConfigPi0.C:261
 ConfigPi0.C:262
 ConfigPi0.C:263
 ConfigPi0.C:264
 ConfigPi0.C:265
 ConfigPi0.C:266
 ConfigPi0.C:267
 ConfigPi0.C:268
 ConfigPi0.C:269
 ConfigPi0.C:270
 ConfigPi0.C:271
 ConfigPi0.C:272
 ConfigPi0.C:273
 ConfigPi0.C:274
 ConfigPi0.C:275
 ConfigPi0.C:276
 ConfigPi0.C:277
 ConfigPi0.C:278
 ConfigPi0.C:279
 ConfigPi0.C:280
 ConfigPi0.C:281
 ConfigPi0.C:282
 ConfigPi0.C:283
 ConfigPi0.C:284
 ConfigPi0.C:285
 ConfigPi0.C:286
 ConfigPi0.C:287
 ConfigPi0.C:288
 ConfigPi0.C:289
 ConfigPi0.C:290
 ConfigPi0.C:291
 ConfigPi0.C:292
 ConfigPi0.C:293
 ConfigPi0.C:294
 ConfigPi0.C:295
 ConfigPi0.C:296
 ConfigPi0.C:297
 ConfigPi0.C:298
 ConfigPi0.C:299
 ConfigPi0.C:300
 ConfigPi0.C:301
 ConfigPi0.C:302
 ConfigPi0.C:303
 ConfigPi0.C:304
 ConfigPi0.C:305
 ConfigPi0.C:306
 ConfigPi0.C:307
 ConfigPi0.C:308
 ConfigPi0.C:309
 ConfigPi0.C:310
 ConfigPi0.C:311
 ConfigPi0.C:312
 ConfigPi0.C:313
 ConfigPi0.C:314
 ConfigPi0.C:315
 ConfigPi0.C:316
 ConfigPi0.C:317
 ConfigPi0.C:318
 ConfigPi0.C:319
 ConfigPi0.C:320
 ConfigPi0.C:321
 ConfigPi0.C:322
 ConfigPi0.C:323
 ConfigPi0.C:324
 ConfigPi0.C:325
 ConfigPi0.C:326
 ConfigPi0.C:327
 ConfigPi0.C:328
 ConfigPi0.C:329
 ConfigPi0.C:330
 ConfigPi0.C:331
 ConfigPi0.C:332
 ConfigPi0.C:333
 ConfigPi0.C:334
 ConfigPi0.C:335
 ConfigPi0.C:336
 ConfigPi0.C:337
 ConfigPi0.C:338
 ConfigPi0.C:339
 ConfigPi0.C:340
 ConfigPi0.C:341
 ConfigPi0.C:342
 ConfigPi0.C:343
 ConfigPi0.C:344
 ConfigPi0.C:345
 ConfigPi0.C:346
 ConfigPi0.C:347
 ConfigPi0.C:348
 ConfigPi0.C:349
 ConfigPi0.C:350
 ConfigPi0.C:351
 ConfigPi0.C:352
 ConfigPi0.C:353
 ConfigPi0.C:354
 ConfigPi0.C:355
 ConfigPi0.C:356
 ConfigPi0.C:357
 ConfigPi0.C:358
 ConfigPi0.C:359
 ConfigPi0.C:360
 ConfigPi0.C:361
 ConfigPi0.C:362
 ConfigPi0.C:363
 ConfigPi0.C:364
 ConfigPi0.C:365
 ConfigPi0.C:366
 ConfigPi0.C:367
 ConfigPi0.C:368
 ConfigPi0.C:369
 ConfigPi0.C:370
 ConfigPi0.C:371
 ConfigPi0.C:372
 ConfigPi0.C:373
 ConfigPi0.C:374
 ConfigPi0.C:375
 ConfigPi0.C:376
 ConfigPi0.C:377
 ConfigPi0.C:378
 ConfigPi0.C:379
 ConfigPi0.C:380