X-Git-Url: http://info.iut-bm.univ-fcomte.fr/pub/gitweb/simgrid.git/blobdiff_plain/bda6e0c064e2ebbac5dc3b5f780bb5e6cb61e9b0..13c5da75068f441142fcf93d4d78124a7885d116:/src/surf/network.c diff --git a/src/surf/network.c b/src/surf/network.c index 7f207d0d23..a8596dcf41 100644 --- a/src/surf/network.c +++ b/src/surf/network.c @@ -20,7 +20,7 @@ xbt_dict_t network_card_set = NULL; double latency_factor = 1.0; /* default value */ double bandwidth_factor = 1.0; /* default value */ - +double weight_S_parameter = 0.0; /* default value */ int card_number = 0; int host_number = 0; @@ -404,7 +404,7 @@ static void update_actions_state(double now, double delta) } if ((action->latency == 0.0) && !(action->suspended)) lmm_update_variable_weight(network_maxmin_system, action->variable, - action->lat_current); + action->weight); } double_update(&(action->generic_action.remains), lmm_variable_getvalue(action->variable) * deltap); @@ -435,9 +435,24 @@ static void update_resource_state(void *id, /* value, event_type); */ if (event_type == nw_link->bw_event) { + double delta = weight_S_parameter/value - weight_S_parameter/nw_link->bw_current; + lmm_variable_t var = NULL; + lmm_element_t elem = NULL; + surf_action_network_CM02_t action = NULL; + nw_link->bw_current = value; lmm_update_constraint_bound(network_maxmin_system, nw_link->constraint, bandwidth_factor*nw_link->bw_current); + if(weight_S_parameter>0) { + while ((var= lmm_get_var_from_cnst + (network_maxmin_system, nw_link->constraint, &elem))) { + action = lmm_variable_id(var); + action->weight += delta; + if (!(action->suspended)) + lmm_update_variable_weight(network_maxmin_system, action->variable, + action->weight); + } + } } else if (event_type == nw_link->lat_event) { double delta = value - nw_link->lat_current; lmm_variable_t var = NULL; @@ -449,6 +464,7 @@ static void update_resource_state(void *id, (network_maxmin_system, nw_link->constraint, &elem))) { action = lmm_variable_id(var); action->lat_current += delta; + action->weight += delta; if (action->rate < 0) lmm_update_variable_bound(network_maxmin_system, action->variable, SG_TCP_CTE_GAMMA / (2.0 * @@ -462,7 +478,7 @@ static void update_resource_state(void *id, lat_current))); if (!(action->suspended)) lmm_update_variable_weight(network_maxmin_system, action->variable, - action->lat_current); + action->weight); } } else if (event_type == nw_link->state_event) { @@ -540,14 +556,16 @@ static surf_action_t communicate(void *src, void *dst, double size, action->rate = rate; action->latency = 0.0; - for (i = 0; i < route_size; i++) + action->weight = 0.0; + for (i = 0; i < route_size; i++) { action->latency += route[i]->lat_current; + action->weight += route[i]->lat_current + weight_S_parameter/route[i]->bw_current; + } /* LARGE PLATFORMS HACK: Add src->link and dst->link latencies */ action->lat_current = action->latency; action->latency *= latency_factor; - /* LARGE PLATFORMS HACK: lmm_variable_new(..., total_route_size)*/ if (action->latency > 0) @@ -645,7 +663,7 @@ static void action_resume(surf_action_t action) ((surf_action_network_CM02_t) action)-> variable, ((surf_action_network_CM02_t) action)-> - lat_current); + weight); ((surf_action_network_CM02_t) action)->suspended = 0; } } @@ -784,6 +802,7 @@ void surf_network_model_init_LegrandVelho(const char *filename) latency_factor = 10.4; bandwidth_factor = 0.92; + weight_S_parameter = 8775; update_model_description(surf_network_model_description, "LegrandVelho",