Как найти смещенный порядок

Вещественные числа обычно представляются в виде чисел с плавающей запятой. Числа с плавающей запятой — один из возможных способов представления действительных чисел, который является компромиссом между точностью и диапазоном принимаемых значений, его можно считать аналогом экспоненциальной записи чисел, но только в памяти компьютера.

Число с плавающей запятой состоит из набора отдельных двоичных разрядов, условно разделенных на так называемые знак (англ. sign), порядок (англ. exponent) и мантиссу (англ. mantis). В наиболее распространённом формате (стандарт IEEE 754) число с плавающей запятой представляется в виде набора битов, часть из которых кодирует собой мантиссу числа, другая часть — показатель степени, и ещё один бит используется для указания знака числа ( — если число положительное, — если число отрицательное). При этом порядок записывается как целое число в коде со сдвигом, а мантисса — в нормализованном виде, своей дробной частью в двоичной системе счисления. Вот пример такого числа из двоичных разрядов:

Знак
Порядок Мантисса
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
14 10 9 0

Знак — один бит, указывающий знак всего числа с плавающей точкой. Порядок и мантисса — целые числа, которые вместе со знаком дают представление числа с плавающей запятой в следующем виде:

, где — знак, — основание, — порядок, а — мантисса.
Десятичное число, записываемое как , где — число в полуинтервале , — степень, в которой стоит множитель ; в нормализированной форме модуль будет являться мантиссой, а — порядком, а будет равно тогда и только тогда, когда принимает отрицательное значение.
Например, в числе

Порядок также иногда называют экспонентой или просто показателем степени.

При этом лишь некоторые из вещественных чисел могут быть представлены в памяти компьютера точным значением, в то время как остальные числа представляются приближёнными значениями.

Более простым вариантом представления вещественных чисел является вариант с фиксированной точкой, когда целая и вещественная части хранятся отдельно. Например, на целую часть отводится всегда бит и на дробную отводится всегда бит. Такой способ в архитектурах процессоров не присутствует. Отдаётся предпочтение числам с плавающей запятой, как компромиссу между диапазоном допустимых значений и точностью.

Содержание

  • 1 Нормальная и нормализованная форма
  • 2 Типы чисел с плавающей точкой (по IEEE 754)
    • 2.1 Число половинной точности (Binary16, Half precision)
    • 2.2 Число одинарной точности (Binary32, Single precision, float)
    • 2.3 Число двойной точности (Binary64, Double precision, double)
    • 2.4 Число четверной точности (Binary128, Quadruple precision)
    • 2.5 Диапазон значений чисел с плавающей запятой
  • 3 Особые значения чисел с плавающей точкой
    • 3.1 Ноль (со знаком)
    • 3.2 Неопределенность (NaN)
    • 3.3 Бесконечности
    • 3.4 Денормализованные числа
  • 4 Действия с числами с плавающей запятой
    • 4.1 Умножение и деление
    • 4.2 Сложение и вычитание
    • 4.3 Алгоритм получения представления вещественного числа в памяти ЭВМ
  • 5 См. также
  • 6 Примечания
  • 7 Ссылки
    • 7.1 Использованные материалы
    • 7.2 Что стоит прочесть

Нормальная и нормализованная форма

Нормальной формой (англ. normal form) числа с плавающей запятой называется такая форма, в которой мантисса (без учёта знака) в десятичной системе находится на полуинтервале . Такая форма записи имеет недостаток: некоторые числа записываются неоднозначно (например, можно записать в 4 формах — , , , ), поэтому распространена также другая форма записи — нормализованная (англ. normalized), в которой мантисса десятичного числа принимает значения от (включительно) до (не включительно), а мантисса двоичного числа принимает значения от (включительно) до (не включительно). То есть в мантиссе слева от запятой до применения порядка находится ровно один знак. В такой форме любое число (кроме ) записывается единственным образом. Ноль же представить таким образом невозможно, поэтому стандарт предусматривает специальную последовательность битов для задания числа (а заодно и некоторых других полезных чисел, таких как и ).
Так как старший двоичный разряд (целая часть) мантиссы вещественного числа в нормализованном виде всегда равен «», то его можно не записывать, сэкономив таким образом один бит, что и используется в стандарте IEEE 754. В позиционных системах счисления с основанием большим, чем (в троичной, четверичной и др.), этого замечательного свойства нет (ведь целая часть там может быть не только единицей).

Типы чисел с плавающей точкой (по IEEE 754)

Число половинной точности (Binary16, Half precision)

Число́ полови́нной то́чности  — компьютерный формат представления чисел, занимающий в памяти половину машинного слова (в случае 32-битного компьютера — бит или байта). В силу невысокой точности этот формат представления чисел с плавающей запятой обычно используется в видеокартах, где небольшой размер и высокая скорость работы важнее точности вычислений.

Знак
Порядок Мантисса
0 0 0 0 0 0 1, 0 0 0 0 0 0 0 0 0 0
14 10 9 0

Порядок записан со сдвигом . То есть чтобы получить актуально значение порядка нужно вычесть из него сдвиг. Сдвиг можно получить по формуле , где — число бит, отведенное на хранение порядка (в случае числа половинной точности ).

Ограничения точности

  • Целые от нуля до передаются как есть.
  • Целые от до округляются к ближайшему чётному целому.
  • Целые от до округляются до ближайшего целого, делящегося нацело на четыре.
  • Целые от до округляются до ближайшего целого, делящегося на восемь.
  • Целые от до округляются до ближайшего целого, делящегося на шестнадцать.
  • Целые от до округляются до ближайшего целого, делящегося на тридцать два.

