Diff for /loncom/interface/statistics/lonproblemanalysis.pm between versions 1.10 and 1.18

version 1.10, 2002/09/07 23:07:38 version 1.18, 2002/12/13 21:39:19
Line 27 Line 27
 #  #
 # (Navigate problems for statistical reports  # (Navigate problems for statistical reports
 # YEAR=2002  # YEAR=2002
 # 5/12,7/26  Behrouz Minaei  # 5/12,7/26,9/7,11/22 Behrouz Minaei
 #  #
 ###  ###
   
 package Apache::lonproblemanalysis;   package Apache::lonproblemanalysis;
   
 use strict;  use strict;
 use Apache::lonnet();  use Apache::lonnet();
Line 66  sub BuildProblemAnalysisPage { Line 66  sub BuildProblemAnalysisPage {
     $Ptr .= '</td></tr></table><br>';      $Ptr .= '</td></tr></table><br>';
     $r->print($Ptr);      $r->print($Ptr);
     $r->rflush();      $r->rflush();
   #   $r->print($cache{'OptionResponses'}.'<br>');
     $r->print(&OptionResponseTable($cache{'OptionResponses'}, \%cache, $r));      $r->print(&OptionResponseTable($cache{'OptionResponses'}, \%cache, $r));
   
     untie(%cache);      untie(%cache);
Line 90  sub BuildAnalyzePage { Line 91  sub BuildAnalyzePage {
   
     # Remove students who don't have the proper section.      # Remove students who don't have the proper section.
     my @sectionsSelected = split(':',$cache{'sectionsSelected'});      my @sectionsSelected = split(':',$cache{'sectionsSelected'});
     for(my $studentIndex=((scalar @$students)-1); $studentIndex>=0;  
       my $studentCount = scalar @$students;
       for(my $studentIndex=$studentCount-1; $studentIndex>=0;
         $studentIndex--) {          $studentIndex--) {
         my $value = $cache{$students->[$studentIndex].':section'};          my $value = $cache{$students->[$studentIndex].':section'};
         my $found = 0;          my $found = 0;
Line 116  sub BuildAnalyzePage { Line 119  sub BuildAnalyzePage {
         $r->rflush();          $r->rflush();
     }      }
   
     my $error =       &Apache::lonhtmlcommon::Close_PrgWin($r);
         &Apache::loncoursedata::DownloadStudentCourseDataSeparate($students,  
                                                                   'true',  
                                                                   $cacheDB,  
                                                                   'true',   
                                                                   'true',  
                                                                   $courseID,  
                                                                   $r, $c);  
     if($error ne 'OK') {  
         $r->print($error.'<br>Error downloading course data<br>');  
         return;  
     }  
   
   ### jason code for checing is there data in cache
   #    my $error =
   #        &Apache::loncoursedata::DownloadStudentCourseDataSeparate($students,
   #                                                                  'true',
   #                                                                  $cacheDB,
   #                                                                  'true',
   #                                                                  'true',
   #                                                                  $courseID,
   #                                                                  $r, $c);
   #    if($error ne 'OK') {
   #        $r->print($error.'<br>Error downloading course data<br>');
   #        return;
   #    }
   
     unless(tie(%cache,'GDBM_File',$cacheDB,&GDBM_READER(),0640)) {      unless(tie(%cache,'GDBM_File',$cacheDB,&GDBM_READER(),0640)) {
         $Str .= 'Unable to tie database.';          $Str .= 'Unable to tie database.';
Line 138  sub BuildAnalyzePage { Line 143  sub BuildAnalyzePage {
   
     my ($problemId, $part, $responseId)=split(':',$cache{'AnalyzeInfo'});      my ($problemId, $part, $responseId)=split(':',$cache{'AnalyzeInfo'});
     my $uri      = $cache{$problemId.':source'};      my $uri      = $cache{$problemId.':source'};
     my $problem  = $cache{$problemId.':problem'};       my $problem  = $cache{$problemId.':problem'};
     my $title    = $cache{$problemId.':title'};      my $title    = $cache{$problemId.':title'};
     my $interval = $cache{'Interval'};      my $interval = $cache{'Interval'};
       my $heading = 'Restore this particular Option Response Problem '.
                     'Results, Please wait...';
   
     my %ConceptData;      my %ConceptData;
     $ConceptData{"Interval"} = $interval;      $ConceptData{"Interval"} = $interval;
   
     #Initialize the option response true answers      #Initialize the option response true answers
     my ($analyzeData) = &InitAnalysis($uri, $part, $responseId, $problem,       my ($analyzeData) = &InitAnalysis($uri, $part, $responseId, $problem,
                                       $students->[0], $courseID);                                        $students->[0], $courseID);
     if(defined($analyzeData->{'error'})) {      if(defined($analyzeData->{'error'})) {
         $Str .= $analyzeData->{'error'}.'<br>Incorrect part requested.<br>';          $Str .= $analyzeData->{'error'}.'<br>Incorrect part requested.<br>';
Line 159  sub BuildAnalyzePage { Line 166  sub BuildAnalyzePage {
     if($c->aborted()) {  untie(%cache); return; }      if($c->aborted()) {  untie(%cache); return; }
   
     #compute the intervals      #compute the intervals
     &Interval($part, $problem, $interval, $analyzeData->{'concepts'},       &Interval($part, $problem, $interval, $analyzeData->{'concepts'},
               \%ConceptData);                \%ConceptData);
   
     $title =~ s/\ /"_"/eg;      $title =~ s/\ /"_"/eg;
Line 168  sub BuildAnalyzePage { Line 175  sub BuildAnalyzePage {
     $r->print($Str);      $r->print($Str);
     $Str = '';      $Str = '';
     if($c->aborted()) {  untie(%cache); return; }      if($c->aborted()) {  untie(%cache); return; }
            
       &Apache::lonhtmlcommon::Create_PrgWin($r, $title, $heading);
   
       my $count=0;
     #Java script Progress window      #Java script Progress window
     for(my $index=0; $index<(scalar @$students); $index++) {      for(my $index=0; $index<(scalar @$students); $index++) {
         if($c->aborted()) {  untie(%cache); return; }          if($c->aborted()) {  untie(%cache); return; }
  &OpStatus($problemId, $students->[$index], \%ConceptData,           $count++;
                   $analyzeData->{'foil_to_concept'}, $analyzeData, \%cache);          my $displayString = $count.'/'.$studentCount.': '.$_;
           &Apache::lonhtmlcommon::Update_PrgWin($displayString, $r);
    &OpStatus($problemId, $students->[$index], \%ConceptData,
                     $analyzeData->{'foil_to_concept'}, $analyzeData,
     \%cache, $courseID);
     }      }
       &Apache::lonhtmlcommon::Close_PrgWin($r);
   
     $Str .= '<br>';      $Str .= '<br>';
     for (my $k=0; $k<$interval; $k++ ) {      for (my $k=0; $k<$interval; $k++ ) {
         if($c->aborted()) {  untie(%cache); return $Str; }          if($c->aborted()) {  untie(%cache); return $Str; }
  $Str .= &DrawGraph($k, $title, $analyzeData->{'concepts'},    $Str .= &DrawGraph($k, $title, $analyzeData->{'concepts'},
                            \%ConceptData);                             \%ConceptData);
         $r->print($Str);          $r->print($Str);
         $Str = '';          $Str = '';
Line 242  sub OptionResponseTable { Line 257  sub OptionResponseTable {
             $sequences{$sequence} .= ':::'.$_;              $sequences{$sequence} .= ':::'.$_;
         }          }
     }      }
       
     my $Str = '';      my $Str = '';
   
     foreach my $sequence (@orderedSequences) {      foreach my $sequence (@orderedSequences) {
Line 289  sub OptionResponseTable { Line 304  sub OptionResponseTable {
   
 #---- Analyze Web Page -------------------------------------------------------  #---- Analyze Web Page -------------------------------------------------------
   
 #restore the student submissions and finding the result  # Joson code for reading data from cache
   =pod
 sub OpStatus {  sub OpStatus {
     my ($problemID, $student, $ConceptData, $foil_to_concept,       my ($problemID, $student, $ConceptData, $foil_to_concept,
         $analyzeData, $cache)=@_;          $analyzeData, $cache)=@_;
   
     my $ids = $analyzeData->{'parts'};      my $ids = $analyzeData->{'parts'};
   
     my @True = ();      my @True = ();
     my @False = ();      my @False = ();
     my $flag=0;      my $flag=0;
Line 302  sub OpStatus { Line 319  sub OpStatus {
     my $tries=0;      my $tries=0;
   
     foreach my $id (@$ids) {      foreach my $id (@$ids) {
         my ($part, $response) = split(/\./, $id);   my ($part, $response) = split(/\./, $id);
         my $time=$cache->{$student.':'.$problemID.':'.$part.':timestamp'};          my $time=$cache->{$student.':'.$problemID.':'.$part.':timestamp'};
         my @submissions = split(':::', $cache->{$student.':'.$problemID.':'.          my @submissions = split(':::', $cache->{$student.':'.$problemID.':'.
                                                 $part.':'.$response.                                                  $part.':'.$response.
Line 313  sub OpStatus { Line 330  sub OpStatus {
                 if($submission{$_}) {                  if($submission{$_}) {
                     my $answer = $analyzeData->{$id.'.foil.value.'.$_};                      my $answer = $analyzeData->{$id.'.foil.value.'.$_};
                     if($submission{$_} eq $answer) {                      if($submission{$_} eq $answer) {
                         &Decide("true", $foil_to_concept->{$_},                           &Decide("true", $foil_to_concept->{$_},
                                 $time, $ConceptData);                                  $time, $ConceptData);
                     } else {                      } else {
                         &Decide("false", $foil_to_concept->{$_},                           &Decide("false", $foil_to_concept->{$_},
                                 $time, $ConceptData);                                  $time, $ConceptData);
                     }                      }
                 }                  }
Line 326  sub OpStatus { Line 343  sub OpStatus {
   
     return;      return;
 }  }
   =cut
   
   
   #restore the student submissions and finding the result
   
   sub OpStatus {
       my ($problemID, $student, $ConceptData, $foil_to_concept,
           $analyzeData, $cache, $courseID)=@_;
   
       my $ids = $analyzeData->{'parts'};
       my ($uname,$udom)=split(/\:/,$student);
       my $symb  = $cache->{$problemID.':problem'};
   
       my @True = ();
       my @False = ();
       my $flag=0;
       my $tries=0;
   
       foreach my $id (@$ids) {
    my ($part, $response) = split(/\./, $id);
       my %reshash=&Apache::lonnet::restore($symb,$courseID,$udom,$uname);
       if ($reshash{'version'}) {
               my $tries=0;
               for (my $version=1;$version<=$reshash{'version'};$version++) {
        my $time=$reshash{"$version:timestamp"};
        foreach my $key (sort(split(/\:/,$reshash{$version.':keys'}))) {
                       if (($key=~/\.(\w+)\.(\w+)\.submission$/)) {
           my $Id1 = $1; my $Id2 = $2;
           #check if this is a repeat submission, if so skip it
                    if ($reshash{"$version:resource.$Id1.previous"}) { next; }
           #if no solved this wasn't a real submission, ignore it
           if (!defined($reshash{"$version:resource.$Id1.solved"})) {
       &Apache::lonxml::debug("skipping ");
       next;
           }
           my $Resp = $reshash{"$version:$key"};
           my %submission=&Apache::lonnet::str2hash($Resp);
           foreach (keys %submission) {
       my $Ansr = $analyzeData->{"$Id1.$Id2.foil.value.$_"};
                          if($submission{$_} eq $Ansr) {
                           &Decide("true", $foil_to_concept->{$_},
                                   $time, $ConceptData);
                          } else {
                           &Decide("false", $foil_to_concept->{$_},
    $time, $ConceptData);
                          }
           }
               }
           }
               }
           }
       }
   
       return;
   }
   
   
 sub DrawGraph {  sub DrawGraph {
     my ($k,$Src,$Concepts,$ConceptData)=@_;      my ($k,$Src,$Concepts,$ConceptData)=@_;
Line 333  sub DrawGraph { Line 406  sub DrawGraph {
     my @data1;      my @data1;
     my @data2;      my @data2;
   
     # Adjust Data and find the Max       # Adjust Data and find the Max
     for (my $n=0; $n<(scalar @$Concepts); $n++ ) {      for (my $n=0; $n<(scalar @$Concepts); $n++ ) {
  my $tmp=$Concepts->[$n];   my $tmp=$Concepts->[$n];
  $data1[$n]=$ConceptData->{$tmp.'.'.$k.'.true'};   $data1[$n]=$ConceptData->{$tmp.'.'.$k.'.true'};
Line 363  sub DrawGraph { Line 436  sub DrawGraph {
     $GData  = $Titr.'&Concepts&Answers&'.$Max.'&'.$P_No.'&';      $GData  = $Titr.'&Concepts&Answers&'.$Max.'&'.$P_No.'&';
     $GData .= (join(',',@data1)).'&'.(join(',',@data2));      $GData .= (join(',',@data1)).'&'.(join(',',@data2));
   
     return '<IMG src="/cgi-bin/graph.gif?'.$GData.'" border=1/>';      return '<IMG src="/cgi-bin/graph.png?'.$GData.'" border=1/>';
 }  }
   
 sub DrawTable {  sub DrawTable {
Line 392  sub DrawTable { Line 465  sub DrawTable {
     my $P_No = (scalar @data1);      my $P_No = (scalar @data1);
     my $Str = '';      my $Str = '';
 #    $Str .= '<br><b>From: ['.localtime($ConceptData->{'Int.'.($k-1)});  #    $Str .= '<br><b>From: ['.localtime($ConceptData->{'Int.'.($k-1)});
 #    $Str .= '] To: ['.localtime($ConceptData->{"Int.$k"}).']</b>';   #    $Str .= '] To: ['.localtime($ConceptData->{"Int.$k"}).']</b>';
     $Str .= "\n".'<table border=2>'.      $Str .= "\n".'<table border=2>'.
             "\n".'<tr>'.              "\n".'<tr>'.
             "\n".'<th> # </th>'.              "\n".'<th> # </th>'.
Line 518  sub Interval { Line 591  sub Interval {
     for(my $i=1; $i<$Int; $i++) {      for(my $i=1; $i<$Int; $i++) {
  $ConceptData->{'Int.'.$i}=$opn+$i*$add;   $ConceptData->{'Int.'.$i}=$opn+$i*$add;
     }      }
     $ConceptData->{'Int.'.$Int}=$due;           $ConceptData->{'Int.'.$Int}=$due;
     for(my $i=0; $i<$Int; $i++) {      for(my $i=0; $i<$Int; $i++) {
  for(my $n=0; $n<(scalar @$Concepts); $n++ ) {   for(my $n=0; $n<(scalar @$Concepts); $n++ ) {
     my $tmp=$Concepts->[$n];      my $tmp=$Concepts->[$n];

Removed from v.1.10  
changed lines
  Added in v.1.18


FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>