'.
&mt('The analysis you have selected is not supported at this time').
@@ -225,7 +221,6 @@ sub RadioResponseAnalysis {
$r->print($analysis_html);
}
-
sub RR_Excel_output {
my ($r,$PerformanceData,$ProblemData) = @_;
return '
No!
';
@@ -237,7 +232,8 @@ sub RR_Tries_Analysis {
my $mintries = 1;
my $maxtries = $ENV{'form.NumPlots'};
my ($table,$Foils,$Concepts) = &build_foil_index($ProblemData);
- if ((@$Concepts < 2) && ($ENV{'form.AnalyzeAs'} ne 'Foils')) {
+ if ((! defined($Concepts)) || ((@$Concepts < 2) &&
+ ($ENV{'form.AnalyzeAs'} ne 'Foils'))) {
$table = '
'.
&mt('Not enough data for concept analysis. '.
'Performing Foil Analysis').
@@ -246,15 +242,15 @@ sub RR_Tries_Analysis {
}
$analysis_html .= $table;
my @TryData = &RR_tries_data_analysis($r,$PerformanceData);
- if ($ENV{'form.AnalyzeAs'} eq 'Foils') {
- $analysis_html = &RR_Tries_Foil_Analysis($mintries,$maxtries,$Foils,
+# if ($ENV{'form.AnalyzeAs'} eq 'Foils') {
+ $analysis_html .= &RR_Tries_Foil_Analysis($mintries,$maxtries,$Foils,
\@TryData,$ProblemData);
- } else {
- $analysis_html = &RR_Tries_Concept_Analysis($mintries,$maxtries,
- $Concepts,
- \@TryData,
- $ProblemData);
- }
+# } else {
+# $analysis_html = &RR_Tries_Concept_Analysis($mintries,$maxtries,
+# $Concepts,
+# \@TryData,
+# $ProblemData);
+# }
return $analysis_html;
}
@@ -284,8 +280,8 @@ sub RR_Tries_Foil_Analysis {
my @PlotData_Correct;
my @PlotData_Incorrect;
next if ($try > scalar(@{$TryData}));
- next if (! defined($TryData->[$try-1]));
- my %DataSet = %{$TryData->[$try-1]};
+ next if (! defined($TryData->[$try]));
+ my %DataSet = %{$TryData->[$try]};
my $total = 0;
foreach my $foilid (@$Foils) {
$total += $DataSet{$foilid};
@@ -316,7 +312,6 @@ sub RR_Tries_Foil_Analysis {
\@PlotData_Correct,
\@PlotData_Incorrect);
}
- &Apache::lonnet::logthis('plot = '.$html);
return $html;
}
@@ -339,14 +334,12 @@ sub RR_Time_Concept_Analysis {
}
-
sub get_Radio_problem_data {
my ($url) = @_;
my $Answ=&Apache::lonnet::ssi($url,('grade_target' => 'analyze'));
(my $garbage,$Answ)=split('_HASH_REF__',$Answ,2);
my %Answer = &Apache::lonnet::str2hash($Answ);
my %Partdata;
- &Apache::lonnet::logthis('url = '.$url);
foreach my $part (@{$Answer{'parts'}}) {
while (my($key,$value) = each(%Answer)) {
# if (ref($value) eq 'ARRAY') {
@@ -372,9 +365,6 @@ sub get_Radio_problem_data {
return %Partdata;
}
-=cut
-
-
#########################################################
#########################################################
##
@@ -383,7 +373,10 @@ sub get_Radio_problem_data {
#########################################################
#########################################################
sub OptionResponseAnalysis {
- my ($r,$resource,$respid,$ProblemData,$Students) = @_;
+ my ($r,$problem,$ProblemData,$Students) = @_;
+ my ($resource,$respid) = ($problem->{'resource'},
+ $problem->{'respid'});
+ # Note: part data is not needed.
my $PerformanceData =
&Apache::loncoursedata::get_response_data
($Students,$resource->{'symb'},$respid);
@@ -395,20 +388,20 @@ sub OptionResponseAnalysis {
} else {
$r->rflush();
if (exists($ENV{'form.ExcelOutput'})) {
- my $result = &prepare_optionresponse_excel_sheet($r,$resource,
- $PerformanceData,
- $ProblemData);
+ my $result = &OR_excel_sheet($r,$resource,
+ $PerformanceData,
+ $ProblemData);
$r->print($result);
$r->rflush();
} else {
if ($ENV{'form.AnalyzeOver'} eq 'Tries') {
- my $analysis_html = &tries_analysis($r,
+ my $analysis_html = &OR_tries_analysis($r,
$PerformanceData,
$ProblemData);
$r->print($analysis_html);
$r->rflush();
} elsif ($ENV{'form.AnalyzeOver'} eq 'Time') {
- my $analysis_html = &time_analysis($PerformanceData,
+ my $analysis_html = &OR_time_analysis($PerformanceData,
$ProblemData);
$r->print($analysis_html);
$r->rflush();
@@ -427,7 +420,7 @@ sub OptionResponseAnalysis {
# Option Response: Tries Analysis
#
#########################################################
-sub tries_analysis {
+sub OR_tries_analysis {
my ($r,$PerformanceData,$ORdata) = @_;
my $mintries = 1;
my $maxtries = $ENV{'form.NumPlots'};
@@ -439,21 +432,21 @@ sub tries_analysis {
'
';
##
##
+ next if (! defined($Datasets[0]));
for (my $i=0; $i< scalar(@{$Datasets[0]});$i++) {
$Datasets[0]->[$i]=0;
}
@@ -534,7 +528,7 @@ sub Tries_Foil_Analysis {
return $analysis_html;
}
-sub Tries_Concept_Analysis {
+sub OR_Tries_Concept_Analysis {
my ($mintries,$maxtries,$Concepts,$respdat,$ORdata) = @_;
my %ResponseData = %$respdat;
my $analysis_html = "
\n";
@@ -600,7 +594,7 @@ sub Tries_Concept_Analysis {
return $analysis_html;
}
-sub analyze_option_data_by_tries {
+sub OR_analyze_by_tries {
my ($r,$PerformanceData,$mintries,$maxtries) = @_;
my %Trydata;
$mintries = 1 if (! defined($mintries) || $mintries < 1);
@@ -628,7 +622,7 @@ sub analyze_option_data_by_tries {
# Option Response: Time Analysis
#
#########################################################
-sub time_analysis {
+sub OR_time_analysis {
my ($PerformanceData,$ORdata) = @_;
my ($table,$Foils,$Concepts) = &build_foil_index($ORdata);
if ((@$Concepts < 2) && ($ENV{'form.AnalyzeAs'} ne 'Foils')) {
@@ -686,10 +680,10 @@ sub time_analysis {
enddateform => $enddateform,
};
if ($ENV{'form.AnalyzeAs'} eq 'Foils') {
- $table .= &Foil_Time_Analysis($PerformanceData,$ORdata,$Foils,
+ $table .= &OR_Foil_Time_Analysis($PerformanceData,$ORdata,$Foils,
$interval);
} else {
- $table .= &Concept_Time_Analysis($PerformanceData,$ORdata,
+ $table .= &OR_Concept_Time_Analysis($PerformanceData,$ORdata,
$Concepts,$interval);
}
}
@@ -697,7 +691,7 @@ sub time_analysis {
return $table;
}
-sub Foil_Time_Analysis {
+sub OR_Foil_Time_Analysis {
my ($PerformanceData,$ORdata,$Foils,$interval) = @_;
my $analysis_html;
my $foilkey = &build_option_index($ORdata);
@@ -792,7 +786,7 @@ sub Foil_Time_Analysis {
return $analysis_html;
}
-sub Concept_Time_Analysis {
+sub OR_Concept_Time_Analysis {
my ($PerformanceData,$ORdata,$Concepts,$interval) = @_;
my $analysis_html;
##
@@ -860,7 +854,7 @@ sub Concept_Time_Analysis {
##
#########################################################
#########################################################
-sub prepare_optionresponse_excel_sheet {
+sub OR_excel_sheet {
my ($r,$resource,$PerformanceData,$ORdata) = @_;
my $response = '';
my (undef,$Foils,$Concepts) = &build_foil_index($ORdata);
@@ -932,7 +926,7 @@ sub prepare_optionresponse_excel_sheet {
return $result;
}
-sub build_problem_data_worksheet {
+sub OR_build_problem_data_worksheet {
my ($worksheet,$format,$Concepts,$ORdata) = @_;
my $rows_output = 3;
my $cols_output = 0;
@@ -1001,7 +995,7 @@ sub build_problem_data_worksheet {
return 'okay';
}
-sub build_student_data_worksheet {
+sub OR_build_student_data_worksheet {
my ($worksheet,$format) = @_;
my $rows_output = 3;
my $cols_output = 0;
@@ -1027,7 +1021,7 @@ sub build_student_data_worksheet {
return;
}
-sub build_response_data_worksheet {
+sub OR_build_response_data_worksheet {
my ($worksheet,$format,$PerformanceData,$Foils,$ORdata)=@_;
my $rows_output = 3;
my $cols_output = 0;
@@ -1257,6 +1251,8 @@ sub build_foil_index {
my @Foils = sort(keys(%Foildata));
my %Concepts;
foreach my $foilid (@Foils) {
+ &Apache::lonnet::logthis('foilid = '.$foilid);
+ &Apache::lonnet::logthis('_Concept = '.$Foildata{$foilid}->{'_Concept'});
push(@{$Concepts{$Foildata{$foilid}->{'_Concept'}}},
$foilid);
}
@@ -1277,16 +1273,25 @@ sub build_foil_index {
ten => 10,);
my $a1 = lc($a);
my $b1 = lc($b);
- if (exists($Numbers{$a})) {
- $a1 = $Numbers{$a};
+ if (exists($Numbers{$a1})) {
+ $a = $Numbers{$a1};
}
- if (exists($Numbers{$b})) {
- $b1 = $Numbers{$b};
+ if (exists($Numbers{$b1})) {
+ $b = $Numbers{$b1};
+ }
+ if (($a =~/^\d+$/) && ($b =~/^\d+$/)) {
+ return $a <=> $b;
+ } else {
+ return $a cmp $b;
}
- $a1 cmp $b1;
};
my @Concepts;
foreach my $concept (sort $sortfunction (keys(%Concepts))) {
+ if (! defined($Concepts{$concept})) {
+ $Concepts{$concept}=[];
+ &Apache::lonnet::logthis('concept error: '.$concept.' does not have a value');
+# next;
+ }
push(@Concepts,{ name => $concept,
foils => [@{$Concepts{$concept}}]});
push(@Foils,(@{$Concepts{$concept}}));
@@ -1517,8 +1522,8 @@ sub ProblemSelector {
for (my $i=0;$i{'ResponseTypes'}});$i++){
my $respid = $partdata->{'ResponseIds'}->[$i];
my $resptype = $partdata->{'ResponseTypes'}->[$i];
- if ($resptype eq 'option' ){
-# if ($resptype eq 'option' || $resptype eq 'radiobutton') {
+# if ($resptype eq 'option' ){
+ if ($resptype eq 'option' || $resptype eq 'radiobutton') {
my $value = &make_target_id({symb=>$res->{'symb'},
part=>$part,
respid=>$respid,
@@ -1533,7 +1538,8 @@ sub ProblemSelector {
}
$seq_str .= '
'.
''.
- '
'.
+ '
'.
+ $resptype.'
'.
''.$title.' ';
# ''.$resptype.' '.$res->{'title'}.' ';
if ($partdata->{'option'} > 1) {
@@ -1545,7 +1551,7 @@ sub ProblemSelector {
}
}
if ($seq_str ne '') {
- $Str .= '
 
'.$seq->{'title'}.'
'.
+ $Str .= '
 
'.$seq->{'title'}.'
'.
"
\n".$seq_str;
}
}
@@ -1594,7 +1600,8 @@ sub get_prev_curr_next {
for (my $i=0;$i{'ResponseTypes'}});$i++){
my $respid = $partdata->{'ResponseIds'}->[$i];
my $resptype = $partdata->{'ResponseTypes'}->[$i];
- next if ($resptype ne 'option');
+ next if ($resptype ne 'option' &&
+ $resptype ne 'radiobutton');
push (@Resource,
{ symb => $res->{symb},
part => $part,