Число одинарной точности (Binary32, Single precision, float)

Число́ одина́рной то́чности — компьютерный формат представления чисел, занимающий в памяти одно машинное слово (в случае 32-битного компьютера — бита или байта). Используется для работы с вещественными числами везде, где не нужна очень высокая точность.

Знак
Порядок (8 бит) Мантисса (23+1 бита)
0 0 0 0 0 0 0 0 0 1, 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
30 23 22 0

Порядок записан со сдвигом .

Число двойной точности (Binary64, Double precision, double)

Число́ двойно́й то́чности
компьютерный формат представления чисел, занимающий в памяти два машинных слова (в случае 32-битного компьютера — бита или байт). Часто используется благодаря своей неплохой точности, даже несмотря на двойной расход памяти и сетевого трафика относительно чисел одинарной точности.

Знак
Порядок
(11 бит)
Мантисса
(52+1 бит)
0 0 0 0 0 0 0 0 0 0 0 0 1, 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
62 52 51 0

Порядок записан со сдвигом .

Число четверной точности (Binary128, Quadruple precision)

Число́ четверно́й то́чности
компьютерный формат представления чисел, занимающий в памяти четыре машинных слова (в случае 32-битного компьютера — бит или байт). Используется в случае необходимости крайне высокой точности.

Знак
Порядок
(15 бит)
Мантисса
(112+1 бит)
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1, 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
126 112 111
Мантисса
(112+1 бит)
0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0
0

Порядок записан со сдвигом .

Обычно этот формат реализуется программно, случаи аппаратной реализации крайне редки. Также не гарантируется поддержка этого типа в языках программирования, хотя кое-где она и реализована (например, компилятор gcc для архитектуры x86 позволяет использовать тип __float128, являющийся программной реализацией числа с четверной точностью).
В совокупности эти факторы делают Quadruple весьма экзотичным и редко встречающимся форматом чисел с плавающей запятой.

Диапазон значений чисел с плавающей запятой

Диапазон чисел, которые можно записать данным способом, зависит от количества бит, отведённых для представления мантиссы и показателя. Пара значений показателя (когда все разряды нули и когда все разряды единицы) зарезервирована для обеспечения возможности представления специальных чисел. К ним относятся ноль, значения NaN (Not a Number, «не число», получается как результат операций типа деления нуля на ноль) и .

Данная таблица только лишь примерно указывает границы допустимых значений, без учета возрастающей погрешности с ростом абсолютного значения и существования денормализованных чисел.

Название в IEEE 754 Название типа переменной в Си Диапазон значений Бит в мантиссе Бит на переменную
Half precision 6,10×10-5..65504 11 16
Single presicion float -3,4×1038..3,4×1038 23 32
Double precision double -1,7×10308..1,7×10308 53 64
Extended precision На некоторых архитектурах (например в сопроцессоре Intel) long double -3,4×104932..3,4×104932 65 80

Особые значения чисел с плавающей точкой

Ноль (со знаком)

Как уже было оговорено выше, в нормализованной форме числа с плавающей точкой невозможно представить ноль. Поэтому для его представления зарезервированы специальные значения мантиссы и порядка — число считается нулём, если все его биты, кроме знакового, равны нулю. При этом в зависимости от значения бита знака ноль может быть как положительным, так и отрицательным.

Знак
Порядок Мантисса
0/1 0 0 0 0 0 1, 0 0 0 0 0 0 0 0 0 0  = 
14 10 9 0

Арифметика нуля со знаком

Арифметика отрицательного нуля аналогична таковой для любого отрицательного числа и понятна интуитивно. Вот несколько примеров:

  • (если )
  • (если )

Неопределенность (NaN)

NaN — это аббревиатура от фразы «not a number«. NaN является результатом арифметических операций, если во время их выполнения произошла ошибка (примеры см. ниже). В IEEE 754 NaN представлен как число, в котором все двоичные разряды порядка — единицы, а мантисса не нулевая.

Знак
Порядок Мантисса
0/1 1 1 1 1 1 1, 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1 0/1  = 
14 10 9 0

Любая операция с NaN возвращает NaN. При желании в мантиссу можно записывать информацию, которую программа сможет интерпретировать. Стандартом это не оговорено и мантисса чаще всего игнорируется.

Как можно получить NaN?

  • , где

Есть и другие способы получения NaN, подробности можно найти по ссылкам в соответствующем разделе.

По определению NaN ≠ NaN, поэтому, для проверки значения переменной нужно просто сравнить ее с собой.

Бесконечности

В число с плавающей запятой можно записать значение или . Как и нули со знаком, бесконечности позволяют получить хотя бы близкий к правильному результат вычисления в случае переполнения. Согласно стандарту IEEE 754 число с плавающей запятой считается равным бесконечности, если все двоичные разряды его порядка — единицы, а мантисса равна нулю. Знак бесконечности определяется знаковым битом числа.

Знак
Порядок Мантисса
0/1 1 1 1 1 1 1, 0 0 0 0 0 0 0 0 0 0  = 
14 10 9 0

Получить бесконечность можно при переполнении и при делении ненулевого числа на ноль. При этом

Денормализованные числа

