--- loncom/interface/statistics/lonstudentassessment.pm 2002/12/11 18:41:00 1.20 +++ loncom/interface/statistics/lonstudentassessment.pm 2002/12/16 23:35:46 1.21 @@ -1,7 +1,7 @@ # The LearningOnline Network with CAPA # (Publication Handler # -# $Id: lonstudentassessment.pm,v 1.20 2002/12/11 18:41:00 minaeibi Exp $ +# $Id: lonstudentassessment.pm,v 1.21 2002/12/16 23:35:46 minaeibi Exp $ # # Copyright Michigan State University Board of Trustees # @@ -34,7 +34,7 @@ # ### -package Apache::lonstudentassessment; +package Apache::lonstudentassessment; use strict; use Apache::lonhtmlcommon; @@ -77,10 +77,10 @@ sub BuildStudentAssessmentPage { } } my ($infoHeadings, $infoKeys, $sequenceHeadings, $sequenceKeys, - $doNotShow) = + $doNotShow) = &ShouldShowColumns(\%cache, $headings, $studentInformation); - my $selectedName = &FindSelectedStudent(\%cache, + my $selectedName = &FindSelectedStudent(\%cache, $cache{'StudentAssessmentStudent'}, $students); $r->print(&CreateInterface(\%cache, $selectedName, $students, $formName, @@ -165,14 +165,10 @@ sub BuildStudentAssessmentPage { } } - -# $r->print("AverageTtal"); -# $r->print(&StudentAverageTotal(\%cache, $spacing, $sequenceKeys)); -# $r->print("\n"); -# $r->rflush(); - untie(%cache); - - + if(tie(%cache,'GDBM_File',$cacheDB,&GDBM_READER(),0640)) { + $r->print(&StudentAverageTotal(\%cache, $students, $sequenceKeys)); + untie(%cache); + } $r->print(''."\n"); if($selected == 0) { $Str .= '

WARNING: '; @@ -183,6 +179,9 @@ sub BuildStudentAssessmentPage { return; } + + + #---- Student Assessment Web Page -------------------------------------------- sub CreateInterface { @@ -195,8 +194,8 @@ sub CreateInterface { $Str .= 'value="Previous Student" />'."\n"; $Str .= '   '."\n"; $Str .= &Apache::lonhtmlcommon::StudentOptions($cache, $students, - $selectedName, - 'StudentAssessment', + $selectedName, + 'StudentAssessment', $formName); $Str .= "\n".'   '."\n"; $Str .= ''; + $Str .= '&command=submission">'; } my $code = $cache->{$name.':'.$problemID.':'.$_.':code'}; my $tries = $cache->{$name.':'.$problemID.':'.$_.':tries'}; @@ -400,84 +399,28 @@ sub StudentReport { sub StudentAverageTotal { - - return ""; - - my ($cache,$name,$spacing,$showSequences)=@_; - my $username = $name; - my $Str = ''; - my $hasVersion = 'false'; - my $hasFinalData = 'false'; - foreach my $sequence (@$showSequences) { - my $hasData = 'false'; - my $characterCount=0; - foreach my $problemID (split(':', $cache->{$sequence.':problems'})) { - my $problem = $cache->{$problemID.':problem'}; - # All grades (except for versionless parts) are displayed as links - # to their submission record. Loop through all the parts for the - # current problem in the correct order and prepare the output links - foreach(split(/\:/,$cache->{$sequence.':'.$problemID. - ':parts'})) { - if($cache->{$name.':'.$problemID.':NoVersion'} eq 'true' || - $cache->{$name.':'.$problemID.':'.$_.':code'} eq ' ' || - $cache->{$name.':'.$problemID.':'.$_.':code'} eq '') { - $Str .= ' '; - $characterCount++; - next; - } - $hasVersion = 'true'; - $hasData = 'true'; - $Str .= ''; - my $code = $cache->{$name.':'.$problemID.':'.$_.':code'}; - my $tries = $cache->{$name.':'.$problemID.':'.$_.':tries'}; - if($code eq '*' && $tries < 10 && $tries ne '') { - $code = $tries; - } - $Str .= $code; - $Str .= ''; - $characterCount++; - } + my ($cache, $students, $sequenceKeys)=@_; + my $Str = "\nAverageTotal\n"; + my %Correct = (); + my $ProblemsSolved = 0; + my $TotalProblems = 0; + my $StudentCount = 0; + + foreach my $name (@$students) { + $StudentCount++; + foreach my $sequence (@$sequenceKeys) { + $Correct{$cache->{$sequence.':title'}} += + $cache->{$name.':'.$sequence.':problemsCorrect'}; } - - # Output the number of correct answers for the current sequence. - # This part takes up 6 character slots, but is formated right - # justified. - my $spacesNeeded=$cache->{$sequence.':columnWidth'}-$characterCount; - $spacesNeeded -= 3; - $Str .= (' 'x$spacesNeeded); - -# my $outputProblemsCorrect = sprintf("%3d", $cache->{$name.':'.$sequence. -# ':problemsCorrect'}); - - my $outputProblemsCorrect = sprintf("%2d/%2d", $cache->{$name.':'.$sequence. - ':problemsCorrect'}, - $characterCount); - if($hasData eq 'true') { - $Str .= ''.$outputProblemsCorrect.''; - $hasFinalData = 'true'; - } else { - $Str .= ' '; - } - $Str .= $spacing; + $ProblemsSolved += $cache->{$name.':problemsSolved'}; + $TotalProblems += $cache->{$name.':totalProblems'}; } - - # Output the total correct problems over the total number of problems. - # I don't like this type of formatting, but it is a solution. Need - # a way to dynamically determine the space requirements. - my $outputProblemsSolved = sprintf("%4d", $cache->{$name.':problemsSolved'}); - my $outputTotalProblems = sprintf("%4d", $cache->{$name.':totalProblems'}); - if($hasFinalData eq 'true') { - $Str .= ''.$outputProblemsSolved. - ' / '.$outputTotalProblems.''; - } else { - $Str .= ' '; - } - - if($hasVersion eq 'false') { - $Str = 'No course data.'; + $ProblemsSolved /= $StudentCount; + $TotalProblems /= $StudentCount; + $Str .= "AvgSlvd:$ProblemsSolved AvgTotal: $TotalProblems\n"; + + foreach (%Correct) { + $Str .= "$_ : $Correct{$_}\n"; } return $Str; @@ -696,7 +639,7 @@ sub ShouldShowColumns { foreach my $sequence (split(/\:/,$cache->{'orderedSequences'})) { $check = 'SequenceColumn'.$sequence; - if($cache->{'SequencesFound'} eq 'All Sequences' || + if($cache->{'SequencesFound'} eq 'All Sequences' || $cache->{'SequencesFound'} =~ /$check/) { push(@sequenceHeadings, $cache->{$sequence.':title'}); push(@sequenceKeys, $sequence); @@ -709,7 +652,7 @@ sub ShouldShowColumns { $doNotShow{'count'} = $count; - return (\@infoHeadings, \@infoKeys, \@sequenceHeadings, + return (\@infoHeadings, \@infoKeys, \@sequenceHeadings, \@sequenceKeys, \%doNotShow); }