8th_lecture_2012_UKR_1.ppt
- Количество слайдов: 76
Учбовий курс Інформатика з основами геоінформатики Тема № 8: Арифметичні основи інформаційних технологій (ІТ) (лекція-презентація подається російською мовою)
План лекции: Общие понятия о системе счисления – слайды 3 -12; 1) l l Принципы десятичной системы счисления. Принципы двоичной системы счисления. Какие системы счисления используются в ИТ? - слайды 14 -21; 3) Некоторые арифметические операции в позиционных системах счисления – слайды 23 -42; 4) Представление в ИТ целых чисел – слайды 44 -63; 5) Представление в ИТ вещественных чисел - слайды 65 -76. 2) 2
1. Общие понятия о системе счисления 3
Система счисления — это способ записи чисел с помощью заданного набора специальных знаков (цифр) Существуют позиционные и непозиционные системы счисления. В непозиционных системах вес цифры (т. е. тот вклад, который она вносит в значение числа) не зависит от ее позиции в записи числа. Так, в римской системе счисления в числе ХХХII (тридцать два) вес цифры Х в любой позиции равен просто десяти. В позиционных системах счисления вес каждой цифры изменяется в зависимости от ее положения (позиции) в последовательности цифр, изображающих число. Например, в числе 757, 7 первая семерка означает 7 сотен, вторая – 7 единиц, а третья – 7 десятых долей единицы. 4
Ø Ø Ø Ø Сама же запись числа 757, 7 означает сокращенную запись выражения 700 + 50 + 7 + 0, 7 = 7 • 102 + 5 • 101 + 7 • 100 + 7 • 10 -1 = 757, 7. Любая позиционная система счисления характеризуется своим основанием. Основание позиционной системы счисления — это количество различных знаков или символов, используемых для изображения цифр в данной системе. За основание системы можно принять любое натуральное число — два, три, четыре и т. д. Следовательно, возможно бесчисленное множество позиционных систем: двоичная, троичная, четверичная и т. д. Запись чисел в каждой из систем счисления с основанием q означает сокращенную запись выражения an-1 qn-1 + an-2 qn-2+. . . + a 1 q 1 + a 0 q 0 + a-1 q-1 +. . . + a-m q-m, где ai – цифры системы счисления; n и m – число целых и дробных разрядов, соответственно. 5
Ø Ø Ø Как порождаются целые числа в позиционных системах счисления? В каждой системе счисления цифры упорядочены в соответствии с их значениями: 1 больше 0, 2 больше 1 и т. д. Продвижением цифры называют замену её следующей по величине. Продвинуть цифру 1 значит заменить её на 2, продвинуть цифру 2 значит заменить её на 3 и т. д. Продвижение старшей цифры (например, цифры 9 в десятичной системе) означает замену её на 0. В двоичной системе, использующей только две цифры – 0 и 1, продвижение 0 означает замену его на 1, а продвижение 1 – замену её на 0. Целые числа в любой системе счисления порождаются с помощью Правила счета: Для образования целого числа, следующего за любым данным целым числом, нужно продвинуть самую правую цифру числа; если какая-либо цифра после продвижения стала нулем, то нужно продвинуть цифру, стоящую слева от неё. Применяя это правило, запишем первые десять целых чисел (давайте самостоятельно!): 6
Ø в двоичной системе: 0, 1, 10, 11, 100, 101, 110, 111, 1000, 1001; Ø в троичной системе: 0, 1, 2, 10, 11, 12, 20, 21, 22, 100; Ø в пятеричной системе: 0, 1, 2, 3, 4, 10, 11, 12, 13, 14; Ø восьмеричной системе: 0, 1, 2, 3, 4, 5, 6, 7, 10, 11. 7
Принципы десятичной системы счисления Ø Ø Ø Число 2358765. Каждая из цифр в данном числе несет двойную информацию: во-первых, свое собственное значение - 2, 3, 5. А во-вторых место (позицию), которое занимает в записи числа (т. е. разряд). Такие системы счисления, как мы уже говорили, называют позиционными. Число разбивается на разряды: 2 х1000000 + 3 х100000 + 5 х100000 + 8 х1000 + 7 х100 + 6 х10 + 5 х1. Римская система непозиционная, а аддитивная, поскольку число образуется при сложении и вычитании значений специальных значков. MCMXCVI = 1000 + (1000 - 100) + 90 + 6 = 1996 Выполнять арифметические действия с этими числами безнадежно. 8
Принципы двоичной системы счисления Ø Ø Ø Язык компьютера - это язык двоичных чисел, алфавит которых состоит всего из двух цифр - 0 и 1. Двоичная система наиболее проста и удобна для автоматизации. Наличие в системе всего лишь двух символов упрощает их преобразование в электрические сигналы. Символы двоичной системы можно передавать и записывать с помощью электрического тока, например, меняя продолжительность его протекания по цепи: коротко точка, длиннее - тире, как в азбуке Морзе. При записи числа в различных системах счисления пользуются указателями оснований используемых систем. Это может быть справа внизу маленькая цифра или в конце буква латинского алфавита D, B, H, O: D (desimal) - десятичный; B (binary) - двоичный; H (hexadcimal) - шестнадцатиричный; 9 O (octal) - восьмеричный.
Принципы двоичной системы счисления (продолжение) 10
Принципы двоичной системы счисления (продолжение) Ø Ø Ø Двоичная система, как и обычная десятичная, по своей структуре относится к позиционным системам счисления. Значение любого числа определяется не только его разрядностью, количеством позиций, но также "весовым значением" и алфавитом системы счисления. Весовое значение позиций зависит от основания системы (т. е. разряда). Для того чтобы перевести десятичное число в двоичное, достаточно знать структуру кода и весовые значения разрядов. Они возрастают справа налево в порядке возрастания номеров разрядов: 1, 2, 4, 8, 16. . . Пример 1: Десятичное число 7 представляется суммой трех весовых значений младших разрядов: 4, 2, 1. 7 D = 4 + 2 + 1 В соответствии с этим обозначаем единицы в правых трех разрядах: 7 D = 111 B или 7 D = 00000111 B. Последняя запись эквивалентная (ноль всегда ноль!). Число 13 в двоичной форме будет иметь вид 00001101. 11
Принципы двоичной системы счисления (окончание) Ø Ø Ø Наибольшее десятичное число, которое можно представить 8 -разрядным двоичным числом, 256, а 16 -разрядным - 65536 (соответственно 28 и 216). Точно так же кодируются и дробные числа. Для этого важно учитывать, что весовые значения разрядов дробной части числа уменьшаются после запятой в следующем порядке: 0, 5; 0, 25; 0, 125; и т. д. Так, дробному числу 7, 125 соответствует двоичный код 00000111, 0010000. Пример 2: Двоичное число 111010 представляется в десятичной форме как сумма весов единиц разрядов 1 1 1 0 1 0 32 + 16 + 8 + 0 + 2 + 0 = 58 D Простые алгоритмы перевода чисел из десятичной системы в двоичную мы будем рассматривать на следующих слайдах. 12
2. Какие системы счисления используются в ИТ? 13
Ø Итак, кроме десятичной широко используются системы с основанием, являющимся целой степенью числа 2, а именно: Ø двоичная (используются цифры 0, 1); Ø восьмеричная (используются цифры 0, 1, . . . , 7); Ø шестнадцатеричная (для первых целых чисел от нуля до девяти используются цифры 0, 1, . . . , 9, а для следующих чисел — от десяти до пятнадцати – в качестве цифр используются символы A, B, C, D, E, F). 14
Почему люди пользуются десятичной системой, а компьютеры — двоичной? Ø Ø Ø Люди предпочитают десятичную систему, вероятно, потому, что с древних времен считали по пальцам, а пальцев у людей по десять на руках и ногах. Не всегда и не везде люди пользуются десятичной системой счисления. В Китае, например, долгое время пользовались пятеричной системой счисления. А компьютеры используют двоичную систему потому, что она имеет ряд преимуществ перед другими системами: для ее реализации нужны технические устройства с двумя устойчивыми состояниями (есть ток — нет тока, намагничен — не намагничен и т. п. ), а не, например, с десятью, — как в десятичной; представление информации посредством только двух состояний надежно и помехоустойчиво; возможно применение аппарата булевой алгебры для выполнения логических преобразований информации; двоичная арифметика намного проще десятичной. 15
Ø Ø Использование в компьютерах восьмеричной и шестнадцатеричной систем счисления Двоичная система, удобная для компьютеров, для человека неудобна из-за ее громоздкости и непривычной записи. Перевод чисел из десятичной системы в двоичную и наоборот выполняет машина. Однако, чтобы профессионально использовать компьютер, следует научиться понимать слово машины. Для этого и разработаны восьмеричная и шестнадцатеричная системы. Числа в этих системах читаются почти так же легко, как десятичные, требуют соответственно в три (восьмеричная) и в четыре (шестнадцатеричная) раза меньше разрядов, чем в двоичной системе (ведь числа 8 и 16 – соответственно, третья и четвертая степени числа 2). Перевод восьмеричных и шестнадцатеричных чисел в двоичную систему очень прост: достаточно каждую цифру заменить эквивалентной ей двоичной триадой (тройкой цифр) или тетрадой (четверкой цифр). Например: Ø 16
Ø Чтобы перевести число из двоичной системы в восьмеричную или шестнадцатеричную, его нужно разбить влево и вправо от запятой на триады (для восьмеричной) или тетрады (для шестнадцатеричной) и каждую такую группу заменить соответствующей восьмеричной (шестнадцатеричной) цифрой. Например: 17
Как перевести целое число из десятичной системы в любую другую позиционную систему счисления? При переводе целого десятичного числа в систему с основанием q его необходимо последовательно делить на q до тех пор, пока не останется остаток, меньший или равный q– 1. Число в системе с основанием q записывается как последовательность остатков от деления, записанных в обратном порядке, начиная с последнего. Ø Пример: Перевести число 75 из десятичной системы в двоичную, восьмеричную и шестнадцатеричную: Ø 18
Какие системы счисления используются в компьютерах? (продолжение) Ø в двоичную; в восьмеричную; в шестнадцатеричную Ответ = 7510=10010112=1138=4 B 19
Как пеpевести пpавильную десятичную дpобь в любую другую позиционную систему счисления? Пpи переводе правильной десятичной дpоби в систему счисления с основанием q необходимо сначала саму дробь, а затем дробные части всех последующих произведений последовательно умножать на q, отделяя после каждого умножения целую часть пpоизведения. Ø Число в новой системе счисления записывается как последовательность полученных целых частей пpоизведения. Умножение пpоизводится до тех поp, пока дpобная часть пpоизведения не станет pавной нулю. Это значит, что сделан точный пеpевод. В пpотивном случае пеpевод осуществляется до заданной точности. Достаточно того количества цифp в pезультате, котоpое поместится в ячейку. Ø 20
Пример перевода десятичных дробей: 21
3. Некоторые арифметические операции в позиционных системах счисления 22
Как пеpевести число из двоичной (восьмеpичной, шестнадцатеpичной) системы в десятичную? Ø При переводе числа из двоичной (восьмеричной, шестнадцатеричной) системы в десятичную надо это число представить в виде суммы степеней основания его системы счисления. 23
Сводная таблица переводов целых чисел из одной системы счисления в другую Рассмотрим только те системы счисления, которые применяются в компьютерах — десятичную, двоичную, восьмеричную и шестнадцатеричную. Ø Для определенности возьмем произвольное десятичное число, например 46, и для него выполним все возможные последовательные переводы из одной системы счисления в другую. Ø Порядок переводов определим в соответствии с иллюстрацией. На этом рисунке использованы следующие обозначения: Ø в кружках записаны основания систем счисления; Ø стрелки указывают направление перевода; Ø номер рядом со стрелкой означает порядковый номер соответствующего примера в сводной таблице на двух следующих слайдах: Ø 24
Сводная таблица переводов целых чисел (начало): Например: означает перевод из двоичной системы в шестнадцатеричную, имеющий в таблице порядковый номер 6. 25
Сводная таблица переводов целых чисел (окончание): 26
Как производятся арифметические операции в позиционных системах счисления? Рассмотрим основные арифметические операции: сложение, вычитание, умножение и деление. Правила выполнения этих операций в десятичной системе хорошо известны — это сложение, вычитание, умножение столбиком и деление углом. Эти правила применимы и ко всем другим позиционным системам счисления. Только таблицами сложения и умножения надо пользоваться особыми для каждой системы. Ø Итак – сложение: Ø Таблицы сложения легко составить, используя Правило Счета. Ø 27
Таблицы сложения в двоичной и восьмеричной системах 28
Таблица сложения в шестнадцатиричной системе 29
При сложении цифры суммируются по разрядам, и если при этом возникает избыток, то он переносится влево. Пример 1. Сложим числа 15 и 6 в различных системах счисления. 30
Ответ: 15+6 = 2110 = 101012 = 258 = 1516. 31
Пример 2. Сложим числа 15, 7 и 3. 32
Ответ: 5+7+3 = 2510 = 110012 = 318 = 1916. 33
Пример 3. Сложим числа 141, 5 и 59, 75. 34
Ответ: 141, 5 + 59, 75 = 201, 2510 = 11001001, 012 = 311, 28 = C 9, 416 35
Вычитание 36
Вычитание (продолжение) 37
Умножение Ø Выполняя умножение многозначных чисел в различных позиционных системах счисления, можно использовать обычный алгоритм перемножения чисел в столбик, но при этом результаты перемножения и сложения однозначных чисел необходимо заимствовать из соответствующих рассматриваемой системе таблиц умножения и сложения. 38
Умножение (продолжение) 39
Умножение (продолжение): Ввиду чрезвычайной простоты таблицы умножения в двоичной системе, умножение сводится лишь к сдвигам множимого и сложениям. 40
Деление: Деление в любой позиционной системе счисления производится по тем же правилам, как и деление углом в десятичной системе. В двоичной системе деление выполняется особенно просто, ведь очередная цифра частного может быть только нулем или единицей. 41
Деление (продолжение): 42
4. Представление в ИТ целых чисел 43
Как представляются в компьютерах целые числа? Целые числа могут представляться в компьютере со знаком или без знака. Ø Целые числа без знака обычно занимают в памяти один или два байта и принимают в однобайтовом формате значения от 00002 до 11112 , а в двубайтовом формате — от 000000002 до 111111112. Ø 44
Примеры представления целых чисел без знака 45
Представление целых чисел со знаком Ø Целые числа со знаком обычно занимают в памяти компьютера один, два или четыре байта, при этом самый левый (старший) разряд содержит информацию о знаке числа. Знак “плюс” кодируется нулем, а “минус” — единицей. 46
Рассмотрим особенности записи целых чисел со знаком на примере однобайтового формата, при котором для знака отводится один разряд, а для цифр абсолютной величины – семь разрядов. Ø В компьютерной технике применяются три формы записи (кодирования) целых чисел со знаком: прямой код, обратный код, дополнительный код. Последние две формы применяются особенно широко, так как позволяют упростить конструкцию арифметико-логического устройства компьютера путем замены разнообразных арифметических операций операцией cложения. 47
Прямой код. В знаковый разряд помещается цифра 1, а в разряды цифровой части числа — двоичный код его абсолютной величины. Ø Например: Ø 48
Обратный код Ø Обратный код. Получается инвертированием всех цифр двоичного кода абсолютной величины числа, включая разряд знака: нули заменяются единицами, а единицы — нулями. Например: 49
Дополнительный код Ø Дополнительный код. Получается образованием обратного кода с последующим прибавлением единицы к его младшему разряду. Например: Обычно отрицательные десятичные числа при вводе в машину автоматически преобразуются в обратный или дополнительный двоичный код и в таком виде хранятся, перемещаются и участвуют в операциях. При выводе таких чисел из машины происходит обратное преобразование в отрицательные десятичные числа. 50
Арифметические действия в ИТ над целыми числами: сложение и вычитание Ø В большинстве компьютеров операция вычитания не используется. Вместо нее производится сложение уменьшаемого с обратным или дополнительным кодом вычитаемого. Это позволяет существенно упростить конструкцию АЛУ. Ø При сложении обратных кодов чисел А и В имеют место четыре основных и два особых случая: 51
Ø 1. А и В положительные. При суммировании складываются все разряды, включая разряд знака. Так как знаковые разряды положительных слагаемых равны нулю, разряд знака суммы тоже равен нулю. Например: 52
Ø 2. А положительное, B отрицательное и по абсолютной величине больше, чем А. Например: 53
Ø 3. А положительное, B отрицательное и по абсолютной величине меньше, чем А. Например: 54
Ø 4. А и В отрицательные. Например: 55
5. А и В положительные, сумма А+В больше, либо равна 2 n– 1, где n – количество разрядов формата чисел (для однобайтового формата n=8, 2 n– 1 = 27 = 128). Например: Ø Семи разрядов цифровой части числового формата недостаточно для размещения восьмиразрядной суммы (16210 = 101000102), поэтому старший разряд суммы оказывается в знаковом разряде. Это вызывает несовпадение знака суммы и знаков слагаемых, что является свидетельством переполнения разрядной сетки. 56
6. А и В отрицательные, сумма абсолютных величин А и В больше, либо равна 2 n– 1. Например: Ø Здесь знак суммы тоже не совпадает со знаками слагаемых, что свидетельствует о переполнении разрядной сетки. 57
Сложение дополнительных кодов чисел: имеют место все указанные выше случаи Ø 1. А и В положительные. Здесь нет отличий от случая 1, рассмотренного для обратного кода. Ø 2. А положительное, B отрицательное и по абсолютной величине больше, чем А. Например: Получен правильный результат в дополнительном коде. При переводе в прямой код биты цифровой части результата инвертируются и к младшему разряду прибавляется единица: 1 0000110 + 1 = 1 0000111 = – 7 10. 58
3. А положительное, B отрицательное и по абсолютной величине меньше, чем А. Например: Ø Получен правильный результат. Единицу переноса из знакового разряда компьютер отбрасывает. 59
4. А и В отрицательные. Например: Получен правильный результат в дополнительном коде. Единицу переноса из знакового разряда компьютер отбрасывает. Ø Случаи переполнения для дополнительных кодов рассматриваются по аналогии со случаями 5 и 6 для обратных кодов. Ø 60
Сравнение рассмотренных форм кодирования целых чисел со знаком показывает: на преобразование отрицательного числа в обратный код компьютер затрачивает меньше времени, чем на преобразование в дополнительный код, так как последнее состоит из двух шагов — образования обратного кода и прибавления единицы к его младшему разряду; Ø время выполнения сложения для дополнительных кодов чисел меньше, чем для их обратных кодов, потому что в таком сложении нет переноса единицы из знакового разряда в младший разряд результата. Ø 61
Умножение и деление Ø Во многих компьютерах умножение производится как последовательность сложений и сдвигов. Для этого в АЛУ имеется регистр, называемый накапливающим сумматором, который до начала выполнения операции содержит число ноль. В процессе выполнения операции в нем поочередно размещаются множимое и результаты промежуточных сложений, а по завершении операции — окончательный результат. Ø Другой регистр АЛУ, участвующий в выполнении этой операции, вначале содержит множитель. Затем по мере выполнения сложений содержащееся в нем число уменьшается, пока не достигнет нулевого значения. 62
Для иллюстрации умножим 1100112 на 1011012. Ø Деление для компьютера является трудной операцией. Обычно оно реализуется путем многократного прибавления к делимому дополнительного кода делителя. 63
5. Представление в ИТ вещественных чисел 64
Представление в компьютере вещественных чисел При их написании вместо запятой принято писать точку. Так, например, число 5 — целое, а числа 5. 1 и 5. 0 — вещественные. Ø Для удобства отображения чисел, принимающих значения из достаточно широкого диапазона (то есть, как очень маленьких, так и очень больших), используется форма записи чисел с порядком основания системы счисления. Например, десятичное число 1. 25 можно в этой форме представить так: Ø 1. 25*100 = 0. 125*101 = 0. 0125*102 =. . . , или так: Ø 12. 5*10– 1 = 125. 0*10– 2 = 1250. 0*10– 3 =. . Ø 65
Любое число N в системе счисления с основанием q можно записать в виде N = M * qp, где M называется мантиссой числа, а p — порядком. Такой способ записи чисел называется представлением с плавающей точкой Ø Если “плавающая” точка расположена в мантиссе перед первой значащей цифрой, то при фиксированном количестве разрядов, отведённых под мантиссу, обеспечивается запись максимального количества значащих цифр числа, то есть максимальная точность представления числа в машине. Из этого следует: Такое, наиболее выгодное для компьютера, представление вещественных чисел называется нормализованным. Мантиссу и порядок q-ичного числа принято записывать в системе с основанием q, а само основание — в десятичной системе. 66
Примеры нормализованного представления вещественных чисел: Десятичная система Двоичная система 753. 15 = 0. 75315*103; -101. 01 = -0. 10101*211 (порядок 11 2 = 310) -0. 000034 = -0. 34*10 -4; -0. 000011 = 0. 11*2 -100 (порядок -100 2 = -410) Ø Ø Вещественные числа в компьютерах различных типов записываются по-разному. При этом компьютер обычно предоставляет программисту возможность выбора из нескольких числовых форматов наиболее подходящего для конкретной задачи — с использованием четырех, шести, восьми или десяти байтов. 67
В качестве примера приведем характеристики форматов вещественных чисел, используемых IBM-совместимыми персональными компьютерами: Ø Из этой таблицы видно, что форма представления чисел с плавающей точкой позволяет записывать числа с высокой точностью и из весьма широкого диапазона. 68
При хранении числа с плавающей точкой отводятся разряды для мантиссы, порядка, знака числа и знака порядка: Чем больше разрядов отводится под запись мантиссы, тем выше точность представления числа. Ø Чем больше разрядов занимает порядок, тем шире диапазон от наименьшего отличного от нуля числа до наибольшего числа, представимого в машине при заданном формате. Ø 69
Примеры записи некоторых чисел в нормализованном виде в четырехбайтовом формате с семью разрядами для записи порядка 70
Как компьютер выполняет арифметические действия над нормализованными числами? К началу выполнения арифметического действия операнды операции помещаются в соответствующие регистры АЛУ. Ø Ø Сложение и вычитание При сложении и вычитании сначала производится подготовительная операция, называемая выравниванием порядков. Ø В процессе выравнивания порядков мантисса числа с меньшим порядком сдвигается в своем регистре вправо на количество разрядов, равное разности порядков операндов. После каждого сдвига порядок увеличивается на единицу. 71
Действия над нормализованными числами: сложение и вычитание (продолжение): Ø Пример 1. Сложить двоичные нормализованные числа 0. 10111 • 2– 1 и 0. 11011*210. Разность порядков слагаемых здесь равна трем, поэтому перед сложением мантисса первого числа сдвигается на три разряда вправо: 72
Действия над нормализованными числами: сложение и вычитание (продолжение): Ø Пример 2. Выполнить вычитание двоичных нормализованных чисел 0. 10101*210 и 0. 11101*21. Разность порядков уменьшаемого и вычитаемого здесь равна единице, поэтому перед вычитанием мантисса второго числа сдвигается на один разряд вправо. Результат получился не нормализованным, поэтому его мантисса сдвигается влево на два разряда с соответствующим уменьшением порядка на две единицы: 0. 1101*20. : 73
Действия над нормализованными числами: умножение Ø При умножении двух нормализованных чисел их порядки складываются, а мантиссы перемножаются. Ø Пример 3. Выполнить умножение двоичных нормализованных чисел: (0. 11101*2101)*(0. 1001*211) = (0. 11101*0. 1001)* 2(101+11) = 0. 100000101*21000. 74
Действия над нормализованными числами: деление При делении двух нормализованных чисел из порядка делимого вычитается порядок делителя, а мантисса делимого делится на мантиссу делителя. Затем в случае необходимости полученный результат нормализуется. Ø Пример 4. Выполнить деление двоичных нормализованных чисел: 0. 1111*2100 : 0. 101*211 = (0. 1111 : 0. 101) * 2(100– 11) = 1. 1*21 = 0. 11 • 210. Использование представления чисел с плавающей точкой существенно усложняет схему арифметико-логического устройства. Ø 75
Thank you for your interest in arithmetic! 76
8th_lecture_2012_UKR_1.ppt