Number Systems
Decimal Numbers – Conversion to Other Number Systems
Contents
Decimal Number Conversion to Other Number SystemsA. Decimal numbers to binary numbers
B. Decimal numbers to Hexadecimal numbers
C. Decimal numbers to octal and other systems
Related topics
• Number Systems and Their Decimal Equivalents
• Conversion Between Binary Numbers and Quaternary, Octal, or Hexadecimal Numbers
• Number Conversion Tool
Decimal numbers and other number systems, along with the process of converting a number from any number system to its decimal equivalent, are explained in Number Systems and Their Decimal Equivalents. On this page, we will discuss how to convert decimal numbers to other number systems.
A. Decimal numbers to binary numbers
To find the value of a decimal number, such as 13, in the binary system, you need to express it in a format similar to the left hand side of Eqs. (B.1) or (B.2) on the page Number Systems and Their Decimal Equivalents. We will explore that process below
Filling the missing term 21 with zero (0), we have
These above calculation steps can be described by a general expression of
(e.g., ) , and can be re-arranged and tabulated as shown in Table A.1.
Conversion of decimal number 13 to binary number
- (i)
- First, divide the number (13 in this demo) by the new base, which is 2. The remainder of this division is the first digit of the binary number, start from right to left, while the quotient becomes the dividend of the next step.
- (ii)
- Next, divide the new dividend by the base, the remainder of this division is the second digit added to the left of the digit obtained in step (i), and so on.
- (iii)
- The calculation stops when the quotient is equal to zero.
To convert a decimal number that has a fractional part, for example 13.325, to a binary number, first take notice that 13.325 = 13 + 0.325. The conversion of decimal number 13 to binary number is described in the previous section. The following section will explain how to convert fractional decimal number 0.325 to binary.
where x1, x2, x3 (highlighted in red) are the unknown digits we want to determine, and Eq. A.2 means
or
There are various ways to find x1, x2, x3, but here we will again use the concept of division’s quotient and remainder, but first take notice that
which implies
or
(Hence, = 0, = 1, and = 1)
Combining Eqs. A.1 and A.3, we have
A table similar to Table A.1 can be constructed for converting steps for number 0.325, but this time the remainder of the division is used as the dividend for the next step, while the quotient becomes a digit of the new number.
Conversion of decimal fractional number 0.325 to binary number
Notes that in this conversion, the divisors are the decimal values of their corresponding terms, i.e., 0.50 = 2-1, 0.25 = 2-2, and so on.
From Table A.2, it can be seen that the steps for converting a decimal fractional number to binary number are as follows
- (i)
- Divide the number (0.325 in this case) by the first term after the fractional point, which is 2-1 (0.5). Unlike conversion of the whole number, for the fractional part, the quotient of this division is the first digit of the binary part after the fractional point, starting from left to right, while the remainder becomes the dividend for the next step.
- (ii)
- Divide the new dividend by the next term of the base, which is 2-2 (0.25), the quotient of this division will be the second digit, on the right of the digit obtained in step 1, and so on.
- (iii)
- The calculation stops when the remainder is equal to zero or meets a pre-set criterion (see below Note).
B. Decimal numbers to Hexadecimal numbers
Conversion of decimal number to hexadecimal number is similar to conversion of decimal number to binary number except that the base is now 16 instead of 2, and the symbols used for representing a hexadecimal number are 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, A, B, C, D, E, F, where the values of A, B, C, D, E, F are 10, 11, 12, 13, 14, 15, respectively. For example, let’s convert the decimal number 2590.175 to a hexadecimal number.
Because 2590.175 = 2590 + 0.175, we can first split the number into two parts: the whole number 2590 and the fractional part, 0.175. We then follow the steps described in Table A.1 for the whole number 2590 and steps in Table A.2 for the fractional number 0.175, and then add the two results together to obtain the final result.
Calculation steps for the whole number 2590 are shown in Table B.1, and calculation steps for the fractional part 0.175 are shown in Table B.2.
Conversion of decimal number 2590 to hexadecimal number
Substitute 10, and 14 with A and E, respectively, decimal number 2590 can be expressed as
Therefore, the hexadecimal value of decimal number 2590 is A1E.
Conversion of decimal fractional number 0.175 to hexadecimal number
Here, we stop after 4 calculations because the remainder of the division will take many more steps to reach zero, but the calculation could continue if higher level of accuracy is desired.
After substituting 12 with C, 0.175 can be expressed as
Therefore, the hexadecimal value for the fractional part 0.175 is .2CCC
Combining Eqs. B.1 and B.2, we have
C. Decimal numbers to octal and other systems
To convert a decimal number to an octal number, or, in fact, to any other base system, the same approach described above can be used. For example, let’s convert the decimal number 2590.175 to an octal number (a base-8 number). As 2590.175 = 2590 + 0.175, we will build two tables, Table C.1 for number 2590 and Table C.2 for 0.175, as follows:
Conversion of decimal number 2590 to octal number (base-8)
Therefore,
Conversion of decimal fractional number 0.175 to octal number (base-8)
The calculation could continue if a higher level of accuracy is desired, but here we stop at remainder = 0.000195, and the base-8 number of 0.175 is
Therefore, the octal number of 2590.175 is
Notes:
- The method described above can be used for any other number systems, only that the base needs to be replaced accordingly.
- The greater the base is, the more compact the number is
- For the fractional part, criterion “Remainder = 0” may be impossible to achieve in many cases, causing the calculations to be infinite. Substituting zero with criterion “Remainder < ε”, where ε is a number close to zero, as seen in the above demo, while not produce the exact value, can overcome the problem. The value of ε can be chosen depending on the level of accuracy required.
- If you are dealing with conversion of binary numbers to quaternary (base 4), or octal (base 8), or hexadecimal (base 16) number systems, and vice versa, there is a simple method to convert the number without using division. This approach is described in Conversion Between Binary Numbers and Quaternary, Octal, or Hexadecimal Numbers.
- Microsoft Excel functions quotient() and mod() can be used to obtain quotient and remainder of a division, respectively. For those who are interested in computing, a Python code showing how to convert a number of any base to another number system, including decimal system, can be found here. An error tolerance (or ε) of 10×-6 is used in the code.