61 fAngle[1] = CLHEP::twopi * rad;
69 G4cout <<
"G4VScoringMesh::ResetScore() is called." <<
G4endl;
70 for(
const auto& mp :
fMap)
73 G4cout <<
"G4VScoringMesh::ResetScore()" << mp.first <<
G4endl;
83 for(
G4int i = 0; i < 3; ++i)
90 G4String message =
" Mesh size has already been set and it cannot be changed.\n";
91 message +=
" This method is ignored.";
93 "DigiHitsUtilsScoreVScoringMesh000",
JustWarning, message);
113 G4ThreeVector(centerPosition[0], centerPosition[1], centerPosition[2]);
121 for(
G4int i = 0; i < 3; ++i)
127 G4String message =
" Number of bins has already been set and it cannot be changed.\n";
128 message +=
" This method is ignored.";
129 G4Exception(
"G4VScoringMesh::SetNumberOfSegments()",
130 "DigiHitsUtilsScoreVScoringMesh000",
JustWarning, message);
136 for(
G4int i = 0; i < 3; ++i)
165 G4cerr <<
"ERROR : G4VScoringMesh::SetPrimitiveScorer() : "
167 <<
" does not yet have mesh size or number of bins. Set them first."
172 G4cout <<
"G4VScoringMesh::SetPrimitiveScorer() : " << prs->
GetName()
179 fMFD->RegisterPrimitive(prs);
189 G4cerr <<
"ERROR : G4VScoringMesh::SetSDFilter() : a quantity must be "
190 "defined first. This method is ignored."
195 G4cout <<
"G4VScoringMesh::SetFilter() : " << filter->
GetName()
199 if(oldFilter !=
nullptr)
201 G4cout <<
"WARNING : G4VScoringMesh::SetFilter() : " << oldFilter->
GetName()
212 G4cerr <<
"ERROR : G4VScoringMesh::SetCurrentPrimitiveScorer() : The "
214 << name <<
"> does not found." <<
G4endl;
220 const auto itr =
fMap.find(psname);
221 return itr !=
fMap.cend();
226 const auto itr =
fMap.find(psname);
227 if(itr ==
fMap.cend())
240 G4String msg =
"ERROR : G4VScoringMesh::GetCurrentPSUnit() : ";
241 msg +=
" Current primitive scorer is null.";
255 G4String msg =
"ERROR : G4VScoringMesh::GetCurrentPSUnit() : ";
256 msg +=
" Current primitive scorer is null.";
267 const auto itr =
fMap.find(psname);
268 if(itr ==
fMap.cend())
278 for(
G4int i = 0; i < 3; ++i)
287 G4int nps =
fMFD->GetNumberOfPrimitives();
288 for(
G4int i = 0; i < nps; ++i)
316 G4int nps =
fMFD->GetNumberOfPrimitives();
318 for(
G4int i = 0; i < nps; ++i)
320 prs =
fMFD->GetPrimitive(i);
332 for(
const auto& mp :
fMap)
335 mp.second->PrintAllHits();
344 const auto fMapItr =
fMap.find(psName);
345 if(fMapItr !=
fMap.cend())
349 Draw(fMapItr->second, colorMap, axflg);
353 G4cerr <<
"Scorer <" << psName <<
"> is not defined. Method ignored."
362 const auto fMapItr =
fMap.find(psName);
363 if(fMapItr !=
fMap.cend())
367 DrawColumn(fMapItr->second, colorMap, idxPlane, iColumn);
371 G4cerr <<
"Scorer <" << psName <<
"> is not defined. Method ignored."
379 const auto fMapItr =
fMap.find(psName);
380 if (fMapItr !=
fMap.cend()) { *(fMapItr->second) += *
map; }
387 if(fMapItr ==
fMap.cend())
403 const auto fMapItr =
fMap.find(psName);
404 if (fMapItr !=
fMap.cend()) { *(fMapItr->second) += *
map; }
411 if(fMapItr ==
fMap.cend())
455 G4cout << fWorldPhys->
GetName() <<
" --- All quantities are reset."
470 auto fMapItr =
fMap.cbegin();
471 auto mapItr = scMap.cbegin();
472 for(; fMapItr !=
fMap.cend(); ++fMapItr)
475 G4cout <<
"G4VScoringMesh::Merge()" << fMapItr->first <<
G4endl;
476 *(fMapItr->second) += *(mapItr->second);
void G4Exception(const char *originOfException, const char *exceptionCode, G4ExceptionSeverity severity, const char *description)
CLHEP::HepRotation G4RotationMatrix
CLHEP::Hep3Vector G4ThreeVector
G4GLOB_DLL std::ostream G4cerr
G4GLOB_DLL std::ostream G4cout
static G4SDManager * GetSDMpointer()
void AddNewDetector(G4VSensitiveDetector *aSD)
const G4String & GetName() const
G4VSDFilter * GetFilter() const
const G4String & GetName() const
void SetNijk(G4int i, G4int j, G4int k)
const G4String & GetUnit() const
G4double GetUnitValue() const
const G4String & GetName() const
void SetFilter(G4VSDFilter *filter)
G4bool ReadyForQuantity() const
G4RotationMatrix * fRotationMatrix
G4ThreeVector GetSize() const
virtual void SetupGeometry(G4VPhysicalVolume *fWorldPhys)=0
virtual void List() const
virtual void WorkerConstruct(G4VPhysicalVolume *fWorldPhys)
G4bool fGeometryHasBeenDestroyed
void RotateY(G4double delta)
void GetNumberOfSegments(G4int nSegment[3])
G4double GetPSUnitValue(const G4String &psname)
G4String GetPSUnit(const G4String &psname)
void SetAngles(G4double, G4double)
void SetCurrentPSUnit(const G4String &unit)
G4MultiFunctionalDetector * fMFD
void SetCurrentPrimitiveScorer(const G4String &name)
G4String fDivisionAxisNames[3]
G4LogicalVolume * fMeshElementLogical
void SetPrimitiveScorer(G4VPrimitiveScorer *ps)
std::map< G4String, RunScore * > MeshScoreMap
G4VPrimitiveScorer * fCurrentPS
G4String GetCurrentPSUnit()
void GetDivisionAxisNames(G4String divisionAxisNames[3])
void DrawMesh(const G4String &psName, G4VScoreColorMap *colorMap, G4int axflg=111)
void Accumulate(G4THitsMap< G4double > *map)
void SetNumberOfSegments(G4int nSegment[3])
G4VScoringMesh(const G4String &wName)
G4ParallelWorldProcess * fParallelWorldProcess
MeshScoreMap GetScoreMap() const
void Merge(const G4VScoringMesh *scMesh)
virtual void Draw(RunScore *map, G4VScoreColorMap *colorMap, G4int axflg=111)=0
void SetCenterPosition(G4double centerPosition[3])
void RotateX(G4double delta)
virtual void Construct(G4VPhysicalVolume *fWorldPhys)
void SetSize(G4double size[3])
virtual void DrawColumn(RunScore *map, G4VScoreColorMap *colorMap, G4int idxProj, G4int idxColumn)=0
G4bool FindPrimitiveScorer(const G4String &psname)
void RotateZ(G4double delta)
G4VPrimitiveScorer * GetPrimitiveScorer(const G4String &name)
G4ThreeVector fCenterPosition