TrigIdentities1: Difference between revisions
Jump to navigation
Jump to search
(Created page with '<h2>Trig Identities 1: Cleverly Redefining Functions</h2> <p style="background-color:#eeeeee;border:black solid 1px;padding:3px;"> This PG code shows how to redefine a named fu…') |
No edit summary |
||
| Line 1: | Line 1: | ||
<h2>Trig Identities | <h2>Requiring Trig Identities to be Used by Cleverly Redefining Functions</h2> | ||
[[File:TrigIdentities1.png|300px|thumb|right|Click to enlarge]] | |||
<p style="background-color:#eeeeee;border:black solid 1px;padding:3px;"> | <p style="background-color:#eeeeee;border:black solid 1px;padding:3px;"> | ||
This PG code shows how to redefine a named function internally so that students must apply a trig identity and simplify their answer. | This PG code shows how to redefine a named function internally so that students must apply a trig identity and simplify their answer. | ||
</p> | </p> | ||
* Download file: [[File:TrigIdentities1.txt]] (change the file extension from txt to pg when you save it) | |||
* File location in NPL: <code>FortLewis/Authoring/Templates/Trig/TrigIdentities.pg</code> | |||
<br clear="all" /> | |||
<p style="text-align:center;"> | <p style="text-align:center;"> | ||
[[SubjectAreaTemplates|Templates by Subject Area]] | [[SubjectAreaTemplates|Templates by Subject Area]] | ||
Revision as of 20:25, 2 December 2010
Requiring Trig Identities to be Used by Cleverly Redefining Functions

This PG code shows how to redefine a named function internally so that students must apply a trig identity and simplify their answer.
- Download file: File:TrigIdentities1.txt (change the file extension from txt to pg when you save it)
- File location in NPL:
FortLewis/Authoring/Templates/Trig/TrigIdentities.pg
| PG problem file | Explanation |
|---|---|
|
Problem tagging: |
|
DOCUMENT(); loadMacros( "PGstandard.pl", "MathObjects.pl", "AnswerFormatHelp.pl", "answerHints.pl", ); TEXT(beginproblem()); |
Initialization: |
Context("Numeric");
Context()->functions->remove("tan");
package NewFunc;
# this next line makes the function a
# function from reals to reals
our @ISA = qw(Parser::Function::numeric);
sub tan {
shift; my $x = shift;
return CORE::exp($x*3.1415926535);
}
package main;
# Make it work on formulas as well as numbers
sub tan {Parser::Function->call('tan',@_)}
# Add the new functions to the Context
Context()->functions->add(
tan => {class =>'NewFunc', TeX =>'\tan'}, );
|
Setup:
We redefine the function whose
name is |
Context()->texStrings;
BEGIN_TEXT
Simplify the expression as much as possible.
$BR
$BR
\( \tan(x) \cos(x) \) = \{ ans_rule(20) \}
\{ AnswerFormatHelp("formulas") \}
END_TEXT
Context()->normalStrings;
|
Main Text: |
$showPartialCorrectAnswers = 1;
ANS(Formula("sin(x)")->cmp()
->withPostFilter(AnswerHints(
Compute("tan(x)*cos(x)") =>
"No credit for entering what you were given.",
))
);
|
Answer Evaluation: |
Context()->texStrings;
BEGIN_SOLUTION
${PAR}SOLUTION:${PAR}
Solution explanation goes here.
END_SOLUTION
Context()->normalStrings;
COMMENT('MathObject version.');
ENDDOCUMENT();
|
Solution: |