Денормализованные числа (англ. denormalized/subnormal numbers) — это способ увеличить количество представимых числом с плавающей запятой значений около нуля, дабы повысить точность вычислений. Каждое значение денормализованного числа меньше самого маленького нормализованного («обычного») значения числа с плавающей запятой.
Согласно стандарту, если порядок равен своему минимальному значению (все его биты — нули, а истинное значение порядка равно его сдвигу) и все биты мантиссы равны нулю, то это . Если же мантисса не равна нулю, то это число с порядком, на единицу большим минимального (все биты порядка, кроме младшего — нули) и данной мантиссой, целая часть которой считается равной нулю, а не единице.

То есть число с плавающей запятой, при учете вышесказанного, можно задать следующим образом:

  • , если (нормализованное число)
  • , если (денормализованное число)

Где — бит знака, — последовательность битов мантиссы, — значение порядка (с учетом сдвига), — минимальное значение порядка, используемое для записи чисел (1 — сдвиг) , — минимальное значение порядка, которое он в принципе может принять (все биты нули, 0 — сдвиг).

Хоть денормализованные числа и позволяют бороться с погрешностями и обрабатывать очень маленькие значения, за эти возможности приходится дорого платить. Ввиду сложности денормализованные числа крайне редко реализуют на аппаратном уровне — вместо этого используются программные реализации, работающие значительно медленнее.

В современных процессорах обработка денормализованных чисел происходит в десятки раз медленнее, чем обработка нормализованных чисел. Ниже приведена часть таблицы из статьи Isaac Dooley, Laxmikant Kale «Quantifying the Interference Caused by Subnormal Floating-Point Values»[1]

Производитель Процессор Замедление (разы)
IBM PowerPC 970 2,4
AMD Athlon 6,0
Intel Pentium 3 15,8
AMD Athlon 64 21,4
AMD Opteron64 23,8
Intel Core Duo 44,2
Intel P4 Xeon 97,9
Intel Pentium 4 131,0
Intel Itanium 2 183,2
Sun UltraSPARC IV 520,0

В таблице приведены наихудшие результаты тестирования среди всех использованных компиляторов (gcc, icc, xlc) со всеми доступными флагами оптимизации. Исследователи утверждают, что различие среднего случая с худшим незначительно.

Поскольку в стандартных форматах (одинарной и двойной точности) денормализованные числа получаются действительно очень маленькими и практически никак не влияют на результат некоторых вычислений (при этом заметно замедляя их скорость), то иногда они просто игнорируются. При этом используются два простых механизма, получивших называние Flush-to-zero (FTZ) и Denormals-are-zero (DAZ). Первый механизм заставляет операции возвращать ноль, как только становится ясно, что результат будет денормализованным. Второй механизм заставляет операции рассматривать поступающие на вход денормализованные числа как нули.
Ярким примером подобного «отсечения» денормализованных чисел могут послужить видеокарты, в которых резкое падение скорости вычислений в сотню раз недопустимо. Так же, например, в областях, связанных с обработкой звука, нет нужды в очень маленьких числах, поскольку они представляют столь тихий звук, что его не способно воспринять человеческое ухо.

В версии стандарта IEEE 754-2008 денормализованные числа (denormal или denormalized numbers) были переименованы в subnormal numbers, то есть в числа, меньшие «нормальных». Поэтому их иногда еще называют «субнормальными«.

Действия с числами с плавающей запятой

Умножение и деление

Самыми простыми для восприятия арифметическими операциями над числами с плавающей запятой являются умножение и деление. Для того, чтобы умножить два вещественных числа в нормализованной форме необходимо перемножить их мантиссы, сложить порядки, округлить и нормализовать полученное число.

Соответственно, чтобы произвести деление нужно разделить мантиссу делимого на мантиссу делителя и вычесть из порядка делимого порядок делителя. Затем точно так же округлить мантиссу результата и привести его к нормализованной форме.

Сложение и вычитание

Идея метода сложения и вычитания чисел с плавающей точкой заключается в приведении их к одному порядку. Сначала выбирается оптимальный порядок, затем мантиссы обоих чисел представляются в соответствии с новым порядком, затем над ними производится сложение/вычитание, мантисса результата округляется и, если нужно, результат приводится к нормализированной форме. Пример:

Выполним сложение чисел с плавающей точкой и смещенным порядком в 32-х разрядном формате   и .
Переведем   в машинный вид. Для этого сначала переведем его в двоичную систему счисления.
   
  
Нормализуем полученное двоичное число по правилам машинной арифметики.
   
Найдем смещенный порядок. Так как в условии говорится о 32-разрядном представлении, то смещение порядка равно .
          
Число отрицательное, следовательно, в бите знака будет стоять единица.
Итак, первое число в машинном 32-разрядном представлении с плавающей точкой будет иметь вид:
10000111 (жирным шрифтом выделен порядок числа, длина мантиссы — 23 бита).
Переведем второе число в машинный вид, совершая те же действия.
 = ,...  ...  
В качестве мантиссы будут сохранены первые  бита после запятой т.е. .
Очевидно, что порядок со смещением у второго числа будет таким же, как и у первого.
Второе число положительное, следовательно, бит знака будет содержать ноль.
Итак в машинном 32-разрядном представлении второе число будет иметь вид:
10000111
Далее в арифметических операциях будет использоваться число ,=, а не = видимо для упрощения(хотя это не совсем корректно).
Порядки у слагаемых равны, поэтому пропускаем шаг выравнивания порядков и проводим вычитание мантисс по правилам двоичной арифметики. В 
компьютере этим занимается арифметический сопроцессор, встроенный в центральный процессор машины.
,    
Приводим полученный результат к машинному виду. Для этого мы должны внести поправку в порядок — уменьшить его на единицу.
Знак результата —  положительный, следовательно, бит знака содержит ноль.
10000110
Проверим правильность наших вычислений. Переведем результат в десятичное представление.
Найдем реальный порядок результата, вычтя из него значение смещения .
            
