X-Git-Url: https://bilbo.iut-bm.univ-fcomte.fr/and/gitweb/loba.git/blobdiff_plain/ba8a9c5fbc92dc95fc99d8078b3474fd2fd5a043..1366ceca8a115df18885fa9ae1f11452630d03bf:/loba_simple.cpp?ds=sidebyside diff --git a/loba_simple.cpp b/loba_simple.cpp index 7d4937c..5702fba 100644 --- a/loba_simple.cpp +++ b/loba_simple.cpp @@ -1,9 +1,9 @@ -#include "loba_simple.h" - #include XBT_LOG_EXTERNAL_DEFAULT_CATEGORY(loba); +#include "loba_simple.h" + /* simple version: * load balance with a least-loaded neighbor, * without breaking the ping-pong condition @@ -14,8 +14,8 @@ double loba_simple::load_balance(double my_load) int imax = -1; double min = my_load; double max = -1.0; - for (unsigned i = 0 ; i < neigh.size() ; ++i) { - double l = neigh[i].get_load(); + for (unsigned i = 0 ; i < pneigh.size() ; ++i) { + double l = pneigh[i]->get_load(); if (l >= my_load) continue; if (l < min) { @@ -29,9 +29,10 @@ double loba_simple::load_balance(double my_load) } if (imin != -1) { // found someone - double balance = (my_load - max) / 2; + double balance = (my_load - min) / 2; DEBUG6("%d:%g %d:%g %g %g", imin, min, imax, max, my_load, balance); - neigh[imin].set_to_send(balance); + pneigh[imin]->set_to_send(balance); + pneigh[imin]->add_load(balance); return balance; } else { return 0.0;