version 1.54, 2004/01/16 15:33:40
|
version 1.58, 2004/01/19 18:55:10
|
Line 159 sub BuildProblemAnalysisPage {
|
Line 159 sub BuildProblemAnalysisPage {
|
'.'. |
'.'. |
$current_problem->{'respid'}}; |
$current_problem->{'respid'}}; |
if ($current_problem->{'resptype'} eq 'option') { |
if ($current_problem->{'resptype'} eq 'option') { |
&OptionResponseAnalysis($r,$resource, |
&OptionResponseAnalysis($r,$current_problem, |
$current_problem->{'respid'}, |
|
$ProblemData, |
$ProblemData, |
\@Students); |
\@Students); |
} elsif ($current_problem->{'resptype'} eq 'radiobutton') { |
} elsif ($current_problem->{'resptype'} eq 'radiobutton') { |
&RadioResponseAnalysis($r,$resource, |
&RadioResponseAnalysis($r,$current_problem, |
$current_problem->{'part'}, |
|
$current_problem->{'respid'}, |
|
$ProblemData, |
$ProblemData, |
\@Students); |
\@Students); |
} else { |
} else { |
Line 183 sub BuildProblemAnalysisPage {
|
Line 180 sub BuildProblemAnalysisPage {
|
} |
} |
} |
} |
|
|
=pod |
|
|
|
Removed code: |
|
|
|
######################################################### |
######################################################### |
######################################################### |
######################################################### |
Line 195 Removed code:
|
Line 189 Removed code:
|
######################################################### |
######################################################### |
######################################################### |
######################################################### |
sub RadioResponseAnalysis { |
sub RadioResponseAnalysis { |
my ($r,$resource,$part,$respid,$ProblemData,$Students) = @_; |
my ($r,$problem,$ProblemData,$Students) = @_; |
|
my ($resource,$respid) = ($problem->{'resource'}, |
|
$problem->{'respid'}); |
my $analysis_html; |
my $analysis_html; |
my $PerformanceData = |
my $PerformanceData = |
&Apache::loncoursedata::get_response_data |
&Apache::loncoursedata::get_response_data |
Line 209 sub RadioResponseAnalysis {
|
Line 205 sub RadioResponseAnalysis {
|
return; |
return; |
} |
} |
if (exists($ENV{'form.ExcelOutput'})) { |
if (exists($ENV{'form.ExcelOutput'})) { |
$analysis_html .= &RR_Excel_output($r,$resource,$PerformanceData, |
$analysis_html .= &RR_Excel_output($r,$problem->{'resource'}, |
$ProblemData); |
$PerformanceData,$ProblemData); |
} elsif ($ENV{'form.AnalyzeOver'} eq 'Tries') { |
} elsif ($ENV{'form.AnalyzeOver'} eq 'Tries') { |
$analysis_html .= &RR_Tries_Analysis($r,$resource,$PerformanceData, |
$analysis_html .= &RR_Tries_Analysis($r,$problem->{'resource'}, |
$ProblemData); |
$PerformanceData,$ProblemData); |
} elsif ($ENV{'form.AnalyzeOver'} eq 'Time') { |
} elsif ($ENV{'form.AnalyzeOver'} eq 'Time') { |
$analysis_html .= &RR_Time_Analysis($r,$resource,$PerformanceData, |
$analysis_html .= &RR_Time_Analysis($r,$problem->{'resource'}, |
$ProblemData); |
$PerformanceData,$ProblemData); |
} else { |
} else { |
$analysis_html .= '<h2>'. |
$analysis_html .= '<h2>'. |
&mt('The analysis you have selected is not supported at this time'). |
&mt('The analysis you have selected is not supported at this time'). |
Line 225 sub RadioResponseAnalysis {
|
Line 221 sub RadioResponseAnalysis {
|
$r->print($analysis_html); |
$r->print($analysis_html); |
} |
} |
|
|
|
|
sub RR_Excel_output { |
sub RR_Excel_output { |
my ($r,$PerformanceData,$ProblemData) = @_; |
my ($r,$PerformanceData,$ProblemData) = @_; |
return '<h1>No!</h1>'; |
return '<h1>No!</h1>'; |
Line 237 sub RR_Tries_Analysis {
|
Line 232 sub RR_Tries_Analysis {
|
my $mintries = 1; |
my $mintries = 1; |
my $maxtries = $ENV{'form.NumPlots'}; |
my $maxtries = $ENV{'form.NumPlots'}; |
my ($table,$Foils,$Concepts) = &build_foil_index($ProblemData); |
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 = '<h3>'. |
$table = '<h3>'. |
&mt('Not enough data for concept analysis. '. |
&mt('Not enough data for concept analysis. '. |
'Performing Foil Analysis'). |
'Performing Foil Analysis'). |
Line 246 sub RR_Tries_Analysis {
|
Line 242 sub RR_Tries_Analysis {
|
} |
} |
$analysis_html .= $table; |
$analysis_html .= $table; |
my @TryData = &RR_tries_data_analysis($r,$PerformanceData); |
my @TryData = &RR_tries_data_analysis($r,$PerformanceData); |
if ($ENV{'form.AnalyzeAs'} eq 'Foils') { |
# if ($ENV{'form.AnalyzeAs'} eq 'Foils') { |
$analysis_html = &RR_Tries_Foil_Analysis($mintries,$maxtries,$Foils, |
$analysis_html .= &RR_Tries_Foil_Analysis($mintries,$maxtries,$Foils, |
\@TryData,$ProblemData); |
\@TryData,$ProblemData); |
} else { |
# } else { |
$analysis_html = &RR_Tries_Concept_Analysis($mintries,$maxtries, |
# $analysis_html = &RR_Tries_Concept_Analysis($mintries,$maxtries, |
$Concepts, |
# $Concepts, |
\@TryData, |
# \@TryData, |
$ProblemData); |
# $ProblemData); |
} |
# } |
return $analysis_html; |
return $analysis_html; |
} |
} |
|
|
Line 284 sub RR_Tries_Foil_Analysis {
|
Line 280 sub RR_Tries_Foil_Analysis {
|
my @PlotData_Correct; |
my @PlotData_Correct; |
my @PlotData_Incorrect; |
my @PlotData_Incorrect; |
next if ($try > scalar(@{$TryData})); |
next if ($try > scalar(@{$TryData})); |
next if (! defined($TryData->[$try-1])); |
next if (! defined($TryData->[$try])); |
my %DataSet = %{$TryData->[$try-1]}; |
my %DataSet = %{$TryData->[$try]}; |
my $total = 0; |
my $total = 0; |
foreach my $foilid (@$Foils) { |
foreach my $foilid (@$Foils) { |
$total += $DataSet{$foilid}; |
$total += $DataSet{$foilid}; |
Line 316 sub RR_Tries_Foil_Analysis {
|
Line 312 sub RR_Tries_Foil_Analysis {
|
\@PlotData_Correct, |
\@PlotData_Correct, |
\@PlotData_Incorrect); |
\@PlotData_Incorrect); |
} |
} |
&Apache::lonnet::logthis('plot = '.$html); |
|
return $html; |
return $html; |
} |
} |
|
|
Line 339 sub RR_Time_Concept_Analysis {
|
Line 334 sub RR_Time_Concept_Analysis {
|
} |
} |
|
|
|
|
|
|
sub get_Radio_problem_data { |
sub get_Radio_problem_data { |
my ($url) = @_; |
my ($url) = @_; |
my $Answ=&Apache::lonnet::ssi($url,('grade_target' => 'analyze')); |
my $Answ=&Apache::lonnet::ssi($url,('grade_target' => 'analyze')); |
(my $garbage,$Answ)=split('_HASH_REF__',$Answ,2); |
(my $garbage,$Answ)=split('_HASH_REF__',$Answ,2); |
my %Answer = &Apache::lonnet::str2hash($Answ); |
my %Answer = &Apache::lonnet::str2hash($Answ); |
my %Partdata; |
my %Partdata; |
&Apache::lonnet::logthis('url = '.$url); |
|
foreach my $part (@{$Answer{'parts'}}) { |
foreach my $part (@{$Answer{'parts'}}) { |
while (my($key,$value) = each(%Answer)) { |
while (my($key,$value) = each(%Answer)) { |
# if (ref($value) eq 'ARRAY') { |
# if (ref($value) eq 'ARRAY') { |
Line 372 sub get_Radio_problem_data {
|
Line 365 sub get_Radio_problem_data {
|
return %Partdata; |
return %Partdata; |
} |
} |
|
|
=cut |
|
|
|
|
|
######################################################### |
######################################################### |
######################################################### |
######################################################### |
## |
## |
Line 383 sub get_Radio_problem_data {
|
Line 373 sub get_Radio_problem_data {
|
######################################################### |
######################################################### |
######################################################### |
######################################################### |
sub OptionResponseAnalysis { |
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 = |
my $PerformanceData = |
&Apache::loncoursedata::get_response_data |
&Apache::loncoursedata::get_response_data |
($Students,$resource->{'symb'},$respid); |
($Students,$resource->{'symb'},$respid); |
Line 395 sub OptionResponseAnalysis {
|
Line 388 sub OptionResponseAnalysis {
|
} else { |
} else { |
$r->rflush(); |
$r->rflush(); |
if (exists($ENV{'form.ExcelOutput'})) { |
if (exists($ENV{'form.ExcelOutput'})) { |
my $result = &prepare_optionresponse_excel_sheet($r,$resource, |
my $result = &OR_excel_sheet($r,$resource, |
$PerformanceData, |
$PerformanceData, |
$ProblemData); |
$ProblemData); |
$r->print($result); |
$r->print($result); |
$r->rflush(); |
$r->rflush(); |
} else { |
} else { |
if ($ENV{'form.AnalyzeOver'} eq 'Tries') { |
if ($ENV{'form.AnalyzeOver'} eq 'Tries') { |
my $analysis_html = &tries_analysis($r, |
my $analysis_html = &OR_tries_analysis($r, |
$PerformanceData, |
$PerformanceData, |
$ProblemData); |
$ProblemData); |
$r->print($analysis_html); |
$r->print($analysis_html); |
$r->rflush(); |
$r->rflush(); |
} elsif ($ENV{'form.AnalyzeOver'} eq 'Time') { |
} elsif ($ENV{'form.AnalyzeOver'} eq 'Time') { |
my $analysis_html = &time_analysis($PerformanceData, |
my $analysis_html = &OR_time_analysis($PerformanceData, |
$ProblemData); |
$ProblemData); |
$r->print($analysis_html); |
$r->print($analysis_html); |
$r->rflush(); |
$r->rflush(); |
Line 427 sub OptionResponseAnalysis {
|
Line 420 sub OptionResponseAnalysis {
|
# Option Response: Tries Analysis |
# Option Response: Tries Analysis |
# |
# |
######################################################### |
######################################################### |
sub tries_analysis { |
sub OR_tries_analysis { |
my ($r,$PerformanceData,$ORdata) = @_; |
my ($r,$PerformanceData,$ORdata) = @_; |
my $mintries = 1; |
my $mintries = 1; |
my $maxtries = $ENV{'form.NumPlots'}; |
my $maxtries = $ENV{'form.NumPlots'}; |
Line 439 sub tries_analysis {
|
Line 432 sub tries_analysis {
|
'</h3>'.$table; |
'</h3>'.$table; |
$ENV{'form.AnalyzeAs'} = 'Foils'; |
$ENV{'form.AnalyzeAs'} = 'Foils'; |
} |
} |
my %ResponseData = &analyze_option_data_by_tries($r,$PerformanceData, |
my %ResponseData = &OR_analyze_by_tries($r,$PerformanceData, |
$mintries,$maxtries); |
$mintries,$maxtries); |
my $analysis = ''; |
my $analysis = ''; |
if ($ENV{'form.AnalyzeAs'} eq 'Foils') { |
if ($ENV{'form.AnalyzeAs'} eq 'Foils') { |
$analysis = &Tries_Foil_Analysis($mintries,$maxtries,$Foils, |
$analysis = &OR_Tries_Foil_Analysis($mintries,$maxtries,$Foils, |
\%ResponseData,$ORdata); |
\%ResponseData,$ORdata); |
} else { |
} else { |
$analysis = &Tries_Concept_Analysis($mintries,$maxtries, |
$analysis = &OR_Tries_Concept_Analysis($mintries,$maxtries, |
$Concepts,\%ResponseData,$ORdata); |
$Concepts,\%ResponseData,$ORdata); |
} |
} |
$table .= $analysis; |
$table .= $analysis; |
return $table; |
return $table; |
} |
} |
|
|
sub Tries_Foil_Analysis { |
sub OR_Tries_Foil_Analysis { |
my ($mintries,$maxtries,$Foils,$respdat,$ORdata) = @_; |
my ($mintries,$maxtries,$Foils,$respdat,$ORdata) = @_; |
my %ResponseData = %$respdat; |
my %ResponseData = %$respdat; |
# |
# |
Line 512 sub Tries_Foil_Analysis {
|
Line 505 sub Tries_Foil_Analysis {
|
$analysis_html.= '<tr><td>'.$correctgraph.'</td>'; |
$analysis_html.= '<tr><td>'.$correctgraph.'</td>'; |
## |
## |
## |
## |
|
next if (! defined($Datasets[0])); |
for (my $i=0; $i< scalar(@{$Datasets[0]});$i++) { |
for (my $i=0; $i< scalar(@{$Datasets[0]});$i++) { |
$Datasets[0]->[$i]=0; |
$Datasets[0]->[$i]=0; |
} |
} |
Line 534 sub Tries_Foil_Analysis {
|
Line 528 sub Tries_Foil_Analysis {
|
return $analysis_html; |
return $analysis_html; |
} |
} |
|
|
sub Tries_Concept_Analysis { |
sub OR_Tries_Concept_Analysis { |
my ($mintries,$maxtries,$Concepts,$respdat,$ORdata) = @_; |
my ($mintries,$maxtries,$Concepts,$respdat,$ORdata) = @_; |
my %ResponseData = %$respdat; |
my %ResponseData = %$respdat; |
my $analysis_html = "<table>\n"; |
my $analysis_html = "<table>\n"; |
Line 600 sub Tries_Concept_Analysis {
|
Line 594 sub Tries_Concept_Analysis {
|
return $analysis_html; |
return $analysis_html; |
} |
} |
|
|
sub analyze_option_data_by_tries { |
sub OR_analyze_by_tries { |
my ($r,$PerformanceData,$mintries,$maxtries) = @_; |
my ($r,$PerformanceData,$mintries,$maxtries) = @_; |
my %Trydata; |
my %Trydata; |
$mintries = 1 if (! defined($mintries) || $mintries < 1); |
$mintries = 1 if (! defined($mintries) || $mintries < 1); |
Line 628 sub analyze_option_data_by_tries {
|
Line 622 sub analyze_option_data_by_tries {
|
# Option Response: Time Analysis |
# Option Response: Time Analysis |
# |
# |
######################################################### |
######################################################### |
sub time_analysis { |
sub OR_time_analysis { |
my ($PerformanceData,$ORdata) = @_; |
my ($PerformanceData,$ORdata) = @_; |
my ($table,$Foils,$Concepts) = &build_foil_index($ORdata); |
my ($table,$Foils,$Concepts) = &build_foil_index($ORdata); |
if ((@$Concepts < 2) && ($ENV{'form.AnalyzeAs'} ne 'Foils')) { |
if ((@$Concepts < 2) && ($ENV{'form.AnalyzeAs'} ne 'Foils')) { |
Line 686 sub time_analysis {
|
Line 680 sub time_analysis {
|
enddateform => $enddateform, |
enddateform => $enddateform, |
}; |
}; |
if ($ENV{'form.AnalyzeAs'} eq 'Foils') { |
if ($ENV{'form.AnalyzeAs'} eq 'Foils') { |
$table .= &Foil_Time_Analysis($PerformanceData,$ORdata,$Foils, |
$table .= &OR_Foil_Time_Analysis($PerformanceData,$ORdata,$Foils, |
$interval); |
$interval); |
} else { |
} else { |
$table .= &Concept_Time_Analysis($PerformanceData,$ORdata, |
$table .= &OR_Concept_Time_Analysis($PerformanceData,$ORdata, |
$Concepts,$interval); |
$Concepts,$interval); |
} |
} |
} |
} |
Line 697 sub time_analysis {
|
Line 691 sub time_analysis {
|
return $table; |
return $table; |
} |
} |
|
|
sub Foil_Time_Analysis { |
sub OR_Foil_Time_Analysis { |
my ($PerformanceData,$ORdata,$Foils,$interval) = @_; |
my ($PerformanceData,$ORdata,$Foils,$interval) = @_; |
my $analysis_html; |
my $analysis_html; |
my $foilkey = &build_option_index($ORdata); |
my $foilkey = &build_option_index($ORdata); |
Line 792 sub Foil_Time_Analysis {
|
Line 786 sub Foil_Time_Analysis {
|
return $analysis_html; |
return $analysis_html; |
} |
} |
|
|
sub Concept_Time_Analysis { |
sub OR_Concept_Time_Analysis { |
my ($PerformanceData,$ORdata,$Concepts,$interval) = @_; |
my ($PerformanceData,$ORdata,$Concepts,$interval) = @_; |
my $analysis_html; |
my $analysis_html; |
## |
## |
Line 860 sub Concept_Time_Analysis {
|
Line 854 sub Concept_Time_Analysis {
|
## |
## |
######################################################### |
######################################################### |
######################################################### |
######################################################### |
sub prepare_optionresponse_excel_sheet { |
sub OR_excel_sheet { |
my ($r,$resource,$PerformanceData,$ORdata) = @_; |
my ($r,$resource,$PerformanceData,$ORdata) = @_; |
my $response = ''; |
my $response = ''; |
my (undef,$Foils,$Concepts) = &build_foil_index($ORdata); |
my (undef,$Foils,$Concepts) = &build_foil_index($ORdata); |
Line 932 sub prepare_optionresponse_excel_sheet {
|
Line 926 sub prepare_optionresponse_excel_sheet {
|
return $result; |
return $result; |
} |
} |
|
|
sub build_problem_data_worksheet { |
sub OR_build_problem_data_worksheet { |
my ($worksheet,$format,$Concepts,$ORdata) = @_; |
my ($worksheet,$format,$Concepts,$ORdata) = @_; |
my $rows_output = 3; |
my $rows_output = 3; |
my $cols_output = 0; |
my $cols_output = 0; |
Line 1001 sub build_problem_data_worksheet {
|
Line 995 sub build_problem_data_worksheet {
|
return 'okay'; |
return 'okay'; |
} |
} |
|
|
sub build_student_data_worksheet { |
sub OR_build_student_data_worksheet { |
my ($worksheet,$format) = @_; |
my ($worksheet,$format) = @_; |
my $rows_output = 3; |
my $rows_output = 3; |
my $cols_output = 0; |
my $cols_output = 0; |
Line 1027 sub build_student_data_worksheet {
|
Line 1021 sub build_student_data_worksheet {
|
return; |
return; |
} |
} |
|
|
sub build_response_data_worksheet { |
sub OR_build_response_data_worksheet { |
my ($worksheet,$format,$PerformanceData,$Foils,$ORdata)=@_; |
my ($worksheet,$format,$PerformanceData,$Foils,$ORdata)=@_; |
my $rows_output = 3; |
my $rows_output = 3; |
my $cols_output = 0; |
my $cols_output = 0; |
Line 1277 sub build_foil_index {
|
Line 1271 sub build_foil_index {
|
ten => 10,); |
ten => 10,); |
my $a1 = lc($a); |
my $a1 = lc($a); |
my $b1 = lc($b); |
my $b1 = lc($b); |
if (exists($Numbers{$a})) { |
if (exists($Numbers{$a1})) { |
$a1 = $Numbers{$a}; |
$a = $Numbers{$a1}; |
} |
} |
if (exists($Numbers{$b})) { |
if (exists($Numbers{$b1})) { |
$b1 = $Numbers{$b}; |
$b = $Numbers{$b1}; |
|
} |
|
if (($a =~/^\d+$/) && ($b =~/^\d+$/)) { |
|
return $a <=> $b; |
|
} else { |
|
return $a cmp $b; |
} |
} |
$a1 cmp $b1; |
|
}; |
}; |
my @Concepts; |
my @Concepts; |
foreach my $concept (sort $sortfunction (keys(%Concepts))) { |
foreach my $concept (sort $sortfunction (keys(%Concepts))) { |
|
if (! defined($Concepts{$concept})) { |
|
$Concepts{$concept}=[]; |
|
# next; |
|
} |
push(@Concepts,{ name => $concept, |
push(@Concepts,{ name => $concept, |
foils => [@{$Concepts{$concept}}]}); |
foils => [@{$Concepts{$concept}}]}); |
push(@Foils,(@{$Concepts{$concept}})); |
push(@Foils,(@{$Concepts{$concept}})); |
Line 1517 sub ProblemSelector {
|
Line 1519 sub ProblemSelector {
|
for (my $i=0;$i<scalar(@{$partdata->{'ResponseTypes'}});$i++){ |
for (my $i=0;$i<scalar(@{$partdata->{'ResponseTypes'}});$i++){ |
my $respid = $partdata->{'ResponseIds'}->[$i]; |
my $respid = $partdata->{'ResponseIds'}->[$i]; |
my $resptype = $partdata->{'ResponseTypes'}->[$i]; |
my $resptype = $partdata->{'ResponseTypes'}->[$i]; |
if ($resptype eq 'option' ){ |
# if ($resptype eq 'option' ){ |
# if ($resptype eq 'option' || $resptype eq 'radiobutton') { |
if ($resptype eq 'option' || $resptype eq 'radiobutton') { |
my $value = &make_target_id({symb=>$res->{'symb'}, |
my $value = &make_target_id({symb=>$res->{'symb'}, |
part=>$part, |
part=>$part, |
respid=>$respid, |
respid=>$respid, |
Line 1533 sub ProblemSelector {
|
Line 1535 sub ProblemSelector {
|
} |
} |
$seq_str .= '<tr><td>'. |
$seq_str .= '<tr><td>'. |
'<input type="radio" name="problemchoice" value="'.$value.'" '.$checked.'/>'. |
'<input type="radio" name="problemchoice" value="'.$value.'" '.$checked.'/>'. |
'</td><td>'. |
'</td><td>'. |
|
$resptype.'</td><td>'. |
'<a href="'.$res->{'src'}.'">'.$title.'</a> '; |
'<a href="'.$res->{'src'}.'">'.$title.'</a> '; |
# '<a href="'.$res->{'src'}.'">'.$resptype.' '.$res->{'title'}.'</a> '; |
# '<a href="'.$res->{'src'}.'">'.$resptype.' '.$res->{'title'}.'</a> '; |
if ($partdata->{'option'} > 1) { |
if ($partdata->{'option'} > 1) { |
Line 1545 sub ProblemSelector {
|
Line 1548 sub ProblemSelector {
|
} |
} |
} |
} |
if ($seq_str ne '') { |
if ($seq_str ne '') { |
$Str .= '<tr><td> </td><td><b>'.$seq->{'title'}.'</b></td>'. |
$Str .= '<tr><td> </td><td colspan="2"><b>'.$seq->{'title'}.'</b></td>'. |
"</tr>\n".$seq_str; |
"</tr>\n".$seq_str; |
} |
} |
} |
} |
Line 1562 sub ProblemSelector {
|
Line 1565 sub ProblemSelector {
|
######################################################### |
######################################################### |
sub get_problem_symb { |
sub get_problem_symb { |
my $problemstring = shift(); |
my $problemstring = shift(); |
&Apache::lonnet::logthis('problemstring = '.$problemstring); |
|
my ($symb,$partid,$respid,$resptype) = split(':',$problemstring); |
my ($symb,$partid,$respid,$resptype) = split(':',$problemstring); |
&Apache::lonnet::logthis("\n". |
|
join(" --- \n",split(':',$problemstring))); |
|
return ({ symb => $symb, |
return ({ symb => $symb, |
part => $partid, |
part => $partid, |
respid => $respid, |
respid => $respid, |
Line 1586 sub get_resource_from_symb {
|
Line 1586 sub get_resource_from_symb {
|
|
|
sub get_prev_curr_next { |
sub get_prev_curr_next { |
my ($target) = @_; |
my ($target) = @_; |
while(my($k,$v) = each(%$target)) { |
|
&Apache::lonnet::logthis($k.' = '.$v); |
|
} |
|
# |
# |
# Build an array with the data we need to search through |
# Build an array with the data we need to search through |
my @Resource; |
my @Resource; |
Line 1600 sub get_prev_curr_next {
|
Line 1597 sub get_prev_curr_next {
|
for (my $i=0;$i<scalar(@{$partdata->{'ResponseTypes'}});$i++){ |
for (my $i=0;$i<scalar(@{$partdata->{'ResponseTypes'}});$i++){ |
my $respid = $partdata->{'ResponseIds'}->[$i]; |
my $respid = $partdata->{'ResponseIds'}->[$i]; |
my $resptype = $partdata->{'ResponseTypes'}->[$i]; |
my $resptype = $partdata->{'ResponseTypes'}->[$i]; |
next if ($resptype ne 'option'); |
next if ($resptype ne 'option' && |
|
$resptype ne 'radiobutton'); |
push (@Resource, |
push (@Resource, |
{ symb => $res->{symb}, |
{ symb => $res->{symb}, |
part => $part, |
part => $part, |
Line 1613 sub get_prev_curr_next {
|
Line 1611 sub get_prev_curr_next {
|
} |
} |
} |
} |
# |
# |
&Apache::lonnet::logthis('size of @Resource = '.scalar(@Resource)); |
|
# |
# |
# Get the index of the current situation |
# Get the index of the current situation |
my $curr_idx; |
my $curr_idx; |
for ($curr_idx=0;$curr_idx<$#Resource;$curr_idx++) { |
for ($curr_idx=0;$curr_idx<$#Resource;$curr_idx++) { |
my $curr_item = $Resource[$curr_idx]; |
my $curr_item = $Resource[$curr_idx]; |
&Apache::lonnet::logthis('-----------------------------------'); |
|
while(my($k,$v) = each(%$curr_item)) { |
|
&Apache::lonnet::logthis($k.' = '.$v); |
|
} |
|
last if ($curr_item->{'symb'} eq $target->{'symb'} && |
last if ($curr_item->{'symb'} eq $target->{'symb'} && |
$curr_item->{'part'} eq $target->{'part'} && |
$curr_item->{'part'} eq $target->{'part'} && |
$curr_item->{'respid'} eq $target->{'respid'} && |
$curr_item->{'respid'} eq $target->{'respid'} && |
Line 1634 sub get_prev_curr_next {
|
Line 1627 sub get_prev_curr_next {
|
$curr_item->{'respid'} ne $target->{'respid'} || |
$curr_item->{'respid'} ne $target->{'respid'} || |
$curr_item->{'resptype'} ne $target->{'resptype'}){ |
$curr_item->{'resptype'} ne $target->{'resptype'}){ |
# bogus symb - return nothing |
# bogus symb - return nothing |
&Apache::lonnet::logthis('bailing out'); |
|
return (undef,undef,undef); |
return (undef,undef,undef); |
} |
} |
# |
# |
Line 1667 sub make_target_id {
|
Line 1659 sub make_target_id {
|
|
|
sub get_target_from_id { |
sub get_target_from_id { |
my ($id) = @_; |
my ($id) = @_; |
&Apache::lonnet::logthis('id = '.$id); |
|
my ($symb,$part,$respid,$resptype) = split(':',$id); |
my ($symb,$part,$respid,$resptype) = split(':',$id); |
&Apache::lonnet::logthis('get_target_from_id:symb='.$symb); |
|
&Apache::lonnet::logthis('get_target_from_id:symb='.$part); |
|
&Apache::lonnet::logthis('get_target_from_id:symb='.$respid); |
|
&Apache::lonnet::logthis('get_target_from_id:symb='.$resptype); |
|
return ({ symb =>&Apache::lonnet::unescape($symb), |
return ({ symb =>&Apache::lonnet::unescape($symb), |
part =>&Apache::lonnet::unescape($part), |
part =>&Apache::lonnet::unescape($part), |
respid =>&Apache::lonnet::unescape($respid), |
respid =>&Apache::lonnet::unescape($respid), |
Line 1730 sub Process_OR_Row {
|
Line 1717 sub Process_OR_Row {
|
my @Foilsubs = split('&',$submission); |
my @Foilsubs = split('&',$submission); |
for (my $j=0;$j<=$#Foilgrades;$j++) { |
for (my $j=0;$j<=$#Foilgrades;$j++) { |
my ($foilid,$correct) = split('=',$Foilgrades[$j]); |
my ($foilid,$correct) = split('=',$Foilgrades[$j]); |
|
$foilid = &Apache::lonnet::unescape($foilid); |
my (undef,$submission) = split('=',$Foilsubs[$j]); |
my (undef,$submission) = split('=',$Foilsubs[$j]); |
if ($correct) { |
if ($correct) { |
$RowData{$foilid}->{'_correct'}++; |
$RowData{$foilid}->{'_correct'}++; |