Следовательно, число результата будет иметь вид:
      ,  
Результат наших вычислений верен, так как  -   .

Алгоритм получения представления вещественного числа в памяти ЭВМ

Покажем преобразование действительного числа для представления его в

памяти ЭВМ на примере величины типа Double.

Как видно из таблицы, величина этого типа занимает в памяти байт. На

рисунке ниже показано, как здесь представлены поля мантиссы и порядка (нумерация битов осуществляется справа налево):

Знак Смещённый порядок Мантисса
63 62..52 51..0

Можно заметить, что старший бит, отведенный под мантиссу, имеет номер

, т.е. мантисса занимает младшие бита. Черта указывает здесь на

положение двоичной запятой. Перед запятой должен стоять бит целой части

мантиссы, но поскольку она всегда равна , здесь данный бит не требуется и

соответствующий разряд отсутствует в памяти (но он подразумевается).

Значение порядка хранится здесь не как целое число, представленное в

дополнительном коде. Для упрощения вычислений и сравнения действительных

чисел значение порядка в ЭВМ хранится в виде смещенного числа, т.е. к

настоящему значению порядка перед записью его в память прибавляется

смещение. Смещение выбирается так, чтобы минимальному значению порядка

соответствовал нуль. Например, для типа Double порядок занимает бит и

имеет диапазон от до , поэтому смещение равно ()

(). Наконец, бит с номером указывает на знак числа.

Таким образом, из вышесказанного вытекает следующий алгоритм для

получения представления действительного числа в памяти ЭВМ:

  1. перевести модуль данного числа в двоичную систему счисления;
  2. нормализовать двоичное число, т.е. записать в виде M 2p, где M —

    мантисса (ее целая часть равна ()) и p — порядок, записанный в

    десятичной системе счисления;

  3. прибавить к порядку смещение и перевести смещенный порядок в двоичную

    систему счисления;

  4. учитывая знак заданного числа (0 — положительное; 1 — отрицательное),

    выписать его представление в памяти ЭВМ.

Пример. Запишем код числа ,.

  1. Двоичная запись модуля этого числа имеет вид .
  2. Имеем

    .

  3. Получаем смещенный порядок . Далее имеем

    () ().

  4. Окончательно
    1 10000000111 0011100001010000000000000000000000000000000000000000
    63 62..52 51..0

Очевидно, что более компактно полученный код стоит записать следующим

образом: C073850000000000(16).

Другой пример иллюстрирует обратный переход от кода действительного

числа к самому числу.

Пример. Пусть дан код 3FEC600000000000(16) или

    0 01111111110 1100011000000000000000000000000000000000000000000000
    63 62..52 51..0
  1. Прежде всего замечаем, что это код положительного числа, поскольку в

    разряде с номером записан нуль. Получим порядок этого числа:

    () (); .

  2. Число имеет вид , или

    ,.

  3. Переводом в десятичную систему счисления получаем ,.

См. также

  • Представление символов, таблицы кодировок
  • Представление целых чисел: прямой код, код со сдвигом, дополнительный код

Примечания

  1. Статья Isaac Dooley, Laxmikant Kale «Quantifying the Interference Caused by Subnormal Floating-Point Values» (англ.)

Ссылки

Использованные материалы

На русском

  • Википедия — Экспоненциальная запись
  • Википедия — Число с плавающей запятой
  • Википедия — Отрицательный и положительный ноль
  • Хабрахабр — статья пользователя Yruslan «Что нужно знать про арифметику с плавающей запятой»
  • Статья Лапшевой Е.Е. «Машинная арифметика с вещественными числами» Статья удалена

На английском

  • Wikipedia — NaN
  • Wikipedia — Floating point
  • Wikipedia — IEEE 754-2008

Что стоит прочесть

  • Материалы по стандарту IEEE 754 (англ.)
  • Русский перевод стандарта IEEE 754

Предыдущая лекция
|
Содержание
|
Следующая лекция

Информатика. Лекция №5. Представление чисел в компьютере.

Представление целых чисел в компьютере.

Целые числа являются простейшими числовыми данными, с которыми оперирует ЭВМ. Для целых
чисел существуют два представления: беззнаковое (только для неотрицательных целых чисел)
и со знаком. Очевидно, что отрицательные числа можно представлять только в знаковом виде.
Целые числа в компьютере хранятся в формате с фиксированной запятой.

Представление целых чисел в беззнаковых целых типах.

Для беззнакового представления все разряды ячейки отводятся под представление самого числа.
Например, в байте (8 бит) можно представить беззнаковые числа от 0 до 255. Поэтому, если
известно, что числовая величина является неотрицательной, то выгоднее рассматривать её
как беззнаковую.

Представление целых чисел в знаковых целых типах.

Для представления со знаком самый старший (левый) бит отводится под знак числа, остальные
разряды — под само число. Если число положительное, то в знаковый разряд помещается 0, если
отрицательное — 1. Например, в байте можно представить знаковые числа от -128 до 127.

Прямой код числа.

