Diff for /loncom/interface/statistics/lonproblemanalysis.pm between versions 1.4 and 1.22

version 1.4, 2002/08/05 20:53:38 version 1.22, 2003/06/18 17:34:02
Line 1 Line 1
 # The LearningOnline Network with CAPA  # The LearningOnline Network with CAPA
 # (Publication Handler  
 #  #
 # $Id$  # $Id$
 #  #
Line 26 Line 25
 # http://www.lon-capa.org/  # http://www.lon-capa.org/
 #  #
 # (Navigate problems for statistical reports  # (Navigate problems for statistical reports
 # YEAR=2001  
 # 5/5,7/9,7/25/1,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  # YEAR=2002
 # 1/22,2/1,2/6,2/25,3/2,3/6,3/17,3/21,3/22,3/26,4/7,5/6 Behrouz Minaei  # 5/12,7/26,9/7,11/22 Behrouz Minaei
 # 5/12,5/14,5/15,5/19,5/26,7/16  Behrouz Minaei  
 #  #
 ###  ###
   
 package Apache::lonproblemanalysis;   package Apache::lonproblemanalysis;
   
 use strict;  use strict;
 use Apache::lonnet();  use Apache::lonnet();
   use Apache::lonhtmlcommon();
 use GDBM_File;  use GDBM_File;
   
 #my $jr;  my $jr;
   
 sub BuildProblemAnalysisPage {  sub BuildProblemAnalysisPage {
     my ($cacheDB, $r)=@_;      my ($cacheDB, $r)=@_;
   
     my %cache;      my %cache;
     unless(tie(%cache,'GDBM_File',$cacheDB,&GDBM_READER(),0640)) {      unless(tie(%cache,'GDBM_File',$cacheDB,&GDBM_READER(),0640)) {
         $r->print('<html><body>Unable to tie database.</body></html>');          $r->print('Unable to tie database.');
         return;          return;
     }      }
   
     $r->print(&IntervalOptions($cache{'Interval'}));      my $Ptr = '';
       $Ptr .= '<table border="0"><tbody>';
       $Ptr .= '<tr><td align="right"><b>Select Sections</b>';
       $Ptr .= '</td>'."\n";
       $Ptr .= '<td align="left">'."\n";
       my @sectionsSelected = split(':',$cache{'sectionsSelected'});
       my @sections = split(':',$cache{'sectionList'});
       $Ptr .= &Apache::lonstatistics::SectionSelect('Section','multiple',5);
       $Ptr .= '</td></tr>'."\n";
       $Ptr .= '<tr><td align="right"><b>Intervals</b></td>'."\n";
       $Ptr .= '<td align="left">';
       $Ptr .= &IntervalOptions($cache{'Interval'});
       $Ptr .= '</td></tr></table><br>';
       $r->print($Ptr);
     $r->rflush();      $r->rflush();
     $r->print(&OptionResponseTable($cache{'OptionResponses'}, \%cache));  #   $r->print($cache{'OptionResponses'}.'<br>');
       $r->print(&OptionResponseTable($cache{'OptionResponses'}, \%cache, $r));
   
     untie(%cache);      untie(%cache);
   
Line 64  sub BuildProblemAnalysisPage { Line 74  sub BuildProblemAnalysisPage {
 sub BuildAnalyzePage {  sub BuildAnalyzePage {
     my ($cacheDB, $students, $courseID,$r)=@_;      my ($cacheDB, $students, $courseID,$r)=@_;
   
 #    $jr = $r;      $jr = $r;
     my $c = $r->connection;      my $c = $r->connection;
   
     my $Str = '</form>';      my $Str = '</form>';
     my %cache;      my %cache;
     &Create_PrgWin($r);  
     my $count=0;      unless(tie(%cache,'GDBM_File',$cacheDB,&GDBM_READER(),0640)) {
     foreach (@$students) {          $Str .= 'Unable to tie database.';
         &Update_PrgWin(scalar(@$students),$count,$_,$r);          $r->print($Str);
         if($c->aborted) {          return;
             return $Str;      }
         }  
         my $downloadTime='';      # Remove students who don't have the proper section.
         if(tie(%cache,'GDBM_File',$cacheDB,&GDBM_READER(),0640)) {      my @sectionsSelected = split(':',$cache{'sectionsSelected'});
             $downloadTime = $cache{$_.':lastDownloadTime'};  
             untie(%cache);      my $studentCount = scalar @$students;
         }      for(my $studentIndex=$studentCount-1; $studentIndex>=0;
         if($downloadTime eq 'Not downloaded') {          $studentIndex--) {
             my $courseData =           my $value = $cache{$students->[$studentIndex].':section'};
                 &Apache::loncoursedata::DownloadCourseInformation($_,           my $found = 0;
                                                                   $courseID);          foreach (@sectionsSelected) {
             if(tie(%cache,'GDBM_File',$cacheDB,&GDBM_WRCREAT(),0640)) {              if($_ eq 'none') {
                 &Apache::loncoursedata::ProcessStudentData(\%cache,                   if($value eq '' || !defined($value) || $value eq ' ') {
                                                            $courseData, $_);                      $found = 1;
                 untie(%cache);                      last;
                   }
             } else {              } else {
                 next;                  if($value eq $_) {
                       $found = 1;
                       last;
                   }
             }              }
         }          }
         $count++;          if($found == 0) {
               splice(@$students, $studentIndex, 1);
           }
     }      }
     &Close_PrgWin($r);      unless(untie(%cache)) {
           $r->print('Can not untie hash.');
           $r->rflush();
       }
   
       &Apache::lonhtmlcommon::Close_PrgWin($r);
   
   ### 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 .= '<html><body>Unable to tie database.</body></html>';          $Str .= 'Unable to tie database.';
         return $Str;          $r->print($Str);
           return;
     }      }
   
     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 .= 'Incorrect part requested.<br>';          $Str .= $analyzeData->{'error'}.'<br>Incorrect part requested.<br>';
         return $Str;          $r->print($Str);
           return;
     }      }
   
     if($c->aborted()) {  untie(%cache); return $Str; }      $r->print($Str);
       $Str = '';
       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;
     $Str .= '<br><b>'.$uri.'</b>';      $Str .= '<br><b>'.$uri.'</b>';
   
     if($c->aborted()) {  untie(%cache); return $Str; }      $r->print($Str);
                $Str = '';
       if($c->aborted()) {  untie(%cache); return; }
   
   
       my %prog_state=&Apache::lonhtmlcommon::Create_PrgWin($r, $title,
         $heading,$#$students+1);
   
     #Java script Progress window      #Java script Progress window
 #    &Create_PrgWin();  
 #    &Update_PrgWin("Starting-to-analyze-problem");  
     for(my $index=0; $index<(scalar @$students); $index++) {      for(my $index=0; $index<(scalar @$students); $index++) {
         if($c->aborted()) {  untie(%cache); return $Str; }          if($c->aborted()) {  untie(%cache); return; }
 # &Update_PrgWin($index);   &Apache::lonhtmlcommon::Increment_PrgWin($r,\%prog_state,
 # &OpStatus($problem, $students->[$index], $courseID, \%ConceptData,   'last student '.$students->[$index]);
 #                  $analyzeData->{'foil_to_concept'}, $analyzeData, \%cache);   &OpStatus($problemId, $students->[$index], \%ConceptData,
  &OpStatus($problem, $students->[$index], \%ConceptData,                     $analyzeData->{'foil_to_concept'}, $analyzeData,
                   $analyzeData->{'foil_to_concept'}, $analyzeData, \%cache);    \%cache, $courseID);
     }      }
 #    &Close_PrgWin();      &Apache::lonhtmlcommon::Close_PrgWin($r,\%prog_state);
   
     $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);
           $Str = '';
     }      }
     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 .= &DrawTable($k, $analyzeData->{'concepts'}, \%ConceptData);   $Str .= &DrawTable($k, $analyzeData->{'concepts'}, \%ConceptData);
           $r->print($Str);
           $Str = '';
     }      }
     my $Answ=&Apache::lonnet::ssi($uri);      my $Answ=&Apache::lonnet::ssi_body($uri);
     $Str .= '<br><b>Here you can see the Problem:</b><br>'.$Answ;      $Str .= '<br><b>Here you can see the Problem:</b><br>'.$Answ;
       $Str .= '<form>';
       $r->print($Str);
   
     untie(%cache);      untie(%cache);
   
     return $Str.'<form>';      return;
 }  }
   
 #---- Problem Analysis Web Page ----------------------------------------------  #---- Problem Analysis Web Page ----------------------------------------------
