--- loncom/homework/default_homework.lcpm 2001/06/14 21:29:14 1.28
+++ loncom/homework/default_homework.lcpm 2001/10/01 20:15:30 1.37
@@ -13,22 +13,29 @@ $rad2deg=180.0/$pi;
$deg2rad=$pi/180.0;
sub caparesponse_check {
- my $answer=''; #done
- my $type=''; #done
+ #not properly used yet: calc
+ #not to be used: $ans_fmt
+ my ($answer,$type,$tol,$sig,$ans_fmt,$unit,$calc) =
+ eval $_[1].';return ($answer,$type,$tol,$sig,$ans_fmt,$unit,$calc);';
+
my $tol_type=''; # gets it's value from whether tol has a % or not done
- my $tol=''; #done
- my $sig=''; #done lowerbnd,upperbnd
my $sig_lbound=''; #done
my $sig_ubound=''; #done
- my $ans_fmt='';
- my $units=''; #done
- my $calc='';
my ($response,$expr)=@_;
-
- ($answer,$type,$tol,$sig,$ans_fmt,
- $units,$calc) = eval $expr.';return $answer,$type,$tol,$sig,$ans_fmt,$units,$calc';
+
+
#type's definitons come from capaParser.h
+ my $message='';
+ #remove leading and trailing whitespace
+ if ($response=~ /^\s|\s$/) {
+ $response=~ s:^\s+|\s+$::g;
+ $message .="Removed ws now :$response:
";
+ } else {
+ $message .="no ws in :$response:
";
+ }
+
if ($type eq '' ) {
+ $message .= "Didn't find a type :$type:$expr: defaulting
";
if ( $answer eq ($answer *1.0)) { $type = 2;
} else { $type = 3; }
} else {
@@ -61,7 +68,7 @@ sub caparesponse_check {
my $result = &caparesponse_capa_check_answer($response,$answer,$type,
$tol_type,$tol,
$sig_lbound,$sig_ubound,
- $ans_fmt,$units,$calc);
+ $ans_fmt,$unit,$calc);
if ($result == '1') { $result='EXACT_ANS'; }
elsif ($result == '2') { $result='APPROX_ANS'; }
@@ -77,34 +84,60 @@ sub caparesponse_check {
elsif ($result =='12') { $result='WANTED_NUMERIC'; }
else {$result = "ERROR: Unknown Result:$result:$@:";}
- return "$result:
Error $error:
Answer $answer:
Response $response:
$type|$tol|$tol_type|$sig:$sig_lbound:$sig_ubound|$units
";
+ return "$result:
Error $error:
Answer $answer:
Response $response:
type-$type|$tol|$tol_type|$sig:$sig_lbound:$sig_ubound|$unit|
$message$expr";
+}
+
+sub get_array_args {
+ my ($expr,$arg)=@_;
+ # do these first, because who knows what varname the instructor might have used
+ # but it probably isn't $CAPARESPONSE_CHECK_LIST_answer
+ my $CAPARESPONSE_CHECK_LIST_answer = eval $expr.';return $'.$arg; #'
+ my (@list) = eval $CAPARESPONSE_CHECK_LIST_answer;
+ my $result='';
+ $result.="error:$@:
";
+ # if the eval fails just use what is in the answer exactly
+ if (!defined(@list) || !defined($list[0])) {
+ $result.="list zero is undefined
";
+ $list[0]=$CAPARESPONSE_CHECK_LIST_answer;
+ }
+ return @list;
}
sub caparesponse_check_list {
my ($response,$expr)=@_;
- my $result='';
+ my (@list) = &get_array_args($expr,'answer');
my $aresult='';
my $current_answer;
- my $answer = eval $expr.';return $answer';
- my (@list) = eval $answer;
- my (@responselist)=split /,/,$response;
+ $result.="Got response :$CAPARESPONSE_CHECK_LIST_answer:$list[0]:
";
+ my @responselist;
+ my $type =eval $expr.';return $answer;';
+ if ($type ne '' && $#list > 0) {
+ (@responselist)=split /,/,$response;
+ } else {
+ (@responselist)=($response);
+ }
my $unit='';
- $result.="Final response :$responselist['-1']:
";
- if ( $responselist['-1']=~ /(.*[^\s])\s+([^\s]+)/ ) {
- $responselist['-1']=$1;
- $unit=$2;
+ $result.="Initial final response :$responselist['-1']:
";
+ if ($type eq '') {
+ #for numerical problems split off the unit
+ if ( $responselist['-1']=~ /(.*[^\s])\s+([^\s]+)/ ) {
+ $responselist['-1']=$1;
+ $unit=$2;
+ }
}
- $result.="Final response :$responselist['-1']:
";
+ $result.="Final final response :$responselist['-1']:
";
+ $result.=":$#list: answers
";
$unit=~s/\s//;
my $i=0;
my $awards='';
for ($i=0; $i<@list;$i++) {
+ $result.="trying answer :$list[$i]:
";
if ($unit eq '') {
$aresult=&caparesponse_check($responselist[$i],
- $expr.';my $answer='.$list[$i].';');
+ $expr.';my $answer=\''.$list[$i].'\';');
} else {
$aresult=&caparesponse_check($responselist[$i]." $unit",
- $expr.';my $answer='.$list[$i].';');
+ $expr.';my $answer=\''.$list[$i].'\';');
}
my ($temp)=split /:/, $aresult;
$awards.="$temp,";
@@ -237,16 +270,9 @@ sub random_noncentral_f {
}
sub random_multivariate_normal {
- my ($item_cnt,$seed,@mean) = @_;
- return "Number of deviates must be greater than 0" if $item_cnt <= 0;
- my (@covar,@retArray);
- my $ind = 0;
- while ($ind<$item_cnt) {
- push @covar, pop (@mean);
- $ind++;
- }
+ my ($item_cnt,$seed,$mean,$covar) = @_;
&random_set_seed_from_phrase($seed);
- @retArray=&math_random_multivariate_normal($item_cnt,@mean,@covar);
+ @retArray=&math_random_multivariate_normal($item_cnt,@$mean,@$covar);
return @retArray;
}