Представление числа в привычной форме «знак»-«величина», при которой старший разряд ячейки
отводится под знак, а остальные — под запись числа в двоичной системе, называется прямым кодом
двоичного числа. Например, прямой код двоичных чисел 1001 и -1001 для 8-разрядной ячейки
равен 00001001 и 10001001 соответственно.
Положительные числа в ЭВМ всегда представляются с помощью прямого кода. Прямой код числа
полностью совпадает с записью самого числа в ячейке машины. Прямой код отрицательного числа
отличается от прямого кода соответствующего положительного числа лишь содержимым знакового
разряда. Но отрицательные целые числа не представляются в ЭВМ с помощью прямого кода, для их
представления используется так называемый дополнительный код.

Дополнительный код числа.

Дополнительный код положительного числа равен прямому коду этого числа. Дополнительный
код отрицательного числа m равен 2k-|m|, где k — количество разрядов в ячейке.
Как уже было сказано, при представлении неотрицательных чисел в беззнаковом формате все
разряды ячейки отводятся под само число. Например, запись числа 243=11110011 в одном байте
при беззнаковом представлении будет выглядеть следующим образом:

1 1 1 1 0 0 1 1

При представлении целых чисел со знаком старший (левый) разряд отводится под знак числа,
и под собственно число остаётся на один разряд меньше. Поэтому, если приведённое выше
состояние ячейки рассматривать как запись целого числа со знаком, то для компьютера в этой
ячейке записано число -13 (243+13=256=28).
Но если это же отрицательное число записать в ячейку из 16-ти разрядов, то содержимое
ячейки будет следующим:

1 1 1 1 1 1 1 1 1 1 1 1 0 0 1 1

Знаковый разряд

Возникает вопрос: с какой целью отрицательные числа записываются в виде дополнительного
кода и как получить дополнительный код отрицательного числа?
Дополнительный код используется для упрощения выполнения арифметических операций.
Если бы вычислительная машина работала с прямыми кодами положительных и отрицательных
чисел, то при выполнении арифметических операций следовало бы выполнять ряд дополнительных
действий. Например, при сложении нужно было бы проверять знаки обоих операндов и определять
знак результата. Если знаки одинаковые, то вычисляется сумма операндов и ей присваивается
тот же знак. Если знаки разные, то из большего по абсолютной величине числа вычитается меньшее
и результату присваивается знак большего числа. То есть при таком представлении чисел (в виде
только прямого кода) операция сложения реализуется через достаточно сложный алгоритм. Если же
отрицательные числа представлять в виде дополнительного кода, то операция сложения, в том числе
и разного знака, сводится к из поразрядному сложению.

Для компьютерного представления целых чисел обычно используется один, два или четыре байта,
то есть ячейка памяти будет состоять из восьми, шестнадцати или тридцати двух разрядов
соответственно.

Алгоритм получения дополнительного кода отрицательного числа.

Для получения дополнительного k-разрядного кода отрицательного числа необходимо

  1. модуль отрицательного числа представить прямым кодом в k двоичных разрядах;
  2. значение всех бит инвертировать:все нули заменить на единицы, а единицы на нули(таким образом, получается k-разрядный обратный код исходного числа);
  3. к полученному обратному коду прибавить единицу.

Пример:
Получим 8-разрядный дополнительный код числа -52:

00110100 - число |-52|=52 в прямом коде
11001011 - число  -52  в обратном коде
11001100 - число  -52  в дополнительном коде

Можно заметить, что представление целого числа не очень удобно изображать в двоичной системе,
поэтому часто используют шестнадцатеричное представление:

1100 1100
 С     С  

Представление вещественных чисел в компьютере.

Для представления вещественных чисел в современных компьютерах принят способ представления
с плавающей запятой. Этот способ представления опирается на нормализованную
(экспоненциальную) запись действительных чисел.
Как и для целых чисел, при представлении действительных чисел в компьютере чаще всего
используется двоичная система, следовательно, предварительно десятичное число должно быть
переведено двоичную систему.

Нормализованная запись числа.

Нормализованная запись отличного от нуля действительного числа — это запись
вида a= m*Pq,
где q — целое число (положительное, отрицательное или ноль), а m — правильная P-ичная дробь,
у которой первая цифра после запятой не равна нулю, то есть
.
При этом m называется мантиссой числа, q — порядком числа.

Примеры:

  1. 3,1415926 = 0, 31415926 * 101;
  2. 1000=0,1 * 104;
  3. 0,123456789 = 0,123456789 * 100;
  4. 0,00001078 = 0,1078 * 8-4; (порядок записан в 10-й системе)
  5. 1000,00012 = 0, 100000012 * 24.

Так как число ноль не может быть записано в нормализованной форме в том виде, в каком она
была определена, то считаем, что нормализованная запись нуля в 10-й системе будет такой:

0 = 0,0 * 100.

Нормализованная экспоненциальная запись числа — это запись вида
a= m*Pq,
где q — целое число (положительное, отрицательное или ноль), а m — P-ичная дробь,
у которой целая часть состоит из одной цифры. При этом (m-целая часть) называется мантиссой
числа, q — порядком числа.

Представление чисел с плавающей запятой.

При представлении чисел с плавающей запятой часть разрядов ячейки отводится для записи порядка
числа, остальные разряды — для записи мантиссы. По одному разряду в каждой группе отводится
для изображения знака порядка и знака мантиссы. Для того, чтобы не хранить знак порядка,
был придуман так называемый смещённый порядок, который рассчитывается по формуле
2a-1+ИП, где a — количество разрядов, отводимых под порядок.

Пример:
Если истинный порядок равен -5, тогда смещённый порядок для 4-байтового числа будет
равен 127-5=122.

