Important changes to repositories hosted on mbed.com
Mbed hosted mercurial repositories are deprecated and are due to be permanently deleted in July 2026.
To keep a copy of this software download the repository Zip archive or clone locally using Mercurial.
It is also possible to export all your personal repositories from the account settings page.
PID.cpp
- Committer:
- ryosukenanoda
- Date:
- 2020-12-30
- Revision:
- 0:4b3a2875ad1d
- Child:
- 1:e2fb92398c1f
File content as of revision 0:4b3a2875ad1d:
#include "mbed.h"
#include "PID.h"
PID::PID(float p, float i, float d) {
    _p = p;
    _i = i;
    _d = d;
    target_val = 0.0;
    integral_val = 0.0;
    last_time = 0; //us
    last_val = 0.0;
    timer.start();
};
float PID::get_input(float val) {
    int now_time = timer.read_us();
    float dt = now_time - last_time;
    dt /= pow(10.0, 6.0);
    val = val - target_val;
    integral_val += (last_val * val) / 2 * dt;
    float d_val = (val - last_val) / dt;
    return _p * val+ _i * integral_val + _d * d_val;
};
void PID::set_target(float val) {
    target_val = val;
    reset_integral_val();
};
void PID::reset_integral_val() {
    integral_val = 0.0;
};