Geant4 11.3.0
Toolkit for the simulation of the passage of particles through matter
Loading...
Searching...
No Matches
G4ScoringCylinder.cc
Go to the documentation of this file.
1//
2// ********************************************************************
3// * License and Disclaimer *
4// * *
5// * The Geant4 software is copyright of the Copyright Holders of *
6// * the Geant4 Collaboration. It is provided under the terms and *
7// * conditions of the Geant4 Software License, included in the file *
8// * LICENSE and available at http://cern.ch/geant4/license . These *
9// * include a list of copyright holders. *
10// * *
11// * Neither the authors of this software system, nor their employing *
12// * institutes,nor the agencies providing financial support for this *
13// * work make any representation or warranty, express or implied, *
14// * regarding this software system or assume any liability for its *
15// * use. Please see the license in the file LICENSE and URL above *
16// * for the full disclaimer and the limitation of liability. *
17// * *
18// * This code implementation is the result of the scientific and *
19// * technical work of the GEANT4 collaboration. *
20// * By using, copying, modifying or distributing the software (or *
21// * any work based on the software) you agree to acknowledge its *
22// * use in resulting scientific publications, and indicate your *
23// * acceptance of all terms of the Geant4 Software license. *
24// ********************************************************************
25//
26// G4ScoringCylinder
27// --------------------------------------------------------------------
28
29#include "G4ScoringCylinder.hh"
30
31#include "G4LogicalVolume.hh"
33#include "G4PVDivision.hh"
34#include "G4PVPlacement.hh"
35#include "G4PVReplica.hh"
37#include "G4SDManager.hh"
38#include "G4ScoringManager.hh"
39#include "G4StatDouble.hh"
40#include "G4SystemOfUnits.hh"
41#include "G4Tubs.hh"
42#include "G4VPhysicalVolume.hh"
43#include "G4VPrimitiveScorer.hh"
44#include "G4VScoreColorMap.hh"
45#include "G4VVisManager.hh"
46#include "G4VisAttributes.hh"
47
49#include "G4Material.hh"
51#include "G4SolidStore.hh"
52#include "G4UnitsTable.hh"
54#include "G4VSolid.hh"
55
56
66
68{
69 if(verboseLevel > 9)
70 G4cout << "G4ScoringCylinder::SetupGeometry() ..." << G4endl;
71
72 // World
73 G4VPhysicalVolume* scoringWorld = fWorldPhys;
74 G4LogicalVolume* worldLogical = scoringWorld->GetLogicalVolume();
75
76 // Scoring Mesh
77 if(verboseLevel > 9)
79 G4String tubsName = fWorldName + "_mesh";
80
81 if(verboseLevel > 9)
82 {
83 G4cout << "R min, R max., Dz =: " << fSize[0] << ", " << fSize[1]
84 << ", " << fSize[2] << G4endl;
85 }
86 G4VSolid* tubsSolid = new G4Tubs(tubsName + "0", // name
87 fSize[0], // R min
88 fSize[1], // R max
89 fSize[2], // Dz
90 fAngle[0], // starting phi
91 fAngle[1]); // segment phi
92 auto tubsLogical = new G4LogicalVolume(tubsSolid, nullptr, tubsName);
94 tubsName + "0", worldLogical, false, 0);
95
96 if(verboseLevel > 9)
97 G4cout << " # of segments : r, phi, z =: " << fNSegment[IR] << ", "
98 << fNSegment[IPHI] << ", " << fNSegment[IZ] << G4endl;
99
100 G4String layerName[2] = { tubsName + "1", tubsName + "2" };
101 G4VSolid* layerSolid[2];
102 G4LogicalVolume* layerLogical[2];
103
104 //-- fisrt nested layer (replicated along z direction)
105 if(verboseLevel > 9)
106 G4cout << "layer 1 :" << G4endl;
107 layerSolid[0] = new G4Tubs(layerName[0], // name
108 fSize[0], // inner radius
109 fSize[1], // outer radius
110 fSize[2] / fNSegment[IZ], // half len. in z
111 fAngle[0], // starting phi angle
112 fAngle[1]); // delta angle of the segment
113 layerLogical[0] = new G4LogicalVolume(layerSolid[0], nullptr, layerName[0]);
114 if(fNSegment[IZ] > 1)
115 {
116 if(verboseLevel > 9)
117 G4cout << "G4ScoringCylinder::Construct() : Replicate along z direction"
118 << G4endl;
120 {
121 if(verboseLevel > 9)
122 G4cout << "G4ScoringCylinder::Construct() : Replica" << G4endl;
123 new G4PVReplica(layerName[0], layerLogical[0], tubsLogical, kZAxis,
124 fNSegment[IZ], 2. * fSize[2] / fNSegment[IZ]);
125 }
126 else
127 {
128 if(verboseLevel > 9)
129 G4cout << "G4ScoringCylinder::Construct() : Division" << G4endl;
130 new G4PVDivision(layerName[0], layerLogical[0], tubsLogical, kZAxis,
131 fNSegment[IZ], 0.);
132 }
133 }
134 else if(fNSegment[IZ] == 1)
135 {
136 if(verboseLevel > 9)
137 G4cout << "G4ScoringCylinder::Construct() : Placement" << G4endl;
138 new G4PVPlacement(nullptr, G4ThreeVector(0., 0., 0.), layerLogical[0],
139 layerName[0], tubsLogical, false, 0);
140 }
141 else
142 {
143 G4cerr << "G4ScoringCylinder::SetupGeometry() : invalid parameter ("
144 << fNSegment[IZ] << ") "
145 << "in placement of the first nested layer." << G4endl;
146 }
147
148 // second nested layer (replicated along phi direction)
149 if(verboseLevel > 9)
150 G4cout << "layer 2 :" << G4endl;
151 layerSolid[1] =
152 new G4Tubs(layerName[1], fSize[0], fSize[1], fSize[2] / fNSegment[IZ],
153 fAngle[0], fAngle[1] / fNSegment[IPHI]);
154 layerLogical[1] = new G4LogicalVolume(layerSolid[1], nullptr, layerName[1]);
155 if(fNSegment[IPHI] > 1)
156 {
157 if(verboseLevel > 9)
158 G4cout << "G4ScoringCylinder::Construct() : Replicate along phi direction"
159 << G4endl;
161 {
162 if(verboseLevel > 9)
163 G4cout << "G4ScoringCylinder::Construct() : Replica" << G4endl;
164 new G4PVReplica(layerName[1], layerLogical[1], layerLogical[0], kPhi,
165 fNSegment[IPHI], fAngle[1] / fNSegment[IPHI], fAngle[0]);
166 }
167 else
168 {
169 if(verboseLevel > 9)
170 G4cout << "G4ScoringCylinder::Construct() : Division" << G4endl;
171 new G4PVDivision(layerName[1], layerLogical[1], layerLogical[0], kPhi,
172 fNSegment[IPHI], 0.);
173 }
174 }
175 else if(fNSegment[IPHI] == 1)
176 {
177 if(verboseLevel > 9)
178 G4cout << "G4ScoringCylinder::Construct() : Placement" << G4endl;
179 new G4PVPlacement(nullptr, G4ThreeVector(0., 0., 0.), layerLogical[1],
180 layerName[1], layerLogical[0], false, 0);
181 }
182 else
183 G4cerr << "ERROR : G4ScoringCylinder::SetupGeometry() : invalid parameter ("
184 << fNSegment[IPHI] << ") "
185 << "in placement of the second nested layer." << G4endl;
186
187 // mesh elements
188 if(verboseLevel > 9)
189 G4cout << "mesh elements :" << G4endl;
190 G4String elementName = tubsName + "3";
191 G4VSolid* elementSolid = new G4Tubs(
192 elementName, fSize[0], (fSize[1] - fSize[0]) / fNSegment[IR] + fSize[0],
193 fSize[2] / fNSegment[IZ], fAngle[0], fAngle[1] / fNSegment[IPHI]);
194 fMeshElementLogical = new G4LogicalVolume(elementSolid, nullptr, elementName);
195 if(fNSegment[IR] >= 1)
196 {
197 if(verboseLevel > 9)
198 G4cout << "G4ScoringCylinder::Construct() : Replicate along r direction"
199 << G4endl;
200
202 {
203 if(verboseLevel > 9)
204 G4cout << "G4ScoringCylinder::Construct() : Replica" << G4endl;
205 new G4PVReplica(elementName, fMeshElementLogical, layerLogical[1], kRho,
206 fNSegment[IR], (fSize[1] - fSize[0]) / fNSegment[IR],
207 fSize[0]);
208 }
209 else
210 {
211 if(verboseLevel > 9)
212 G4cout << "G4ScoringCylinder::Construct() : Division" << G4endl;
213 new G4PVDivision(elementName, fMeshElementLogical, layerLogical[1], kRho,
214 fNSegment[IR], 0.);
215 }
216 }
217 else
218 {
219 G4cerr << "G4ScoringCylinder::SetupGeometry() : "
220 << "invalid parameter (" << fNSegment[IR] << ") "
221 << "in mesh element placement." << G4endl;
222 }
223
224 // set the sensitive detector
225 fMeshElementLogical->SetSensitiveDetector(fMFD);
226
227 // vis. attributes
228 auto visatt = new G4VisAttributes(G4Colour(.5, .5, .5));
229 visatt->SetVisibility(true);
230 layerLogical[0]->SetVisAttributes(visatt);
231 layerLogical[1]->SetVisAttributes(visatt);
232 visatt = new G4VisAttributes(G4Colour(.5, .5, .5, 0.01));
233 // visatt->SetForceSolid(true);
234 fMeshElementLogical->SetVisAttributes(visatt);
235
236 if(verboseLevel > 9)
237 DumpVolumes();
238}
239
241{
242 G4cout << "G4ScoringCylinder : " << fWorldName
243 << " --- Shape: Cylindrical mesh" << G4endl;
244
245 G4cout << " Size (Rmin, Rmax, Dz): (" << fSize[0] / cm << ", "
246 << fSize[1] / cm << ", " << fSize[2] / cm << ") [cm]" << G4endl;
247 G4cout << " Angle (start, span): (" << fAngle[0] / deg << ", "
248 << fAngle[1] / deg << ") [deg]" << G4endl;
249
251}
252
254 G4int axflg)
255{
257 if(pVisManager != nullptr)
258 {
259 // cell vectors
260 std::vector<G4double> ephi;
261 for(G4int phi = 0; phi < fNSegment[IPHI]; phi++)
262 ephi.push_back(0.);
263 //-
264 std::vector<std::vector<G4double>> zphicell; // zphicell[Z][PHI]
265 for(G4int z = 0; z < fNSegment[IZ]; z++)
266 zphicell.push_back(ephi);
267 //-
268 std::vector<std::vector<G4double>> rphicell; // rphicell[R][PHI]
269 for(G4int r = 0; r < fNSegment[IR]; r++)
270 rphicell.push_back(ephi);
271
272 // projections
273 G4int q[3];
274 auto itr = map->GetMap()->begin();
275 for(; itr != map->GetMap()->end(); itr++)
276 {
277 if(itr->first < 0)
278 {
279 G4cout << itr->first << G4endl;
280 continue;
281 }
282 GetRZPhi(itr->first, q);
283
284 zphicell[q[IZ]][q[IPHI]] += (itr->second->sum_wx()) / fDrawUnitValue;
285 rphicell[q[IR]][q[IPHI]] += (itr->second->sum_wx()) / fDrawUnitValue;
286 }
287
288 // search min./max. values
289 G4double zphimin = DBL_MAX, rphimin = DBL_MAX;
290 G4double zphimax = 0., rphimax = 0.;
291 for(G4int iphi = 0; iphi < fNSegment[IPHI]; iphi++)
292 {
293 for(G4int iz = 0; iz < fNSegment[IZ]; iz++)
294 {
295 if(zphimin > zphicell[iz][iphi])
296 zphimin = zphicell[iz][iphi];
297 if(zphimax < zphicell[iz][iphi])
298 zphimax = zphicell[iz][iphi];
299 }
300 for(G4int ir = 0; ir < fNSegment[IR]; ir++)
301 {
302 if(rphimin > rphicell[ir][iphi])
303 rphimin = rphicell[ir][iphi];
304 if(rphimax < rphicell[ir][iphi])
305 rphimax = rphicell[ir][iphi];
306 }
307 }
308
309 G4VisAttributes att;
310 att.SetForceSolid(true);
311 att.SetForceAuxEdgeVisible(true);
312
313 G4Scale3D scale;
314 if(axflg / 100 == 1)
315 {
316 // rz plane
317 }
318 axflg = axflg % 100;
319 if(axflg / 10 == 1)
320 {
321 pVisManager->BeginDraw();
322
323 // z-phi plane
324 if(colorMap->IfFloatMinMax())
325 {
326 colorMap->SetMinMax(zphimin, zphimax);
327 }
328
329 G4double zhalf = fSize[2] / fNSegment[IZ];
330 for(G4int phi = 0; phi < fNSegment[IPHI]; phi++)
331 {
332 for(G4int z = 0; z < fNSegment[IZ]; z++)
333 {
334 //-
335 G4double angle = fAngle[0] + fAngle[1] / fNSegment[IPHI] * phi;
336 G4double dphi = fAngle[1] / fNSegment[IPHI];
338 "z-phi", // name
339 fSize[1] * 0.99, fSize[1], // inner radius, outer radius
340 zhalf, // half length in z
341 angle, dphi * 0.99999); // starting phi angle, delta angle
342 //-
343 G4ThreeVector zpos(
344 0., 0., -fSize[2] + fSize[2] / fNSegment[IZ] * (1 + 2. * z));
345 G4Transform3D trans;
346 if(fRotationMatrix != nullptr)
347 {
348 trans =
349 G4Rotate3D(*fRotationMatrix).inverse() * G4Translate3D(zpos);
350 trans = G4Translate3D(fCenterPosition) * trans;
351 }
352 else
353 {
355 }
356 G4double c[4];
357 colorMap->GetMapColor(zphicell[z][phi], c);
358 att.SetColour(c[0], c[1], c[2]); //, c[3]);
359 //-
360 G4Polyhedron* poly = cylinder.GetPolyhedron();
361 poly->Transform(trans);
362 poly->SetVisAttributes(att);
363 pVisManager->Draw(*poly);
364 }
365 }
366 pVisManager->EndDraw();
367 }
368 axflg = axflg % 10;
369 if(axflg == 1)
370 {
371 pVisManager->BeginDraw();
372
373 // r-phi plane
374 if(colorMap->IfFloatMinMax())
375 {
376 colorMap->SetMinMax(rphimin, rphimax);
377 }
378
379 G4double rsize = (fSize[1] - fSize[0]) / fNSegment[IR];
380 for(G4int phi = 0; phi < fNSegment[IPHI]; phi++)
381 {
382 for(G4int r = 0; r < fNSegment[IR]; r++)
383 {
384 G4double rs[2] = { fSize[0] + rsize * r, fSize[0] + rsize * (r + 1) };
385 G4double angle = fAngle[0] + fAngle[1] / fNSegment[IPHI] * phi;
386 G4double dphi = fAngle[1] / fNSegment[IPHI];
387 G4Tubs cylindern("z-phi", rs[0], rs[1], 0.001, angle, dphi * 0.99999);
388 G4Tubs cylinderp = cylindern;
389
390 G4ThreeVector zposn(0., 0., -fSize[2]);
391 G4ThreeVector zposp(0., 0., fSize[2]);
392 G4Transform3D transn, transp;
393 if(fRotationMatrix != nullptr)
394 {
395 transn =
396 G4Rotate3D(*fRotationMatrix).inverse() * G4Translate3D(zposn);
397 transn = G4Translate3D(fCenterPosition) * transn;
398 transp =
399 G4Rotate3D(*fRotationMatrix).inverse() * G4Translate3D(zposp);
400 transp = G4Translate3D(fCenterPosition) * transp;
401 }
402 else
403 {
406 }
407 G4double c[4];
408 colorMap->GetMapColor(rphicell[r][phi], c);
409 att.SetColour(c[0], c[1], c[2]); //, c[3]);
410
411 G4Polyhedron* polyn = cylindern.GetPolyhedron();
412 polyn->Transform(transn);
413 polyn->SetVisAttributes(att);
414 pVisManager->Draw(*polyn);
415
416 G4Polyhedron* polyp = cylinderp.GetPolyhedron();
417 polyp->Transform(transp);
418 polyp->SetVisAttributes(att);
419 pVisManager->Draw(*polyp);
420 }
421 }
422
423 pVisManager->EndDraw();
424 }
425
426 colorMap->SetPSUnit(fDrawUnit);
427 colorMap->SetPSName(fDrawPSName);
428 colorMap->DrawColorChart();
429 }
430}
431
433 G4int idxProj, G4int idxColumn)
434{
435 G4int projAxis = 0;
436 switch(idxProj)
437 {
438 case 0:
439 projAxis = IR;
440 break;
441 case 1:
442 projAxis = IZ;
443 break;
444 case 2:
445 projAxis = IPHI;
446 break;
447 }
448
449 if(idxColumn < 0 || idxColumn >= fNSegment[projAxis])
450 {
451 G4cerr << "Warning : Column number " << idxColumn
452 << " is out of scoring mesh [0," << fNSegment[projAxis] - 1
453 << "]. Method ignored." << G4endl;
454 return;
455 }
457 if(pVisManager != nullptr)
458 {
459 // cell vectors
460 std::vector<std::vector<std::vector<G4double>>> cell; // cell[R][Z][PHI]
461 std::vector<G4double> ephi;
462 for(G4int phi = 0; phi < fNSegment[IPHI]; phi++)
463 ephi.push_back(0.);
464 std::vector<std::vector<G4double>> ezphi;
465 for(G4int z = 0; z < fNSegment[IZ]; z++)
466 ezphi.push_back(ephi);
467 for(G4int r = 0; r < fNSegment[IR]; r++)
468 cell.push_back(ezphi);
469
470 std::vector<std::vector<G4double>> rzcell; // rzcell[R][Z]
471 std::vector<G4double> ez;
472 for(G4int z = 0; z < fNSegment[IZ]; z++)
473 ez.push_back(0.);
474 for(G4int r = 0; r < fNSegment[IR]; r++)
475 rzcell.push_back(ez);
476
477 std::vector<std::vector<G4double>> zphicell; // zphicell[Z][PHI]
478 for(G4int z = 0; z < fNSegment[IZ]; z++)
479 zphicell.push_back(ephi);
480
481 std::vector<std::vector<G4double>> rphicell; // rphicell[R][PHI]
482 for(G4int r = 0; r < fNSegment[IR]; r++)
483 rphicell.push_back(ephi);
484
485 // projections
486 G4int q[3];
487 auto itr = map->GetMap()->begin();
488 for(; itr != map->GetMap()->end(); itr++)
489 {
490 if(itr->first < 0)
491 {
492 G4cout << itr->first << G4endl;
493 continue;
494 }
495 GetRZPhi(itr->first, q);
496
497 if(projAxis == IR && q[IR] == idxColumn)
498 { // zphi plane
499 zphicell[q[IZ]][q[IPHI]] += (itr->second->sum_wx()) / fDrawUnitValue;
500 }
501 if(projAxis == IZ && q[IZ] == idxColumn)
502 { // rphi plane
503 rphicell[q[IR]][q[IPHI]] += (itr->second->sum_wx()) / fDrawUnitValue;
504 }
505 if(projAxis == IPHI && q[IPHI] == idxColumn)
506 { // rz plane
507 rzcell[q[IR]][q[IZ]] += (itr->second->sum_wx()) / fDrawUnitValue;
508 }
509 }
510
511 // search min./max. values
512 G4double rzmin = DBL_MAX, zphimin = DBL_MAX, rphimin = DBL_MAX;
513 G4double rzmax = 0., zphimax = 0., rphimax = 0.;
514 for(G4int r = 0; r < fNSegment[IR]; r++)
515 {
516 for(G4int phi = 0; phi < fNSegment[IPHI]; phi++)
517 {
518 if(rphimin > rphicell[r][phi])
519 rphimin = rphicell[r][phi];
520 if(rphimax < rphicell[r][phi])
521 rphimax = rphicell[r][phi];
522 }
523 for(G4int z = 0; z < fNSegment[IZ]; z++)
524 {
525 if(rzmin > rzcell[r][z])
526 rzmin = rzcell[r][z];
527 if(rzmax < rzcell[r][z])
528 rzmax = rzcell[r][z];
529 }
530 }
531 for(G4int z = 0; z < fNSegment[IZ]; z++)
532 {
533 for(G4int phi = 0; phi < fNSegment[IPHI]; phi++)
534 {
535 if(zphimin > zphicell[z][phi])
536 zphimin = zphicell[z][phi];
537 if(zphimax < zphicell[z][phi])
538 zphimax = zphicell[z][phi];
539 }
540 }
541
542 G4VisAttributes att;
543 att.SetForceSolid(true);
544 att.SetForceAuxEdgeVisible(true);
545
546 pVisManager->BeginDraw();
547
548 G4Scale3D scale;
549 // z-phi plane
550 if(projAxis == IR)
551 {
552 if(colorMap->IfFloatMinMax())
553 {
554 colorMap->SetMinMax(zphimin, zphimax);
555 }
556
557 G4double zhalf = fSize[2] / fNSegment[IZ];
558 G4double rsize[2] = {
559 fSize[0] + (fSize[1] - fSize[0]) / fNSegment[IR] * idxColumn,
560 fSize[0] + (fSize[1] - fSize[0]) / fNSegment[IR] * (idxColumn + 1)
561 };
562 for(int phi = 0; phi < fNSegment[IPHI]; phi++)
563 {
564 for(int z = 0; z < fNSegment[IZ]; z++)
565 {
566 G4double angle = fAngle[0] + fAngle[1] / fNSegment[IPHI] * phi;
567 G4double dphi = fAngle[1] / fNSegment[IPHI];
568 G4Tubs cylinder("z-phi", rsize[0], rsize[1], zhalf, angle,
569 dphi * 0.99999);
570
571 G4ThreeVector zpos(
572 0., 0., -fSize[2] + fSize[2] / fNSegment[IZ] * (1 + 2. * z));
573 G4Transform3D trans;
574 if(fRotationMatrix != nullptr)
575 {
576 trans =
577 G4Rotate3D(*fRotationMatrix).inverse() * G4Translate3D(zpos);
578 trans = G4Translate3D(fCenterPosition) * trans;
579 }
580 else
581 {
583 }
584 G4double c[4];
585 colorMap->GetMapColor(zphicell[z][phi], c);
586 att.SetColour(c[0], c[1], c[2]); //, c[3]);
587
588 G4Polyhedron* poly = cylinder.GetPolyhedron();
589 poly->Transform(trans);
590 poly->SetVisAttributes(att);
591 pVisManager->Draw(*poly);
592 }
593 }
594
595 // r-phi plane
596 }
597 else if(projAxis == IZ)
598 {
599 if(colorMap->IfFloatMinMax())
600 {
601 colorMap->SetMinMax(rphimin, rphimax);
602 }
603
604 G4double rsize = (fSize[1] - fSize[0]) / fNSegment[IR];
605 for(G4int phi = 0; phi < fNSegment[IPHI]; phi++)
606 {
607 for(G4int r = 0; r < fNSegment[IR]; r++)
608 {
609 G4double rs[2] = { fSize[0] + rsize * r, fSize[0] + rsize * (r + 1) };
610 G4double angle = fAngle[0] + fAngle[1] / fNSegment[IPHI] * phi;
611 G4double dz = fSize[2] / fNSegment[IZ];
612 G4double dphi = fAngle[1] / fNSegment[IPHI];
613 G4Tubs cylinder("r-phi", rs[0], rs[1], dz, angle, dphi * 0.99999);
614 G4ThreeVector zpos(
615 0., 0., -fSize[2] + fSize[2] / fNSegment[IZ] * (idxColumn * 2 + 1));
616 G4Transform3D trans;
617 if(fRotationMatrix != nullptr)
618 {
619 trans =
620 G4Rotate3D(*fRotationMatrix).inverse() * G4Translate3D(zpos);
621 trans = G4Translate3D(fCenterPosition) * trans;
622 }
623 else
624 {
626 }
627 G4double c[4];
628 colorMap->GetMapColor(rphicell[r][phi], c);
629 att.SetColour(c[0], c[1], c[2]); //, c[3]);
630
631 G4Polyhedron* poly = cylinder.GetPolyhedron();
632 poly->Transform(trans);
633 poly->SetVisAttributes(att);
634 pVisManager->Draw(*poly);
635 }
636 }
637
638 // r-z plane
639 }
640 else if(projAxis == IPHI)
641 {
642 if(colorMap->IfFloatMinMax())
643 {
644 colorMap->SetMinMax(rzmin, rzmax);
645 }
646
647 G4double rsize = (fSize[1] - fSize[0]) / fNSegment[IR];
648 G4double zhalf = fSize[2] / fNSegment[IZ];
649 G4double angle = fAngle[0] + fAngle[1] / fNSegment[IPHI] * idxColumn;
650 G4double dphi = fAngle[1] / fNSegment[IPHI];
651 for(G4int z = 0; z < fNSegment[IZ]; z++)
652 {
653 for(G4int r = 0; r < fNSegment[IR]; r++)
654 {
655 G4double rs[2] = { fSize[0] + rsize * r, fSize[0] + rsize * (r + 1) };
656 G4Tubs cylinder("z-phi", rs[0], rs[1], zhalf, angle, dphi);
657
658 G4ThreeVector zpos(
659 0., 0., -fSize[2] + fSize[2] / fNSegment[IZ] * (2. * z + 1));
660 G4Transform3D trans;
661 if(fRotationMatrix != nullptr)
662 {
663 trans =
664 G4Rotate3D(*fRotationMatrix).inverse() * G4Translate3D(zpos);
665 trans = G4Translate3D(fCenterPosition) * trans;
666 }
667 else
668 {
670 }
671 G4double c[4];
672 colorMap->GetMapColor(rzcell[r][z], c);
673 att.SetColour(c[0], c[1], c[2]); //, c[3]);
674
675 G4Polyhedron* poly = cylinder.GetPolyhedron();
676 poly->Transform(trans);
677 poly->SetVisAttributes(att);
678 pVisManager->Draw(*poly);
679 }
680 }
681 }
682 pVisManager->EndDraw();
683 }
684
685 colorMap->SetPSUnit(fDrawUnit);
686 colorMap->SetPSName(fDrawPSName);
687 colorMap->DrawColorChart();
688}
689
691{
692 // index = k + j * k-size + i * jk-plane-size
693
694 // nested : z -> phi -> r
695 G4int i = IZ;
696 G4int j = IPHI;
697 G4int k = IR;
698 G4int jk = fNSegment[j] * fNSegment[k];
699 q[i] = index / jk;
700 q[j] = (index - q[i] * jk) / fNSegment[k];
701 q[k] = index - q[j] * fNSegment[k] - q[i] * jk;
702}
703
704void G4ScoringCylinder::DumpVolumes()
705{
706 G4int lvl = 2;
707 DumpSolids(lvl);
708 DumpLogVols(lvl);
709 DumpPhysVols(lvl);
710}
711
712void G4ScoringCylinder::DumpSolids(G4int lvl)
713{
714 G4cout << "*********** List of registered solids *************" << G4endl;
715 auto store = G4SolidStore::GetInstance();
716 auto itr = store->begin();
717 for(; itr != store->end(); itr++)
718 {
719 switch(lvl)
720 {
721 case 0:
722 G4cout << (*itr)->GetName() << G4endl;
723 break;
724 case 1:
725 G4cout << (*itr)->GetName() << "\t volume = "
726 << G4BestUnit((*itr)->GetCubicVolume(), "Volume")
727 << "\t surface = "
728 << G4BestUnit((*itr)->GetSurfaceArea(), "Surface") << G4endl;
729 break;
730 default:
731 (*itr)->DumpInfo();
732 break;
733 }
734 }
735}
736
737void G4ScoringCylinder::DumpLogVols(G4int lvl)
738{
739 G4cout << "*********** List of registered logical volumes *************"
740 << G4endl;
742 auto itr = store->begin();
743 for(; itr != store->end(); itr++)
744 {
745 G4cout << (*itr)->GetName()
746 << "\t Solid = " << (*itr)->GetSolid()->GetName();
747 if((*itr)->GetMaterial() != nullptr)
748 {
749 G4cout << "\t Material = " << (*itr)->GetMaterial()->GetName() << G4endl;
750 }
751 else
752 {
753 G4cout << "\t Material : not defined " << G4endl;
754 }
755 if(lvl < 1)
756 continue;
757 G4cout << "\t region = ";
758 if((*itr)->GetRegion() != nullptr)
759 {
760 G4cout << (*itr)->GetRegion()->GetName();
761 }
762 else
763 {
764 G4cout << "not defined";
765 }
766 G4cout << "\t sensitive detector = ";
767 if((*itr)->GetSensitiveDetector() != nullptr)
768 {
769 G4cout << (*itr)->GetSensitiveDetector()->GetName();
770 }
771 else
772 {
773 G4cout << "not defined";
774 }
775 G4cout << G4endl;
776 G4cout << "\t daughters = " << (*itr)->GetNoDaughters();
777 if((*itr)->GetNoDaughters() > 0)
778 {
779 switch((*itr)->CharacteriseDaughters())
780 {
781 case kNormal:
782 G4cout << " (placement)";
783 break;
784 case kReplica:
785 G4cout << " (replica : " << (*itr)->GetDaughter(0)->GetMultiplicity()
786 << ")";
787 break;
788 case kParameterised:
789 G4cout << " (parameterized : "
790 << (*itr)->GetDaughter(0)->GetMultiplicity() << ")";
791 break;
792 default:;
793 }
794 }
795 G4cout << G4endl;
796 if(lvl < 2)
797 continue;
798 if((*itr)->GetMaterial() != nullptr)
799 {
800 G4cout << "\t weight = " << G4BestUnit((*itr)->GetMass(), "Mass")
801 << G4endl;
802 }
803 else
804 {
805 G4cout << "\t weight : not available" << G4endl;
806 }
807 }
808}
809
810void G4ScoringCylinder::DumpPhysVols(G4int lvl)
811{
812 G4cout << "*********** List of registered physical volumes *************"
813 << G4endl;
815 auto itr = store->begin();
816 for(; itr != store->end(); itr++)
817 {
818 switch(lvl)
819 {
820 case 0:
821 G4cout << (*itr)->GetName() << G4endl;
822 break;
823 case 1:
824 G4cout << (*itr)->GetName() << "\t logical volume = "
825 << (*itr)->GetLogicalVolume()->GetName()
826 << "\t mother logical = ";
827 if((*itr)->GetMotherLogical() != nullptr)
828 {
829 G4cout << (*itr)->GetMotherLogical()->GetName();
830 }
831 else
832 {
833 G4cout << "not defined";
834 }
835 G4cout << G4endl;
836 break;
837 default:
838 G4cout << (*itr)->GetName() << "\t logical volume = "
839 << (*itr)->GetLogicalVolume()->GetName()
840 << "\t mother logical = ";
841 if((*itr)->GetMotherLogical() != nullptr)
842 {
843 G4cout << (*itr)->GetMotherLogical()->GetName();
844 }
845 else
846 {
847 G4cout << "not defined";
848 }
849 G4cout << "\t type = ";
850 switch((*itr)->VolumeType())
851 {
852 case kNormal:
853 G4cout << "placement";
854 break;
855 case kReplica:
856 G4cout << "replica";
857 break;
858 case kParameterised:
859 G4cout << "parameterized";
860 break;
861 default:;
862 }
863 G4cout << G4endl;
864 }
865 }
866}
#define G4BestUnit(a, b)
CLHEP::Hep3Vector G4ThreeVector
HepGeom::Transform3D G4Transform3D
HepGeom::Translate3D G4Translate3D
HepGeom::Scale3D G4Scale3D
HepGeom::Rotate3D G4Rotate3D
double G4double
Definition G4Types.hh:83
int G4int
Definition G4Types.hh:85
G4GLOB_DLL std::ostream G4cerr
#define G4endl
Definition G4ios.hh:67
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
G4double fDrawUnitValue
G4MultiFunctionalDetector * fMFD
G4String fDivisionAxisNames[3]
G4LogicalVolume * fMeshElementLogical
G4double fAngle[2]
G4double fSize[3]
G4VScoringMesh(const G4String &wName)
G4ThreeVector fCenterPosition
virtual void EndDraw()=0
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 *)
Definition G4Visible.cc:98
Transform3D inverse() const
HepPolyhedron & Transform(const G4Transform3D &t)
@ kPhi
Definition geomdefs.hh:60
@ kZAxis
Definition geomdefs.hh:57
@ kRho
Definition geomdefs.hh:58
@ kNormal
Definition geomdefs.hh:84
@ kParameterised
Definition geomdefs.hh:86
@ kReplica
Definition geomdefs.hh:85
#define DBL_MAX
Definition templates.hh:62