--- loncom/interface/lonstatistics.pm 2002/03/02 01:42:42 1.5
+++ loncom/interface/lonstatistics.pm 2002/03/22 00:18:12 1.12
@@ -1,7 +1,7 @@
# The LearningOnline Network with CAPA
# (Publication Handler
#
-# $Id: lonstatistics.pm,v 1.5 2002/03/02 01:42:42 minaeibi Exp $
+# $Id: lonstatistics.pm,v 1.12 2002/03/22 00:18:12 minaeibi Exp $
#
# Copyright Michigan State University Board of Trustees
#
@@ -30,7 +30,7 @@
# 5/05,7/09,7/25/01,8/11,9/13,9/26,10/5,10/9,10/22,10/26 Behrouz Minaei
# 11/1, 11/4, 11/16, 12/14, 12/16, 12/18,12/20,12/31 Behrouz Minaei
# YEAR=2002
-# 1/22, 2/1, 2/6, 2/25 Behrouz Minaei
+# 1/22, 2/1, 2/6, 2/25, 3/2, 3/6, 3/17, 3/21 Behrouz Minaei
###
package Apache::lonstatistics;
@@ -39,19 +39,23 @@ use strict;
use Apache::Constants qw(:common :http);
use Apache::lonnet();
use Apache::lonhomework;
+use Apache::loncommon;
use HTML::TokeParser;
use GDBM_File;
-#use Benchmark;
# -------------------------------------------------------------- Module Globals
my %hash;
my %CachData;
my %GraphDat;
+my %OpResp;
my %maps;
my %mapsort;
my %section;
my %StuBox;
my %DiscFac;
+my %DisUp;
+my %DisLow;
+my $UpCnt;
my $CurMap;
my $CurSec;
my $CurStu;
@@ -65,7 +69,6 @@ my $OpSel1;
my $OpSel2;
my $OpSelDis1;
my $OpSelDis2;
-my $CurDis=0;
my $OpSel3;
my $OpSel4;
my $GData;
@@ -75,24 +78,95 @@ my $lastres;
my $DiscFlag;
my $HWN;
my $P_Order;
-my %Header = (0,"Homework Problems",1,"#Stdnts",2,"Tries",3,"Mod",
+my %Header = (0,"Homework Sets Order",1,"#Stdnts",2,"Tries",3,"Mod",
4,"Mean",5,"#YES",6,"#yes",7,"%Wrng",8,"DoDiff",
- 9,"S.D.",10,"Skew.",11,"Map");
-# 11,"Dis.F.",12,"Resourse URL");
+ 9,"S.D.",10,"Skew.",11,"D.F.1st",12,"D.F.2nd");#,13,"OpResp");
+
+#------- Processing upperlist and lowerlist according to each problem
+sub ProcessDisc {
+ my @List = @_;
+ @List = sort (@List);
+ my $Count = $#List+1;
+ my $Prb;
+ my @Dis;
+ my $Slvd=0;
+ my $tmp;
+ my $Sum1=0;
+ my $Sum2=0;
+ my $nIdx=0;
+ my $nStud=0;
+ my %Proc;
+ undef %Proc;
+ while ($nIdx<$Count) {
+ ($Prb,$tmp)=split(/\=/,$List[$nIdx]);
+ @Dis=split(/\+/,$tmp);
+ my $Temp = $Prb;
+ do {
+ $nIdx++;
+ $nStud++;
+ $Sum1 += $Dis[0];
+ $Sum2 += $Dis[1];
+ ($Prb,$tmp)=split(/\=/,$List[$nIdx]);
+ @Dis=split(/\+/,$tmp);
+ } while ( $Prb eq $Temp && $nIdx < $Count );
+# $Proc{$Temp}=($Sum1/$nStud).':'.$nStud;
+ $Proc{$Temp}=($Sum1/$nStud).':'.($Sum2/$nStud);
+# $r->print("$nIdx) $Temp --> ($nStud) $Proc{$Temp}
");
+ $Sum1=0;
+ $Sum2=0;
+ $nStud=0;
+ }
+ return %Proc;
+}
+
+
+#------- Creating Discimination factor
+sub Discriminant {
+ my $Count=0;
+ foreach (keys(%DiscFac)){
+ $Count++;
+ }
+ $UpCnt = int(0.27*$Count);
+ my $low=0;
+ my $up=$Count-$UpCnt;
+ my @UpList=();
+ my @LowList=();
+ $Count=0;
+ foreach my $key (sort(keys(%DiscFac))){
+ $Count++;
+ #$r->print("
$Count) $key = $DiscFac{$key}");
+ if ($low < $UpCnt || $Count > $up) {
+ $low++;
+ my $str=$DiscFac{$key};
+ foreach(split(/\:/,$str)){
+ if ($_) {
+ if ($low<$UpCnt){push(@LowList,$_);}
+ else {push(@UpList,$_);}
+ }
+ }
+ }
+ }
+ %DisUp=&ProcessDisc(@UpList);
+ %DisLow=&ProcessDisc(@LowList);
+}
+
+
sub NumericSort {
$a <=> $b;
}
# ------ Create different Student Report
sub StudentReport {
+
my ($sname,$sdom)=@_;
+
if ( $sname eq 'All Students' ) {
$r->print( '
WARNING:
Please select a student
' );
return;
}
- my $shome=&Apache::lonnet::homeserver( $sname,$sdom );
+ my $shome=&Apache::lonnet::homeserver($sname,$sdom);
my $reply=&Apache::lonnet::reply('dump:'.$sdom.':'.$sname.':'.$cid,$shome );
my %result = ();
my $ResId;
@@ -147,7 +221,7 @@ sub StudentReport {
my $PartNo = 0;
undef %TempHash;
foreach (split(/\,/,&Apache::lonnet::metadata($meta,'keys'))){
- if ($_=~/^stores\_(\d+)\_tries$/) {
+ if ($_=~/^stores\_(\w+)\_tries$/) {
my $Part=&Apache::lonnet::metadata($meta,$_.'.part');
if ( $TempHash{"$Part"} eq '' ) {
$TempHash{"$Part"} = $Part;
@@ -157,6 +231,7 @@ sub StudentReport {
$PartNo++;
}
}
+ #if ($_=~/^parameter\_(\w+)\_package$/) {
}
my $Prob = $Map.'___'.$2.'___'.
@@ -164,8 +239,7 @@ sub StudentReport {
$Code='U';
$Tries = 0;
$Wrongs = 0;
- $LatestVersion = $result{"version:$Prob"};
-
+ $LatestVersion = $result{"version:$Prob"};
if ( $LatestVersion ) {
for ( my $Version=1; $Version<=$LatestVersion; $Version++ ) {
my $vkeys = $result{"$Version:keys:$Prob"};
@@ -189,7 +263,7 @@ sub StudentReport {
$TempHash{"$Part.Wrongs"} = $Wrongs;
}
}
- }
+ }
for ( my $n = 0; $n < $PartNo; $n++ ) {
my $part = $TempHash{$n};
if ($PtrTry ne '') {$PtrTry .= ',';}
@@ -212,17 +286,18 @@ sub StudentReport {
}
sub CreateTable {
+ my $ColNo=0;
+ foreach (keys(%Header)){
+ $ColNo++;
+ }
my ($Hd, $Hid)=@_;
if ( $Hd == 1 ) {
-# $Hid=~/(\d+)\.(\d+)/;
$r->print('
'.$hash{'title_'.$Hid}.''
-# .' ('.&Apache::lonnet::declutter($hash{'map_id_'.$1}).')'
- );
+ '" target="_blank">'.$hash{'title_'.$Hid}.'');
}
my $Result = "\n".'';
$Result .= 'P# | '."\n";
- for ( my $nIdx=0; $nIdx < 11; $nIdx++ ) {
+ for ( my $nIdx=0; $nIdx < $ColNo; $nIdx++ ) {
$Result .= ''.''.' | '."\n";
}
@@ -242,11 +317,22 @@ sub PreStatTable {
"_$ENV{'user.domain'}_$cid\_statistics.db";
my $GraphDB = "/home/httpd/perl/tmp/$ENV{'user.name'}".
"_$ENV{'user.domain'}_$cid\_graph.db";
- my $CachDisFac = "/home/httpd/perl/tmp/$ENV{'user.name'}".
- "_$ENV{'user.domain'}_$cid\_DiscFactor.db";
- $r->print('
');
+ my $OpSel11='';
+ my $OpSel12='';
+ my $OpSel13='';
+ my $Status = $ENV{'form.status'};
+ if ( $Status eq 'Any' ) { $OpSel13='selected'; }
+ elsif ($Status eq 'Expired' ) { $OpSel12 = 'selected'; }
+ else { $OpSel11 = 'selected'; }
my $Ptr = '';
+ $Ptr .= '
Student Status: '."\n".
+ ' '."\n";
+ $Ptr .= ' ';
+ $Ptr .= ''."\n";
$Ptr .= '
Sorting Type: '."\n".
'
' );
$GraphDat{$RealIdx}=$DoD.':'.$Wrng;
}
@@ -839,6 +1012,7 @@ sub initial {
undef %CachData;
undef %GraphDat;
undef %DiscFac;
+ undef %OpResp;
undef $CurMap;
undef $CurSec;
undef $CurStu;
@@ -866,23 +1040,40 @@ sub ClassList {
my $classlst=&Apache::lonnet::reply
('dump:'.$cdom.':'.$cnum.':classlist',$chome);
my $StudNo = 0;
+ my $now=time;
unless ($classlst=~/^error\:/) {
foreach (sort split(/\&/,$classlst)) {
my ($name,$value)=split(/\=/,$_);
my ($end,$start)=split(/\:/,&Apache::lonnet::unescape($value));
$name=&Apache::lonnet::unescape($name);
my ($sname,$sdom)=split(/\:/,$name);
- my $ssec=&Apache::lonnet::usection($sdom,$sname,$cid);
- if ($ssec==-1) {next;}
- $ssec=($ssec) ? $ssec : '(none)';
- #$ssec=(int($ssec)) ? int($ssec) : $ssec;
- #$r->print($sname.'...'.$ssec.'
');
- $section{$ssec}=$ssec;
- if ($CurSec eq 'All Sections' || $ssec eq $CurSec) {
- $students[$StudNo]=$name;
- $StuBox{$sname}=$ssec;
- }
- $StudNo++;
+ my $active=1;
+ my $Status=$ENV{'form.status'};
+ $Status = ($Status) ? $Status : 'Active';
+ if ( ( ($end) && $now > $end ) &&
+ ( ($Status eq 'Active') ) ) { $active=0; }
+ if ( ($Status eq 'Expired') &&
+ ($end == 0 || $now < $end) ) { $active=0; }
+ if ($active) {
+ my $thisindex=$#students+1;
+ $name=&Apache::lonnet::unescape($name);
+ $students[$thisindex]=$name;
+ my ($sname,$sdom)=split(/\:/,$name);
+ #my %reply=&Apache::lonnet::idrget($sdom,$sname);
+ #my $reply=&Apache::lonnet::reply('get:'.$sdom.':'.$sname.
+ # ':environment:lastname&generation&firstname&middlename',
+ # &Apache::lonnet::homeserver($sname,$sdom));
+ my $ssec=&usection($sdom,$sname,$cid,$Status);
+ if ($ssec==-1) {next;}
+ $ssec=($ssec) ? $ssec : '(none)';
+ #$ssec=(int($ssec)) ? int($ssec) : $ssec;
+ $section{$ssec}=$ssec;
+ if ($CurSec eq 'All Sections' || $ssec eq $CurSec) {
+ $students[$StudNo]=$name;
+ $StuBox{$sname}=$sdom;
+ }
+ $StudNo++;
+ }
}
}
else {
@@ -892,18 +1083,11 @@ sub ClassList {
$r->rflush();
# --------------- Find all assessments and put them into some linear-like order
&tracetable($firstres,'&'.$lastres.'&');
-
# my $c=0;
# foreach (sort keys %mapsort) {
# $r->print('
'.$c.')'.$_.' ... '.$mapsort{$_});
# $c++;
# }
-#foreach(@cols) {
-# $c++;
-# $r->print('
'.$cols[$c]);
-#}
-#$r->print('
Count = '.$c);
-
}
# ------------------------------------------------------------- End render page
@@ -939,22 +1123,16 @@ sub Menu {
my $content = $ENV{'form.sort'};
if ($content eq '' || $content eq 'Return to Menu') {
my $Ptr = '';
- $Ptr .= '';#General Statistics"/>';
+ $Ptr .= '';
$Ptr .= '
';
$Ptr .= '';
- $Ptr .= '
';
-# $Ptr .= '';#"Problem Evaluation"/>';
$Ptr .= '
';
$r->print( $Ptr );
}
else {
&initial();
&ClassList();
- if ( $content eq 'Discrimination' || #'Problem Evaluation' ||
- $content eq 'Recalculate Discrimintion Factor' ) {
- &CreateDiscFac();
- }
- elsif ( $content eq 'Student Assessment' ||
+ if ( $content eq 'Student Assessment' ||
$content eq 'Create Student Report' ) {
&StudentOptions();
&StudentReport($CurStu,$StuBox{"$CurStu"});
@@ -994,20 +1172,11 @@ sub StudentOptions {
}
sub GetStatus {
-
- $OpSelDis1='';
- $OpSelDis2='';
$OpSel1='';
$OpSel2='';
$OpSel3='';
$OpSel4='';
-# if ( $ENV{'form.DisType'} eq 'Total Number of Correct Answers' ) {
-# $OpSelDis1='selected';
-# $CurDis=0;
-# }
-# else { $OpSel2 = 'selected'; $CurDis = 1;}
-
if ( $ENV{'form.order'} eq 'Descending' ) { $OpSel2='selected'; }
else { $OpSel1 = 'selected'; }