Mercurial > hg > beaglert
view include/VirtualClock.h @ 149:134bff10e561 ClockSync
Added simple one-variable one-measurement Kalman filter, Pid controller(which output is not used). Virtual clock is now much more precise and reactive for period. Still it is lagging behind a bit on the overall offset.
author | Giulio Moro <giuliomoro@yahoo.it> |
---|---|
date | Mon, 21 Sep 2015 03:12:21 +0100 |
parents | 44d07fa9bd03 |
children | ebbfb154351a |
line wrap: on
line source
#ifndef VIRTUAL_CLOCK_H_INCLUDED #define VIRTUAL_CLOCK_H_INCLUDED #include "math.h" #include "stats.hpp" #include "Clock.h" #include "IirFilter.h" #include "Kalman.h" #ifdef USE_JUCE #else #include <BeagleRT.h> #endif /* USE_JUCE */ class VirtualClock{ private: myClock_t startTime; myClock_t startTimeOffset; myClock_t lastSyncTime; // myClock_t lastSyncEstimatedTime; double lastSyncEstimatedTime; bool firstRun; double elapsedPeriods; double elapsedPeriodsOffset; double blockPeriod; double period; MovingAverage<double> movingAverage; IirFilter iir; KalmanOne kalman; public: void init(float initialValueUs); VirtualClock(); /** Call this method at regular intervals to sync che virtual clock */ void sync(); /** Call this method asynchronously, passing a number of equally spaced events that have elapsed since the last call. */ void sync(double numPeriods); /** Get the current time according to the VirtualClock. @return Time elapsed since the first call to sync(), in period units. */ double getNow(); /** Get the length of the period. Get the length of the period (difference between calls to sync() after various filtering operations) */ double getPeriod(); /** * Add an offset to the number of elapsed periods. * * Add an offset to the number of elapsed periods. It also compensates for the corresponding time offset. */ void addOffset(double periodOffset); }; #endif /* VIRTUAL_CLOCK_H_INCLUDED */