Base Number Calculation
CalcES allow you to perform calculation on DECIMAL, BINARY, OCTAL and HEXADECIMAL bases.
-
Press MODE , select
BASE-N
to enter Base-N Calculations mode -
The Base-N display contains the current base and the bit size.
Base-n and bit size
Supported bases
- BINARY: base 2, 01
- OCTAL: base 8, 01234567
- DECIMAL: base 10, 0123456789
- HEXADECIMAL: base 16: 0123456789ABCDEF
data:image/s3,"s3://crabby-images/94791/947917eed91646e9b7b2f463a212440891ef10ab" alt="drawing"
Supported data types
- 8 bits (byte, int8)
- 16 bits (short, int16)
- 32 bits (int, int32)
- 64 bits (long, int64)
data:image/s3,"s3://crabby-images/d2001/d2001b1cd3a18ccb2881711c4824c8e4b81f1dcd" alt="drawing"
Converting from a base to another base
Example: Converting 542
(base 10) to base 2
(binary) and base 16
(hex)
-
Switch to
DECIMAL
base by pressingDEC
-
Enter
542
-
Press
HEX
to convert to hex -
Press
BIN
to convert to binary
Operators
Arithmetic operators
Plus:
BINARY 16 bits signed
1001 + 1111 = 1 1000
data:image/s3,"s3://crabby-images/aa383/aa383fb2f2dacc78eea4165b8aa49b82c9d40cf1" alt="drawing"
Subtract:
BINARY 16 bits signed
1 0101- 11 0100=1111 1111 1110 0001
data:image/s3,"s3://crabby-images/27afe/27afe686ac8fb90fc7146ae394ac594197e27c67" alt="drawing"
Multiply
HEXADECIMAL 16 bits34E * FECB = 2DA
data:image/s3,"s3://crabby-images/e71a6/e71a612df609b711fedea0bc0a12436cbdfdb2a1" alt="drawing"
Divide
For non-integer value, (like 12.5
), the calculator DOES NOT use an IEEE-754 format.
Instead, it uses the following format:
12.52 (decimal) = 1100.1000 0101 0001 1110... (binary)
12.52 = 12 + 0.52
12 (decimal) = 1100 (binary) = 1*2^3 + 1*2^2 + 0*2^1 + 0*2^0 (decimal) = 8 + 4 + 0 + 0 (decimal) = 12 (decimal)
0.52 (decimal) = 0.1000 0101 0001 1110 (binary) = 1*2^-1 + 1*2^-6 + 1*2^-8 + 1*2^-12 ... (decimal) = 0.5 + 0.0015625 + 0.003 906 25 + ... (decimal) = 0.52
Example
BINARY 16 bits signed1110 ÷ 110 = 10.0101 0101 0101 0101
(14 ÷ 6) = 2.333 333 ... (decimal)
data:image/s3,"s3://crabby-images/e21ca/e21cab82d707e02bf44352d1da561adc22fceda4" alt="drawing"
Mod
DECIMAL63 mod 60 = 3
data:image/s3,"s3://crabby-images/39ae8/39ae8046a99642cfd7184b32fba8a4ce1a1f33a0" alt="drawing"
Logical operators
And
1 0011^1 0110=1 0011
data:image/s3,"s3://crabby-images/8227f/8227fc002ac56730c20a91643454245fdc2d006a" alt="drawing"
Nand
Or
1 0011v 1 0110= 1 0111
data:image/s3,"s3://crabby-images/222e2/222e256ef5e64f7205ce8831067b5286b13809ae" alt="drawing"
Nor
Xor
1 0011⊕ 1 0110= 0 0101
data:image/s3,"s3://crabby-images/e2fa0/e2fa039c16fe8b071eab292860c508ce49121fe1" alt="drawing"
Nxor
Not
BINARY 8 bits signed
~1 0011 = 1110 1100
data:image/s3,"s3://crabby-images/38d13/38d13994fbe4ad859a70cd4c857fa965f1f4f421" alt="drawing"
ShiftRight
When shifting right, the right most bit is lost and 0 is inserted on the left most.
1011 >>> 1 = 0101
data:image/s3,"s3://crabby-images/f1e9f/f1e9f75cb1c8b675aaff99fbdd887bf015026b90" alt="drawing"
If a number is negative (encoded using two’s complement), then a right shift preserves the number’s sign
BINARY 8 bits signed
1101 1111 >> 1 = 1110 1111
data:image/s3,"s3://crabby-images/5879f/5879f55506722f81b25adae0d112c7544bd9a9b2" alt="drawing"
data:image/s3,"s3://crabby-images/f70cb/f70cb3bbe57ad585f912f44b6cc9682c07f3c5c9" alt="drawing"
ShiftLeft
0010 << 1 = 0100
data:image/s3,"s3://crabby-images/51f7d/51f7d586408053aa95ef1c3ed8310126f9819981" alt="drawing"
Logical functions
RotateLeft
BINARY 8 bits signed
RotateLeft(1001 0111, 1)=0010 1111
data:image/s3,"s3://crabby-images/17f87/17f876adf4eac865a77fe4e09dd80bb19a74e0a2" alt="drawing"
RotateRight
BINARY 8 bits signed
RotateRight(1001 0111, 1)=1100 1011
data:image/s3,"s3://crabby-images/d8ebc/d8ebc88cc229355e9fee9af288f9441b9ce8fb23" alt="drawing"
Floor
Ceil
Settings
Digit grouping format settings
The calculator allow to customize the digits grouping.
Example: the number 1001010010101001
can be formatted with 4, 9, 16 and 32 digits per group
1001 0100 1010 100110010100 101010011001010010101001
data:image/s3,"s3://crabby-images/01d81/01d810e865cd2fddfecb476660802a28747e4a55" alt="drawing"
data:image/s3,"s3://crabby-images/e709b/e709bf1c8e7ff6215a8cbb70cd69c8de9cb00487" alt="drawing"
Fractional part precision of non-integer
This option allow to change the number of digits in fractional part of non-integer number.
3.1235123 (decimal) = 11.00011111 (binary)3.1235123 (decimal) = 11.0001111110011110 (binary)3.1235123 (decimal) = 11.00011111100111101000000010001001 (binary)
data:image/s3,"s3://crabby-images/926e4/926e4ee70c996a19da6576d7446a846ba33484d2" alt="drawing"