for (i = 0; i < var->cnsts_number; i++) {
elem = &var->cnsts[i];
xbt_swag_remove(elem, &(elem->constraint->element_set));
+ xbt_swag_remove(elem, &(elem->constraint->active_element_set));
if (!xbt_swag_size(&(elem->constraint->element_set)))
make_constraint_inactive(sys, elem->constraint);
}
{
lmm_variable_disable(sys, var);
-
+ memset(var->cnsts,0,var->cnsts_size*sizeof(s_lmm_element_t));
xbt_free(var->cnsts);
xbt_free(var);
}
if(elem->variable->weight <=0) break;
if ((elem->value > 0)) {
cnst->usage += elem->value / elem->variable->weight;
- insert_active_elem_in_constraint(elem);
+ make_elem_active(elem);
}
}
cnst = elem->constraint;
cnst->remaining -= elem->value * var->value;
cnst->usage -= elem->value / var->weight;
- remove_active_elem_in_constraint(elem);
+ make_elem_inactive(elem);
}
xbt_swag_remove(var, var_list);
}
void lmm_update_variable_weight(lmm_system_t sys, lmm_variable_t var,
double weight)
{
+ int i ;
+ lmm_element_t elem;
+
sys->modified = 1;
var->weight = weight;
xbt_swag_remove(var,&(sys->variable_set));
if(weight) xbt_swag_insert_at_head(var,&(sys->variable_set));
else xbt_swag_insert_at_tail(var,&(sys->variable_set));
-}
+ for (i = 0; i < var->cnsts_number; i++) {
+ elem = &var->cnsts[i];
+ xbt_swag_remove(elem, &(elem->constraint->element_set));
+ if(weight) xbt_swag_insert_at_head(elem, &(elem->constraint->element_set));
+ else xbt_swag_insert_at_tail(elem, &(elem->constraint->element_set));
+ }
+}
double lmm_get_variable_weight(lmm_variable_t var)