--- loncom/interface/statistics/lonproblemanalysis.pm 2003/10/06 20:51:20 1.25 +++ loncom/interface/statistics/lonproblemanalysis.pm 2003/10/09 22:10:02 1.28 @@ -1,6 +1,6 @@ # The LearningOnline Network with CAPA # -# $Id: lonproblemanalysis.pm,v 1.25 2003/10/06 20:51:20 matthew Exp $ +# $Id: lonproblemanalysis.pm,v 1.28 2003/10/09 22:10:02 matthew Exp $ # # Copyright Michigan State University Board of Trustees # @@ -39,6 +39,9 @@ sub BuildProblemAnalysisPage { my ($r,$c)=@_; $r->print('

'.&mt('Option Response Problem Analysis').'

'); $r->print(&CreateInterface()); + # + my @Students = @Apache::lonstatistics::Students; + # if (exists($ENV{'form.problemchoice'})) { $r->print('
'); &Apache::lonstatistics::Gather_Full_Student_Data($r); @@ -46,42 +49,59 @@ sub BuildProblemAnalysisPage { my ($symb,$part,$resid) = &get_problem_symb( &Apache::lonnet::unescape($ENV{'form.problemchoice'}) ); - $r->print('
'); + # +# my ($firsttime,$lasttime) = +# &Apache::loncoursedata::get_timestamp_data($symb,$resid); + # my $resource = &get_resource_from_symb($symb); if (defined($resource)) { my %Data = &get_problem_data($resource->{'src'}); my $ORdata = $Data{$part.'.'.$resid}; ## - ## Render the problem for display + ## Render the problem my $base; ($base,undef) = ($resource->{'src'} =~ m|(.*/)[^/]*$|); $base = "http://".$ENV{'SERVER_NAME'}.$base; - $r->print(''. - '
'. + my $rendered_problem = + &Apache::lonnet::ssi_body($resource->{'src'}); + $rendered_problem =~ s/
/<\/nop>/g; + $r->print('
'. ''. -# &Apache::loncommon::get_student_view -# ($symb,$ENV{'user.name'},$ENV{'user.domain'},$ENV{'request.course.id'},'web'). - &Apache::lonnet::ssi_body($resource->{'src'}). - '
'. - ''); + $rendered_problem. + '
'); ## ## Analyze the problem - my @Data = &Apache::loncoursedata::get_optionresponse_data - (undef,$symb,$resid); - my $analysis_html = &DoTriesAnalysis(\@Data,$ORdata); - $r->print($analysis_html); + my $PerformanceData = + &Apache::loncoursedata::get_optionresponse_data + (\@Students,$symb,$resid); + if (defined($PerformanceData) && + ref($PerformanceData) eq 'ARRAY') { + if ($ENV{'form.AnalyzeBy'} eq 'Tries') { + my $analysis_html = &DoTriesAnalysis($PerformanceData, + $ORdata); + $r->print($analysis_html); +# } elsif ($ENV{'form.AnalyzeBy'} eq 'Time') { +# my $analysis_html = &DoTimeAnalysis($PerformanceData, +# $ORdata); +# $r->print($analysis_html); + } else { + $r->print('

'. + &mt('The analysis you have selected is '. + 'not supported at this time'). + '

'); + } + } else { + $r->print('

'. + &mt('There is no student data for this problem.'). + '

'); + } } else { $r->print('resource is undefined'); } - $r->print('
    '); - $r->print("
  1. render problem\n"); - $r->print("
  2. Get student response data\n"); - $r->print("
  3. image tag for plot\n"); - $r->print("
  4. plot key\n"); - $r->print('
'); $r->print('
'); } else { - $r->print('

No Problem Selected

'); + $r->print('

'.&mt('Please select a problem to analyze').'

'); } # Okay, they asked for data, so make sure we get the latest data. $r->print(&OptionResponseProblemSelector()); @@ -89,16 +109,16 @@ sub BuildProblemAnalysisPage { sub DoTriesAnalysis { - my ($Data,$ORdata) = @_; + my ($PerformanceData,$ORdata) = @_; my $mintries = 1; - my $maxtries = 3; - my %ResponseData = &analyze_option_data_by_tries($Data, + my $maxtries = 10; + my %ResponseData = &analyze_option_data_by_tries($PerformanceData, $mintries,$maxtries); my @Foils = sort(keys(%ResponseData)); my %Row_Label; foreach my $foilid (@Foils) { my $value = $ORdata->{'Foiltext'}->{$foilid}; - &Apache::lonnet::logthis('row label '.$foilid.' = '.$value); +# &Apache::lonnet::logthis('row label '.$foilid.' = '.$value); $Row_Label{$foilid} = $ORdata->{'Foiltext'}->{$foilid}; } my @Rows; @@ -149,10 +169,38 @@ sub DoTriesAnalysis { } my @Data = (''); for (my $i=$mintries;$i<=$maxtries;$i++) { - push(@Data,''.&DrawGraph('Attempt '.$i,'Foil Number', - 'Percent Correct',100, - $PlotData[$i]->{'good'}, - $PlotData[$i]->{'bad'}).''); + my $minstu = $ResponseData{$Foils[0]}->[$i]->{'total'}; + my $maxstu = $ResponseData{$Foils[0]}->[$i]->{'total'}; + foreach my $foilid (@Foils) { + if ($minstu > $ResponseData{$foilid}->[$i]->{'total'}) { + $minstu = $ResponseData{$foilid}->[$i]->{'total'}; + } + if ($maxstu < $ResponseData{$foilid}->[$i]->{'total'}) { + $maxstu = $ResponseData{$foilid}->[$i]->{'total'}; + } + } + $maxstu = 0 if (! $maxstu); + $minstu = 0 if (! $minstu); + my $graphlink; + if ($maxstu == $minstu) { + $graphlink = &Apache::loncommon::DrawGraph + ('Attempt '.$i.', '.$maxstu.' students', + 'Foil Number', + 'Percent Correct', + 100, + $PlotData[$i]->{'good'}, + $PlotData[$i]->{'bad'}); + } else { + $graphlink = &Apache::loncomon::DrawGraph + ('Attempt '.$i.', '.$minstu.'-'.$maxstu. + ' students', + 'Foil Number', + 'Percent Correct', + 100, + $PlotData[$i]->{'good'}, + $PlotData[$i]->{'bad'}); + } + push(@Data,''.$graphlink.''); } push (@Rows,\@Data); my $table = ''."\n"; @@ -164,11 +212,12 @@ sub DoTriesAnalysis { } sub analyze_option_data_by_tries { - my ($data,$mintries,$maxtries) = @_; + my ($PerformanceData,$mintries,$maxtries) = @_; my %Trydata; $mintries = 1 if (! defined($mintries) || $mintries < 1); $maxtries = $mintries if (! defined($maxtries) || $maxtries < $mintries); - foreach my $row (@$data) { + foreach my $row (@$PerformanceData) { + next if (! defined($row)); my ($grading,$submission,$time,$tries) = @$row; my @Foilgrades = split('&',$grading); my @Foilsubs = split('&',$submission); @@ -191,6 +240,8 @@ sub analyze_option_data_by_tries { ! exists($tryhash->{'incorrect'})) || ($tryhash->{'correct'} < 1 && $tryhash->{'incorrect'} < 1)); + $tryhash->{'total'} = $tryhash->{'correct'} + + $tryhash->{'incorrect'}; $tryhash->{'percent_corr'} = 100 * ($tryhash->{'correct'} / ($tryhash->{'correct'} + $tryhash->{'incorrect'}) @@ -200,37 +251,6 @@ sub analyze_option_data_by_tries { return %Trydata; } -sub DrawGraph { - my ($title,$xlabel,$ylabel,$MaxY,$values1,$values2)=@_; - $title = '' if (! defined($title)); - $xlabel = '' if (! defined($xlabel)); - $ylabel = '' if (! defined($ylabel)); - $title = &Apache::lonnet::escape($title); - $xlabel = &Apache::lonnet::escape($xlabel); - $ylabel = &Apache::lonnet::escape($ylabel); - # - my $sendValues1 = join(',', @$values1); - my $sendValues2; - if (defined($values2)) { - $sendValues2 = join(',', @$values2); - } - - my $sendCount = scalar(@$values1); - $MaxY =1 if ($MaxY < 1); - if ( int($MaxY) < $MaxY ) { - $MaxY++; - $MaxY = int($MaxY); - } - my @GData = ($title,$xlabel,$ylabel,$MaxY,$sendCount,$sendValues1); - if (defined($sendValues2)) { - push (@GData,$sendValues2); - } - return ''; -} - - - sub get_problem_symb { my $problemstring = shift(); my ($symb,$partid,$resid) = ($problemstring=~ /^(.*):([^:]*):([^:]*)$/); @@ -238,19 +258,31 @@ sub get_problem_symb { } sub CreateInterface { + ## + ## Environment variable initialization + if (! exists$ENV{'form.AnalyzeBy'}) { + $ENV{'form.AnalyzeBy'} = 'Tries'; + } + ## + ## Build the menu my $Str = ''; $Str .= '
'."\n"; $Str .= ''; $Str .= ''; $Str .= ''; $Str .= ''; + $Str .= ''; $Str .= ''."\n"; # $Str .= ''; + # + $Str .= ''; + # + $Str .= ''."\n"; + $Str .= ''; + # + $Str .= ''; + # + $Str .= ''."\n"; $Str .= '
'.&mt('Sections').''.&mt('Enrollment Status').''.&mt('Sequences and Folders').''.&mt('Analyze By').'
'."\n"; $Str .= &Apache::lonstatistics::SectionSelect('Section','multiple',5); - $Str .= ''; + $Str .= ''; $Str .= &Apache::lonhtmlcommon::StatusOptions(undef,undef,5); - $Str .= ''; + $Str .= ''; my $only_seq_with_assessments = sub { my $s=shift; if ($s->{'num_assess'} < 1) { @@ -261,7 +293,22 @@ sub CreateInterface { }; $Str .= &Apache::lonstatistics::MapSelect('Maps','multiple,all',5, $only_seq_with_assessments); - $Str .= '
'; + $Str .=''; + $Str .=''; + $Str .= '
'."\n"; $Str .= ''; @@ -280,7 +327,7 @@ sub OptionResponseProblemSelector { my $seq_str = ''; foreach my $res (@{$seq->{'contents'}}) { # &Apache::lonnet::logthis('checking '.$res->{'title'}); -# next if ($res->{'type'} ne 'assessment'); + next if ($res->{'type'} ne 'assessment'); foreach my $part (@{$res->{'parts'}}) { my $partdata = $res->{'partdata'}->{$part}; if (! exists($partdata->{'option'}) || @@ -359,8 +406,8 @@ sub get_problem_data { $Partdata{$part}->{$foil}->{'Concept'}=$concept; } } - &Apache::lonnet::logthis($part.' '.$key.' (array) = '. - join(', ',@$value)); + # &Apache::lonnet::logthis($part.' '.$key.' (array) = '. + # join(', ',@$value)); } else { $value =~ s/^\s*//g; $value =~ s/\s*$//g; @@ -371,7 +418,7 @@ sub get_problem_data { my $foil = $1; $Partdata{$part}->{'FoilValues'}->{$foil}=$value; } - &Apache::lonnet::logthis($part.' '.$key.' = '.$value); +# &Apache::lonnet::logthis($part.' '.$key.' = '.$value); } } }