Perform variable manipulation (wordsizetowordsize).
Maths is performed strictly from left to right. The ‘let’ keyword is optional.
The microcontroller supports word (16 bit) mathematics. Valid integers are 0 to 65535. All mathematics can also be performed on byte (8 bit) variables (0255). The microcontroller does not support fractions or negative numbers. However it is sometimes possible to rewrite equations to use integers instead of fractions, e.g. let w1 = w2 / 5.7 is not valid, but let w1 = w2 * 10 / 57 is mathematically equal and valid.
The mathematical functions supported by all parts
+ 
add 
 
subtract

* 
multiply (returns low word of result) 
** 
multiply (returns high word of result) 
/ 
divide (returns quotient) 
// (or %) 
modulus divide (returns remainder) 
MAX 
limit value to a maximum value 
MIN 
limit value to a minimum value 
AND (or &) 
bitwise AND 
OR (or ) 
bitwise OR (typed as SHIFT + \ on UK keyboard) 
XOR (or ^) 
bitwise XOR (typed as SHIFT + 6 on UK keyboard) 
NAND 
bitwise NAND 
NOR 
bitwise NOR 
ANDNOT (or &/) 
bitwise AND NOT (NB this is not the same as NAND) 
ORNOT (or /) 
bitwise OR NOT (NB this is not the same as NOR) 
XORNOT (or ^/) 
bitwise XOR NOT (same as XNOR) 
The X1 and X2 parts also support
<< 
shift left 
>> 
shift right 
*/ 
multiply (returns middle word of result) 
The X1 and X2 parts also support these unary operators
SIN 
sine of angle (0 to 65535) in degrees (value * 100 is returned) 
COS 
cosine of angle in degrees (value * 100 is returned) 
SQR 
square root 
INV 
invert 
NCD 
encoder (2n power encoder) 
DCD 
decoder (2n power decoder) 
BINTOBCD 
convert binary value to BCD 
BCDTOBIN 
convert BCD value to binary 
REV 
reverse a number of bits 
DIG 
return a BCD digit 
NOB 
count number of set bits (X2 only) 
ATAN 
calculate the arctan of a value (result 045 degrees) (X2 only) 
All mathematics is performed strictly from left to right.
LET dirs / dirsA / dirsB / dirsC / dirsD = value
Some microcontrollers allow inputs to be configured as inputs or outputs. In these cases it is necessary to tell the microcontroller which pins to use as inputs and/or outputs (all are configured as inputs on first power up). There are a number of ways of doing this:
1) Use the input/output/reverse commands.
2) Use an output command (high, pulsout etc) that automatically configures the pin as an output.
3) Use the let dirs = statement. When working with this statement it is conventional to use binary notation. With binary notation pin 7 is on the left and pin 0 is on the right. If the bit is set to 0 the pin will be an input, if the bit is set to 1 the pin will be an output. Note that the 8 pin PICAXE have some preconfigured pins (e.g. pin 0 is always an output and pin 3 is always an input). Adjusting the bits for these pins will have no effect on the microcontroller.
For M2 and X2 parts which have more than one configurable port, you must use port specific commands by adding the letter of the port after dirs, eg LET dirsB = %00000010 to make pin1 of port B an output, and all other pins inputs.
Configure pins as inputs or outputs 
(let dirs =) 
(08/08M/08M2) 
Configure pins as inputs or outputs on portc 
(let dirsc =) 
(14M) 
Configure pins as inputs or outputs on portc 
(let dirsc =) 
(28X/40X) 
Configure pins as inputs or outputs on portc 
(let dirsc =) 
(28X1/40X1) 
LET pins / pinsA / pinsB / pinsC / pinsD = value
Set/clear all outputs on the main output port (let pins = ), or on a specific port (let pinsA/pinsB/pinsC/pinsD =).
High and low commands can be used to switch individual outputs high and low. However when working with multiple outputs it is often convenient to change all outputs simultaneously. When working with this statement it is conventional to use binary notation. With binary notation output7 is on the left and output0 is on the right. If the bit is set to 0 the output will be off (low), if the bit is set to 1 the output will be on (high).
Do not confuse the input port with the output port. These are separate ports on all except the 8 pin PICAXE. The command let pins = pins means 'make the output port the same as the input port'. Note that on devices that have input/output bidirectional pins (08 / 08M), this command will only function on pins configured as outputs. In this case it is necessary to configure the pins as outputs (using a let dirs/dirsX = command) before use of this command.
SIN and COS functions
The SIN function returns a value 0 to 100 for an input degree value of 0 through 180. This is the 0 to 1 value a mathematical sine function would return multiplied by 100.
For input degree values of 181 through 359 the result value is the same as for 1 through 179 with 128 added. The value will therefore be 128 to 228. The 128 value added indicates the sine result is negative, the least significant bits of the result indicate the value. Note that the 128 is used as a sign indicator and the resulting value is not a two's complement representation.
The COS function is similar to SIN but with a 90 degree phase shift. For input degree values of 0 to 90 the result will be 0 to 100, from 91 to 269 degrees the result is 128 to 228 indicating a negative result, then from 270 to 360 the result is 0 to 100.
DCD and NCD functions
The DCD (decode) function gives a poweroftwo result and is the equivalent to shifting a value of 1 to the left. The following two assignments are equivalent 
Let w1 = DCD b0
Let w1 = 1 << b0
If variable 'b0' held the value 3, the result would be 1 shifted left 3 binary digits, %1000 binary or 16 decimal, which is also 2^{3}.
The NCD (encode) function determines the highest poweroftwo which is greater than a variable or constants's value. It also allows the highest bit set in a variable or constant's value to be determined.
Let w1 = NCD w0
If variable 'w0' held the value 123, the largest poweroftwo value greater than 123 is 128 (2^{7}), so the variable 'w1' will be set to 7.