Алгоритм представления числа с плавающей запятой.

  1. Перевести число из p-ичной системы счисления в двоичную;
  2. представить двоичное число в нормализованной экспоненциальной форме;
  3. рассчитать смещённый порядок числа;
  4. разместить знак, порядок и мантиссу в соответствующие разряды сетки.

Пример:
Представить число -25,625 в машинном виде с использованием 4 байтового представления
(где 1 бит отводится под знак числа, 8 бит — под смещённый порядок, остальные биты —
под мантиссу).

2510=1000112
0,62510=0,1012

-25,62510= -100011,1012

2. -100011,1012 = -1,000111012 * 24
3. СП=127+4=131
4.

Можно заметить, что представление действительного числа не очень удобно изображать в
двоичной системе, поэтому часто используют шестнадцатеричное представление:

Окончательный ответ: C1CD0000.

Hosted by uCoz

Автор статьи

Сергей Андреевич Дремук

Эксперт по предмету «Информатика»

Задать вопрос автору статьи

В $60$-х и $70$-х гг. не было единопризнанного стандарта представления чисел с плавающей запятой, из-за чего программы того времени не были переносимыми приложениями. Также большой проблемой были «странности» разных компьютеров, которые нужно было знать и учитывать при создании программ.

В $1976$ году была появилась инициатива создать единый стандарт для представления чисел с плавающей запятой, что существенно упростило работу с числами.

Вычисления компьютера ограничены его памятью, поэтому дробная часть вещественных чисел не является бесконечной и хранится в памяти с определенной точностью.

Числа в нормализованном виде чаще всего записываются только на экране компьютера, поэтому принято запятую в них заменять на точку.

Принятый способ хранения вещественных (действительных) чисел в памяти компьютера использует нормализованную (экспоненциальную) запись действительных чисел.

Для хранения вещественных чисел (как и для целых) используется двоичная система. Таким образом, число предварительно должно быть переведено двоичный код.

Нормализованная запись числа

Определение 1

Запись в виде

[a=pm mcdot q^n]

является нормализованной записью отличного от нуля действительного числа,

где $n$ — любое целое число (в том числе и ноль),

$m$ — правильная дробь в системе счисления с основой $q$, у которой первая цифра после запятой не равна нулю, то есть $frac{1}{q}le m

$m$ называется мантиссой числа, $n$ — порядком числа, $q$ — основанием системы счисления.

Пример 1

Приведем числа десятеричной системы к нормализованной записи:

[1.3579=0.13579cdot {10}^1;] [10000=0.1cdot {10}^5;] [0,123456=0.123456cdot {10}^0.]

Приведем число восьмеричной системы счисления к нормализованной записи:

${0,0000119}_8={0.119}_8cdot 8^{-4}$ (порядок записан в десятичной системе).

Приведем число двоичной системы счисления к нормализованной записи:

[{200.002}_2={0.200002}_2cdot 2^{-3}.]

«Хранение в памяти вещественных чисел» 👇

Ноль в десятичной системе будет записан в нормализованном виде следующим образом:

Определение 2

Нормализованная экспоненциальная запись (НЭЗ) числа — это запись в виде

[a=pm mcdot q^n,]

где $n$ — любое целое число (в том числе и ноль),

$m$ — правильная дробь в системе счисления с основой $q$, целая часть которой состоит из одной цифры,

$m$ —мантисса числа, а $n$ — порядок (или экспонента) числа.

Рассмотрим вышеописанные числа в нормализованной экспоненциальной записи.

Пример 2

НЭЗ десятичных чисел:

[1.3579=0.13579cdot {10}^1=1.3579cdot {10}^0;] [10000=0.1cdot {10}^5=1.0cdot {10}^4;] [0.123456=0.123456cdot {10}^0=1.23456cdot {10}^{-1}.]

НЭЗ восьмеричного числа:

[{0.0000119}_8={0.119}_8cdot 8^{-4}={1.19}_8cdot 8^{-5}.]

НЭЗ двоичного числа:

[{200.002}_2={0.200002}_2cdot 2^{-3}={2.00002}_2cdot 2^{-4}.]

Замечание 1

Обратите внимание, что в НЭЗ записи первая цифра после запятой может быть нулём, в отличие от нормализованной записи.

Хранение чисел с плавающей запятой

Для хранения вещественных чисел в памяти компьютера часть разрядов ячейки отводится для записи порядка числа, остальные — для записи мантиссы. По одному разряду в каждой группе разрядов отводится для знака порядка и знака мантиссы. Чтобы не хранить знак порядка был придуман смещенный порядок.

Если для задания порядка выделено k разрядов, то к истинному порядку (ИП) прибавляют смещение, таким образом, смещённый порядок (СП) рассчитывается по формуле:

Пример 3

Найдем смещённый порядок для истинного порядка, лежащего в диапазоне от $-127$ до $+128$.

Возьмем начальное значение ИП= $-127$:

[СП=-127+2^{8-1}-1=-127+128-1=0.]

Возьмем конечное значение ИП = $128$:

[СП=128+2^{8-1}-1=128+128-1=255.]

Таким образом, ИП, лежащий в диапазоне от $-127$ до $+128$, представляется смещённым порядком, значения которого меняются в диапазоне от $0$ до $255$.

Алгоритм представления вещественного числа:

  1. Перевести число в двоичную систему счисления.

  2. Привести число к нормализованной записи.

  3. Найти смещённый порядок числа.

  4. Поместить знак, порядок и мантиссу в соответствующие разряды.

Пример 4

Представим число $-25.625$ в $4$-байтовом представлении ($1$ бит отводится под знак числа, $8$ бит — под смещённый порядок, остальные биты — под мантиссу).

