Belle II Software development
BKLMAlignment.cc
1/**************************************************************************
2 * basf2 (Belle II Analysis Software Framework) *
3 * Author: The Belle II Collaboration *
4 * *
5 * See git log for contributors and copyright holders. *
6 * This file is licensed under LGPL-3.0, see LICENSE.md. *
7 **************************************************************************/
8
9/* Own header. */
10#include <klm/dbobjects/bklm/BKLMAlignment.h>
11
12using namespace Belle2;
13
15{
16}
17
19{
20}
21
24{
25 std::map<KLMModuleNumber, KLMAlignmentData>::iterator it;
26 it = m_ModuleAlignment.find(module);
27 if (it == m_ModuleAlignment.end()) {
28 m_ModuleAlignment.insert(
29 std::pair<KLMModuleNumber, KLMAlignmentData>(module, *dat));
30 } else {
31 it->second = *dat;
32 }
33}
34
36 KLMModuleNumber module) const
37{
38 std::map<KLMModuleNumber, KLMAlignmentData>::const_iterator it;
39 it = m_ModuleAlignment.find(module);
40 if (it == m_ModuleAlignment.end())
41 return nullptr;
42 return &(it->second);
43}
44
45double BKLMAlignment::getGlobalParam(unsigned short element,
46 unsigned short param) const
47{
48 const KLMAlignmentData* alignmentData = getModuleAlignment(element);
49 if (alignmentData == nullptr)
50 return 0;
51 return alignmentData->getParameter(
52 static_cast<enum KLMAlignmentData::ParameterNumbers>(param));
53}
54
55void BKLMAlignment::setGlobalParam(double value, unsigned short element,
56 unsigned short param)
57{
58 KLMAlignmentData* alignmentData =
59 const_cast<KLMAlignmentData*>(getModuleAlignment(element));
60 /*
61 * Create alignment data if it does not exist.
62 * This is necessary for errors and corrections.
63 */
64 if (alignmentData == nullptr) {
65 KLMAlignmentData newAlignmentData(0, 0, 0, 0, 0, 0);
66 newAlignmentData.setParameter(
67 static_cast<enum KLMAlignmentData::ParameterNumbers>(param), value);
68 m_ModuleAlignment.insert(
69 std::pair<KLMModuleNumber, KLMAlignmentData>(element, newAlignmentData));
70 } else {
71 alignmentData->setParameter(
72 static_cast<enum KLMAlignmentData::ParameterNumbers>(param), value);
73 }
74}
75
76/* TODO: this function is not implemented. */
77std::vector< std::pair<unsigned short, unsigned short> >
79{
80 return {};
81}
std::vector< std::pair< unsigned short, unsigned short > > listGlobalParams()
Get a list of stored global parameters.
double getGlobalParam(unsigned short element, unsigned short param) const
Get global parameter.
void setModuleAlignment(KLMModuleNumber module, KLMAlignmentData *dat)
Set module alignment data.
std::map< KLMModuleNumber, KLMAlignmentData > m_ModuleAlignment
Module alignment.
Definition: BKLMAlignment.h:92
const KLMAlignmentData * getModuleAlignment(KLMModuleNumber module) const
Get module alignment data.
BKLMAlignment()
Constructor.
void setGlobalParam(double value, unsigned short element, unsigned short param)
Set global parameter.
~BKLMAlignment()
Destructor.
KLM Alignment data.
ParameterNumbers
Alignment parameter numbers.
void setParameter(enum ParameterNumbers number, float value)
Set parameter by number.
uint16_t KLMModuleNumber
Module number.
Abstract base class for different kinds of events.