/* */ #include "SpeedCalc.h" #include #include namespace aria2 { #define CHANGE_INTERVAL_SEC 15 class Reset { public: void operator()(Time& tm) { tm.reset(); } }; void SpeedCalc::reset() { std::fill(&lengthArray[0], &lengthArray[2], 0); std::for_each(&cpArray[0], &cpArray[2], Reset()); sw = 0; maxSpeed = 0; prevSpeed = 0; start.reset(); accumulatedLength = 0; nextInterval = CHANGE_INTERVAL_SEC; } unsigned int SpeedCalc::calculateSpeed() { uint64_t milliElapsed = cpArray[sw].differenceInMillis(); if(milliElapsed) { unsigned int speed = lengthArray[sw]*1000/milliElapsed; prevSpeed = speed; maxSpeed = std::max(speed, maxSpeed); return speed; } else { return prevSpeed; } } unsigned int SpeedCalc::calculateSpeed(const struct timeval& now) { uint64_t milliElapsed = cpArray[sw].differenceInMillis(now); if(milliElapsed) { unsigned int speed = lengthArray[sw]*1000/milliElapsed; prevSpeed = speed; maxSpeed = std::max(speed, maxSpeed); return speed; } else { return prevSpeed; } } void SpeedCalc::update(size_t bytes) { accumulatedLength += bytes; std::transform(&lengthArray[0], &lengthArray[2], &lengthArray[0], std::bind1st(std::plus(), (uint64_t)bytes)); if(isIntervalOver()) { changeSw(); } } bool SpeedCalc::isIntervalOver() const { return nextInterval <= cpArray[sw].difference(); } void SpeedCalc::changeSw() { lengthArray[sw] = 0; cpArray[sw].reset(); sw ^= 0x01; nextInterval = cpArray[sw].difference()+CHANGE_INTERVAL_SEC; } unsigned int SpeedCalc::getAvgSpeed() const { uint64_t milliElapsed = start.differenceInMillis(); if(milliElapsed) { unsigned int speed = accumulatedLength*1000/milliElapsed; return speed; } else { return 0; } } } // namespace aria2