70 G4cout <<
"G4ScoringCylinder::SetupGeometry() ..." <<
G4endl;
94 tubsName +
"0", worldLogical,
false, 0);
100 G4String layerName[2] = { tubsName +
"1", tubsName +
"2" };
107 layerSolid[0] =
new G4Tubs(layerName[0],
113 layerLogical[0] =
new G4LogicalVolume(layerSolid[0],
nullptr, layerName[0]);
117 G4cout <<
"G4ScoringCylinder::Construct() : Replicate along z direction"
122 G4cout <<
"G4ScoringCylinder::Construct() : Replica" <<
G4endl;
129 G4cout <<
"G4ScoringCylinder::Construct() : Division" <<
G4endl;
137 G4cout <<
"G4ScoringCylinder::Construct() : Placement" <<
G4endl;
139 layerName[0], tubsLogical,
false, 0);
143 G4cerr <<
"G4ScoringCylinder::SetupGeometry() : invalid parameter ("
145 <<
"in placement of the first nested layer." <<
G4endl;
154 layerLogical[1] =
new G4LogicalVolume(layerSolid[1],
nullptr, layerName[1]);
158 G4cout <<
"G4ScoringCylinder::Construct() : Replicate along phi direction"
163 G4cout <<
"G4ScoringCylinder::Construct() : Replica" <<
G4endl;
170 G4cout <<
"G4ScoringCylinder::Construct() : Division" <<
G4endl;
178 G4cout <<
"G4ScoringCylinder::Construct() : Placement" <<
G4endl;
180 layerName[1], layerLogical[0],
false, 0);
183 G4cerr <<
"ERROR : G4ScoringCylinder::SetupGeometry() : invalid parameter ("
185 <<
"in placement of the second nested layer." <<
G4endl;
190 G4String elementName = tubsName +
"3";
198 G4cout <<
"G4ScoringCylinder::Construct() : Replicate along r direction"
204 G4cout <<
"G4ScoringCylinder::Construct() : Replica" <<
G4endl;
212 G4cout <<
"G4ScoringCylinder::Construct() : Division" <<
G4endl;
219 G4cerr <<
"G4ScoringCylinder::SetupGeometry() : "
220 <<
"invalid parameter (" <<
fNSegment[IR] <<
") "
221 <<
"in mesh element placement." <<
G4endl;
229 visatt->SetVisibility(
true);
243 <<
" --- Shape: Cylindrical mesh" <<
G4endl;
245 G4cout <<
" Size (Rmin, Rmax, Dz): (" <<
fSize[0] / cm <<
", "
247 G4cout <<
" Angle (start, span): (" <<
fAngle[0] / deg <<
", "
257 if(pVisManager !=
nullptr)
260 std::vector<G4double> ephi;
264 std::vector<std::vector<G4double>> zphicell;
266 zphicell.push_back(ephi);
268 std::vector<std::vector<G4double>> rphicell;
270 rphicell.push_back(ephi);
274 auto itr =
map->GetMap()->begin();
275 for(; itr !=
map->GetMap()->end(); itr++)
284 zphicell[q[IZ]][q[IPHI]] += (itr->second->sum_wx()) /
fDrawUnitValue;
285 rphicell[q[IR]][q[IPHI]] += (itr->second->sum_wx()) /
fDrawUnitValue;
290 G4double zphimax = 0., rphimax = 0.;
295 if(zphimin > zphicell[iz][iphi])
296 zphimin = zphicell[iz][iphi];
297 if(zphimax < zphicell[iz][iphi])
298 zphimax = zphicell[iz][iphi];
302 if(rphimin > rphicell[ir][iphi])
303 rphimin = rphicell[ir][iphi];
304 if(rphimax < rphicell[ir][iphi])
305 rphimax = rphicell[ir][iphi];
341 angle, dphi * 0.99999);
363 pVisManager->
Draw(*poly);
387 G4Tubs cylindern(
"z-phi", rs[0], rs[1], 0.001, angle, dphi * 0.99999);
388 G4Tubs cylinderp = cylindern;
414 pVisManager->
Draw(*polyn);
419 pVisManager->
Draw(*polyp);
449 if(idxColumn < 0 || idxColumn >=
fNSegment[projAxis])
451 G4cerr <<
"Warning : Column number " << idxColumn
452 <<
" is out of scoring mesh [0," <<
fNSegment[projAxis] - 1
453 <<
"]. Method ignored." <<
G4endl;
457 if(pVisManager !=
nullptr)
460 std::vector<std::vector<std::vector<G4double>>> cell;
461 std::vector<G4double> ephi;
464 std::vector<std::vector<G4double>> ezphi;
466 ezphi.push_back(ephi);
468 cell.push_back(ezphi);
470 std::vector<std::vector<G4double>> rzcell;
471 std::vector<G4double> ez;
475 rzcell.push_back(ez);
477 std::vector<std::vector<G4double>> zphicell;
479 zphicell.push_back(ephi);
481 std::vector<std::vector<G4double>> rphicell;
483 rphicell.push_back(ephi);
487 auto itr =
map->GetMap()->begin();
488 for(; itr !=
map->GetMap()->end(); itr++)
497 if(projAxis == IR && q[IR] == idxColumn)
499 zphicell[q[IZ]][q[IPHI]] += (itr->second->sum_wx()) /
fDrawUnitValue;
501 if(projAxis == IZ && q[IZ] == idxColumn)
503 rphicell[q[IR]][q[IPHI]] += (itr->second->sum_wx()) /
fDrawUnitValue;
505 if(projAxis == IPHI && q[IPHI] == idxColumn)
513 G4double rzmax = 0., zphimax = 0., rphimax = 0.;
518 if(rphimin > rphicell[r][phi])
519 rphimin = rphicell[r][phi];
520 if(rphimax < rphicell[r][phi])
521 rphimax = rphicell[r][phi];
525 if(rzmin > rzcell[r][z])
526 rzmin = rzcell[r][z];
527 if(rzmax < rzcell[r][z])
528 rzmax = rzcell[r][z];
535 if(zphimin > zphicell[z][phi])
536 zphimin = zphicell[z][phi];
537 if(zphimax < zphicell[z][phi])
538 zphimax = zphicell[z][phi];
562 for(
int phi = 0; phi <
fNSegment[IPHI]; phi++)
591 pVisManager->
Draw(*poly);
597 else if(projAxis == IZ)
613 G4Tubs cylinder(
"r-phi", rs[0], rs[1], dz, angle, dphi * 0.99999);
634 pVisManager->
Draw(*poly);
640 else if(projAxis == IPHI)
678 pVisManager->
Draw(*poly);
700 q[j] = (index - q[i] * jk) /
fNSegment[k];
701 q[k] = index - q[j] *
fNSegment[k] - q[i] * jk;
704void G4ScoringCylinder::DumpVolumes()
712void G4ScoringCylinder::DumpSolids(
G4int lvl)
714 G4cout <<
"*********** List of registered solids *************" <<
G4endl;
716 auto itr = store->begin();
717 for(; itr != store->end(); itr++)
725 G4cout << (*itr)->GetName() <<
"\t volume = "
726 <<
G4BestUnit((*itr)->GetCubicVolume(),
"Volume")
737void G4ScoringCylinder::DumpLogVols(
G4int lvl)
739 G4cout <<
"*********** List of registered logical volumes *************"
742 auto itr = store->begin();
743 for(; itr != store->end(); itr++)
745 G4cout << (*itr)->GetName()
746 <<
"\t Solid = " << (*itr)->GetSolid()->GetName();
747 if((*itr)->GetMaterial() !=
nullptr)
749 G4cout <<
"\t Material = " << (*itr)->GetMaterial()->GetName() <<
G4endl;
758 if((*itr)->GetRegion() !=
nullptr)
760 G4cout << (*itr)->GetRegion()->GetName();
766 G4cout <<
"\t sensitive detector = ";
767 if((*itr)->GetSensitiveDetector() !=
nullptr)
769 G4cout << (*itr)->GetSensitiveDetector()->GetName();
776 G4cout <<
"\t daughters = " << (*itr)->GetNoDaughters();
777 if((*itr)->GetNoDaughters() > 0)
779 switch((*itr)->CharacteriseDaughters())
785 G4cout <<
" (replica : " << (*itr)->GetDaughter(0)->GetMultiplicity()
789 G4cout <<
" (parameterized : "
790 << (*itr)->GetDaughter(0)->GetMultiplicity() <<
")";
798 if((*itr)->GetMaterial() !=
nullptr)
810void G4ScoringCylinder::DumpPhysVols(
G4int lvl)
812 G4cout <<
"*********** List of registered physical volumes *************"
815 auto itr = store->begin();
816 for(; itr != store->end(); itr++)
824 G4cout << (*itr)->GetName() <<
"\t logical volume = "
825 << (*itr)->GetLogicalVolume()->GetName()
826 <<
"\t mother logical = ";
827 if((*itr)->GetMotherLogical() !=
nullptr)
829 G4cout << (*itr)->GetMotherLogical()->GetName();
838 G4cout << (*itr)->GetName() <<
"\t logical volume = "
839 << (*itr)->GetLogicalVolume()->GetName()
840 <<
"\t mother logical = ";
841 if((*itr)->GetMotherLogical() !=
nullptr)
843 G4cout << (*itr)->GetMotherLogical()->GetName();
850 switch((*itr)->VolumeType())
859 G4cout <<
"parameterized";
CLHEP::Hep3Vector G4ThreeVector
G4GLOB_DLL std::ostream G4cerr
G4GLOB_DLL std::ostream G4cout
G4Polyhedron * GetPolyhedron() const override
static G4LogicalVolumeStore * GetInstance()
void SetVisAttributes(const G4VisAttributes *pVA)
static G4PhysicalVolumeStore * GetInstance()
void GetRZPhi(G4int index, G4int q[3]) const
void SetupGeometry(G4VPhysicalVolume *fWorldPhys) override
void Draw(RunScore *map, G4VScoreColorMap *colorMap, G4int axflg=111) override
void List() const override
G4ScoringCylinder(const G4String &wName)
void DrawColumn(RunScore *map, G4VScoreColorMap *colorMap, G4int idxProj, G4int idxColumn) override
static G4int GetReplicaLevel()
static G4SolidStore * GetInstance()
G4LogicalVolume * GetLogicalVolume() const
virtual void DrawColorChart(G4int nPoint=5)
G4bool IfFloatMinMax() const
void SetPSName(const G4String &psName)
void SetMinMax(G4double minVal, G4double maxVal)
virtual void GetMapColor(G4double val, G4double color[4])=0
void SetPSUnit(const G4String &unit)
G4THitsMap< G4StatDouble > RunScore
G4RotationMatrix * fRotationMatrix
virtual void List() const
G4MultiFunctionalDetector * fMFD
G4String fDivisionAxisNames[3]
G4LogicalVolume * fMeshElementLogical
G4VScoringMesh(const G4String &wName)
G4ThreeVector fCenterPosition
static G4VVisManager * GetConcreteInstance()
virtual void Draw(const G4Circle &, const G4Transform3D &objectTransformation=G4Transform3D())=0
virtual void BeginDraw(const G4Transform3D &objectTransformation=G4Transform3D())=0
void SetColour(const G4Colour &)
void SetForceAuxEdgeVisible(G4bool=true)
void SetForceSolid(G4bool=true)
void SetVisAttributes(const G4VisAttributes *)
HepPolyhedron & Transform(const G4Transform3D &t)