Diff for /loncom/interface/statistics/lonproblemanalysis.pm between versions 1.112 and 1.114

version 1.112, 2005/02/22 04:32:46 version 1.114, 2005/02/22 22:51:16
Line 303  sub numerical_plot_percent { Line 303  sub numerical_plot_percent {
     #      #
     my $total = $stats->{'submission_count'};      my $total = $stats->{'submission_count'};
     return '' if ($total == 0);      return '' if ($total == 0);
     my $min_bin_size = $stats->{'min_abs'};      my $max_bins = 50;
     my $low_bin  = $stats->{'lowest_ans'}-$stats->{'max_bin_size'};      my $lowest_percent = $stats->{'min_percent'};
     my $high_bin = $stats->{'highest_ans'}+$stats->{'max_bin_size'};      my $highest_percent = $stats->{'max_percent'};
       my $percent_spread = $highest_percent - $lowest_percent;
       foreach (qw/20 30 40 50 100 200/) {
           if ($percent_spread < $_) {
               $highest_percent =$_/2;
               last;
           }
       }
       my $bin_size = 1;
       foreach (qw/0.01 0.05 0.1 0.5 1 2 5 10 20 25 50 100/) {
           if ($lowest_percent/2 < $_){
               $bin_size = $_;
               last;
           }
       }
     my @bins;      my @bins;
     for (my $num = $low_bin;$num <= $high_bin;$num+=($min_bin_size/2)) {      for (my $bin = -$highest_percent;$bin<0;$bin+=$bin_size) {
         push(@bins,$num);          push (@bins,$bin);
     }      }
       for (my $bin = 0; $bin<$highest_percent;$bin+=$bin_size) {
           push (@bins,$bin);
       }
       push(@bins,$highest_percent);
     #      #
     my @correct;      my @correct;
     my @incorrect;      my @incorrect;
Line 317  sub numerical_plot_percent { Line 335  sub numerical_plot_percent {
     while (my ($ans,$submissions) = each(%$responses)) {      while (my ($ans,$submissions) = each(%$responses)) {
         while (my ($submission,$counts) = each(%$submissions)) {          while (my ($submission,$counts) = each(%$submissions)) {
             my ($correct_count,$incorrect_count) = @$counts;              my ($correct_count,$incorrect_count) = @$counts;
             my $scaled_value = abs(($submission-$ans)/$ans);              my $scaled_value = 100*($submission-$ans)/abs($ans);
             my $bin=0;              if ($scaled_value < $bins[0]) {
             for ($bin=0;$bin<$#bins;$bin++) { # not <= for a reason                  $bins[0]=$scaled_value -1;
               }
               my $bin;
               for ($bin=0;$bin<$#bins;$bin++) {
                 last if ($bins[$bin]>$scaled_value);                  last if ($bins[$bin]>$scaled_value);
             }              }
             $correct[$bin]+=$correct_count;              $correct[$bin-1]+=$correct_count;
             $incorrect[$bin]+=$incorrect_count;              $incorrect[$bin-1]+=$incorrect_count;
             $count[$bin]+=$correct_count+$incorrect_count;              $count[$bin-1]+=$correct_count+$incorrect_count;
         }          }
     }      }
     #      #
     # Skip empty bins      my @plot_correct   = @correct;
     my (@plot_correct,@plot_incorrect,@new_bins,@new_count);      my @plot_incorrect = @incorrect;
     my $min_skip = 2;      my $max;
     for (my $i=0;$i<=$#bins;$i++) {      for (my $i=0;$i<$#bins;$i++) {
         my $sum=0;  
         for (my $j=-$min_skip;$j<=$min_skip && $i+$j<=$#bins;$j++) {  
             $sum += $correct[$i+$j] + $incorrect[$i+$j];  
         }  
         if ($sum) {  
             push(@new_bins,$bins[$i]);  
             push(@plot_correct,$correct[$i]);  
             push(@plot_incorrect,$incorrect[$i]);  
             push(@new_count,$correct[$i]+$incorrect[$i]);  
         }  
     }  
     @correct   = @plot_correct;  
     @incorrect = @plot_incorrect;  
     @count     = @new_count;  
     @bins      = @new_bins;  
     for (my $i=0;$i<=$#bins;$i++) {  
         $plot_correct[$i]   *= 100/$total;          $plot_correct[$i]   *= 100/$total;
         $plot_incorrect[$i] *= 100/$total;          $plot_incorrect[$i] *= 100/$total;
           if (! defined($max) || 
               $max < $plot_correct[$i]+$plot_incorrect[$i] ) {
               $max = $plot_correct[$i]+$plot_incorrect[$i];
           }
       }
       foreach (qw/1 5 10 15 20 25 30 40 50 75 100/) {
           if ($max <$_) { $max = $_; last; }
     }      }
     #      #
     my $title = &mt('Distribution by Percent');      my $title = &mt('Percent Difference');
     my @labels = (1..scalar(@bins));      my @labels = (1..scalar(@bins)-1);
     my $graph = &Apache::loncommon::DrawBarGraph      my $graph = &Apache::loncommon::DrawBarGraph
         ($title,'Percent difference from correct','Number of answers',          ($title,'Percent Difference from Correct','Percent of Answers',
          100,['#33FF00','#FF3300'],\@labels,\@plot_correct,\@plot_incorrect,           $max,['#33FF00','#FF3300'],\@labels,\@plot_correct,\@plot_incorrect,
          {xskip=>1});           {xskip=>1});
     #      #
     my $table = $graph.$/.      my $table = $graph.$/.
Line 369  sub numerical_plot_differences { Line 381  sub numerical_plot_differences {
     #      #
     my $total = $stats->{'submission_count'};      my $total = $stats->{'submission_count'};
     return '' if ($total == 0);      return '' if ($total == 0);
     #      my $max_bins = 21;
       my $min_bin_size = $stats->{'min_abs'};
       my $low_bin  = $stats->{'lowest_ans'}-$stats->{'max_bin_size'};
       my $high_bin = $stats->{'highest_ans'}+$stats->{'max_bin_size'};
       if ($high_bin > 0 && $low_bin > -$high_bin) {
           $low_bin = -$high_bin;
       } elsif ($low_bin < 0 && $high_bin < -$low_bin) {
           $high_bin = -$low_bin;
       }
       if (($high_bin -$low_bin)/$min_bin_size * 2 > $max_bins) {
           $min_bin_size = abs($high_bin - $low_bin) / $max_bins * 2;
       }
     my @bins;      my @bins;
     my @labels;      for (my $num = $low_bin;$num <= $high_bin;$num+=($min_bin_size/2)) {
     # Hmmmm, should switch to absolute difference          push(@bins,$num);
     for (my $i=1;$i<=20;$i++) {  
         push(@bins,$i/2);  
         push(@labels,$i);  
     }      }
     #      #
     my @correct;      my @correct;
     my @incorrect;      my @incorrect;
     my @count;      my @count;
     while (my ($ans,$submissions) = each(%$responses)) {      while (my ($ans,$submissions) = each(%$responses)) {
         next if ($ans =~ /^_/);  
         while (my ($submission,$counts) = each(%$submissions)) {          while (my ($submission,$counts) = each(%$submissions)) {
             my ($correct_count,$incorrect_count) = @$counts;              my ($correct_count,$incorrect_count) = @$counts;
             my $value = abs($submission-$ans);              my $scaled_value = $submission-$ans;
               if ($scaled_value < $bins[0]) {
                   $bins[0]=$scaled_value-1;
               }
             my $bin=0;              my $bin=0;
             for ($bin=0;$bin<$#bins;$bin++) { # not <= for a reason              for ($bin=0;$bin<$#bins;$bin++) {
                 last if ($bins[$bin]>$value);                  last if ($bins[$bin]>$scaled_value);
             }              }
             $correct[$bin]+=$correct_count;              $correct[$bin-1]+=$correct_count;
             $incorrect[$bin]+=$incorrect_count;              $incorrect[$bin-1]+=$incorrect_count;
             $count[$bin]+=$correct_count+$incorrect_count;              $count[$bin-1]+=$correct_count+$incorrect_count;
         }          }
     }      }
     #      my @plot_correct   = @correct;
     my @plot_correct;      my @plot_incorrect = @incorrect;
     my @plot_incorrect;      my $max;
     for (my $i=0;$i<=$#bins;$i++) {      for (my $i=0;$i<=$#bins;$i++) {
         $plot_correct[$i]   =   $correct[$i]*100/$total;          $plot_correct[$i]   *= 100/$total;
         $plot_incorrect[$i] = $incorrect[$i]*100/$total;          $plot_incorrect[$i] *= 100/$total;
           if (! defined($max) || 
               $max < $plot_correct[$i]+$plot_incorrect[$i] ) {
               $max = $plot_correct[$i]+$plot_incorrect[$i];
           }
       }
       foreach (qw/1 5 10 15 20 25 30 40 50 75 100/) {
           if ($max <$_) { $max = $_; last; }
     }      }
     my $title = &mt('Distribution by Magnitude');      #
       my $title = &mt('Difference between submission and correct');
       my @labels = (1..scalar(@bins)-1);
     my $graph = &Apache::loncommon::DrawBarGraph      my $graph = &Apache::loncommon::DrawBarGraph
         ($title,'magnitude difference from correct','Number of answers',          ($title,'Difference from Correct','Percent of Answers',
          100,['#33FF00','#FF3300'],\@labels,\@plot_correct,\@plot_incorrect,           $max,['#33FF00','#FF3300'],\@labels,\@plot_correct,\@plot_incorrect,
          {xskip=>1});           {xskip=>1});
     #      #
     my $table = $graph.$/.      my $table = $graph.$/.
Line 482  sub numerical_classify_responses { Line 513  sub numerical_classify_responses {
                 &capa::caparesponse_get_real_response($myunit,                  &capa::caparesponse_get_real_response($myunit,
                                                       $mysub,                                                        $mysub,
                                                       \$scaled);                                                        \$scaled);
             &Apache::lonnet::logthis('scaled = '.$scaled.' result ='.$result);  #            &Apache::lonnet::logthis('scaled = '.$scaled.' result ='.$result);
             next if (! defined($scaled));              next if (! defined($scaled));
 #            next if ($result ne '6');  #            next if ($result ne '6');
             my $submission = $scaled;              my $submission = $scaled;
Line 528  sub numerical_bin_table { Line 559  sub numerical_bin_table {
         '<th>'.&mt('Correct').'</th>'.          '<th>'.&mt('Correct').'</th>'.
         '<th>'.&mt('Count').'</th>'.          '<th>'.&mt('Count').'</th>'.
         '</tr>'.$/;          '</tr>'.$/;
     for (my $i=0;$i<scalar(@{$bins});$i++) {      for (my $i=0;$i<scalar(@{$bins}-1);$i++) {
         my $lownum;          my $lownum = $bins->[$i];
         if ($i == 0) {          if ($i == 0) { $lownum = '-&infin;'; }
             $lownum = 0;          my $highnum = $bins->[$i+1];
         } else {          if ($i == scalar(@{$bins})-2) { $highnum = '&infin;'; }
             $lownum = $bins->[$i-1];  
         }  
         my $highnum = $bins->[$i];  
         $table .=           $table .= 
             '<tr>'.              '<tr>'.
             '<td>'.$labels->[$i].'</td>'.              '<td>'.$labels->[$i].'</td>'.

Removed from v.1.112  
changed lines
  Added in v.1.114


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