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.
Dependencies: HIDScope QEI biquadFilter mbed
Fork of NR_method by
PID_controler.cpp
- Committer:
- fabuled
- Date:
- 2018-11-01
- Revision:
- 6:96fcb711f300
- Parent:
- 2:f68fd7b1c655
File content as of revision 6:96fcb711f300:
#include "PID_controler.h"
#include "mbed.h"
#include "BiQuad.h"
#include <math.h>
#include <stdio.h>
#include <iostream>
#include <stdlib.h>
#include <ctime>
#include <QEI.h>
double PID_controller(double error, double Kp, double Ki, double Kd, double Ts)
{
static double error_integral = 0;
static double error_prev = error;
static BiQuad LowPassFilter(0.0640, 0.1279, 0.0640, -1.1683, 0.4241);
//proportional part
double u_k = Kp * error;
//Integral part
error_integral = error_integral + error * Ts;
double u_i = Ki * error_integral;
// Derivative part
double error_derivative = (error - error_prev)/Ts;
double filtered_error_derivative = LowPassFilter.step(error_derivative);
double u_d = Kd * filtered_error_derivative;
error_prev = error;
return ((u_k + u_i + u_d)/5000);
}
