Two’s complement is a binary representation of a signed number.

We use B2Tw to represent a complement. W represents the bit length of binary number, and B2T actually means “binary to complement code”. To calculate the actual number represented by the complement, we need to multiply the value of each digit by the corresponding weight and then add it. Each bit (index I, starting at 0 and increasing from right to left) has a weight of 2i, but the highest bit has a special weight, which requires a negative value of -2W-1.

The mathematical formula for the complement

For vector x = [xw-1, xw-2… x0], there is:

Here are a few simple examples:

A complement is simply an unsigned binary number that is converted to decimal after the highest bit. And then if the highest place is 1, you subtract 2W minus 1, you get a negative number; If the highest digit is 0, you don’t have to deal with that, you end up with a non-negative number. The representation of complement code uses the method of subtracting offset value (2W-1), which solves the drawback that 0 represented by original code and inverse code has two ways of representation, and becomes the standard storage method of signed numbers in the current machine.

The maximum and minimum value of the complement representation

For a complement representation of bit length w, the maximum value TMaxw is 2W-1-1, where the highest bit is 0 and the rest bits are 1. The minimum value TMinw is -2w-1, where the highest bit is 1 and the rest bits are 0.

For example, for the 4-bit complement, the maximum value TMax4 = B2T4([0111]), the corresponding value is 23-1 = 7, the minimum value is B2T4([1000]), the corresponding value is -23 = -8.

The code “Two’s complement” is named after Two’s complement

Two’s complement = Two’s complement This designation does not describe the definition of the complement, but it does describe a property of the complement: a complement can be subtracted by 2w to obtain its negative, namely -x = 2w-x.

For example, if the complement of word length 4 represents 0001 (1 in decimal), its negative is 10000 (24) -0001 = 1111 (-1 in decimal).

When we are learning source code, inverse code, complement code and refer to relevant articles, we can always see the sentence similar to the following.

The complement of a positive number and 0 is the number itself, and the complement of a negative number is the inverse of the corresponding positive number and the addition of 1.

The latter part of the sentence is difficult to understand because it is a variant of the feature I mentioned earlier. Let’s look at how this variant is derived.

According to the complement characteristics, the sum of the complement of word length W and its negation gives 2W, such as 0001 + 1111 = 10000 (that is, 24). The sum of the bits inverse of the complement and complement gives 2W-1, i.e. 0001 + 1110 = 1111 (i.e. 10000-1). Subtract the former from the latter equation and we get:

1111 (complement of negative numbers) = 1110 (inverse of positive numbers) + 1Copy the code

So we have the conclusion that “the complement of a negative number is the inverse of its corresponding positive number and the addition of 1”.

Make sure you don’t use this sentence to understand complement. It’s not intuitive, it’s not a definition, it’s just a feature. Instead, it should go straight to the essentials: the complement is the value of the offset (2w, where w is the bit length) subtracted from the value of the offset (2W), which is the value of the corresponding digit except the highest bit.

Source code and inverse code

Since we have talked about the complement, we might as well talk briefly about the source code and inverse code closely related to the complement. Source code and inverse code and complement code, are signed number representation.

The original code (Sign Magnitude) is composed of the highest symbol bit (Sign) and the Magnitude represented by the rest bits (Magnitude). The source code is similar to the signed numbers we use everyday, with the highest bit representing the sign (0 is positive, 1 is negative) and the remaining bits representing the absolute value of the number. The calculation formula of the original code is:

“Ones’ Complement” is calculated in much the same way as Complement, except that the offset is 2W-1-1 instead of 2W-1.

The inverse of a positive number is equal to its source code, while the inverse of a negative number can be obtained by preserving its sign bits and inverting the numeric bits of the source code.

The inverse formula is:

“Ones’ Complement” means “Ones’ Complement”. “Ones” means multiple ones, which is 2W-1-1 for the inverse of a W-bit. Similarly, like the complement, the inverse has the property that a complement can be subtracted by 2w-1 to obtain its negative, namely -x = 2W-1-x.

The article was first posted on my blog site.

reference

  • Wikipedia – Complement
  • Wikipedia – Has symbolic number processing
  • Inverse code, complement code why also called “one of the complement”, “two of the complement”?
  • Why do computers use complement rather than source or inverse? – Drunk on the battlefield answer – Zhihu
  • In-depth understanding of computer systems (3rd edition) – Chapter 2 – Presentation and processing of information