X-Git-Url: https://bilbo.iut-bm.univ-fcomte.fr/and/gitweb/loba.git/blobdiff_plain/8996be78fd84b1a3e10a2b7e66b264e28b524ebd..324204969dba501413a9f62de983806a6fddd6a0:/loba_makhoul.cpp?ds=sidebyside diff --git a/loba_makhoul.cpp b/loba_makhoul.cpp index dcce7b7..cfc9483 100644 --- a/loba_makhoul.cpp +++ b/loba_makhoul.cpp @@ -2,40 +2,28 @@ XBT_LOG_EXTERNAL_DEFAULT_CATEGORY(loba); -#include -#include #include "loba_makhoul.h" void loba_makhoul::load_balance() { - using std::tr1::bind; - using std::tr1::placeholders::_1; - using std::tr1::placeholders::_2; - pneigh_sort_by_load(std::less()); - print_loads_p(false, xbt_log_priority_debug); - // find limit between least loaded neighbors, and more loaded ones - pneigh_type::iterator bound = - std::lower_bound(pneigh.begin(), pneigh.end(), - get_load(), - bind(std::less(), - bind(&neighbor::get_load, _1), _2)); - - // compute load differences - std::vector delta(bound - pneigh.begin()); - std::transform(pneigh.begin(), bound, delta.begin(), - bind(std::minus(), - get_load(), bind(&neighbor::get_load, _1))); - - // send load... double alpha = 1.0 / (pneigh.size() + 1.0); + double my_load = get_load(); + bool cont = true; for (unsigned i = 0 ; - i < delta.size() && pneigh[i]->get_load() < get_load() ; ++i) { - double balance = delta[i] * alpha; - send(pneigh[i], balance); - XBT_DEBUG("sent %g to %s", balance, pneigh[i]->get_name()); + cont && i < pneigh.size() && pneigh[i]->get_load() < my_load ; ++i) { + + double delta = my_load - pneigh[i]->get_load(); + double transfer = alpha * delta; + XBT_DEBUG("delta = %g ; transfer = %g", delta, transfer); + if (pneigh[i]->get_load() + transfer <= get_load() - transfer) { + send(pneigh[i], transfer); + XBT_DEBUG("sent %g to %s", transfer, pneigh[i]->get_name()); + } else { + cont = false; + } } }