M1M3 Support System
Loading...
Searching...
No Matches
BalanceForceComponent.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_BALANCEFORCECOMPONENT_H_
25#define LSST_M1M3_SS_FORCECONTROLLER_BALANCEFORCECOMPONENT_H_
26
27#include <SAL_MTM1M3C.h>
28
29#include <ForceActuatorApplicationSettings.h>
30#include <ForceComponent.h>
31#include <PID.h>
32#include <SafetyController.h>
33
34namespace LSST {
35namespace M1M3 {
36namespace SS {
37
55public:
56 BalanceForceComponent(ForceActuatorApplicationSettings *forceActuatorApplicationSettings);
57
58 void applyBalanceForces(float *x, float *y, float *z, bool check = true);
59
72 void applyBalanceForcesByMirrorForces(float xForce, float yForce, float zForce, float xMoment,
73 float yMoment, float zMoment);
74 bool applyFreezedForces();
75
76 void updatePID(int id, PIDParameters parameters);
77 void resetPID(int id);
78 void resetPIDs();
79
80 void freezePIDs();
81 void thawPIDs();
82
83 void postEnableDisableActions() override;
84
85protected:
86 void postUpdateActions() override;
87
88private:
89 PID *_idToPID(int id);
90
91 SafetyController *_safetyController;
92 ForceActuatorApplicationSettings *_forceActuatorApplicationSettings;
93
94 PID _fx;
95 PID _fy;
96 PID _fz;
97 PID _mx;
98 PID _my;
99 PID _mz;
100
101 MTM1M3_logevent_forceSetpointWarningC *_forceSetpointWarning;
102 MTM1M3_appliedBalanceForcesC *_appliedBalanceForces;
103 MTM1M3_logevent_preclippedBalanceForcesC *_preclippedBalanceForces;
104};
105
106} /* namespace SS */
107} /* namespace M1M3 */
108} /* namespace LSST */
109
110#endif /* LSST_M1M3_SS_FORCECONTROLLER_BALANCEFORCECOMPONENT_H_ */
Distributes balance forces.
Definition BalanceForceComponent.h:54
void postUpdateActions() override
Called after update to forces.
Definition BalanceForceComponent.cpp:196
void applyBalanceForcesByMirrorForces(float xForce, float yForce, float zForce, float xMoment, float yMoment, float zMoment)
Called from ForceController::updateAppliedForces.
Definition BalanceForceComponent.cpp:80
void postEnableDisableActions() override
Called after enable/disable changes.
Definition BalanceForceComponent.cpp:190
(Almost) constant force actuator values.
Definition ForceActuatorApplicationSettings.h:87
Abstract parent class of all force components.
Definition ForceComponent.h:65
Implements PID discrete time controller.
Definition PID.h:50
Controls mirror safety.
Definition SafetyController.h:50
Parameters for PID calculations.
Definition PIDParameters.h:36