giuliomoro@135: #include "VirtualClock.h" giuliomoro@135: void VirtualClock::init(){ giuliomoro@135: firstRun=true; giuliomoro@135: movingAverage.setLength(31); //TODO: a better filtering algorithm ( Did you say Kalman?) giuliomoro@135: period=-1; giuliomoro@135: } giuliomoro@135: giuliomoro@135: VirtualClock::VirtualClock(){ giuliomoro@135: init(); giuliomoro@135: } giuliomoro@135: void VirtualClock::sync(){ giuliomoro@135: sync(1); giuliomoro@135: } giuliomoro@135: void VirtualClock::sync(double count){ giuliomoro@135: myClock_t currentTime=Clock::getTimeUs(); giuliomoro@135: if(firstRun==true){ giuliomoro@135: firstRun=false; giuliomoro@135: startTime=currentTime; giuliomoro@135: } else { giuliomoro@135: period=movingAverage.add((currentTime-lastSync)/count); //TODO: replace with Kalman filter giuliomoro@135: } giuliomoro@135: lastSync=currentTime; giuliomoro@139: // printf("lastSync: %lld\n",lastSync-startTime); giuliomoro@135: } giuliomoro@135: giuliomoro@135: double VirtualClock::getNow(){ giuliomoro@139: myClock_t currentSystemTime=Clock::getTimeUs(); giuliomoro@135: if(period<=0){ giuliomoro@139: return currentSystemTime; giuliomoro@135: } giuliomoro@135: // double beginningOfPeriod=lastSync; // TODO: if sync() does not get called every time (but e.g. only every so often), giuliomoro@135: // then this line (and the class) needs editing giuliomoro@139: myClock_t elapsed=(currentSystemTime-startTime); giuliomoro@139: double now=elapsed/(double)period; giuliomoro@139: // printf("elapsed=%lld; sincelastSync=%lld; period=%f; now=%f\n", elapsed, currentSystemTime-lastSync, period, now); giuliomoro@139: return now; giuliomoro@135: } giuliomoro@135: giuliomoro@135: double VirtualClock::getPeriod(){ giuliomoro@135: return period; giuliomoro@135: }