This section deals with logical values ("Booleans").
Booleans are primarily of importance as (return) values for (intrinsic) predicates. It is important to know that the truth-value of the operators and and or is always evaluated left to right, that is, the left-most clause is evaluated first, and if that determines the value of the operator evaluation is aborted; if not, the next clause is evaluated, etc. So, for example, if x is a boolean, it is safe (albeit silly) to type:
> if x eq true or x eq false or x/0 eq 1 then > "fine"; > else > "error"; > end if;even though x/0 would cause an error ("Bad arguments", not "Division by zero"!) upon evaluation, because the truth value will have been determined before the evaluation of x/0 takes place.
The Boolean structure.
Cardinality of Boolean structure (2).
The Boolean elements.
Return a random Boolean.
Returns true if both x and y are true, false otherwise. If x is false, the expression for y is not evaluated.
Returns true if at least one of x and y is true, false otherwise. If x is true, the expression for y is not evaluated.
Returns true if either x or y is true, but not both, false otherwise.
Negate the truth value of x.
Magma provides two equality operators: eq for strong (comparable) equality testing, and cmpeq for weak equality testing. The operators depend on the concept of comparability. Objects x and y in Magma are said to be comparable if both of the following points hold:
If x and y are comparable, return true if x equals y (which will always work by the second rule above). If x and y are not comparable, an error results.
If x and y are comparable, return true if x does not equal y. If x and y are not comparable, an error results.
If x and y are comparable, return whether x equals y. Otherwise, return false. Thus this operator always returns a value and an error never results. It is useful when comparing two objects of completely different types where it is desired that no error should occur. However, it is strongly recommended that eq is usually used to allow Magma to pick up common unintentional type errors.
If x and y are comparable, return whether x does not equal y. Otherwise, return true. Thus this operator always returns a value and an error never results. It is useful when comparing two objects of completely different types where it is desired that no error can happen. However, it is strongly recommended that ne is usually used to allow Magma to pick up common unintentional type errors.
> 1 eq 2/2; true > 1 cmpeq 2/2; true > 1 eq "x"; Runtime error in 'eq': Bad argument types > 1 cmpeq "x"; false > [1] eq ["x"]; Runtime error in 'eq': Incompatible sequences > [1] cmpeq ["x"]; false
A Boolean structure B may be used for enumeration: for x in B do, and x in B in set and sequence constructors.
> P := Booleans(); > for x, y in P do > (x ne y) eq (x xor y); > end for; true true true trueSimilarly, we can test whether for any pair of Booleans x, y it is true that x = y iff (x ^ y) v (not x ^ not y).
> equal := true; > for x, y in P do > if (x eq y) and not ((x and y) or (not x and not y)) then > equal := false; > end if; > end for; > equal; true