Line 173  sub IntervalOptions { Line 224  sub IntervalOptions {
         }          }
     }      }
   
     my $Ptr = '<br><b>Select number of intervals</b>'."\n".      my $Ptr = '<select name="Interval">'."\n";
              '<select name="Interval">'."\n";  
     for(my $n=1; $n<=7;$ n++) {      for(my $n=1; $n<=7;$ n++) {
  $Ptr .= '<option';   $Ptr .= '<option';
         if($interval == $n) {          if($interval == $n) {
Line 188  sub IntervalOptions { Line 238  sub IntervalOptions {
 }  }
   
 sub OptionResponseTable {  sub OptionResponseTable {
     my ($optionResponses,$cache)=@_;      my ($optionResponses,$cache,$r)=@_;
     my $Str = '';  
     $Str .= '<br><b> Option Response Problems in this course:</b>'."\n";  
     $Str .= '<br><br>'."\n";  
     $Str .= "<table border=2><tr><th> \# </th><th> Problem Title </th>";  
     $Str .= '<th> Resource </th><th> Analysis  </th></tr>'."\n";  
   
     my $number=1;  
     my @optionResponses=split(':::', $optionResponses);      my @optionResponses=split(':::', $optionResponses);
     my %partCount;      my %partCount;
     foreach (@optionResponses) {      my %sequences;
         my ($problemId, $part, undef)=split(':',$_);      my @orderedSequences=();
       foreach(@optionResponses) {
           my ($sequence, $problemId, $part, undef)=split(':',$_);
         $partCount{$problemId.':'.$part}++;          $partCount{$problemId.':'.$part}++;
     }          if(!defined($sequences{$sequence})) {
               push(@orderedSequences, $sequence);
     foreach (@optionResponses) {              $sequences{$sequence} = $_;
         my ($problemId, $part, $response)=split(':',$_);  
         my $uri = $cache->{$problemId.':source'};  
         my $title = $cache->{$problemId.':title'};  
   
         my $Temp = '<a href="'.$uri.'" target="_blank">'.$title.'</a>';  
         $Str .= '<tr>';  
         $Str .= '<td> '.$number.' </td>';  
         $Str .= '<td bgcolor="#DDFFDD">'.$Temp.'</td>';  
         $Str .= '<td bgcolor="#EEFFCC">'.$uri.'</td>';  
         if($partCount{$problemId.':'.$part} < 2) {  
             $Str .= '<td><input type="submit" name="Analyze:::';  
             $Str .= $problemId.':'.$part.'" value="';  
             $Str .= 'Part '.$part;  
             $Str .= '" /></td></tr>'."\n";  
         } else {          } else {
             $Str .= '<td><input type="submit" name="Analyze:::'.$_.'" value="';              $sequences{$sequence} .= ':::'.$_;
             $Str .= 'Part '.$part.' Response '.$response;  
             $Str .= '" /></td></tr>'."\n";  
         }          }
         $number++;  
     }      }
     $Str .= '</table>'."\n";  
   
     return $Str;      my $Str = '';
 }  
   
 # Create progress      foreach my $sequence (@orderedSequences) {
 sub Create_PrgWin {          my @optionProblems = split(':::', $sequences{$sequence});
     my ($r)=@_;  
     $r->print(<<ENDPOP);  
     <script>  
     popwin=open('','popwin','width=400,height=100');  
     popwin.document.writeln('<html><body bgcolor="#88DDFF">'+  
       '<title>LON-CAPA Statistics</title>'+  
       '<h4>Computation Progress</h4>'+  
       '<form name=popremain>'+  
       '<input type=text size=35 name=remaining value=Starting></form>'+  
       '</body></html>');  
     popwin.document.close();  
     </script>  
 ENDPOP  
   
     $r->rflush();          $Str .= '<b>'.$cache->{$sequence.':title'}.'</b>'."\n";
 }          $Str .= "<table border=2><tr><th> \# </th><th> Problem Title </th>";
           $Str .= '<th> Resource </th><th> Analysis  </th></tr>'."\n";
   
           my $count = 1;
           foreach(@optionProblems) {
               my (undef, $problemId, $part, $response)=
                   split(':',$optionProblems[$count-1]);
   #                split(':',$sequences{$sequence});
               my $uri = $cache->{$problemId.':source'};
               my $title = $cache->{$problemId.':title'};
   
               my $Temp = '<a href="'.$uri.'" target="_blank">'.$title.'</a>';
               $Str .= '<tr>';
               $Str .= '<td> '.$count.' </td>';
               $Str .= '<td bgcolor="#DDFFDD">'.$Temp.'</td>';
               $Str .= '<td bgcolor="#EEFFCC">'.$uri.'</td>';
               if($partCount{$problemId.':'.$part} < 2) {
                   $Str .= '<td><input type="submit" name="Analyze:::';
                   $Str .= $problemId.':'.$part.'" value="';
                   $Str .= 'Part '.$part;
                   $Str .= '" /></td></tr>'."\n";
               } else {
                   my $value = $problemId.':'.$part.':'.$response;
                   $Str .= '<td><input type="submit" name="Analyze:::'.$value;
                   $Str .= '" value="';
                   $Str .= 'Part '.$part.' Response '.$response;
                   $Str .= '" /></td></tr>'."\n";
               }
               $count++;
           }
           $Str .= '</table><br>'."\n";
       }
   
 # update progress      return $Str;
 sub Update_PrgWin {  
     my ($totalStudents,$index,$name,$r)=@_;  
     $r->print('<script>popwin.document.popremain.remaining.value="'.  
               'Computing '.$index.'/'.$totalStudents.': '.  
               $name.'";</script>');  
     $r->rflush();  
 }  }
   
 # close Progress Line  
 sub Close_PrgWin {  
     my ($r)=@_;  
     $r->print('<script>popwin.close()</script>');  
     $r->rflush();   
 }  
    
 #---- END Problem Analysis Web Page ------------------------------------------  #---- END Problem Analysis Web Page ------------------------------------------
   
 #---- 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 ($problem, $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;
     my $latestVersion = $cache->{$student.':version:'.$problem};  
     if(!$latestVersion) {  
         return;  
     }  
   
     my $tries=0;      my $tries=0;
     for(my $version=1; $version<=$latestVersion; $version++) {  
         my $time=$cache->{$student.':'.$version.':'.$problem.':timestamp'};  
   
         foreach my $id (@$ids) {      foreach my $id (@$ids) {
             my ($currentPart, undef) = split(/\./, $id);   my ($part, $response) = split(/\./, $id);
             #check if this is a repeat submission, if so skip it          my $time=$cache->{$student.':'.$problemID.':'.$part.':timestamp'};
             next if($cache->{$student.':'.$version.':'.$problem.          my @submissions = split(':::', $cache->{$student.':'.$problemID.':'.
                              ':resource.'.$currentPart.'.previous'});                                                  $part.':'.$response.
             #if no solved this wasn't a real submission, ignore it                                                  ':submission'});
             if(!defined($cache->{"$student:$version:$problem".          foreach my $Resp (@submissions) {
                                  ":resource.$currentPart.solved"})) {  
                 &Apache::lonxml::debug("skipping ");  
                 next;  
             }  
             my $Resp = $cache->{$student.':'.$version.':'.$problem.  
                                 ':resource.'.$id.'.submission'};  
             my %submission=&Apache::lonnet::str2hash($Resp);              my %submission=&Apache::lonnet::str2hash($Resp);
             foreach (keys(%submission)) {              foreach (keys(%submission)) {
                 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 318  sub OpStatus { Line 340  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 325  sub DrawGraph { Line 403  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 355  sub DrawGraph { Line 433  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 384  sub DrawTable { Line 462  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 441  sub InitAnalysis { Line 519  sub InitAnalysis {
                                         'grade_domain'   => $domain,                                          'grade_domain'   => $domain,
                                         'grade_courseid' => $courseID,                                          'grade_courseid' => $courseID,
                                         'grade_symb'     => $problem));                                          'grade_symb'     => $problem));
       my ($Answer)=&Apache::lonnet::str2hashref($Answ);
     my %Answer=();  
     %Answer=&Apache::lonnet::str2hash($Answ);  
   
     my $found = 0;      my $found = 0;
     my @parts=();      my @parts=();
     if(defined($responseId)) {      if(defined($responseId)) {
         foreach (@{$Answer{'parts'}}) {          foreach (@{$Answer->{'parts'}}) {
             if($_ eq $part.'.'.$responseId) {              if($_ eq $part.'.'.$responseId) {
                 push(@parts, $_);                  push(@parts, $_);
                 $found = 1;                  $found = 1;
Line 456  sub InitAnalysis { Line 532  sub InitAnalysis {
             }              }
         }          }
     } else {      } else {
         foreach (@{$Answer{'parts'}}) {          foreach (@{$Answer->{'parts'}}) {
             if($_ =~ /$part/) {              if($_ =~ /$part/) {
                 push(@parts, $_);                  push(@parts, $_);
                 $found = 1;                  $found = 1;
Line 473  sub InitAnalysis { Line 549  sub InitAnalysis {
     my @Concepts=();      my @Concepts=();
     my %foil_to_concept;      my %foil_to_concept;
     foreach my $currentPart (@parts) {      foreach my $currentPart (@parts) {
         if(defined($Answer{$currentPart.'.concepts'})) {          if(defined($Answer->{$currentPart.'.concepts'})) {
             foreach my $concept (@{$Answer{$currentPart.'.concepts'}}) {              foreach my $concept (@{$Answer->{$currentPart.'.concepts'}}) {
                 push(@Concepts, $concept);                  push(@Concepts, $concept);
                 foreach my $foil (@{$Answer{$currentPart.'.concept.'.                  foreach my $foil (@{$Answer->{$currentPart.'.concept.'.
                                             $concept}}) {                                              $concept}}) {
                     $analyzeData{$currentPart.'.foil.value.'.$foil} =                      $analyzeData{$currentPart.'.foil.value.'.$foil} =
                         $Answer{$currentPart.'.foil.value.'.$foil};                          $Answer->{$currentPart.'.foil.value.'.$foil};
                     $foil_to_concept{$foil} = $concept;                      $foil_to_concept{$foil} = $concept;
                 }                  }
             }              }
         } else {          } else {
             foreach (keys(%Answer)) {              foreach (keys(%$Answer)) {
                 if(/$currentPart.foil\.value\.(.*)$/) {                  if(/$currentPart.foil\.value\.(.*)$/) {
                     push(@Concepts, $1);                      push(@Concepts, $1);
                     $foil_to_concept{$1} = $1;                      $foil_to_concept{$1} = $1;
                     $analyzeData{$currentPart.'.foil.value.'.$1} =                      $analyzeData{$currentPart.'.foil.value.'.$1} =
                         $Answer{$currentPart.'.foil.value.'.$1};                          $Answer->{$currentPart.'.foil.value.'.$1};
                 }                  }
             }              }
         }          }
Line 512  sub Interval { Line 588  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.4  
changed lines
  Added in v.1.22


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