, * Andreas Oesterreicher , * Rudolf Hangl and * gerald Raab . */ class studentnote { var $conn; // resource DB-Handle var $errormsg; // string var $new; // boolean var $beispiele = array(); // lehreinheit Objekt //Vars var $uebung_id; // serial var $gewicht; // smalint var $punkte; // Real var $note; var $note_gesamt; var $negativ; var $fehlt; // ************************************************************************* // * Konstruktor - Uebergibt die Connection und laedt optional eine Uebung // * @param $conn Datenbank-Connection // * $uebung_id // * $unicode Gibt an ob die Daten mit UNICODE Codierung // * oder LATIN9 Codierung verarbeitet werden sollen // ************************************************************************* function studentnote($conn, $unicode=false) { $this->conn = $conn; if($unicode) $qry = "SET CLIENT_ENCODING TO 'UNICODE';"; else $qry = "SET CLIENT_ENCODING TO 'LATIN9';"; if(!pg_query($this->conn,$qry)) { $this->errormsg = 'Encoding konnte nicht gesetzt werden'; return false; } } function calc_gesamtnote($lehreinheit_id, $ss, $student_uid) { { $conn = $this->conn; $studentgesamtnote = 0; $counter = 0; $gewichte = 0; $negativ_all = false; $note_x_gewicht = 0; $note_x_gewicht_l1 = 0; $gewichte_l1 = 0; $fehlt_all = false; $beispiele = false; $ueb1_obj = new uebung($conn); $ueb1_obj->load_uebung($lehreinheit_id,1); foreach($ueb1_obj->uebungen as $ueb1) { $this->calc_l1_note($ueb1->uebung_id, $student_uid, $lehreinheit_id); $note_x_gewicht_l1 += ($this->l1_note * $this->l1_gewicht); $gewichte_l1 += $this->l1_gewicht; if ($this->negativ) $negativ_all = $this->negativ; if ($this->fehlt) $fehlt_all = $this->fehlt; } if ($gewichte_l1 > 0) { $this->studentgesamtnote = ($note_x_gewicht_l1 / $gewichte_l1); $this->negativ = $negativ_all; $this->fehlt = $fehlt_all; } else { $this->studentgesamtnote = "n"; $this->negativ = $negativ_all; $this->fehlt = $fehlt_all; } } } function calc_l1_note($uebung_id, $student_uid, $lehreinheit_id) { { $conn = $this->conn; $studentgesamtnote = 0; $counter = 0; $gewichte = 0; $negativ = false; $note_x_gewicht = 0; $note_x_gewicht_l1 = 0; $gewichte_l1 = 0; $fehlt = false; $beispiele = false; $punkte_gesamt = 0; $punkte_mitarbeit = 0; $punkte_eingetragen = 0; $l1_gewicht = 0; $ueb1 = new uebung($conn, $uebung_id); $ueb_obj = new uebung($conn); $ueb_obj->load_uebung($lehreinheit_id, 2, $uebung_id); if ($ueb_obj->uebungen) { $note_x_gewicht = 0; $gewichte = 0; $punkte_gesamt = 0; foreach ($ueb_obj->uebungen as $ueb) { if ($ueb->abgabe && !$ueb->beispiele) { if ($this->calc_note($ueb->uebung_id, $student_uid)) { if (is_numeric($this->note)) { if ($ueb->positiv && $this->note == 5) $negativ = true; $note_x_gewicht += ($this->note * $this->gewicht); $gewichte += $this->gewicht; } else { $fehlt = true; if ($ueb->positiv) $negativ = true; } } } else { $this->calc_punkte($ueb->uebung_id, $student_uid); $punkte_gesamt += $this->punkte_gesamt; $punkte_mitarbeit += $this->punkte_mitarbeit; $punkte_eingetragen += $this->punkte_eingetragen; $beispiele = true; } } if ($gewichte > 0) { $l1_note = ($note_x_gewicht / $gewichte); $l1_gewicht = $ueb1->gewicht; } //if ($punkte_gesamt > 0) if ($beispiele) { if ($ueb1->prozent == 't') { $qry = "SELECT sum(tbl_beispiel.punkte) as punktegesamt_alle FROM campus.tbl_beispiel, campus.tbl_uebung WHERE tbl_uebung.uebung_id=tbl_beispiel.uebung_id AND tbl_uebung.lehreinheit_id='$lehreinheit_id' and tbl_uebung.liste_id = '$ueb1->uebung_id'"; $punkte_moeglich=1; if($result=pg_query($conn, $qry)) if($row = pg_fetch_object($result)) $punkte_moeglich = $row->punktegesamt_alle; if ($punkte_moeglich == 0) $punkte_moeglich = 1; $punkte_ns = $punkte_gesamt/$punkte_moeglich*100; } else $punkte_ns = $punkte_gesamt; //Prozentpunkte $qry = "SELECT min(note) as note from campus.tbl_notenschluesseluebung where punkte <= '".$punkte_ns."' and uebung_id = '".$ueb1->uebung_id."'"; // Punkteanzahl //$qry = "SELECT min(note) as note from campus.tbl_notenschluesseluebung where punkte <= '".$punkte_gesamt."' and uebung_id = '".$ueb1->uebung_id."'"; if($result=pg_query($this->conn, $qry)) { if($row = pg_fetch_object($result)) $note = $row->note; else $note = 5; } if ($ueb1->positiv && ($note == 5)) $negativ = true; $l1_note = $note; //$l1_note = ($note * $ueb1->gewicht); if ($note != null) $l1_gewicht = $ueb1->gewicht; else $l1_gewicht = 0; } if ($ueb1->positiv && $beispiele && ($punkte_gesamt == 0)) $negativ = true; //else if ($beispiele && ($punkte_gesamt == 0)) // $felt = true; } // keine kreuzerllisten/abgaben else { $s = new uebung($conn); $s->load_studentuebung($student_uid, $ueb1->uebung_id); if ($s->note && $ueb1->gewicht) { if ($s->note == 5 && $ueb1->positiv) $negativ = true; $l1_note= $s->note; $l1_gewicht = $ueb1->gewicht; } else { $fehlt = true; if ($ueb1->positiv) $negativ = true; } } if ($l1_gewicht > 0) { $this->l1_note = $l1_note; $this->l1_gewicht = $l1_gewicht; $this->negativ = $negativ; $this->fehlt = $fehlt; $this->punkte_gesamt_l1 = $punkte_gesamt; $this->punkte_eingetragen_l1 = $punkte_eingetragen; $this->punkte_mitarbeit_l1 = $punkte_mitarbeit; } else { $this->l1_note = null; $this->l1_gewicht = 0; $this->negativ = $negativ; $this->fehlt = $fehlt; $this->punkte_gesamt_l1 = null; $this->punkte_eingetragen_l1 = null; $this->punkte_mitarbeit_l1 = null; } } } // ********************************************************* // * berechnet die note der übung // * @param uebung_id, student_uid // * setzt this->note, this->gewicht // ********************************************************* function calc_note($uebung_id, $student_uid) { if(!is_numeric($uebung_id)) { $this->errormsg='Uebung_id muss eine gueltige Zahl sein'; return false; } else { $note = null; $punkte_eingetragen = 0; $punkte_gesamt = 0; $mitarbeit = 0; $ueb = new uebung($this->conn); $ueb->load($uebung_id); if($ueb->load_studentuebung($student_uid, $uebung_id)) { $this->note = $ueb->note; $this->gewicht = $ueb->gewicht; return true; } else { $this->note = null; $this->gewicht = 0; return true; } } } // ********************************************************* // * berechnet die punkte der übung (kreuzerlliste) // * @param uebung_id, student_uid // * setzt this->punkte_gesamt // ********************************************************* function calc_punkte($uebung_id, $student_uid) { if(!is_numeric($uebung_id)) { $this->errormsg='Uebung_id muss eine gueltige Zahl sein'; return false; } else { $note = null; $punkte_eingetragen = 0; $punkte_gesamt = 0; $mitarbeit = 0; $ueb = new uebung($this->conn); //Eingetragen diese Kreuzerlliste $qry = "SELECT sum(punkte) as punkteeingetragen FROM campus.tbl_beispiel JOIN campus.tbl_studentbeispiel USING(beispiel_id) WHERE uebung_id='$uebung_id' AND student_uid='$student_uid' AND vorbereitet=true"; $punkte_eingetragen=0; if($result=pg_query($this->conn, $qry)) if($row = pg_fetch_object($result)) $punkte_eingetragen = ($row->punkteeingetragen!=''?$row->punkteeingetragen:0); if($ueb->load_studentuebung($student_uid, $uebung_id)) { $mitarbeit = $ueb->mitarbeitspunkte; } $punkte_gesamt = $punkte_eingetragen + $mitarbeit; $this->punkte_gesamt = $punkte_gesamt; $this->punkte_eingetragen = $punkte_eingetragen; $this->punkte_mitarbeit = $mitarbeit; return true; } } } ?>