M1M3 Support System
Loading...
Searching...
No Matches
PIDParameters.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 PIDPARAMETERS_H_
25#define PIDPARAMETERS_H_
26
27#include <math.h>
28
29namespace LSST {
30namespace M1M3 {
31namespace SS {
32
37 PIDParameters() { Timestep = P = I = D = N = NAN; }
38
39 PIDParameters(const PIDParameters &pid) {
40 Timestep = pid.Timestep;
41 P = pid.P;
42 I = pid.I;
43 D = pid.D;
44 N = pid.N;
45 }
46
47 PIDParameters(double _timestep, double _p, double _i, double _d, double _n) {
48 Timestep = _timestep;
49 P = _p;
50 I = _i;
51 D = _d;
52 N = _n;
53 }
54
55 //* Length of step (seconds)
56 double Timestep;
57 //* Proportional gain (unitless)
58 double P;
59 //* Integral gain (unitless)
60 double I;
61 //* Derivative gain (unitless)
62 double D;
68 double N;
69};
70
71} // namespace SS
72} // namespace M1M3
73} // namespace LSST
74
75#endif /* PIDPARAMETERS_H_ */
Parameters for PID calculations.
Definition PIDParameters.h:36
double N
The N term.
Definition PIDParameters.h:68