982{
983 G4Material* fCrystalMaterial = G4Material::GetMaterial("Cesiumiodide");
984
985
986
987
988
989
990
991 solidEnd = new G4Cons("EndWorld",(*emcEnd).WorldRmin1,(*emcEnd).WorldRmax1,(*emcEnd).WorldRmin2,(*emcEnd).WorldRmax2,
992 (*emcEnd).WorldDz/2,0.*deg,360.*deg);
993 logicEnd = new G4LogicalVolume(solidEnd, G4Material::GetMaterial("Air"), "EndWorld", 0, 0, 0);
994 physiEnd = new G4PVPlacement(0,
995 G4ThreeVector(0,0,(*emcEnd).WorldZPosition),
996 logicEnd,
997 "EndWorld",
998 logicEMC,
999 false,
1000 0);
1001
1002
1003
1004
1005
1006 G4RotationMatrix *rotateEnd = new G4RotationMatrix();
1007 rotateEnd->rotateY(180.*deg);
1008 physiEnd = new G4PVPlacement(rotateEnd,
1009 G4ThreeVector(0,0,-(*emcEnd).WorldZPosition),
1010 logicEnd,
1011 "EndWorld",
1012 logicEMC,
1013 false,
1014 2);
1015
1016
1017
1018
1019
1020
1021
1022
1023
1024
1025
1026
1027
1028
1029
1030
1031
1032
1033
1034
1035
1036
1037
1038
1039
1040
1041 solidEndPhi = new G4Cons("EndPhi",(*emcEnd).WorldRmin1,(*emcEnd).WorldRmax1,(*emcEnd).WorldRmin2,(*emcEnd).WorldRmax2,
1042 (*emcEnd).WorldDz/2,0*deg,22.5*deg);
1043 logicEndPhi = new G4LogicalVolume(solidEndPhi, G4Material::GetMaterial("Air"), "EndPhi", 0, 0, 0);
1044 for(G4int i=0;i<14;i++)
1045 {
1046 if((i!=6)&&(i!=7))
1047 {
1048 G4RotationMatrix *rotatePhi = new G4RotationMatrix();
1049 rotatePhi->rotateZ(-i*22.5*deg+67.5*deg);
1050 physiEndPhi = new G4PVPlacement(rotatePhi,G4ThreeVector(0,0,0),logicEndPhi,"EndPhi",logicEnd,false,i,false);
1051 }
1052 }
1053
1054
1055
1056 for(G4int i=0;i<35;i++)
1057 {
1059
1060 solidEndCasing = new G4IrregBox("EndCasing",(*emcEnd).fPnt[i]);
1061 logicEndCasing = new G4LogicalVolume(solidEndCasing,fCasingMaterial,"EndCasing");
1062 physiEndCasing = new G4PVPlacement(0,G4ThreeVector(0,0,0),logicEndCasing,"EndCasing",logicEndPhi,false,copyNb,false);
1063
1064 emcEnd->ModifyForCasing((*emcEnd).fPnt[i],i);
1065 solidEndCrystal = new G4IrregBox("EndCrystal",(*emcEnd).cryPoint);
1066 logicEndCrystal = new G4LogicalVolume(solidEndCrystal,fCrystalMaterial,"EndCrystal");
1067 physiEndCrystal = new G4PVPlacement(0,G4ThreeVector(0,0,0),logicEndCrystal,"EndCrystal",logicEndCasing,false,copyNb,false);
1068
1069
1070
1071
1072 }
1073
1074
1075
1076
1077 solidEndPhi = new G4Cons("EndPhi",(*emcEnd).WorldRmin1,(*emcEnd).WorldRmax1,(*emcEnd).WorldRmin2,(*emcEnd).WorldRmax2,
1078 (*emcEnd).WorldDz/2,67.5*deg,22.5*deg);
1079 logicEndPhi = new G4LogicalVolume(solidEndPhi, G4Material::GetMaterial("Air"), "EndPhi", 0, 0, 0);
1080 for(G4int i=0;i<2;i++)
1081 {
1082 G4RotationMatrix *rotatePhi = new G4RotationMatrix();
1083 rotatePhi->rotateZ(-i*180.*deg);
1084 physiEndPhi = new G4PVPlacement(rotatePhi,G4ThreeVector(0,0,0),logicEndPhi,"EndPhi",logicEnd,false,i*8+6,false);
1085 }
1086
1087
1088
1089 for(G4int i=0;i<35;i++)
1090 {
1092 solidEndCasing = new G4IrregBox("EndCasing",(*emcEnd).fPnt1[i]);
1093 logicEndCasing = new G4LogicalVolume(solidEndCasing,fCasingMaterial,"EndCasing");
1094 physiEndCasing = new G4PVPlacement(0,G4ThreeVector(0,0,0),logicEndCasing,"EndCasing",logicEndPhi,false,copyNb,false);
1095
1096 emcEnd->ModifyForCasing((*emcEnd).fPnt1[i],i);
1097 solidEndCrystal = new G4IrregBox("EndCrystal",(*emcEnd).cryPoint);
1098 logicEndCrystal = new G4LogicalVolume(solidEndCrystal,fCrystalMaterial,"EndCrystal");
1099 physiEndCrystal = new G4PVPlacement(0,G4ThreeVector(0,0,0),logicEndCrystal,"EndCrystal",logicEndCasing,false,copyNb,false);
1100
1101
1102
1103
1104 }
1105
1106 (*emcEnd).ReflectX();
1107
1108
1109 for(G4int i=0;i<35;i++)
1110 for (G4int j=0;j<8;j++)
1111 (*emcEnd).fPnt1[i][j].rotateZ(-90.*deg);
1112
1113 solidEndPhi = new G4Cons("EndPhi",(*emcEnd).WorldRmin1,(*emcEnd).WorldRmax1,(*emcEnd).WorldRmin2,(*emcEnd).WorldRmax2,
1114 (*emcEnd).WorldDz/2,0*deg,22.5*deg);
1115 logicEndPhi = new G4LogicalVolume(solidEndPhi, G4Material::GetMaterial("Air"), "EndPhi", 0, 0, 0);
1116 for(G4int i=0;i<2;i++)
1117 {
1118 G4RotationMatrix *rotatePhi = new G4RotationMatrix();
1119 rotatePhi->rotateZ(-i*180.*deg-90.*deg);
1120 physiEndPhi = new G4PVPlacement(rotatePhi,G4ThreeVector(0,0,0),logicEndPhi,"EndPhi",logicEnd,false,i*8+7,false);
1121 }
1122
1123
1124
1125 for(G4int i=0;i<35;i++)
1126 {
1128 solidEndCasing = new G4IrregBox("EndCasing",(*emcEnd).fPnt1[i]);
1129 logicEndCasing = new G4LogicalVolume(solidEndCasing,fCrystalMaterial,"EndCasing");
1130 physiEndCasing = new G4PVPlacement(0,G4ThreeVector(0,0,0),logicEndCasing,"EndCasing",logicEndPhi,false,copyNb,false);
1131
1132 emcEnd->ModifyForCasing((*emcEnd).fPnt1[i],i);
1133 solidEndCrystal = new G4IrregBox("EndCrystal",(*emcEnd).cryPoint);
1134 logicEndCrystal = new G4LogicalVolume(solidEndCrystal,fCrystalMaterial,"EndCrystal");
1135 physiEndCrystal = new G4PVPlacement(0,G4ThreeVector(0,0,0),logicEndCrystal,"EndCrystal",logicEndCasing,false,copyNb,false);
1136
1137
1138
1139
1140 }
1141}
G4int ComputeEndCopyNb(G4int)