Будем действовать по алгоритму:

  1. Переведем число $-25.625$ в двоичный код:

    Рисунок 1.

    [{25}_{10}={11001}_2]

    Рисунок 2.

    [{25}_{10}={11001}_2] [{0.625}_{10}={0.101}_2] [{-25.625}_{10}={-11001.101}_2]

  2. Приведем число к нормализованному виду:

    [{-11001.101}_2={-1.1001101}_2cdot 2^4]

  3. Найдем смещенный порядок числа:

    [СП=127+4=131]

  4. Поместим знак, порядок и мантиссу в соответствующие разряды:

    Рисунок 3.

Находи статьи и создавай свой список литературы по ГОСТу

Поиск по теме

При выполнении операций с числами в
форматах с плавающей точкой вычисляют
мантиссы и порядки результата. Совокупность
правил и операций, выполняемых над
порядками, называют Арифметикой
порядков
. В их числе сложение и
вычитание, сравнение
порядков, оценка выхода порядка за
границы предельных значений и др.

В этом подразделе рассматривается
арифметика порядков, прежде всего для
распространенного в практике случая,
когда порядок


в формате представлен смещенным
порядком


. (6-16)

Во вводной части раздела 5 рассматриваются
два варианта смещения порядка числа с
плавающей точкой. В первом варианте
смещение

,
а во втором

,
где

– индекс старшего значащего разряда
целого порядка со знаком. Стандарт IEEE
754 применяет

.
В формате одинарной точности при

значение

.
В формате двойной точности

и

.
В специализированных вычислителях, не
удовлетворяющих требованиям стандарта
IEEE 754, может быть выбрано
смещение

.
Тогда при

смещение

.
При


.

При выполнении операций над числами с
плавающей точкой выполняют операции
над смещенными порядками.

6.6.1. Вычисление порядка и смещенного порядка

Исходные данные могут вводиться в ЦВМ
в естественной или нормальной форме в
разных системах счисления и затем
преобразовываться в двоичную систему
счисления с записью в формат с плавающей
точкой со смещенным порядком. До записи
в формат порядок E
представлен, как правило, в прямом
или в дополнительном двоичном коде
числом со знаком. Для записи в формат
необходимо вычислить смещенный порядок


.
При выводе числа из ЦВМ, а иногда с иной
целью, необходимо вычислять порядок E
по значению смещенного порядка

.
При обоих вариантах преобразования
следует поддерживать отношение (6-16), но
с некоторыми оговорками.

В базовых форматах стандарта IEEE
754 (раздел 5.3) отношение (6-16) справедливо,
если число нормализованное и порядок
не выходит за пределы интервала

допустимых значений. Если число
ненормализованное с минимальным
порядком, смещенный порядок


(6-17)

В табл.6.2 приведен прямой, обратный,
дополнительный и смещенные коды порядка
E при длине поля порядка
8 бит.

Сопоставляя смещенный код с прямым,
обратным или дополнительным кодом,
можно выявить закономерности, позволяющие
сформулировать варианты правил их
взаимного преобразования и выбрать то
из них, которое наиболее удобно для
применения в заданных условиях.

Например, из табл.6.2 следует, что
дополнительный код E
отличается от смещенного при

лишь содержимым разряда знака. Из этого
следует, что при их взаимном преобразовании
достаточно инвертировать код в старшем
разряде.

При преобразовании прямого или обратного
кода в смещенный при

достаточно выполнять их преобразования
в дополнительный код (раздел 3.2.1) и
инвертировать разряд знака результата.
При обратном преобразовании инвертировать
старший разряд и полученный дополнительный
код преобразовать в прямой или
дополнительный.

Таблица 6.2

Порядок

E

Прямой

код

Обратный

код

Смещенный

bias=127

Дополн.

код

Смещенный

bias=128

+127

+126

+125

+3

+2

+1

+0

–0

–1

–2

–3

–125

–126

–127

01111111

01111110

01111101

00000011

00000010

00000001

00000000

10000000

10000001

10000010

10000011

11111101

11111110

11111111

01111111

01111110

01111101

00000011

00000010

00000001

00000000

11111111

11111110

11111101

11111100

10000010

10000001

10000000

11111110

11111101

11111100

10000010

10000001

10000000

01111111

01111111

01111110

01111101

01111100

00000010

00000001

00000000

01111111

01111110

01111101

00000011

00000010

00000001

00000000

00000000

11111111

11111110

11111101

10000011

10000010

10000001

11111111

11111110

11111101

10000011

10000010

10000001

10000000

10000000

01111111

01111110

01111101

00000011

00000010

00000001

Для преобразования смещенного кода при

в дополнительный код достаточно к
смещенному коду прибавить константу

,
отбрасывая перенос из старшего разряда.
При обратном преобразовании достаточно
из дополнительного кода вычесть константу

,
отбрасывая заем из старшего разряда,
или прибавить к дополнительному коду
константу

,
отбрасывая перенос из старшего разряда.

Для преобразования смещенного кода при

в прямой код достаточно, если в старшем
разряде смещенного кода 0, инвертировать
все его разряды, иначе прибавить константу

,
отбрасывая перенос из старшего разряда.
При обратном преобразовании, если код
знака 1, инвертировать все разряды,
включая знак, иначе прибавить константу

,
отбрасывая перенос из старшего разряда.

Безусловно, существует множество иных
вариантов преобразования.

При преобразовании порядка E
в смещенный порядок


