[LON-CAPA-cvs] cvs: loncom /homework functionplotresponse.pm

www www@source.lon-capa.org
Sat, 30 Oct 2010 02:31:27 -0000


www		Sat Oct 30 02:31:27 2010 EDT

  Modified files:              
    /loncom/homework	functionplotresponse.pm 
  Log:
  Server-side calculation of the splines, based on parameters
  
  
Index: loncom/homework/functionplotresponse.pm
diff -u loncom/homework/functionplotresponse.pm:1.17 loncom/homework/functionplotresponse.pm:1.18
--- loncom/homework/functionplotresponse.pm:1.17	Fri Oct 29 19:18:48 2010
+++ loncom/homework/functionplotresponse.pm	Sat Oct 30 02:31:27 2010
@@ -1,7 +1,7 @@
 # LearningOnline Network with CAPA
 # option list style responses
 #
-# $Id: functionplotresponse.pm,v 1.17 2010/10/29 19:18:48 www Exp $
+# $Id: functionplotresponse.pm,v 1.18 2010/10/30 02:31:27 www Exp $
 #
 # Copyright Michigan State University Board of Trustees
 #
@@ -499,6 +499,55 @@
 }
 
 #
+# Array index calculation
+#
+sub array_index {
+   my ($xmin,$xmax,$x)=@_;
+   my $index=int(($x-$xmin)/($xmax-$xmin)*200.+0.5);
+   return $index;
+}
+
+#
+# Populate the arrays
+#
+
+sub populate_arrays {
+    my ($id,$xmin,$xmax)=@_;
+    for (my $i=0; $i<=200; $i++) {
+       undef $Apache::functionplotresponse::func[$i];
+       undef $Apache::functionplotresponse::dfunddx[$i];
+       undef $Apache::functionplotresponse::d2funcd2x[$i];
+    }
+    unless ($xmax>$xmin) { return; }
+# Run over all splines in response
+    foreach my $label (split(/\,/,$env{"form.HWVAL_AllSplines_$id"})) {
+# Run over all points in spline
+        for (my $i=0; $i<$env{"form.HWVAL_SplineOrder_".$id."_".$label}; $i++) {
+            my $xiold=-1;
+            my $ni=$i+1;
+            my @xparms=($env{'form.HWVAL_'.$id.'_'.$label.'P'.$i.'_x'},
+                        $env{'form.HWVAL_'.$id.'_'.$label.'S'.$i.'_x'},
+                        $env{'form.HWVAL_'.$id.'_'.$label.'P'.$ni.'_x'},
+                        $env{'form.HWVAL_'.$id.'_'.$label.'S'.$ni.'_x'});
+            my @yparms=($env{'form.HWVAL_'.$id.'_'.$label.'P'.$i.'_y'},
+                        $env{'form.HWVAL_'.$id.'_'.$label.'S'.$i.'_y'},
+                        $env{'form.HWVAL_'.$id.'_'.$label.'P'.$ni.'_y'},
+                        $env{'form.HWVAL_'.$id.'_'.$label.'S'.$ni.'_y'});
+
+# Run in small steps over spline parameter
+            for (my $t=0; $t<=1; $t+=0.00025) {
+                my $xi=&array_index($xmin,$xmax,&cubic_hermite($t,@xparms));
+                if ($xi<$xiold-5) { return 'no_func'; }
+                if ($xi>$xiold) {
+                   $xiold=$xi;
+                   $Apache::functionplotresponse::func[$xi]=&cubic_hermite($t,@yparms);
+                }
+            }
+        }
+    }
+}
+
+#
 # Implentation of <functionplotresponse>
 #
 
@@ -525,13 +574,13 @@
 
 # Parameters of <functionplotresponse>
   my $xmin=&Apache::lonxml::get_param('xmin',$parstack,$safeeval);
-  $xmin=($xmin?$xmin:-10);
+  $xmin=(defined($xmin)?$xmin:-10);
   my $xmax=&Apache::lonxml::get_param('xmax',$parstack,$safeeval);
-  $xmax=($xmax?$xmax:10);
+  $xmax=(defined($xmax)?$xmax:10);
   my $ymin=&Apache::lonxml::get_param('ymin',$parstack,$safeeval);
-  $ymin=($ymin?$ymin:-10);
+  $ymin=(defined($ymin)?$ymin:-10);
   my $ymax=&Apache::lonxml::get_param('ymax',$parstack,$safeeval);
-  $ymax=($ymax?$ymax:10);
+  $ymax=(defined($ymax)?$ymax:10);
   my $xaxisvisible=(&Apache::lonxml::get_param('xaxisvisible',$parstack,$safeeval)=~/on|true|yes|1/i?'true':'false');
   my $yaxisvisible=(&Apache::lonxml::get_param('yaxisvisible',$parstack,$safeeval)=~/on|true|yes|1/i?'true':'false');
   my $gridvisible=(&Apache::lonxml::get_param('gridvisible',$parstack,$safeeval)=~/on|true|yes|1/i?'true':'false');
@@ -612,7 +661,16 @@
 #
 # Actually grade
 #
-        my $ad='INCORRECT';
+        my $xmin=&Apache::lonxml::get_param('xmin',$parstack,$safeeval);
+        $xmin=(defined($xmin)?$xmin:-10);
+        my $xmax=&Apache::lonxml::get_param('xmax',$parstack,$safeeval);
+        $xmax=(defined($xmax)?$xmax:10);
+        my $ad;
+        if (&populate_arrays($internalid,$xmin,$xmax) eq 'no_func') {
+           $ad='BAD_FORMULA';
+        } else {
+           $ad='INCORRECT';
+        }
 #
 # Store grading info
 #