M1M3 Support System
Loading...
Searching...
No Matches
ForceControllerState.h
1/*
2 * This file is part of LSST M1M3 support system package.
3 *
4 * Developed for the Vera C. Rubin Telescope and Site System.
5 * This product includes software developed by the LSST Project
6 * (https://www.lsst.org).
7 * See the COPYRIGHT file at the top-level directory of this distribution
8 * for details of code ownership.
9 *
10 * This program is free software: you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation, either version 3 of the License, or
13 * (at your option) any later version.
14 *
15 * This program is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
19 *
20 * You should have received a copy of the GNU General Public License
21 * along with this program. If not, see <https://www.gnu.org/licenses/>.
22 */
23
24#ifndef LSST_FORCECONTROLLERSTATE_H
25#define LSST_FORCECONTROLLERSTATE_H
26
27#include <string.h>
28
29#include <SAL_MTM1M3.h>
30
31#include <cRIO/Singleton.h>
32
33#include <M1M3SSPublisher.h>
34
35namespace LSST {
36namespace M1M3 {
37namespace SS {
38
42class ForceControllerState : public MTM1M3_logevent_forceControllerStateC,
43 public cRIO::Singleton<ForceControllerState> {
44public:
49 slewFlag = false;
50 accelerationForcesApplied = false;
51 activeOpticForcesApplied = false;
52 azimuthForcesApplied = false;
53 balanceForcesApplied = false;
54 elevationForcesApplied = false;
55 offsetForcesApplied = false;
56 staticForcesApplied = false;
57 thermalForcesApplied = false;
58 velocityForcesApplied = false;
59 }
60
64 void log() { M1M3SSPublisher::instance().logForceControllerState(this); }
65
66#define appliedSetter(name) \
67 void set_##name(bool applied) { \
68 if (name != applied) { \
69 name = applied; \
70 log(); \
71 } \
72 }
73
74 appliedSetter(slewFlag);
75 appliedSetter(accelerationForcesApplied);
76 appliedSetter(activeOpticForcesApplied);
77 appliedSetter(azimuthForcesApplied);
78 appliedSetter(balanceForcesApplied);
79 appliedSetter(elevationForcesApplied);
80 appliedSetter(offsetForcesApplied);
81 appliedSetter(staticForcesApplied);
82 appliedSetter(thermalForcesApplied);
83 appliedSetter(velocityForcesApplied);
84};
85
86} // namespace SS
87} // namespace M1M3
88} // namespace LSST
89
90#endif // LSST_FORCECONTROLLERSTATE_H
Wrapper object for MTM1M3_logevent_forceControllerStateC.
Definition ForceControllerState.h:43
ForceControllerState(token)
Construct new ForceActuatorState.
Definition ForceControllerState.h:48
void log()
Sends updates through SAL/DDS.
Definition ForceControllerState.h:64