### updating oE shift_bits

#### shift_bits

```include math.e
namespace math
public function shift_bits(object source_number, integer shift_distance)
```

moves the bits in the input value by the specified distance.

##### Parameters:
1. source_number : object: The value or values whose bits will be be moved.
2. shift_distance : integer: number of bits to be moved by.
• If source_number is a sequence, each element is shifted.
• The value or values in source_number are first truncated to a 32-bit integer.
• The output is truncated to a 32-bit integer.
• Vacated bits are replaced with zero.
• If shift_distance is negative, the bits in source_number are moved left.
• If shift_distance is positive, the bits in source_number are moved right.
• If shift_distance is zero, the bits in source_number are not moved.
##### Returns:

Atom or atoms containing a 32-bit integer. A single atom in source_number is an atom, or a sequence in the same form as source_number containing 32-bit integers.

##### Example 1:
```? shift_bits((7, -3) --> 56
? shift_bits((0, -9) --> 0
? shift_bits((4, -7) --> 512
? shift_bits((8, -4) --> 128
? shift_bits((0xFE427AAC, -7) --> 0x213D5600
? shift_bits((-7, -3) --> -56  which is 0xFFFFFFC8
? shift_bits((131, 0) --> 131
? shift_bits((184.464, 0) --> 184
? shift_bits((999_999_999_999_999, 0) --> -1530494977 which is 0xA4C67FFF
? shift_bits((184, 3) -- 23
? shift_bits((48, 2) --> 12
? shift_bits((121, 3) --> 15
? shift_bits((0xFE427AAC, 7) -->  0x01FC84F5
? shift_bits((-7, 3) --> 0x1FFFFFFF
? shift_bits({48, 121}, 2) --> {12, 30}
```