X-Git-Url: https://bilbo.iut-bm.univ-fcomte.fr/and/gitweb/loba.git/blobdiff_plain/de044764fcc724b2bbfa26ccf77804070498aa12..8bdfda4ed37966fcac00b37ddca740afaba48b28:/process.cpp?ds=sidebyside diff --git a/process.cpp b/process.cpp index 23c7abf..99bd039 100644 --- a/process.cpp +++ b/process.cpp @@ -65,10 +65,21 @@ process::~process() int process::run() { + double next_iter_after_date = 0.0; INFO1("Initial load: %g", load); VERB0("Starting..."); comp_iter = lb_iter = 0; while (true) { + if (opt::min_iter_duration) { + double now = MSG_get_clock(); + if (now < next_iter_after_date){ + double delay = next_iter_after_date - now; + DEBUG1("sleeping for %g s", delay); + MSG_process_sleep(next_iter_after_date - now); + } + next_iter_after_date = MSG_get_clock() + opt::min_iter_duration; + } + if (load > 0.0) { ++comp_iter; if (opt::log_rate && comp_iter % opt::log_rate == 0) { @@ -99,6 +110,10 @@ int process::run() break; if (opt::lb_maxiter && lb_iter >= opt::lb_maxiter) break; + if (opt::time_limit && MSG_get_clock() >= opt::time_limit) { + VERB2("Reached time limit: %g/%g", MSG_get_clock(), opt::time_limit); + break; + } // block on receiving unless there is something to compute or // to send