paysages3d/src/render/software/RenderProgress.cpp

105 lines
2.1 KiB
C++
Raw Normal View History

#include "RenderProgress.h"
#include "Mutex.h"
#include "Timing.h"
2015-09-13 20:38:44 +00:00
#include "Logs.h"
RenderProgress::RenderProgress(int count) {
lock = new Mutex();
global = 0.0;
2015-12-17 00:13:20 +00:00
step = 1.0 / to_double(count);
2015-11-02 22:39:34 +00:00
start_time = 0;
2015-09-13 20:38:44 +00:00
end_time = 0;
2015-11-02 22:39:34 +00:00
reset();
}
paysages::software::RenderProgress::~RenderProgress() {
delete lock;
}
void RenderProgress::reset() {
2015-09-09 22:40:47 +00:00
lock->acquire();
global = 0.0;
while (not subs.empty()) {
2015-09-09 22:40:47 +00:00
subs.pop();
}
start_time = Timing::getRelativeTimeMs();
2015-09-13 20:38:44 +00:00
2015-11-02 22:39:34 +00:00
prev_est_spent = 0;
prev_est_done = 0.0;
prev_est_speed = 0.0;
2015-09-09 22:40:47 +00:00
lock->release();
}
void RenderProgress::add(int value) {
lock->acquire();
2015-12-17 00:13:20 +00:00
global += step * to_double(value);
lock->release();
}
void RenderProgress::enterSub(int count) {
struct RenderSub sub;
sub.start = global;
sub.end = global + step;
sub.count = count;
sub.previous_step = step;
lock->acquire();
subs.push(sub);
2015-12-17 00:13:20 +00:00
step /= to_double(count);
lock->release();
}
void RenderProgress::exitSub() {
lock->acquire();
struct RenderSub sub = subs.top();
global = sub.end;
step = sub.previous_step;
subs.pop();
lock->release();
}
2015-09-13 20:38:44 +00:00
void RenderProgress::end() {
if (subs.size() > 0) {
2015-12-13 19:08:38 +00:00
Logs::error("Software") << subs.size() << " progress subs remaining at the end of render" << endl;
2015-09-13 20:38:44 +00:00
}
end_time = Timing::getRelativeTimeMs();
2015-09-13 20:38:44 +00:00
}
unsigned long RenderProgress::getDuration() const {
if (end_time) {
2015-09-13 20:38:44 +00:00
return end_time - start_time;
} else {
return Timing::getRelativeTimeMs() - start_time;
2015-09-13 20:38:44 +00:00
}
}
unsigned long RenderProgress::estimateRemainingTime() {
2015-11-02 22:39:34 +00:00
unsigned long spent = getDuration();
2015-12-17 00:13:20 +00:00
double speed = (global - prev_est_done) / to_double(spent - prev_est_spent);
2015-11-02 22:39:34 +00:00
prev_est_speed = prev_est_speed ? (prev_est_speed * 0.8 + speed * 0.2) : speed;
if (spent - prev_est_spent > 5000) {
2015-11-02 22:39:34 +00:00
prev_est_spent = spent;
prev_est_done = global;
}
if (prev_est_speed > 0.0000000001) {
2015-11-02 22:39:34 +00:00
return (unsigned long)((1.0 - global) / prev_est_speed);
} else {
2015-11-02 22:39:34 +00:00
return 0;
2015-09-13 20:38:44 +00:00
}
}