60 physicalTreatmentRoom(0),iortDetectorConstruction(0),
64 solidFinalCollimatorIORT(0),
65 physiFinalCollimatorIORT(0),
67 solidGiunz1FinalCollIORT(0),
68 physiGiunz1FinalCollIORT(0),
70 solidGiunz2FinalCollIORT(0),
71 physiGiunz2FinalCollIORT(0),
73 solidGiunz3FinalCollIORT(0),
74 physiGiunz3FinalCollIORT(0),
76 solidGiunz3FinalCollIntIORT(0),
77 physiGiunz3FinalCollIntIORT(0),
79 solidGiunz4FinalCollIORT(0),
80 physiGiunz4FinalCollIORT(0),
82 solidGiunz5FinalCollIORT(0),
83 physiGiunz5FinalCollIORT(0),
94 solidBlocco20mmIORT(0),
95 physiBlocco20mmIORT(0),
170 white -> SetVisibility(
true);
174 blue -> SetVisibility(
true);
178 gray-> SetVisibility(
true);
182 red-> SetVisibility(
true);
186 yellow-> SetVisibility(
true);
190 green -> SetVisibility(
true);
202 skyBlue -> SetVisibility(
true);
208 G4double defaultOuterRadiusFinalCollimatorIORT = 40. *
mm;
211 G4double defaultinnerRadiusFinalCollimatorIORT = 35. *
mm;
326 G4Box* treatmentRoom =
new G4Box(
"TreatmentRoom",worldX,worldY,worldZ);
329 "logicTreatmentRoom",
333 "physicalTreatmentRoom",
371 const G4double XPositionVSIORT = -862.797 *
mm;
377 spanningAngleVSIORT);
385 logVSIORT -> SetVisAttributes(
green);
406 const G4double XPositionFTIORT = -861.791 *
mm;
412 spanningAngleFTIORT);
420 logFTIORT -> SetVisAttributes(
yellow);
447 const G4double XPositionPFS3IORT = -848.755 *
mm;
453 spanningAnglePFS3IORT);
461 logPFS3IORT -> SetVisAttributes(
white);
473 const G4double XPositionPFS2IORT = -844.255 *
mm;
479 spanningAnglePFS2IORT);
487 logPFS2IORT -> SetVisAttributes(
green);
498 const G4double XPositionPFS1IORT = -841.905 *
mm;
504 spanningAnglePFS1IORT);
512 logPFS1IORT -> SetVisAttributes(
green);
523 const G4double XPositionCCMIORT = -837.0125 *
mm;
529 spanningAngleCCMIORT);
537 logCCMIORT -> SetVisAttributes(
green);
544 const G4double outRadiusCM2_2_2IORT = 20. *
mm;
548 const G4double spanningAngleCM2_2_2IORT = 360.*
deg;
549 const G4double XPositionCM2_2_2IORT = -841. *
mm;
552 outRadiusCM2_2_2IORT,
554 startAngleCM2_2_2IORT,
555 spanningAngleCM2_2_2IORT);
563 logCM2_2_2IORT -> SetVisAttributes(
green);
570 const G4double outRadiusCM2_1_2IORT = 20. *
mm;
574 const G4double spanningAngleCM2_1_2IORT = 360.*
deg;
575 const G4double XPositionCM2_1_2IORT = -839. *
mm;
578 outRadiusCM2_1_2IORT,
580 startAngleCM2_1_2IORT,
581 spanningAngleCM2_1_2IORT);
589 logCM2_1_2IORT -> SetVisAttributes(
yellow);
595 const G4double outRadiusCM1_2_2IORT = 20. *
mm;
599 const G4double spanningAngleCM1_2_2IORT = 360.*
deg;
600 const G4double XPositionCM1_2_2IORT = -837. *
mm;
603 outRadiusCM1_2_2IORT,
605 startAngleCM1_2_2IORT,
606 spanningAngleCM1_2_2IORT);
614 logCM1_2_2IORT -> SetVisAttributes(
yellow);
620 const G4double outRadiusCM1_1_2IORT = 20. *
mm;
624 const G4double spanningAngleCM1_1_2IORT = 360.*
deg;
625 const G4double XPositionCM1_1_2IORT = -835. *
mm;
628 outRadiusCM1_1_2IORT,
630 startAngleCM1_1_2IORT,
631 spanningAngleCM1_1_2IORT);
639 logCM1_1_2IORT -> SetVisAttributes(
yellow);
661 const G4double outRadiusBlocco20mmIORT = 36.5 *
mm;
662 const G4double innRadiusBlocco20mmIORT = 10. *
mm;
665 const G4double spanningAngleBlocco20mmIORT = 360.*
deg;
666 const G4double XPositionBlocco20mmIORT = -830. *
mm;
669 outRadiusBlocco20mmIORT,
671 startAngleBlocco20mmIORT,
672 spanningAngleBlocco20mmIORT);
680 logBlocco20mmIORT -> SetVisAttributes(
green);
687 const G4double outRadiusBlocco3IORT = 36.5 *
mm;
688 const G4double innRadiusBlocco3IORT = 15. *
mm;
691 const G4double spanningAngleBlocco3IORT = 360.*
deg;
692 const G4double XPositionBlocco3IORT = -823.5 *
mm;
695 outRadiusBlocco3IORT,
697 startAngleBlocco3IORT,
698 spanningAngleBlocco3IORT);
706 logBlocco3IORT -> SetVisAttributes(
yellow);
712 const G4double outRadiusBlocco2IORT = 41.5 *
mm;
713 const G4double innRadiusBlocco2IORT = 15. *
mm;
716 const G4double spanningAngleBlocco2IORT = 360.*
deg;
717 const G4double XPositionBlocco2IORT = -812. *
mm;
720 outRadiusBlocco2IORT,
722 startAngleBlocco2IORT,
723 spanningAngleBlocco2IORT);
731 logBlocco2IORT -> SetVisAttributes(
red);
737 const G4double outRadiusBlocco1IORT = 52.0 *
mm;
738 const G4double innRadiusBlocco1IORT = 15. *
mm;
741 const G4double spanningAngleBlocco1IORT = 360.*
deg;
742 const G4double XPositionBlocco1IORT = -795.5*
mm;
745 outRadiusBlocco1IORT,
747 startAngleBlocco1IORT,
748 spanningAngleBlocco1IORT);
756 logBlocco1IORT -> SetVisAttributes(
white);
772 const G4double outRadiusGiunz5FinalCollIORT = 48.25 *
mm;
773 const G4double innRadiusGiunz5FinalCollIORT = 13.75 *
mm;
774 const G4double hightGiunz5FinalCollIORT = 3.5 *
mm;
775 const G4double startAngleGiunz5FinalCollIORT = 0.*
deg;
776 const G4double spanningAngleGiunz5FinalCollIORT = 360.*
deg;
777 const G4double Giunz5FinalCollXPositionIORT = -783.5 *
mm;
780 outRadiusGiunz5FinalCollIORT,
781 hightGiunz5FinalCollIORT,
782 startAngleGiunz5FinalCollIORT,
783 spanningAngleGiunz5FinalCollIORT);
791 logGiunz5FinalCollIORT -> SetVisAttributes(
yellow);
797 const G4double outRadiusGiunz4FinalCollIORT = 42. *
mm;
798 const G4double innRadiusGiunz4FinalCollIORT = 13.75 *
mm;
799 const G4double hightGiunz4FinalCollIORT = 8.5 *
mm;
800 const G4double startAngleGiunz4FinalCollIORT = 0.*
deg;
801 const G4double spanningAngleGiunz4FinalCollIORT = 360.*
deg;
802 const G4double Giunz4FinalCollXPositionIORT = -771.5 *
mm;
805 outRadiusGiunz4FinalCollIORT,
806 hightGiunz4FinalCollIORT,
807 startAngleGiunz4FinalCollIORT,
808 spanningAngleGiunz4FinalCollIORT);
816 logGiunz4FinalCollIORT -> SetVisAttributes(
blue);
824 const G4double outRadiusGiunz3FinalCollIORT = 42. *
mm;
825 const G4double innRadiusGiunz3FinalCollIORT = 0. *
mm;
826 const G4double hightGiunz3FinalCollIORT = 4.25 *
mm;
827 const G4double startAngleGiunz3FinalCollIORT = 0.*
deg;
828 const G4double spanningAngleGiunz3FinalCollIORT = 360.*
deg;
829 const G4double Giunz3FinalCollXPositionIORT = -758.75 *
mm;
832 outRadiusGiunz3FinalCollIORT,
833 hightGiunz3FinalCollIORT,
834 startAngleGiunz3FinalCollIORT,
835 spanningAngleGiunz3FinalCollIORT);
843 logicsolidGiunz3FinalCollIORT -> SetVisAttributes(
yellow);
861 logicsolidGiunz3FinalCollIntIORT -> SetVisAttributes(
yellow);
868 const G4double outRadiusGiunz2FinalCollIORT = 42. *
mm;
869 const G4double innRadiusGiunz2FinalCollIORT = 22.25 *
mm;
870 const G4double hightGiunz2FinalCollIORT = 5.75 *
mm;
871 const G4double startAngleGiunz2FinalCollIORT = 0.*
deg;
872 const G4double spanningAngleGiunz2FinalCollIORT = 360.*
deg;
873 const G4double Giunz2FinalCollXPositionIORT = -748.75 *
mm;
876 outRadiusGiunz2FinalCollIORT,
877 hightGiunz2FinalCollIORT,
878 startAngleGiunz2FinalCollIORT,
879 spanningAngleGiunz2FinalCollIORT);
887 logGiunz2FinalCollIORT -> SetVisAttributes(
red);
893 const G4double outRadiusGiunz1FinalCollIORT = 50. *
mm;
894 const G4double innRadiusGiunz1FinalCollIORT = 22.25 *
mm;
895 const G4double hightGiunz1FinalCollIORT = 10. *
mm;
896 const G4double startAngleGiunz1FinalCollIORT = 0.*
deg;
897 const G4double spanningAngleGiunz1FinalCollIORT = 360.*
deg;
898 const G4double Giunz1FinalCollXPositionIORT = -733.*
mm;
901 outRadiusGiunz1FinalCollIORT,
902 hightGiunz1FinalCollIORT,
903 startAngleGiunz1FinalCollIORT,
904 spanningAngleGiunz1FinalCollIORT);
912 logGiunz1FinalCollIORT -> SetVisAttributes(
gray);
924 const G4double hightFinalCollimatorIORT = 334. *
mm;
925 const G4double startAngleFinalCollimatorIORT = 0.*
deg;
926 const G4double spanningAngleFinalCollimatorIORT = 360.*
deg;
927 const G4double finalCollimatorXPositionIORT = -389.*
mm;
941 hightFinalCollimatorIORT,
942 startAngleFinalCollimatorIORT,
943 spanningAngleFinalCollimatorIORT);
952 logFinalCollimatorIORT -> SetVisAttributes(
darkOrange3);
964 G4cout<<
"Inner Radius of the final collimator IORT is (mm):"
975 G4cout<<
"Outer Radius of the final collimator IORT is (mm):"
G4Material * VSIORTMaterialIORT
G4VPhysicalVolume * physiBlocco2IORT
G4Material * Giunz5FinalCollMaterialIORT
G4Material * PFS3IORTMaterialIORT
G4Tubs * solidCM2_2_2IORT
G4Material * FTIORTMaterialIORT
G4Material * FindOrBuildMaterial(const G4String &name, G4bool isotopes=true, G4bool warning=false)
G4Tubs * solidGiunz1FinalCollIORT
G4Tubs * solidGiunz5FinalCollIORT
void ConstructCollimator70BeamLine()
G4VPhysicalVolume * physiPFS3IORT
CLHEP::Hep3Vector G4ThreeVector
CLHEP::HepRotation G4RotationMatrix
G4Tubs * solidCM2_1_2IORT
G4Material * Giunz3FinalCollMaterialIntIORT
G4VPhysicalVolume * physiCM2_1_2IORT
void SetDefaultDimensions()
G4VPhysicalVolume * physiCM2_2_2IORT
G4Tubs * solidBlocco3IORT
G4Tubs * solidFinalCollimatorIORT
G4VPhysicalVolume * physiPFS1IORT
G4VisAttributes * darkGreen
G4VPhysicalVolume * physiFinalCollimatorIORT
void IortBeamLineFinalCollimator()
G4double innerRadiusFinalCollimatorIORT
G4double OuterRadiusFinalCollimatorIORT
G4VPhysicalVolume * physiGiunz1FinalCollIORT
static G4NistManager * Instance()
G4VisAttributes * darkOrange3
G4VPhysicalVolume * physiGiunz5FinalCollIORT
void IortBeamLineMonitorChambers()
G4Tubs * solidBlocco20mmIORT
void IortBeamLineBlocks()
Collimator70BeamLineMessenger * collimatorMessenger
G4Material * Blocco1IORTMaterialIORT
G4Material * CM1_1_2IORTMaterialIORT
G4GLOB_DLL std::ostream G4cout
G4VPhysicalVolume * physiGiunz3FinalCollIntIORT
G4Tubs * solidCM1_1_2IORT
G4Material * Blocco20mmIORTMaterialIORT
G4Material * finalCollimatorMaterialIORT
G4VPhysicalVolume * physiGiunz3FinalCollIORT
G4Tubs * solidGiunz4FinalCollIORT
G4Material * CM2_2_2IORTMaterialIORT
G4VPhysicalVolume * physiCM1_1_2IORT
G4VPhysicalVolume * physiBlocco1IORT
static const double perCent
G4Material * Giunz3FinalCollMaterialIORT
G4VPhysicalVolume * physiCM1_2_2IORT
G4VPhysicalVolume * physicalTreatmentRoom
G4Material * CM1_2_2IORTMaterialIORT
static G4RunManager * GetRunManager()
G4VPhysicalVolume * physiBlocco3IORT
G4Material * PFS2IORTMaterialIORT
G4VPhysicalVolume * physiFTIORT
G4Material * Blocco3IORTMaterialIORT
static const G4VisAttributes Invisible
G4Tubs * solidBlocco1IORT
G4Material * Blocco2IORTMaterialIORT
G4Material * CCMIORTMaterialIORT
void SetOuterRadiusFinalCollimatorIORT(G4double)
void SetInnerRadiusFinalCollimatorIORT(G4double)
G4Material * Giunz2FinalCollMaterialIORT
G4Material * Giunz4FinalCollMaterialIORT
G4Material * CM2_1_2IORTMaterialIORT
G4Cons * solidGiunz3FinalCollIntIORT
G4Tubs * solidGiunz3FinalCollIORT
G4VisAttributes * skyBlue
void IortBeamLineTitaniumWindows()
G4Element * FindOrBuildElement(G4int Z, G4bool isotopes=true)
G4VPhysicalVolume * physiGiunz2FinalCollIORT
G4VPhysicalVolume * physiPFS2IORT
G4Material * PFS1IORTMaterialIORT
G4VPhysicalVolume * physiVSIORT
G4VPhysicalVolume * physiCCMIORT
void IortBeamLineVacuumSource()
G4VPhysicalVolume * physiGiunz4FinalCollIORT
G4Material * Giunz1FinalCollMaterialIORT
IORTDetectorConstruction * iortDetectorConstruction
G4Tubs * solidBlocco2IORT
G4Tubs * solidGiunz2FinalCollIORT
G4VPhysicalVolume * Construct()
void IortBeamLineJunctions()
G4VPhysicalVolume * physiBlocco20mmIORT
G4Tubs * solidCM1_2_2IORT