1
0
Fork 0
mirror of https://git.rwth-aachen.de/acs/public/villas/node/ synced 2025-03-23 00:00:01 +01:00
VILLASnode/common/lib/dsp/pid.cpp

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

56 lines
1.1 KiB
C++
Raw Normal View History

2019-04-12 09:45:12 +02:00
/** A PID controller.
*
* @author Steffen Vogel <post@steffenvogel.de>
2022-03-15 09:05:42 -04:00
* @copyright 2014-2022, Institute for Automation of Complex Power Systems, EONERC
2022-05-19 17:40:10 +02:00
* @license Apache License 2.0
2019-04-12 09:45:12 +02:00
*********************************************************************************/
#include <iostream>
#include <cmath>
#include <villas/dsp/pid.hpp>
using namespace std;
using namespace villas::dsp;
PID::PID(double _dt, double _max, double _min, double _Kp, double _Kd, double _Ki) :
dt(_dt),
max(_max),
min(_min),
Kp(_Kp),
Kd(_Kd),
Ki(_Ki),
pre_error(0),
integral(0)
2019-04-12 09:45:12 +02:00
{ }
double PID::calculate(double setpoint, double pv)
{
// Calculate error
2019-04-12 09:45:12 +02:00
double error = setpoint - pv;
// Proportional term
2019-04-12 09:45:12 +02:00
double Pout = Kp * error;
// Integral term
2019-04-12 09:45:12 +02:00
integral += error * dt;
double Iout = Ki * integral;
// Derivative term
2019-04-12 09:45:12 +02:00
double derivative = (error - pre_error) / dt;
double Dout = Kd * derivative;
// Calculate total output
2019-04-12 09:45:12 +02:00
double output = Pout + Iout + Dout;
// Restrict to max/min
2019-04-12 09:45:12 +02:00
if (output > max)
output = max;
else if (output < min)
output = min;
// Save error to previous error
2019-04-12 09:45:12 +02:00
pre_error = error;
return output;
}