Mercurial > hg > beaglert
view core/Pid.cpp @ 150:ebbfb154351a ClockSync
Now leveraging BBB's lock between xenomai clock and audio clock for ultra-accurate, low-latency clocking. CAVEAT: fractions of samples drifts will occurr every time the clock is changed
author | Giulio Moro <giuliomoro@yahoo.it> |
---|---|
date | Tue, 22 Sep 2015 04:09:13 +0100 |
parents | 134bff10e561 |
children | 8f98b32d0e23 |
line wrap: on
line source
/* * Pid.cpp * * Created on: 14 Sep 2015 * Author: giulio */ #include "Pid.h" Pid::Pid(){ integralError = 0; pastError = 0; error = 0; differentialError = 0; kp = 5; ki = 2; kd = 0.8; idleTimeout = 0; timeoutCount = 0; output = 0; // printf("----------%f %f %f %f %f %f\n", kp, error, ki, integralError, kd, differentialError); } void Pid::updateIntegralError(){ integralError += (error + pastError) * 0.5 * ts; } void Pid::updateDifferentialError(){ differentialError = (error - pastError) / ts; } float Pid::setError(float anError){ pastError = error; error = anError; ts = 1; //TODO: this should be passed as a parameter, unless setError() gets always called at constant intervals updateIntegralError(); updateDifferentialError(); output= kp * error + ki * integralError + kd * differentialError; // printf("%f %f %f %f %f %f %f\n", output, kp, error, ki, integralError, kd, differentialError); return output; } float Pid::getOutput(){ return output; }