Mercurial > hg > beaglert
view core/VirtualClock.cpp @ 136:772dbb57442b ClockSync
Implemented xenomai version of Clock
author | Giulio Moro <giuliomoro@yahoo.it> |
---|---|
date | Sun, 13 Sep 2015 21:26:38 +0100 |
parents | e77e2e712fbc |
children | 4e2dd3eb1d28 |
line wrap: on
line source
#include "VirtualClock.h" void VirtualClock::init(){ firstRun=true; movingAverage.setLength(31); //TODO: a better filtering algorithm ( Did you say Kalman?) period=-1; } VirtualClock::VirtualClock(){ init(); } void VirtualClock::sync(){ sync(1); } void VirtualClock::sync(double count){ myClock_t currentTime=Clock::getTimeUs(); if(firstRun==true){ firstRun=false; startTime=currentTime; } else { period=movingAverage.add((currentTime-lastSync)/count); //TODO: replace with Kalman filter } lastSync=currentTime; } double VirtualClock::getNow(){ myClock_t now=Clock::getTimeUs(); if(period<=0){ return now; } // double beginningOfPeriod=lastSync; // TODO: if sync() does not get called every time (but e.g. only every so often), // then this line (and the class) needs editing myClock_t elapsed=(now-startTime); double frac=elapsed/(double)period; // printf("now=%lld; beginningOfPeriod=%f; lastSync=%lld; period=%lld; frac=%f\n", now, beginningOfPeriod, lastSync, period, frac); return frac; } double VirtualClock::getPeriod(){ return period; }