X-Git-Url: https://bilbo.iut-bm.univ-fcomte.fr/and/gitweb/loba.git/blobdiff_plain/76d4afa3496d7710e7548b6bca27473db7c9308c..6f21403d553131b282aeff52a2c496d71d05c97e:/loba_makhoul.cpp?ds=sidebyside diff --git a/loba_makhoul.cpp b/loba_makhoul.cpp index 2fca60b..cfc9483 100644 --- a/loba_makhoul.cpp +++ b/loba_makhoul.cpp @@ -2,38 +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; - 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::find_if(pneigh.begin(), pneigh.end(), - bind(std::less_equal(), - get_load(), bind(&neighbor::get_load, _1))); - - // 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; + } } }