version 1.28, 2010/11/07 13:15:28
|
version 1.30, 2010/11/09 02:29:52
|
Line 392 sub start_functionplotrule {
|
Line 392 sub start_functionplotrule {
|
&Apache::lonxml::get_param('value',$parstack,$safeeval) |
&Apache::lonxml::get_param('value',$parstack,$safeeval) |
))); |
))); |
} elsif ($target eq 'edit') { |
} elsif ($target eq 'edit') { |
$result=&Apache::edit::tag_start($target,$token,'Function Plot Evaluation Rule'). |
$result=&Apache::edit::tag_start($target,$token,'Function Plot Evaluation Rule'). |
&Apache::edit::end_row(); |
&Apache::edit::text_arg('Index:','index', |
|
$token,'4').' '. |
|
&Apache::edit::select_arg(&mt('Function:'),'derivative', |
|
[['0','Function itself'], |
|
['1','First derivative'], |
|
['2','Second derivative']],$token).' '. |
|
|
|
&Apache::edit::text_arg('(Initial) x-value:','xinitial', |
|
$token,'4'). |
|
&Apache::edit::select_or_text_arg('(Initial) x-value label:','xinitiallabel', |
|
[['start','Start of Plot']],$token,'8').' '. |
|
|
|
&Apache::edit::text_arg('Optional final x-value for ranges:','xfinal', |
|
$token,'4'). |
|
&Apache::edit::select_or_text_arg('Optional final x-value label:','xfinallabel', |
|
[['end','End of Plot']],$token,'8').' '. |
|
|
|
&Apache::edit::select_arg(&mt('Relationship:'),'relationship', |
|
[['eq','equal'], |
|
['ne','not equal'], |
|
['ge','greater than or equal'], |
|
['gt','greater than'], |
|
['lt','less than'], |
|
['le','less than or equal']],$token). |
|
$result.= &Apache::edit::select_or_text_arg('Value:','value', |
|
[['undef','not defined']],$token,'4'). |
|
&Apache::edit::text_arg('Percent error:','percenterror', |
|
$token,'4'). |
|
&Apache::edit::end_row(); |
|
} elsif ($target eq 'modified') { |
|
my $constructtag=&Apache::edit::get_new_args($token,$parstack, |
|
$safeeval,'index','derivative','xinitial','xinitiallabel','xfinal','xfinallabel','relationship', |
|
'value','percenterror'); |
|
if ($constructtag) { $result=&Apache::edit::rebuild_tag($token); } |
} |
} |
return $result; |
return $result; |
} |
} |
Line 590 sub populate_arrays {
|
Line 623 sub populate_arrays {
|
if (defined($Apache::functionplotresponse::func[$xi])) { return 'no_func'; } |
if (defined($Apache::functionplotresponse::func[$xi])) { return 'no_func'; } |
$xiold=$xi; |
$xiold=$xi; |
# Function value |
# Function value |
$Apache::functionplotresponse::func[$xi]=&cubic_hermite($t,@yparms); |
my $funcval=&cubic_hermite($t,@yparms); |
|
$Apache::functionplotresponse::func[$xi]=$funcval; |
|
if (defined($funcval)) { |
|
if ($xi<$Apache::functionplotresponse::functionplotrulelabels{'start'}) { |
|
$Apache::functionplotresponse::functionplotrulelabels{'start'}=$xi; |
|
} |
|
if ($xi>$Apache::functionplotresponse::functionplotrulelabels{'end'}) { |
|
$Apache::functionplotresponse::functionplotrulelabels{'end'}=$xi; |
|
} |
|
} |
# Chain rule |
# Chain rule |
# dy/dx=dy/dt/(dx/dt) |
# dy/dx=dy/dt/(dx/dt) |
my $dxdt=&ddt_cubic_hermite($t,@xparms); |
my $dxdt=&ddt_cubic_hermite($t,@xparms); |
Line 712 sub start_functionplotresponse {
|
Line 754 sub start_functionplotresponse {
|
|
|
sub compare_rel { |
sub compare_rel { |
my ($relationship,$value,$realval,$tol)=@_; |
my ($relationship,$value,$realval,$tol)=@_; |
|
|
|
|
&Apache::lonnet::logthis("Rel $relationship Val $value RV $realval T $tol"); |
|
# is the real value defined? |
# is the real value defined? |
unless (defined($realval)) { |
unless (defined($realval)) { |
if ($relationship eq 'eq') { |
if ($relationship eq 'eq') { |
Line 756 sub functionplotrulecheck {
|
Line 795 sub functionplotrulecheck {
|
&Apache::lonnet::logthis("Rule $rule TolFunc $tolfunc TolDfDx $toldfdx TolD2fDx2 $told2fdx2"); |
&Apache::lonnet::logthis("Rule $rule TolFunc $tolfunc TolDfDx $toldfdx TolD2fDx2 $told2fdx2"); |
my ($label,$derivative,$xinitial,$xinitiallabel,$xfinal,$xfinallabel,$relationship,$value) |
my ($label,$derivative,$xinitial,$xinitiallabel,$xfinal,$xfinallabel,$relationship,$value) |
=split(/\:/,$rule); |
=split(/\:/,$rule); |
|
|
|
my $li=0; |
|
my $lh=400; |
|
|
# if a hard value is set for the boundaries, it overrides the label |
# if a hard value is set for the boundaries, it overrides the label |
if (($xinitial ne '') && ($xinitiallabel ne '')) { |
if (($xinitial ne '') && ($xinitiallabel ne '') && ($xinitiallabel ne 'start')) { |
$Apache::functionplotresponse::functionplotrulelabels{$xinitiallabel}=$xinitial; |
$li=&array_index($xmin,$xmax,$xinitial); |
} |
$Apache::functionplotresponse::functionplotrulelabels{$xinitiallabel}=$li; |
if (($xfinal ne '') && ($xfinallabel ne '')) { |
} |
$Apache::functionplotresponse::functionplotrulelabels{$xfinallabel}=$xfinal; |
if (($xfinal ne '') && ($xfinallabel ne '') && ($xfinallabel ne 'end')) { |
|
$lh=&array_index($xmin,$xmax,$xfinal); |
|
$Apache::functionplotresponse::functionplotrulelabels{$xfinallabel}=$lh; |
} |
} |
if (defined($Apache::functionplotresponse::functionplotrulelabels{$xinitiallabel})) { |
if (defined($Apache::functionplotresponse::functionplotrulelabels{$xinitiallabel})) { |
$xinitial=$Apache::functionplotresponse::functionplotrulelabels{$xinitiallabel}; |
$li=$Apache::functionplotresponse::functionplotrulelabels{$xinitiallabel}; |
|
} else { |
|
$li=&array_index($xmin,$xmax,$xinitial); |
} |
} |
if (defined($Apache::functionplotresponse::functionplotrulelabels{$xfinallabel})) { |
if (defined($Apache::functionplotresponse::functionplotrulelabels{$xfinallabel})) { |
$xfinal=$Apache::functionplotresponse::functionplotrulelabels{$xfinallabel}; |
$lh=$Apache::functionplotresponse::functionplotrulelabels{$xfinallabel}; |
|
} else { |
|
$lh=&array_index($xmin,$xmax,$xfinal); |
} |
} |
# Basic sanity checks |
# Basic sanity checks |
if ($xinitial eq '') { |
if ($li<0) { $li=0; } |
$xinitial=0; |
if ($lh>400) { $lh=400; } |
|
if ($li>$lh) { |
|
$lh=$li; |
} |
} |
if ($xfinal eq '') { |
&Apache::lonnet::logthis("Init $xinitial=$li Final $xfinal=$lh"); |
$xfinal=$xinitial; |
|
} |
|
if ($xinitial>$xfinal) { |
|
$xfinal=$xinitial; |
|
} |
|
&Apache::lonnet::logthis("Init $xinitial Final $xfinal"); |
|
my $tol=$tolfunc; |
my $tol=$tolfunc; |
if ($derivative==2) { |
if ($derivative==2) { |
$tol=$told2fdx2; |
$tol=$told2fdx2; |
} elsif ($derivative==1) { |
} elsif ($derivative==1) { |
$tol=$toldfdx; |
$tol=$toldfdx; |
} |
} |
|
|
my $li=&array_index($xmin,$xmax,$xinitial); |
|
my $lh=&array_index($xmin,$xmax,$xfinal); |
|
for (my $i=$li; $i<=$lh; $i++) { |
for (my $i=$li; $i<=$lh; $i++) { |
my $val; |
my $val; |
if ($derivative==2) { |
if ($derivative==2) { |
&Apache::lonnet::logthis("Second ". |
|
|
|
$Apache::functionplotresponse::d2funcdx2[$i-1].'__'.$Apache::functionplotresponse::d2funcdx2[$i].'__'.$Apache::functionplotresponse::d2funcdx2[$i+1]); |
|
$val=$Apache::functionplotresponse::d2funcdx2[$i]; |
$val=$Apache::functionplotresponse::d2funcdx2[$i]; |
} elsif ($derivative==1) { |
} elsif ($derivative==1) { |
$val=$Apache::functionplotresponse::dfuncdx[$i]; |
$val=$Apache::functionplotresponse::dfuncdx[$i]; |
Line 852 sub end_functionplotresponse {
|
Line 891 sub end_functionplotresponse {
|
} |
} |
|
|
my $ad=''; |
my $ad=''; |
|
undef %Apache::functionplotresponse::functionplotrulelabels; |
|
$Apache::functionplotresponse::functionplotrulelabels{'start'}=400; |
|
$Apache::functionplotresponse::functionplotrulelabels{'end'}=0; |
if (&populate_arrays($internalid,$xmin,$xmax) eq 'no_func') { |
if (&populate_arrays($internalid,$xmin,$xmax) eq 'no_func') { |
$ad='NOT_FUNCTION'; |
$ad='NOT_FUNCTION'; |
} else { |
} else { |
# We have a function that we can actually grade, go through the spline rules. |
# We have a function that we can actually grade, go through the spline rules. |
undef %Apache::functionplotresponse::functionplotrulelabels; |
|
foreach my $rule (@Apache::functionplotresponse::functionplotrules) { |
foreach my $rule (@Apache::functionplotresponse::functionplotrules) { |
unless (&functionplotrulecheck($rule,$xmin,$xmax,$tolfunc,$toldfdx,$told2fdx2)) { |
unless (&functionplotrulecheck($rule,$xmin,$xmax,$tolfunc,$toldfdx,$told2fdx2)) { |
$ad='INCORRECT'; |
$ad='INCORRECT'; |