static double conf_penalty_bound = 100, conf_stagnation_bound = 10;
static int conf_iteration_limit = 200;
+static double conf_rank_distance_w = 1, conf_rank_overlap_w = 1, conf_rank_omittment_w = 1;
+
static int breed_pop_size;
static int breed_rbest_size;
CF_DOUBLE("MutateRegenBound", &conf_mutate_regen_bound),
CF_DOUBLE("MutateChvarBound", &conf_mutate_chvar_bound),
CF_DOUBLE("ElitePopSize", &conf_elite_pop_size),
+ CF_DOUBLE("DistanceWeight", &conf_rank_distance_w),
+ CF_DOUBLE("OverlapWeight", &conf_rank_overlap_w),
+ CF_DOUBLE("OmittmentWeight", &conf_rank_omittment_w),
CF_END
}
};
DEBUG(dbg_rank, VERBOSITY_INDIVIDUAL, "Individual %d\n", i);
population1[i]->penalty = 0;
- penalty = individual_omittment(population1[i]);
+ penalty = conf_rank_omittment_w * individual_omittment(population1[i]);
DEBUG(dbg_rank, VERBOSITY_INDIVIDUAL, "Increasing penalty by %d for omittment\n", penalty);
population1[i]->penalty += penalty;
- penalty = individual_overlap(population1[i]);
+ penalty = conf_rank_overlap_w * individual_overlap(population1[i]);
DEBUG(dbg_rank, VERBOSITY_INDIVIDUAL, "Increasing penalty by %d for overlap\n", penalty);
population1[i]->penalty += penalty;
- penalty = individual_distances(population1[i]);
+ penalty = conf_rank_distance_w * individual_distances(population1[i]);
DEBUG(dbg_rank, VERBOSITY_INDIVIDUAL, "Increasing penalty by %d for distances\n", penalty);
population1[i]->penalty += penalty;
}