Equivalence reasoning input
This is reference documentation for the equivalence reasoning input.
What is reasoning by equivalence and this input type?
Reasoning by equivalence is a particularly important activity in elementary algebra.
It is an iterative formal symbolic procedure where algebraic expressions, or terms within an expression,
are replaced by an equivalent until a "solved" form is reached.
An example of solving a quadratic equation is shown below.
The point is that replacing an expression or a sub-expression in a problem by an equivalent expression provides a new problem having the same solutions. This input type enables us to capture and evaluate student's line-by-line reasoning, i.e. their steps in working, during this kind of activity.
Reasoning by equivalence is very common in elementary mathematics. It is either the entire task (such as when solving a quadratic) or it is an important part of a bigger problem. E.g. proving the induction step is often achieved by reasoning by equivalence.
How do students use this input?
In traditional practice students work line by line rewriting an equation until it is solved.
This input type is designed to capture this kind of working and evaluate it based on the assumption that each line should be equivalent to the previous one.
Instructions for students are here. Some common observations about this form of reasoning are
- Students often use no logical connectives between lines.
- Students ignore the natural domain of an expression, e.g. in the value is excluded from the domain of definition.
- Operations which do not result in equivalence are often used, e.g. squaring both sides of an equation.
This input type mirrors current common practice and does not expect students to indicate either logic or domains.
The input type itself will give students feedback on these issues.
Note that students must use correct propositional logic connectives or
and and
.
E.g. their answer must be something correct such as x=1 or x=2
, not something sloppy like x=1 or 2
or x=1,2
.
It certainly can't be something wrong such as x=1 and x=2
which is often seen in written answers!
Note that students may not take square roots of both sides of an equation. This will be rejected because it is not equivalent! Similarly, students may not cancel terms from both sides which may be zero. As we require equivalence, students may not multiply either. This will probably not correspond to students' expectations, and may take a bit of getting used to.
But should students really use logical connectives? Yes, I (CJS) believe they should but to require this from the input type now would be too big a step for students and their teachers. Students are already being expected to use connectives such as and
and or
correctly. The input type uses these connectives and in the future options may be added to this input type which require students to be explicit about logical connectives, especially when we add support for implication in addition to equivalence. As we gain confidence in teaching with equivalence reasoning, we will add more options to this input type.
If you have strong views on how this input type should behave, please contact the developers.
Validation and correctness
STACK carefully separates out validation of a student's answer from the correctness.
This idea is encapsulated in the separation of validation feedback via the tags [[validation]]
which is tied to inputs, from the potential response trees which establish the mathematical properties.
Each line of a student's answer must be a valid expression, just as with the algebraic input type.
However, sets, lists and matrices are not permitted in this input type.
The internal result is a list of expressions (equations or inequalities).
Example use cases for this input type
-
Reasoning by equivalence is the entire task. The argument must be correct and the last line is the final answer.
-
In a formative setting, we want immediate feedback on whether the argument consists of equivalent lines. This feedback can be given
- as the student types line by line, or
- at the end when they press "check".
The ability to give feedback on the equivalence of adjacent lines as the student types their answer somewhat blurs the distinction between validation and correctness, but in a way which is probably very useful to students.
Notes for question authors
- The position of the validation tags, e.g.
[[validation:ans1]]
are ignored for this input type. Validation feedback is always displayed next to the TextArea into which students type their answer. - The teacher's answer and any syntax hint must be a list. If you just pass in an expression strange behaviour may result.
- The input type works very much like the TextArea input type. Internally, the student's lines are turned into a list. If you want to use the "final answer" then use code such as
last(ans1)
in your potential response tree. - If students type in an expression rather than an equation, the system will assume they forgot to add at the end and act accordingly. This is displayed to the student.
If the student starts their line with an =
sign, this is accepted. Teachers cannot use a prefix =
. In a worked solution the teacher must use the prefix function stackeq
. For example,
ta:[(x-1)^2,stackeq(x^2-2*x+1)]
Teachers must explicitly use the nounor
and nounand
commands, not the and
and or
logic. For more details see the section on simplification. For example, a worked solution might be
ta:[p=0,(v-n1)*(v-n2)=0,v-n1=0 nounor v-n2=0,v=n1 nounor v=n2]
Input type options
To enter options for this input use the "extra options field". Options should be a comma separated list of values only from the following list.
hideequiv
does not display whether each line is equivalent to the next at validation time.
hidedomain
does not display natural domain information.
comments
allows students to include comments in their answer. By default comments are not permitted as it breaks up the argument and stops automatic marking.
firstline
takes the first line of the teacher's answer and forces the student to have this as the first line of the student's answer. The test used is equality up to commutativity and associativity (EqualComAss answer test).
assume_pos
sets the value of Maxima's assume_pos
variable to be true.
If we assume_pos
they any negative solutions will be ignored, whether or not they exist. So will now be equivalent to .
You might not want this equivalence. In particular, this also has the effect of condoning squaring or rooting both sides of an equation.
For example will now be equivalent to (rather than ).
This is not the default, but is useful in situations where a student is rearranging an equation to a given subject, and all the variables are assumed to be positive. Note, this option is only for the input type. You will also need to set this in the question options to also affect the answer test.
assume_real
sets an internal flag to work over the real numbers. If true
then will be considered equivalent to . Note, this option is only for the input type. You will also need to set this in the question options to also affect the answer test.
calculus
allows calculus operations in an argument. Note, this option is only for the input type. You will also need to set this in the answer test options to also affect the answer test. This is at a very early stage of development.
For example, constants of integration are not currently checked by this currently.
If the syntax hint is just the keyword firstline
then the first line of the value of the teacher's answer will appear as a syntax hint.
This enables a randomly generated syntax hint to appear in the box.
"let"
Students can assigne a value to a variable by typing let v=a
. This value will be used in all subsequent working.
For example, try the following in the equiv-reasoning input.
x^2=a^2
let a=2
(x-2)*(x+2)=0
Internally there is a special function stacklet(v,a)
which is used to indicate the variable v
should have the value a
within equivalence reasoning.
To find all assignments in a student's answer, such as ans1
, you can filter on the stacklet
function within the feedback variables. Note, the student's answer will be a list..
L1:sublist(ans1,lambda([ex],safe_op(ex)="stacklet"));
Then L1
will be a list of the assignments. If you want to turn this into a list of equations then
L1:ev(L1,stacklet="=");