Hello,
I am working on Garfield and Geant4 Interface. I am defining a bunch of Air Cylinders enclosed in a slab of PlexiGlass. I am adding the logicVolume of the Air Cylinders as the RootLogicalVolume, and looping over the physical volume of the air cylinders to write it to the GDML file. The problem is when I do this, the initial positions that GarfieldPhysics gets from the DoIt() function are very wrong. When I simplify the geometry to let’s say a slab of air, it works perfectly and it takes the correct initial coordinates. What I want is for the code to not consider any protons that pass through the PlexiGlass. I can do that in the GarfieldPhysics class where I define initial SolidTube but I’d rather figure out how to add the appropriate G4LogicalVolume and G4PVPlacement to regionGarfield and GarfieldG4FastSimulationModel so it can know the right geometry.
Here is the part of the code for DetectorConstruction. If there is no proper way to point correctly to the Cylinders and ignore the PlexiGlass, I’ll just create SolidTube in GarfieldPhysics. I have attached a picture of the geometry. The Cylinders are the active region.
G4Material* shape2_mat = nist->FindOrBuildMaterial("G4_PLEXIGLASS");
G4ThreeVector pos2 = G4ThreeVector(0, 0, 0);
// Trapezoid shape
G4double shape2_XY = 0.5* 5.2*cm;
G4double shape2_Z =0.5*2*mm;
G4Box* solidShape2 = new G4Box("Shape2", shape2_XY,shape2_Z,shape2_XY);
auto logicShape2 = new G4LogicalVolume(solidShape2, // its solid
shape2_mat, // its material
"Shape2"); // its name
auto physShape2 = new G4PVPlacement(nullptr, // no rotation
pos2, // at position
logicShape2, // its logical volume
"Shape2", // its name
logicEnv, // its mother volume
false, // no boolean operation
1, // copy number
checkOverlaps); // overlaps checking
G4double nbTubes = 8;
G4double width = 0.65;
G4cout << "The width is: " << width << G4endl;
G4Material* air = nist->FindOrBuildMaterial("G4_AIR");
G4double innerRadius = 0.0*cm ;
G4double outerRadius = 0.25*0.65 *cm;
G4double hz = 0.5 * 0.8 * cm;
G4double startAngle = 0.0 * deg;
G4double spanningAngle = 360.0 * deg;
G4Tubs* airCylinder = new G4Tubs("AirCylinder",
innerRadius,
outerRadius,
0.11*cm,
startAngle,
spanningAngle);
auto logicCylinder = new G4LogicalVolume(airCylinder,air,"AirCylinder");
G4RotationMatrix* rotm = new G4RotationMatrix();
rotm->rotateX(-90*deg);
std::vector<G4PVPlacement*> physCylinders;
for (int j=0; j<nbTubes; j++) {
for (int i=0; i<nbTubes; i++) {
auto physCylinder = new G4PVPlacement(rotm,
G4ThreeVector((-2.6+width/2.0 + i*width)*cm,
0,(-2.6+width/2.0+ j*width)*cm),
logicCylinder,
"AirCylinder",
logicShape2,
false,
j+i*nbTubes,
checkOverlaps);
physCylinders.push_back(physCylinder);
}
}
G4Region* regionGarfield = new G4Region("RegionGarfield");
regionGarfield->AddRootLogicalVolume(logicCylinder);
fGarfieldG4FastSimulationModel = new GarfieldG4FastSimulationModel(
"GarfieldG4FastSimulationModel", regionGarfield);
for (auto& physCylinder : physCylinders) {
fGarfieldG4FastSimulationModel->WriteGeometryToGDML(physCylinder);
}