Использование калькулятора для изучения логических функций
Встроенный калькулятор, работающий в режиме «инженерный», позволяет выполнять и соответственно иллюстрировать операции логической арифметики. Эти операции используются в двоичной системе счисления в работе компьютера при обработке информации. В работе инженерного калькулятора используют четыре логических операции: AND, OR, XOR, NOT. Кнопки с соответствующими названиями можно увидеть на панели инженерного калькулятора. Для работы с логическими функциями необходимо перевести числа из десятичной системы счисления в двоичную, используя соответствующую кнопку «Bin». В дальнейшем мы будем называть числа, участвующие в операции операндами. 1. Инверсия (функция отрицания). Отрицание - это логическая функция от одной переменной, которая принимает единичное значение при нулевом значении переменной и наоборот. В программировании операция обозначается NOT (от английского «Не»). Операция позволяет изменять значения всех битов операнда на противоположные. Таблица истинности выглядит следующим образом:
Пример. Выполните операцию логическое «Не» для байта 10101010. Решение. Прежде чем выполнить инверсию для байта необходимо перейти в режим работы в двоичной системе счисления ( кнопка «Bin» ) и указать длину двоичного числа. Длину двоичного числа можно выбрать, используя следующие переключатели: «Byte» - задает длину 8 битов ( байт), «Word» - задает длину 16 битов ( машинное слово ), «Dword» - задает длину 32 битов ( двойное слово ). После выполнения алгоритма получаем результат: «Bin» «Byte» 10101010 «NOT» 01010101. Эта операция унарная, выполняется над одним числом, поэтому после нажатия кнопки «NOT» результат сразу появляется на дисплее. Обратите внимание учащихся на то, что такой результат появляется лишь в том случае, если задана длина двоичного числа в один байт, т.е. включена кнопка «Byte». Если же включена , например, кнопка «Dword», то значащих цифр в ответе будет в четыре раза больше: «Bin» «Dword» 10101010 «NOT» 11111111111111111111111101010101 По умалчиванию все значения введенного операнда, стоящие перед первой слева единицей, приняты за нули. После операции «NOT» значения всех битов операнда изменились на противоположные. 2. Конъюнкция. Логическое умножение - это логическая функция от двух переменных, которая принимает единичное значение при единичных значениях всех переменных. В программировании эту операцию обозначают «AND» ( от английского «и» ). Результат этой операции равен 1, если оба операнда равны 1. В других случаях результат равен 0. Покажем действие функции с помощью таблицы истинности, устанавливающей соответствие между набором всех возможных значений логических переменных и значениями логических функций:
На логический элемент воздействуют два входных сигнала Х1 и Х2. Выходной сигнал Y принимает значения, указанные в третьем столбике таблицы. Проиллюстрируем действие функции с помощью калькулятора. Предложите учащимся набрать на калькуляторе значения, которые могут принимать логические переменные ( столбцы Х1 и Х2), используя команду AND, и сравнить полученный результат с значениями логической функции ( столбец Y). Пример. Объясните результат команды 49 AND 51, представив числа в двоичной системе счисления. Решение. Переведем каждое из чисел 49 и 61 в двоичную систему счисления: 4910 = 1100012 512 = 1111012 В результате логического умножения 110001 AND 111101 получается результат 110001 Если посмотреть на результат операции, то в нем оказываются только те включенные биты (логическая переменная Х1), значения которых совпадают с включенными битами второго порядка ( логическая переменная Х2). Действие этой логической функции применяется в компьютере для фильтрации, чтобы отсеять ненужную информацию. Операция «AND» является бинарной, т.е. в ней участвуют два числа, поэтому для получения ответа надо нажать кнопку «=». Алгоритм набора команд и операндов для этого случая также как и для остальных бинарных операций (OR, XOR) выглядит следующим образом: 110001 «AND» 111101 «=» 110001. 3. Дизъюнкция. Логическое сложение - функция от двух переменных, которая принимает нулевое значение при нулевых значениях всех переменных. В программировании эта операция обозначается союзом «OR» ( от английского «или» ). Результат этой операции равен 1, если хотя бы один из операндов равен 1. Результат будет 0, когда оба операнда равны нулю. Таблица истинности дизъюнкции выглядит следующим образом:
Первая строка таблицы показывает, что результат лишь только тогда равен нулю, когда оба операнда равны нулю. Это позволяет проверить содержимое ячейки: содержит она ноль или нет, т.е. поступает сигнал на логический элемент или нет. Пример. Выполните логическое сложение для следующих байтов 10110001 и 10010100. Решение. В двоичной системе счисления 10110001 «OR» 10010100 «=»10110101 Как видно из результата логическое сложение ничего общего не имеет с операцией сложения двух байтов в двоичной системе счисления. В логических функциях 1 является не числом, а символом, означающим истинную величину, т.е. 1+1=1, а не 1+1=10 для математического сложения в двоичной системе счисления. Выражение 1+1=1 означает, что, если есть две истинные величины, то результат их сложения тоже будет истинной величиной. Для логической функции значение 1 означает «правда», «истина», а значение 0 - это «ложь», «нет». В компьютере логическая функция дизъюнкция используется в программах, где ведется отсчет времени или числа попыток. Если ваше время закончилось или количество попыток исчерпано, то это значит , что с помощью функции «OR» это было обнаружено и действие программы было приостановлено. 3. Отрицание от конъюнкции. Отрицание от конъюнкции (исключающее или ) - это логическая функция от двух переменных, которая принимает нулевое значение при единичных значениях всех переменных. В программировании функция обозначается XOR. Результат операции XOR равен 1, если хотя бы один из операндов равен 1, но не оба вместе. Если оба операнда ( Х1 и Х2 ) равны 1 или 0, то результатом ( Y) будет 0. Таблица истинности для этого случая :
Пример. Выполнить операцию XOR для двух машинных слов 1010101010101111 и 01010101010000, а также к полученному результату и второму операнду. Решение. Алгоритм выполнения действий на калькуляторе выглядит следующим образом: «Bin» «WORD» 1010101010101111 «XOR» 0101010101000011 «=»1111111111101100. Получен результат от операции исключающее «ИЛИ». Применим к нему и ко второму операнду вновь эту операцию: 1111111111101100 «XOR» 0101010101000011 «=»1010101010101111. Как видно из второго результата вновь на дисплее калькулятора появился первый операнд. Из примера видно , что двукратное применение операции позволяет восстановить исходные данные. Работая с текстовым редактором «Microsoft Word» мы часто используем из меню две команды «Отменить» и «Повторить», которые позволяют соответственно отменить действие по вводу текста или вновь восстановить стертый нами текст без каких-либо изменений. Использование этих команд текстового редактора аналогично действию команды «XOR», которая рассмотрена в последнем примере.
|