M1M3 Support System
Loading...
Searching...
No Matches
ElevationForceComponent.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_M1M3_SS_FORCECONTROLLER_ELEVATIONFORCECOMPONENT_H_
25#define LSST_M1M3_SS_FORCECONTROLLER_ELEVATIONFORCECOMPONENT_H_
26
27#include <SAL_MTM1M3C.h>
28
29#include <ForceActuatorApplicationSettings.h>
30#include <ForceComponent.h>
31#include <SafetyController.h>
32
33namespace LSST {
34namespace M1M3 {
35namespace SS {
36
37class ElevationForceComponent : public ForceComponent {
38public:
39 ElevationForceComponent(ForceActuatorApplicationSettings *forceActuatorApplicationSettings);
40
41 void applyElevationForces(float *x, float *y, float *z);
42
48 void applyElevationForcesByElevationAngle(float elevationAngle);
49
50 void postEnableDisableActions() override;
51
52protected:
53 void postUpdateActions() override;
54
55private:
56 SafetyController *_safetyController;
57 ForceActuatorApplicationSettings *_forceActuatorApplicationSettings;
58
59 MTM1M3_logevent_forceSetpointWarningC *_forceSetpointWarning;
60 MTM1M3_appliedElevationForcesC *_appliedElevationForces;
61 MTM1M3_logevent_preclippedElevationForcesC *_preclippedElevationForces;
62};
63
64} /* namespace SS */
65} /* namespace M1M3 */
66} /* namespace LSST */
67
68#endif /* LSST_M1M3_SS_FORCECONTROLLER_ELEVATIONFORCECOMPONENT_H_ */
void applyElevationForcesByElevationAngle(float elevationAngle)
Calculate offset forces from current telescope elevation.
Definition ElevationForceComponent.cpp:76
void postUpdateActions() override
Called after update to forces.
Definition ElevationForceComponent.cpp:104
void postEnableDisableActions() override
Called after enable/disable changes.
Definition ElevationForceComponent.cpp:98
(Almost) constant force actuator values.
Definition ForceActuatorApplicationSettings.h:87
ForceComponent(const char *name, ForceComponentSettings *forceComponentSettings)
Construct ForceComponent.
Definition ForceComponent.cpp:33
Controls mirror safety.
Definition SafetyController.h:50