diff --git a/plugins/evaluations/eval_calc_scores.php b/plugins/evaluations/eval_calc_scores.php
index c6845041..188dc327 100644
--- a/plugins/evaluations/eval_calc_scores.php
+++ b/plugins/evaluations/eval_calc_scores.php
@@ -31,9 +31,9 @@
include "sfiab_common.inc.php"; // check SFIAB install and get config etc.
include "eval_common.inc.php"; // check Evaluations setup and get eval_config
include "eval_menu_inc.php";
-echo "
Note: For now, this just calculates scores for every project in table 'judges_teams_timeslots_projects_link'
";
-echo " and lists just the project number for each and then lists the details for the last project in the list.
";
-echo " and storese the results into table eval_projects and 'judges_teams_timeslots_projects_link' score field
";
+echo "
Note: For now, this updates the score field in 'judges_teams_timeslots_projects_link' for every team/project with a complete evaluation entry
";
+echo " and updates the eval_score and eval_score_status fields in table eval_projects for every project for which a score can be calculated.
";
+echo "For test purposes it lists just the project number for each project, then lists the scores details for the last project in the list.
";
// do all projects
$q = mysql_query("SELECT DISTINCT projects_id from judges_teams_timeslots_projects_link");
while($r=mysql_fetch_object($q)) {
@@ -50,7 +50,9 @@ while($r=mysql_fetch_object($q)) {
if (is_null($score)) {$score = "NULL";}
$up = mysql_query("UPDATE judges_teams_timeslots_projects_link SET score = ".$score.
" WHERE judges_teams_id = '".$team_id."' AND projects_id = '".$r->projects_id."' ");
- }
+ }
+ // update eval_judges table
+ $up = mysql_query("UPDATE eval_projects SET eval_score = '".$ret_array[eval_score]."', eval_score_status = '".$ret_array[eval_score_status]."' WHERE project_id = '".$r->projects_id."' ");
}
}
echo "
";
diff --git a/plugins/evaluations/eval_common.inc.php b/plugins/evaluations/eval_common.inc.php
index 5db31c5f..18c11679 100644
--- a/plugins/evaluations/eval_common.inc.php
+++ b/plugins/evaluations/eval_common.inc.php
@@ -262,6 +262,7 @@ function calc_scores($project_id)
$list_array[$team] = array(team_id=>$arr[$team][0][0],team_num=>$arr[$team][0][5],proj_num=>$arr[$team][0][6],team_score=>$team_score,team_status=>$err_codes);
} // ****** Loop thr Judge Teams ******************************
// This gets the project score based on the average of the sum of the criteria averages (Dennis Spanogle method)
+ $num_bad_crits = 0;
for ($cc = 0;$cc<$num_criterias;$cc++) {
$judcritttl = 0;
$avg_cnt = 0;
@@ -271,7 +272,8 @@ function calc_scores($project_id)
$level_value =$arr[$jj][$cc][2];
$spec_use = $arr[$jj][$cc][3];
$spec_use_code = $arr[$jj][$cc][4];
- if($spec_use == "no"){
+ // add in the good judge entries for this criteria
+ if($spec_use == "no" && $level_value != -1){
$judcritttl += $level_value * $weight;
$avg_cnt++;
}
@@ -288,12 +290,15 @@ function calc_scores($project_id)
}
}
}
- // have values for this criteria, get average
+ // Get the average for this criteria
if ($avg_cnt >0){
$crit_avg_wtd = $judcritttl/$avg_cnt;
}
- else{
+ else{ // This criteria had no entries so the total score can not be calculated unless weight = 0 then don't care
$crit_avg_wtd = 0;
+ if ($weight > 0){
+ $num_bad_crits ++;
+ }
}
$rst[$cc] = array($crit_avg_wtd,$err_codes);
}
@@ -310,7 +315,12 @@ function calc_scores($project_id)
}
}
}
- $score = $ttl/$max_level_val;
+ if ($num_bad_crits == 0){ // if any criteria had no entries then cannot use the score
+ $score = $ttl/$max_level_val;
+ }
+ else {
+ $score = 0;
+ }
//echo "Project number ".$project_num." (id ".$project_id.") Score=".$score." code: ".$ttlcode."
";
//for ($i=0;$i < $num_judges_teams; $i++){
// echo "id ".$list_array[$i][team_id]." score ".$list_array[$i][team_score]."
";