в формате стандарта IEEE
754 необходимо учитывать, что прямой код
минимально допустимого порядка

,
и если мантисса нормализована, он
преобразуется в смещенный порядок

.
Если мантисса ненормализованная, то
смещенный порядок, соответствующий

,
следует принять равным 00…0. При обратном
преобразовании смещенному порядку


ненормализованного числа соответствует
минимальный порядок E=
1|11…10. Кроме того, необходимо учитывать
особенности представления числа равного
нулю.

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]

  • #
  • #
  • #
  • #
  • #
  • #
  • #
  • #
  • #
  • #
  • #

Слайд 2Пример выполнения КР
представления чисел в соответствии со стандартом IEEE 754:

Пример выполнения КРпредставления чисел в соответствии со стандартом IEEE 754:


Слайд 3Однобитовое поле S (sign — знак) используется для указания знака

числа. Для положительного числа S = 0, для отрицательного S

= 1.
Поле F (fraction). В нем записывается дробная часть мантиссы (fraction). Мантисса наряду с дробной частью содержит целую часть (1 или 0). Бит целой части мантиссы в памяти не хранится для уменьшения объема запоминаемых данных, при отображении данных он автоматически учитывается.
Поле экспоненты (E – exponent), содержит смещённый порядок E=P+Bias. Biass – смещение, выбирается так, чтобы смещённый порядок был положительным или равным нулю.

Однобитовое поле S (sign - знак) используется для указания знака числа. Для положительного числа S = 0,


Слайд 4Сравнительные данные форм в стандарте IEEE 754:

Сравнительные данные форм в стандарте IEEE 754:


Слайд 5Позиционные системы исчисления

Позиционные системы исчисления


Слайд 6Пример №1
Задание 1.
В соответствии с последними цифрами номера зачетной книжки

ABCDEF, представить число ABC,DEF в форматах SP, DP, SEP. Для

каждого формата указать шестнадцатеричный эквивалент полученного результата.

Исходное число
ABC,DEF =405,875

Пример №1Задание 1.В соответствии с последними цифрами номера зачетной книжки ABCDEF, представить число ABC,DEF в форматах SP,


Слайд 7Пример №1
Переведем исходное число в двоичную систему счисления:
405,87510 = 110010101,1112

Нормализуем полученное двоичное число по правилам машинной арифметики.
110010101,1112 = 1,100101011112

× 21000

10002=810

Пример №1Переведем исходное число в двоичную систему счисления:405,87510 = 110010101,1112 Нормализуем полученное двоичное число по правилам машинной


Слайд 8Пример №1
Найдем смещенный порядок. Так как переводим в 32-разрядном представление

SP, то смещение порядка равно 12710. (для перевода в форматы

DP, SEP прибавляем смещение 1023)

E = 810 + 12710 = 10002 + 11111112 = 100001112

Пример №1Найдем смещенный порядок. Так как переводим в 32-разрядном представление SP, то смещение порядка равно 12710. (для


Слайд 9Пример №1
Число положительное, следовательно, в бите знака будет стоять ноль.
Итак,

число 405,87510 в машинном 32-разрадном представлении с плавающей точкой будет

иметь вид:
0 10000111 10010101111000000000000 (жирным шрифтом выделен порядок числа, длина мантиссы — 23 бита).

Пример №1Число положительное, следовательно, в бите знака будет стоять ноль.Итак, число 405,87510 в машинном 32-разрадном представлении с


Слайд 10Пример №1
Преобразуем полученный результат в шестнадцатеричный эквивалент. Для этого исходное

число:
0 10000111 10010101111000000000000
разобьем по четверкам
0100 0011 1100 1010 1111

0000 0000 0000
В соответствии с таблицей перевода:

0100 0011 1100 1010 1111 0000 0000 0000
4 3 C A F 0 0 0
= 43CAF000

Пример №1Преобразуем полученный результат в шестнадцатеричный эквивалент. Для этого исходное число:0 10000111 10010101111000000000000 разобьем по четверкам0100 0011


Слайд 11Пример №1

По аналогии переводим в другие форматы DP и SEP

изменяя на соответствующую мантису.

Пример №1По аналогии переводим в другие форматы DP и SEP изменяя на соответствующую мантису.


Слайд 12Пример № 2
Получить десятичный эквивалент числа формата SP
Исходное число

в формате SP:
0 10000110 00010001010100000000000
Выделяем:
S=0
F= 00010001010100000000000
E = 100001102

Пример № 2Получить десятичный эквивалент числа формата SP Исходное число в формате SP:0 10000110 00010001010100000000000Выделяем:S=0F= 00010001010100000000000E =


Слайд 13Пример № 2

Найдем реальный порядок результата, вычтя из него значение

смещения 12710.(Т.к. число в формате SP смещенный порядок =127)
E =

100001102 — 11111112 = 13410 — 12710 = 710 = 1112

Пример № 2Найдем реальный порядок результата, вычтя из него значение смещения 12710.(Т.к. число в формате SP смещенный


Слайд 14Пример № 2

Следовательно, число результата будет иметь вид:

A =

1,000100010101 × 10111 = 10001000,101012 = 136,6562510

Пример № 2Следовательно, число результата будет иметь вид: A = 1,000100010101 × 10111 = 10001000,101012 = 136,6562510


Понравилась статья? Поделить с друзьями:
  • Как найти источник запаха в доме
  • Как найти умные часы хонор
  • Как составить объявление для подростков
  • Как найти мое образование на госуслугах
  • Как найти жена узбечка