version 1.61, 2002/09/30 18:32:45
|
version 1.65, 2002/10/14 20:37:27
|
Line 168 sub end_numericalresponse {
|
Line 168 sub end_numericalresponse {
|
my $unit=&Apache::lonxml::get_param_var('unit',$parstack,$safeeval); |
my $unit=&Apache::lonxml::get_param_var('unit',$parstack,$safeeval); |
|
|
if ($target eq 'web') { |
if ($target eq 'web') { |
$result="<br />The computer got "; |
$result="<br />The correct answer is "; |
} elsif ($target eq 'tex') { |
} elsif ($target eq 'tex') { |
$result='\vskip 0 mm The computer got \\texttt{'; |
$result='\vskip 0 mm The correct answer is \\texttt{'; |
} |
} |
for (my $i=0; $i <= $#answers; $i++) { |
for (my $i=0; $i <= $#answers; $i++) { |
my $answer=$answers[$i]; |
my $answer=$answers[$i]; |
Line 225 sub end_numericalresponse {
|
Line 225 sub end_numericalresponse {
|
if ($target eq 'web') { |
if ($target eq 'web') { |
$result.= '<table border="1"><tr>'; |
$result.= '<table border="1"><tr>'; |
for ($ind=0;$ind<$number_of_bubbles;$ind++) { |
for ($ind=0;$ind<$number_of_bubbles;$ind++) { |
|
my $ans; |
if ($formats[0] ne '') { |
if ($formats[0] ne '') { |
my $ans = sprintf('%.'.$formats[0],$bubbles_values[$ind]); |
$ans = sprintf('%.'.$formats[0],$bubbles_values[$ind]); |
$result.='<td>'.$alphabet[$ind].': '.$ans.'</td>'; |
|
} else { |
} else { |
my $ans = sprintf('%.'.'d',$bubbles_values[$ind]); |
my $badans = $bubbles_values[$ind]; |
$result.='<td>'.$alphabet[$ind].': '.$ans.'</td>'; |
my $format = ''; |
|
#What is the number? (integer,decimal,floating point) |
|
if ($badans=~/^(\d*\.?\d*)(E|e)(\d*)$/) { |
|
$format = 'e'.$2; |
|
} elsif ($badans=~/^(\d*)\.(\d*)$/) { |
|
$format = '4f'; |
|
} elsif ($badans=~/^(\d*)$/) { |
|
$format = 'd'; |
|
} |
|
$ans = sprintf('%.'.$format,$bubbles_values[$ind]); |
} |
} |
|
$result.='<td>'.$alphabet[$ind].': '.$ans.'</td>'; |
} |
} |
$result.='</tr></table>'; |
$result.='</tr></table>'; |
} elsif ($target eq 'tex') { |
} elsif ($target eq 'tex') { |
Line 260 sub end_numericalresponse {
|
Line 270 sub end_numericalresponse {
|
} |
} |
$result.='}\hline'; |
$result.='}\hline'; |
for ($ind=$cou;$ind<$cou+$table_range[$j];$ind++) { |
for ($ind=$cou;$ind<$cou+$table_range[$j];$ind++) { |
|
my $ans; |
if ($formats[0] ne '') { |
if ($formats[0] ne '') { |
my $ans = sprintf('%.'.$formats[0],$bubbles_values[$ind]); |
$ans = sprintf('%.'.$formats[0],$bubbles_values[$ind]); |
$result.=' '.$alphabet[$ind].': & '.$ans.' '; |
|
} else { |
} else { |
my $ans = sprintf('%.'.'d',$bubbles_values[$ind]); |
my $badans = $bubbles_values[$ind]; |
$result.=' '.$alphabet[$ind].': & '.$ans.' '; |
my $format = ''; |
|
#What is the number? (integer,decimal,floating point) |
|
if ($badans=~/^(\d*\.?\d*)(E|e)(\d*)$/) { |
|
$format = 'e'.$2; |
|
} elsif ($badans=~/^(\d*)\.(\d*)$/) { |
|
$format = '4f'; |
|
} elsif ($badans=~/^(\d*)$/) { |
|
$format = 'd'; |
|
} |
|
$ans = sprintf('%.'.$format,$bubbles_values[$ind]); |
} |
} |
|
$result.=' '.$alphabet[$ind].': & '.$ans.' '; |
if ($ind != $cou+$table_range[$j]-1) {$result.=' & ';} |
if ($ind != $cou+$table_range[$j]-1) {$result.=' & ';} |
} |
} |
$j++; |
|
$cou += $table_range[$j]; |
$cou += $table_range[$j]; |
|
$j++; |
$result.='\\\\\hline\end{tabular}\vskip 0 mm '; |
$result.='\\\\\hline\end{tabular}\vskip 0 mm '; |
} |
} |
} |
} |
} |
} |
} elsif ($target eq 'edit') { |
} elsif ($target eq 'edit') { |
$result.='</td></tr>'.&Apache::edit::end_table; |
$result.='</td></tr>'.&Apache::edit::end_table; |
} elsif ($target eq 'answer') { |
} elsif ($target eq 'answer' || $target eq 'analyze') { |
|
|
&Apache::response::setup_params($$tagstack[-1]); |
my $part_id="$Apache::inputtags::part.$Apache::inputtags::response[-1]"; |
my (@answers)=&Apache::lonxml::get_param_var('answer',$parstack,$safeeval); |
if ($target eq 'analyze') { |
my (@formats)=&Apache::lonxml::get_param_var('format',$parstack,$safeeval); |
push (@{ $Apache::lonhomework::analyze{"parts"} },$part_id); |
my $unit=&Apache::lonxml::get_param_var('unit',$parstack,$safeeval); |
$Apache::lonhomework::analyze{"$part_id.type"} = $$tagstack[-1]; |
my $type=&Apache::lonxml::get_param('type',$parstack,$safeeval); |
} |
|
&Apache::response::setup_params($$tagstack[-1]); |
|
my (@answers)=&Apache::lonxml::get_param_var('answer',$parstack,$safeeval); |
|
my (@formats)=&Apache::lonxml::get_param_var('format',$parstack,$safeeval); |
|
my $unit=&Apache::lonxml::get_param_var('unit',$parstack,$safeeval); |
|
my $type=&Apache::lonxml::get_param('type',$parstack,$safeeval); |
|
|
$result.=&Apache::response::answer_header($$tagstack[-1]); |
if ($target eq 'answer') { |
for(my $i=0;$i<=$#answers;$i++) { |
$result.=&Apache::response::answer_header($$tagstack[-1]); |
my $ans=$answers[$i]; |
|
my $fmt; |
|
if (@formats) { |
|
if ($#formats) { |
|
$fmt=$formats[$i]; |
|
} else { |
|
$fmt=$formats[0]; |
|
} |
|
} |
} |
my ($high,$low); |
for(my $i=0;$i<=$#answers;$i++) { |
if ($Apache::inputtags::params{'tol'}) { |
my $ans=$answers[$i]; |
($high,$low)=&get_tolrange($ans,$Apache::inputtags::params{'tol'}); |
my $fmt; |
} |
if (@formats) { |
my ($sighigh,$siglow); |
if ($#formats) { |
if ($Apache::inputtags::params{'sig'}) { |
$fmt=$formats[$i]; |
($sighigh,$siglow)=&get_sigrange($Apache::inputtags::params{'sig'}); |
} else { |
} |
$fmt=$formats[0]; |
if ($fmt) { |
} |
$ans = sprintf('%.'.$fmt,$ans); |
} |
if ($high) { |
my ($high,$low); |
$high = sprintf('%.'.$fmt,$high); $low = sprintf('%.'.$fmt,$low); |
if ($Apache::inputtags::params{'tol'}) { |
} |
($high,$low)=&get_tolrange($ans,$Apache::inputtags::params{'tol'}); |
|
} |
|
my ($sighigh,$siglow); |
|
if ($Apache::inputtags::params{'sig'}) { |
|
($sighigh,$siglow)=&get_sigrange($Apache::inputtags::params{'sig'}); |
|
} |
|
if ($fmt) { |
|
$ans = sprintf('%.'.$fmt,$ans); |
|
if ($high) { |
|
$high = sprintf('%.'.$fmt,$high); $low = sprintf('%.'.$fmt,$low); |
|
} |
|
} |
|
if ($target eq 'answer') { |
|
if ($high) { $ans.=' ['.$low.','.$high.'] '; } |
|
if ($sighigh) { $ans.= "Sig <i>$siglow - $sighigh</i>"; } |
|
$result.=&Apache::response::answer_part($$tagstack[-1],$ans); |
|
} elsif ($target eq 'analyze') { |
|
push (@{ $Apache::lonhomework::analyze{"$part_id.answer"} }, |
|
$ans); |
|
if ($high) { |
|
push (@{ $Apache::lonhomework::analyze{"$part_id.ans_high"} }, $high); |
|
push (@{ $Apache::lonhomework::analyze{"$part_id.ans_low"} }, $low); |
|
} |
|
} |
} |
} |
if ($high) { $ans.=' ['.$low.','.$high.'] '; } |
if ($unit) { |
if ($sighigh) { $ans.= "Sig <i>$siglow - $sighigh</i>"; } |
if ($target eq 'answer') { |
$result.=&Apache::response::answer_part($$tagstack[-1],$ans); |
$result.=&Apache::response::answer_part($$tagstack[-1], |
} |
"Unit: <b>$unit</b>"); |
if ($unit) { |
} elsif ($target eq 'analyze') { |
$result.=&Apache::response::answer_part($$tagstack[-1],"Unit: <b>$unit</b>"); |
push (@{ $Apache::lonhomework::analyze{"$part_id.unit"} }, |
} |
$unit); |
if ($type || $token->[1] eq 'stringresponse') { |
} |
my $string='Case Insensitive'; |
} |
if ($type eq 'mc') { |
if ($type || $token->[1] eq 'stringresponse') { |
$string='Multiple Choice'; |
my $string='Case Insensitive'; |
} elsif ($type eq 'cs') { |
if ($type eq 'mc') { |
$string='Case Sensitive'; |
$string='Multiple Choice'; |
} elsif ($type eq 'ci') { |
} elsif ($type eq 'cs') { |
$string='Case Insensitive'; |
$string='Case Sensitive'; |
} elsif ($type eq 'fml') { |
} elsif ($type eq 'ci') { |
$string='Formula'; |
$string='Case Insensitive'; |
|
} elsif ($type eq 'fml') { |
|
$string='Formula'; |
|
} |
|
if ($target eq 'answer') { |
|
$result.=&Apache::response::answer_part($$tagstack[-1], |
|
'<b>'.$string.'</b>'); |
|
} elsif ($target eq 'analyze') { |
|
push (@{ $Apache::lonhomework::analyze{"$part_id.type"} }, |
|
$type); |
|
} |
|
} |
|
if ($$tagstack[-1] eq 'formularesponse' && $target eq 'answer') { |
|
my $samples=&Apache::lonxml::get_param('samples',$parstack,$safeeval); |
|
$result.=&Apache::response::answer_part($$tagstack[-1],$samples); |
|
} |
|
if ($target eq 'answer') { |
|
$result.=&Apache::response::answer_footer($$tagstack[-1]); |
} |
} |
$result.=&Apache::response::answer_part($$tagstack[-1], |
|
'<b>'.$string.'</b>'); |
|
} |
|
if ($$tagstack[-1] eq 'formularesponse') { |
|
my $samples=&Apache::lonxml::get_param('samples',$parstack,$safeeval); |
|
$result.=&Apache::response::answer_part($$tagstack[-1],$samples); |
|
} |
|
$result.=&Apache::response::answer_footer($$tagstack[-1]); |
|
} |
} |
&Apache::response::end_response; |
&Apache::response::end_response; |
return $result; |
return $result; |