Options
Options affect the behaviour of each question.
Question Level Simplify
See the entry on simplification. Default is true
.
Assume Positive
This option sets the value of Maxima's
assume_pos
variable.
If true
and the sign of a parameter cannot be determined from the current context or
other considerations, sign
and asksign(x)
return true
. This may forestall some automatically-generated
asksign queries, such as may arise from integrate or other computations
Default is False
Question Penalty
This is the percentage of the marks deducted from each different and valid attempt which is not completely correct, when the penalty mark modification scheme is in use. The default is of the marks available for this question, entered at .
Note that Moodle stores scores to 7 decimal places, so, should be entered as , and as . If you input any number close to , but with less precision, then the extra digits will automatically be added. The exact range affected is that any penalty and is changed to , and any penalty and is changed to .
Output
The following options affect how mathematics is displayed.
Decimal separator
Choose the symbol for the decimal separator used by student input. There are currently two choices.
.
, the British decimal point.,
, the comma, as used in much of Europe.
The design of this option is discussed further in the developer docs.
Teachers must always use strict Maxima syntax, which requires .
, including in test case construction.
Scientific notation formal
Choose the format for display of scientific notation.
- '*10', numbers will be displayed as .
- 'E', numbers will be displayed as .
Multiplication Sign
- (none), e.g.
- Dot, e.g.
- Cross, e.g.
- Numbers only, e.g. .
In practice it is very helpful to have some kind of multiplication sign displayed to the student. The difference between
is very subtle. Notice the spacing? The first means xe^x=(xe)^x
the second is x*e^x
. Could be quite confusing to students if there is no multiplication sign. Using neatly solves this problem.
Internally the display of multiplication signs is controlled by the STACK function make_multsgn(ex)
, where the argument can be one of the strings "cross"
, "dot"
or "blank"
. This can be switched part-way through a session. E.g. consider the following castext.
Default: {@a*b@}.
Switch to cross: {@(make_multsgn("cross"), a*b)@}.
Cross remains: {@a*b@}.
The expression (make_multsgn("cross"), a*b)
uses parentheses as an abbreviation for Maxima's block
command. So, the first expression make_multsgn("cross")
is evaluated which changes the display option to a cross. Then the second expression is evaluated and displayed as . The new option persists in the next expression.
The value of this option onum
will only put a multiplication sign between numbers. This means you will see and not as you would if you have "none".
There is a special atom which controls the multiplication symbol used with option onum
. If you would like a dot then define
texput(multsgnonlyfornumberssym, "\\cdot");
in the question variables.
Logic symbols
How logical symbols should be displayed. The values are language, e.g. or symbol, e.g. .
Surd for Square Root
This option sets the value of Maxima's
sqrtdispflag
When false the prefix function sqrt(x)
will be displayed as . This setting is global to the question, and having both notations co-exist in one question is very tricky. You need to have simp:false
throughout the question.
By default Maxima does not like to use the symbol. The internal representation favours fractional powers, for very good reasons. In Maxima we get:
(%i1) 4*sqrt(2);
(%o1) 2^(5/2)
(%i2) 6*sqrt(2);
(%o2) 3*2^(3/2)
Furthermore, if you execute this in a Maxima session
simp:true;
p:1+sqrt(x);
?print(p);
Then the displayed value of p
is whereas the internal representation of p
is
((MPLUS SIMP) 1 ((MEXPT SIMP) $X ((RAT SIMP) 1 2)))
This means that internally Maxima has converted sqrt(x)
to x^(1/2)
, even though it is by default displayed as sqrt
. This is an example where the displayed form (text and LaTeX) does not match Maxima's internal representation.
Do you really want to continue using in your teaching? In his Elements of Algebra, L. Euler wrote the following.
We may therefore entirely reject the radical signs at present made use of, and employ in their stead the fractional exponents which we have just explained: but as we have been long accustomed to those signs, and meet with them in most books of Algebra, it might be wrong to banish them entirely from calculations; there is, however, sufficient reason also to employ, as is now frequently done, the other method of notation, because it manifestly corresponds with the nature of the thing. In fact we see immediately that is the square root of , because we know that the square of , that is to say multiplied by is equal to , or .
A lot of elementary mathematics involves converting from one form to another and back again. Sometimes these forms have important differences of use, e.g. factored form or completed square form for a quadratic. However, sometimes these equivalent forms are more customary than because it "manifestly corresponds with the nature of the thing" in question. I digress...
STACK defines an th root function root(x,n)
which is a noun form for . This can be used by students, but if teachers wish to use this in question variables etc. then they must prefix this with the apostophie to create the nounform 'root(x,n)
to prevent immediate evaluation to x^(1/n)
.
sqrt(-1)
In Maxima %i
is the complex unit satisfying %i^2=-1
. However, students would
like to type i
and physicists and engineers j
.
We also sometimes need to use symbols i
and j
for vectors.
To accommodate these needs we have an option ComplexNo
which provides a context for these symbols
and affects the way they are displayed.
Option | Interpretation | Display | ~ | ~ | ~ | ~ |
---|---|---|---|---|---|---|
%i^2 | i^2 | j^2 | %i | i | j | |
-------- | ---------------- | --------- | ----- | ---- | ----- | ----- |
i | -1 | -1 | j^2 | i | i | j |
j | -1 | i^2 | -1 | j | i | j |
symi | -1 | i^2 | j^2 | i | i | j |
symj | -1 | i^2 | j^2 | j | i | j |
Note the use of both Roman and italic symbols in this table.
If you are using as basis vectors then consider the following in your question variables
/* Below means set the ComplexNo option in the question to "symi". */
make_complexJ("symi");
ordergreat(i,j,k);
texput(i,"\\vec{i}");
texput(j,"\\vec{j}");
texput(k,"\\vec{k}");
%_stack_preamble_end;
/* These are examples. */
p:3*i+4*j+5*k;
q:a*i+b*j+c*k;
Then, your expressions p
and q
will be displayed repectively as and
Further examples are given in the vectors.documentation.
Matrix parentheses
See the entry on matrices.
Inline and displayed fractions.
There are three ways to display fractions.
- displayed ;
- inline ;
- negative powers .
The default behaviour is displayed, i.e. using LaTeX \frac{}{}
.
The function stack_disp_fractions(ex)
can be used to control the display globally within a question.
stack_disp_fractions("i")
switches display to inline.stack_disp_fractions("d")
switches display to display.
Note, for CASText the display is controlled by the prevailing setting at the moment the text is displayed, not when a variable is defined in the question variables. Hence, if you would like a single inline fraction within a CASText you will need to use
Normally fractions are displayed {@1/x@}. This switches to inline {@(stack_disp_fractions("i"), 1/x)@}, which persists {@1/a@}. Switch explicitly back to displayed {@(stack_disp_fractions("d"),1/x)@}.
For scientific units we also have an input "extra option" negpow
for student's input to be displayed as negative powers, e.g. .
We do not, currently, have support for global display of fractions using negative powers (Dec 2024). This is because the difference between displayed and inline fractions is purely notational, involving the TeX output from the division operator. Converting division to negative powers is a mathematical re-write rule and is therefore significantly more complicated. E.g. we would have to decide how to display .