149 {
150 std::set<TgcChamber> to_ret{};
151 std::cout<<
"Read the Tgc geometry tree dump from "<<
inputFile<<std::endl;
153 if (!inFile || !
inFile->IsOpen()) {
154 std::cerr<<
"runTgcComparison() "<<__LINE__<<
": Failed to open "<<
inputFile<<std::endl;
155 return to_ret;
156 }
159 std::cerr<<
"runTgcComparison() "<<__LINE__<<
": The file "<<
inputFile<<
" does not contain the 'TgcGeoModelTree'"<<std::endl;
160 return to_ret;
161 }
163 TTreeReaderValue<unsigned short> stationIndex{
treeReader,
"stationIndex"};
166 TTreeReaderValue<std::string> stationDesign{
treeReader,
"stationDesign"};
167 TTreeReaderValue<uint8_t> nGasGaps{
treeReader,
"nGasGaps"};
168
169 TTreeReaderValue<float> shortWidth{
treeReader,
"ChamberWidthS"};
170 TTreeReaderValue<float> longWidth{
treeReader,
"ChamberWidthL"};
171 TTreeReaderValue<float> height{
treeReader,
"ChamberHeight"};
172 TTreeReaderValue<float> thickness{
treeReader,
"ChamberThickness"};
174 TTreeReaderValue<std::vector<float>> geoModelTransformX{
treeReader,
"GeoModelTransformX"};
175 TTreeReaderValue<std::vector<float>> geoModelTransformY{
treeReader,
"GeoModelTransformY"};
176 TTreeReaderValue<std::vector<float>> geoModelTransformZ{
treeReader,
"GeoModelTransformZ"};
177
178 TTreeReaderValue<std::vector<float>> alignableNodeX{
treeReader,
"AlignableNodeX"};
179 TTreeReaderValue<std::vector<float>> alignableNodeY{
treeReader,
"AlignableNodeY"};
180 TTreeReaderValue<std::vector<float>> alignableNodeZ{
treeReader,
"AlignableNodeZ"};
181
182
183 TTreeReaderValue<std::vector<float>> gangCenterX{
treeReader,
"gangCenterX"};
184 TTreeReaderValue<std::vector<float>> gangCenterY{
treeReader,
"gangCenterY"};
185 TTreeReaderValue<std::vector<float>> gangCenterZ{
treeReader,
"gangCenterZ"};
186
187 TTreeReaderValue<std::vector<float>> gangLocalPosX{
treeReader,
"gangLocalPosX"};
188 TTreeReaderValue<std::vector<float>> gangLocalPosY{
treeReader,
"gangLocalPosY"};
189
190
191 TTreeReaderValue<std::vector<float>> stripCenterX{
treeReader,
"stripCenterX"};
192 TTreeReaderValue<std::vector<float>> stripCenterY{
treeReader,
"stripCenterY"};
193 TTreeReaderValue<std::vector<float>> stripCenterZ{
treeReader,
"stripCenterZ"};
194
195 TTreeReaderValue<std::vector<float>> stripBottomX{
treeReader,
"stripBottomX"};
196 TTreeReaderValue<std::vector<float>> stripBottomY{
treeReader,
"stripBottomY"};
197 TTreeReaderValue<std::vector<float>> stripBottomZ{
treeReader,
"stripBottomZ"};
198
199 TTreeReaderValue<std::vector<float>> stripTopX{
treeReader,
"stripTopX"};
200 TTreeReaderValue<std::vector<float>> stripTopY{
treeReader,
"stripTopY"};
201 TTreeReaderValue<std::vector<float>> stripTopZ{
treeReader,
"stripTopZ"};
202
203 TTreeReaderValue<std::vector<float>> stripLocalCenterX{
treeReader,
"stripLocalCenterX"};
204 TTreeReaderValue<std::vector<float>> stripLocalCenterY{
treeReader,
"stripLocalCenterY"};
205 TTreeReaderValue<std::vector<float>> stripLocalBottomX{
treeReader,
"stripLocalBottomX"};
206 TTreeReaderValue<std::vector<float>> stripLocalBottomY{
treeReader,
"stripLocalBottomY"};
207 TTreeReaderValue<std::vector<float>> stripLocalTopX{
treeReader,
"stripLocalTopX"};
208 TTreeReaderValue<std::vector<float>> stripLocalTopY{
treeReader,
"stripLocalTopY"};
209
210 TTreeReaderValue<std::vector<uint8_t>> stripGasGap{
treeReader,
"stripGasGap"};
211 TTreeReaderValue<std::vector<unsigned int>> stripNum{
treeReader,
"stripNumber"};
212
213
214 TTreeReaderValue<std::vector<uint8_t>> gangGasGap{
treeReader,
"gangGasGap"};
215 TTreeReaderValue<std::vector<unsigned int>> gangNum{
treeReader,
"gangNumber"};
216 TTreeReaderValue<std::vector<uint8_t>> gangNumWires{
treeReader,
"gangNumWires"};
217 TTreeReaderValue<std::vector<float>> gangLength{
treeReader,
"gangLength"};
218
219 TTreeReaderValue<std::vector<float>> layerCol1X{
treeReader,
"layerLinearCol1X"};
220 TTreeReaderValue<std::vector<float>> layerCol1Y{
treeReader,
"layerLinearCol1Y"};
221 TTreeReaderValue<std::vector<float>> layerCol1Z{
treeReader,
"layerLinearCol1Z"};
222
223 TTreeReaderValue<std::vector<float>> layerCol2X{
treeReader,
"layerLinearCol2X"};
224 TTreeReaderValue<std::vector<float>> layerCol2Y{
treeReader,
"layerLinearCol2Y"};
225 TTreeReaderValue<std::vector<float>> layerCol2Z{
treeReader,
"layerLinearCol2Z"};
226
227 TTreeReaderValue<std::vector<float>> layerCol3X{
treeReader,
"layerLinearCol3X"};
228 TTreeReaderValue<std::vector<float>> layerCol3Y{
treeReader,
"layerLinearCol3Y"};
229 TTreeReaderValue<std::vector<float>> layerCol3Z{
treeReader,
"layerLinearCol3Z"};
230
231 TTreeReaderValue<std::vector<float>> layerTransX{
treeReader,
"layerTranslationX"};
232 TTreeReaderValue<std::vector<float>> layerTransY{
treeReader,
"layerTranslationY"};
233 TTreeReaderValue<std::vector<float>> layerTransZ{
treeReader,
"layerTranslationZ"};
234
235 TTreeReaderValue<std::vector<bool>> layerMeasPhi{
treeReader,
"layerMeasPhi"};
236 TTreeReaderValue<std::vector<uint8_t>> layerNumber{
treeReader,
"layerNumber"};
237
238 TTreeReaderValue<std::vector<float>> layShortWidth{
treeReader,
"layerWidthS"};
239 TTreeReaderValue<std::vector<float>> layLongWidth{
treeReader,
"layerWidthL"};
240 TTreeReaderValue<std::vector<float>> layHeight{
treeReader,
"layerHeight"};
241 TTreeReaderValue<std::vector<uint16_t>> layerNumWires{
treeReader,
"layerNumWires"};
242
245
246 newchamber.
stIdx = (*stationIndex);
247 newchamber.
eta = (*stationEta);
248 newchamber.
phi = (*stationPhi);
249 newchamber.
techName = (*stationDesign);
252 newchamber.
height = (*height);
255 Amg::Vector3D geoTrans{(*geoModelTransformX)[0], (*geoModelTransformY)[0], (*geoModelTransformZ)[0]};
257 geoRot.col(0) =
Amg::Vector3D((*geoModelTransformX)[1], (*geoModelTransformY)[1], (*geoModelTransformZ)[1]);
258 geoRot.col(1) =
Amg::Vector3D((*geoModelTransformX)[2], (*geoModelTransformY)[2], (*geoModelTransformZ)[2]);
259 geoRot.col(2) =
Amg::Vector3D((*geoModelTransformX)[3], (*geoModelTransformY)[3], (*geoModelTransformZ)[3]);
261
262 geoRot.col(0) =
Amg::Vector3D((*alignableNodeX)[1], (*alignableNodeY)[1], (*alignableNodeZ)[1]);
263 geoRot.col(1) =
Amg::Vector3D((*alignableNodeX)[2], (*alignableNodeY)[2], (*alignableNodeZ)[2]);
264 geoRot.col(2) =
Amg::Vector3D((*alignableNodeX)[3], (*alignableNodeY)[3], (*alignableNodeZ)[3]);
265 geoTrans =
Amg::Vector3D{(*alignableNodeX)[0], (*alignableNodeY)[0], (*alignableNodeZ)[0]};
267
268
269 for (size_t g = 0; g < gangGasGap->size(); ++g) {
271 newGang.
gasGap = (*gangGasGap)[g];
272 newGang.
number = (*gangNum)[g];
273 newGang.
numWires =(*gangNumWires)[g];
276 newGang.
length = (*gangLength)[g];
277 auto insert_itr = newchamber.
etaWires.insert(std::move(newGang));
278 if (!insert_itr.second) {
279 std::stringstream
err{};
280 err<<
"runTgcComparison() "<<__LINE__<<
": The wire "<<(*insert_itr.first)
281 <<" has already been inserted. "<<std::endl;
282 throw std::runtime_error(
err.str());
283 }
284 }
285
286 for (
size_t s = 0;
s < stripNum->size(); ++
s) {
288 strip.gasGap = (*stripGasGap)[
s];
289 strip.number = (*stripNum) [
s];
290
293
296
299
300 auto insert_itr = newchamber.
strips.insert(std::move(
strip));
301 if (!insert_itr.second) {
302 std::stringstream
err{};
303 err<<
"runTgcComparison() "<<__LINE__<<
": The strip "<<(*insert_itr.first)
304 <<" has already been inserted. "<<std::endl;
305 throw std::runtime_error(
err.str());
306 }
307 }
308 for (
size_t l = 0 ;
l < layerMeasPhi->size(); ++
l) {
310 layRot.col(0) =
Amg::Vector3D{(*layerCol1X)[
l], (*layerCol1Y)[
l], (*layerCol1Z)[
l]};
311 layRot.col(1) =
Amg::Vector3D{(*layerCol2X)[
l], (*layerCol2Y)[
l], (*layerCol2Z)[
l]};
312 layRot.col(2) =
Amg::Vector3D{(*layerCol3X)[
l], (*layerCol3Y)[
l], (*layerCol3Z)[
l]};
316 layTrans.
gasGap = (*layerNumber)[
l];
317 layTrans.
measPhi = (*layerMeasPhi)[
l];
320 layTrans.
height = (*layHeight)[
l];
322 auto insert_itr = newchamber.
transforms.insert(std::move(layTrans));
323 if (!insert_itr.second) {
324 std::stringstream
err{};
325 err<<
"runTgcComparison() "<<__LINE__<<
": The layer transformation "<<(*insert_itr.first)
326 <<" has already been inserted. "<<std::endl;
327 throw std::runtime_error(
err.str());
328 }
329 }
330
331 auto insert_itr = to_ret.insert(std::move(newchamber));
332 if (!insert_itr.second) {
333 std::stringstream
err{};
334 err<<
"runTgcComparison() "<<__LINE__<<
": The chamber "<<(*insert_itr.first)
335 <<" has already been inserted. "<<std::endl;
336 throw std::runtime_error(
err.str());
337 }
338 }
339 return to_ret;
340}
Eigen::Matrix< double, 3, 3 > RotationMatrix3D
Amg::Transform3D getTransformFromRotTransl(Amg::RotationMatrix3D rot, Amg::Vector3D transl_vec)
constexpr uint8_t stationPhi
station Phi 1 to 8
constexpr uint8_t stationEta
1 to 3
l
Printing final latex table to .tex output file.
std::set< WireGang > etaWires
std::set< RadialStrip > strips
Amg::Transform3D alignableTransform
Transformation of the underlying Alignable node.
Amg::Transform3D geoModelTransform
Transformation of the underlying GeoModel element.
std::set< LayerTrans > transforms