EIC Software
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Macros Groups Pages
lqst.C
Go to the documentation of this file. Or view the newest version in sPHENIX GitHub for file lqst.C
1 
2 void lqst()
3 {
4  gROOT->Macro("$VMCWORKDIR/gconfig/rootlogon.C");
5 
6  EicGeoParData *lqst = new EicGeoParData("LQST", 0, 0);
7  lqst->SetFileName("lqst.root");
8 
9  UInt_t waferNum = 2;
10  Double_t waferThickness = 0.3;
11  // Just very large rectangular pieces of silicon;
12  Double_t waferWidth = 1200.0;
13  Double_t waferHeight = 1000.0;
14  Double_t waferSpacing = 200.0;
15  // Move roughly to the beam line axis;
16  Double_t beamLineOffsetX = 0.0;
17  Double_t beamLineOffsetZ = -28000.0;
18 
19  // Silicon wafer;
20  TGeoBBox *wafer = new TGeoBBox("LqstSiliconWafer",
21  0.1 * waferWidth/2,
22  0.1 * waferHeight/2,
23  0.1 * waferThickness/2);
24  TGeoVolume *vwafer = new TGeoVolume("LqstSiliconWafer", wafer, lqst->GetMedium("silicon"));
25 
26  EicGeoMap *fgmap = lqst->CreateNewMap();
27  fgmap->AddGeantVolumeLevel("LqstSiliconWafer", waferNum);
28  fgmap->SetSingleSensorContainerVolume("LqstSiliconWafer");
29 
30  lqst->AddLogicalVolumeGroup(0, 0, waferNum);
31 
32  // And place all wafers into the container volume;
33  for(unsigned wf=0; wf<waferNum; wf++)
34  {
35  double offset = 0.1 * (wf - (waferNum-1)/2.)*waferSpacing;
36 
37  UInt_t geant[1] = {wf}, group = 0, logical[3] = {0, 0, wf};
38 
39  if (lqst->SetMappingTableEntry(fgmap, geant, group, logical)) {
40  cout << "Failed to set mapping table entry!" << endl;
41  exit(0);
42  } //if
43 
44  lqst->GetTopVolume()->AddNode(vwafer, wf, new TGeoCombiTrans(0.1 * beamLineOffsetX, 0.0, offset + 0.1 * beamLineOffsetZ, 0));
45  } // for wf
46 
47  lqst->GetColorTable()->AddPatternMatch ("Silicon", kYellow);
48  lqst->GetTransparencyTable()->AddPatternMatch("Silicon", 50);
49 
50  lqst->FinalizeOutput();
51 
52  exit(0);
53 } // lqst()
54