Принципы организации баз данных 3 страница

1000012 11000012 сумма

отбрасываемая единица

Целые числа в математике и их аналоги в n-разрядных арифметиках тождественны (по количеству) в рамках их представления с этой разрядностью. При этом можно отметить основные отличия представления чисел в поле памяти человека и в поле памяти n-разрядной арифметики:

1. Бесконечное и счетное множество целых чисел представляется отрезком [–N; +N], где N – максимальное число, представимое в этой арифметике (многоточие – общее число единиц, равное n): N = (111…1)2;

2. Бесконечное и несчетное множество действительных чисел принципы организации баз данных 3 страница - student2.ru , располагающееся на числовой оси равномерно и плотно, представляется в n-разрядной арифметике множеством с неравномерной плотностью (сгущение у нуля и сжатость со стороны меньших чисел);

3. Нуль во множестве действительных чисел в любой своей окрестности имеет множество чисел, а нуль в n-разрядной арифметике представлен изолированно.

С точки зрения обычной арифметики, например, в интервале (–1; 1) имеется бесконечное множество "плотно" расположенных точек, причем в любой окрестности каждой такой точки имеется хотя бы одна точка из этого множества. Такую арифметику называют часто регулярной арифметикой. Машинная же арифметика имеет следующие особенности. Она нерегулярна – точки интервала сгущаются около нуля; кроме того, в этом интервале точка х "изолирована" – если взять любую ее окрестность (х–а; х+а), где а – число, которое не превосходит машинного нуля (наименьшего представимого в машине числа), то в этом интервале нет других точек (отличных от х). Говоря языком теории вероятности, плотности распределения чисел в регулярной и нерегулярной арифметике – различны, как, впрочем, плотности распределения целых и вещественных чисел в одной и той же арифметике.

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

Различия в представлении чисел в обычной и в машинной (n-разрядной) арифметике ограничивают как "математические" возможности компьютера, так и "компьютерные" возможности математики, использование математических методов, алгоритмов в компьютерах.

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

Так как диапазон n-разрядных чисел системы счисления с основанием p находится в пределах принципы организации баз данных 3 страница - student2.ru , то для представления дробных чисел этот диапазон еще снижается, поскольку часть разрядов необходимо отвести под изображение мантиссы. Таким образом, имеются так называемые "зоны нечувствительности" форм представления чисел в n-разрядных арифметиках.

В 1937 году Конрадом Цузе для увеличения диапазона чисел, представимых в арифметике двоичных чисел, а также для повышения точности этого представления чисел было предложено представление чисел в плавающей, нормализованной форме – число x представляется в виде: принципы организации баз данных 3 страница - student2.ru , где m – мантисса числа, k – целый порядок числа, принципы организации баз данных 3 страница - student2.ru .

Пусть даны два числа: принципы организации баз данных 3 страница - student2.ru и принципы организации баз данных 3 страница - student2.ru (k > l). Тогда можно проверить, что результаты выполнения операций будут равны:

принципы организации баз данных 3 страница - student2.ru

Если из n разрядов, отводимых под изображение чисел, m двоичных разрядов отвести под мантиссу, k – под порядок, один разряд – под знак числа и один разряд – под знак порядка (например, 0 – плюс, 1 – минус), то диапазон представимых в форме с плавающей запятой чисел резко увеличивается – m + k + 2 = n (многоточие соответствует k единицам):

принципы организации баз данных 3 страница - student2.ru .

Числа, меньшие нижней границы положительных чисел и большие верхней границы отрицательных чисел, считаются равными нулю, не различаются между собой. Числа, большие верхней границы положительных чисел, полагаются равными положительной бесконечности (меньшие нижней границы отрицательных – отрицательной бесконечности). Сравнение двух разных по величине чисел в арифметике с ограниченной разрядностью может, поэтому, приводить к неверному результату, как и сравнение двух равных в таких системах чисел с точки зрения математической.

Такое представление очень удобно для хранения в ЭВМ, так как на самом деле необходимо хранить не само число, а его знак, мантиссу, порядок и знак порядка, и все операции с числами сводятся к операциям с этими объектами. Операции же с этими объектами просты: сравнение знаков, увеличение, уменьшение порядка, сложение мантисс, нормализация, то есть в конечном итоге сводятся к достаточно просто реализуемым операциям сдвига, выравнивания, сравнения разрядов.

Пример. Вычислить наибольшее и наименьшее 5-разрядное целое число в системе счисления с основанием 3. Наибольшее целое n-разрядное число, которое возможно записать в системе счисления с основанием р, равно:

принципы организации баз данных 3 страница - student2.ru .

Наименьшее целое n-разрядное число в этой системе равно

принципы организации баз данных 3 страница - student2.ru

Таким образом, в системе счисления с основанием 3 и числом разрядов 5 представим диапазон следующих чисел:

принципы организации баз данных 3 страница - student2.ru .

Формулам можно придать более компактный вид. Например, для двоичной системы принципы организации баз данных 3 страница - student2.ru

принципы организации баз данных 3 страница - student2.ru ,

а в восьмеричной системе счисления эти числа

принципы организации баз данных 3 страница - student2.ru .

К "неудобствам" этой формы представления чисел можно отнести возможность возникновения следующих "особо опасных" ситуаций:

1. если число достаточно мало, например, а = 0.12Е+00, то оно может быть представлено любым числом из наименьшего интервала включающего а, в частности числом 0.120000001 или 0.199999999 и в этом случае сравнивать на равенство "в лоб" нельзя (вещественные числа в форме с плавающей запятой опасно сравнивать на совпадение);

2. порядок выполнения операций может влиять на результат, например, в 4-разрядной арифметике с фиксированной запятой 20.0000 + 0.0001 = 20.0001, но при этом 0.2000Е+02 + 0.1000Е–05 = 0.2000Е+02;

3. может возникнуть так называемая ситуация "переполнения порядка" при сложении (умножении) очень больших чисел или "исчезновения порядка" при сложении (умножении) "очень малых чисел", в частности, 0.6000Е+39 × 0.1200Е+64 = 0.9999Е + 99 (или же не определено), а также 0.6000Е–35 × 0.0200Е–65 = 0.9999Е–99 (или же не определено), при соответствующим образом определенной разрядности десятичной арифметики;

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

Есть много различных способов (часто искусственных) формирования систем чисел.

Пример. В факториальной системе счисления целые числа записывают линейной комбинацией факториалов, например, принципы организации баз данных 3 страница - student2.ru . Эта система (условно) позиционна. Так как 0! = 1! = 1, то два младших разряда n-разрядного числа принципы организации баз данных 3 страница - student2.ru в разложении этого числа по факториалам представимы как принципы организации баз данных 3 страница - student2.ru и поэтому веса этих разрядов не зависят от позиции (поэтому при принципы организации баз данных 3 страница - student2.ru это число можно считать непозиционным лишь условно). Формула перевода из факториальной системы счисления в десятичную систему:

принципы организации баз данных 3 страница - student2.ru .

История развития систем счисления достаточно интересна. Приведем лишь некоторые факты. Счет вначале велся с помощью пальцев рук (пятерками и затем – десятками). В некоторых странах сохранился счет с основанием 12 (например, Великобритания – 12 шиллингов) и 20 (например, Франция – "quatre–vingts" или "четыре-двадцать" то есть 80; у древних адыгов счет велся аналогично: "тощIищ", то есть "двадцать-три" – 60) и др.

Более подробно о системах счисления, правилах перевода и арифметических операциях в них можно ознакомиться в методических указаниях:

Барилов И. В. Арифметические и логические основы ЭВМ: Пособие / И. В. Барилов, И. В. Москаленко, В. И. Науменко. – Шахты: Изд-во ЮРГУЭС, 2005.– 32с

5 Лекция: Высказывания и предикаты

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

принципы организации баз данных 3 страница - student2.ru

Информатика, как было рассмотрено выше, изучает знаковые (алфавитные) системы. Алгебра – наиболее адекватный математический аппарат описания действий в них, поэтому алгебраический аппарат наилучшим образом подходит для описания информационных систем общей природы, отвлеченно от их предметной направленности. Информационные процессы хорошо формализуются с помощью различных алгебраических структур.

Алгеброй A называется некоторая совокупность определенных элементов X, с заданными над ними определенными операциями f (часто определяемые по сходству с операциями сложения и умножения чисел), которые удовлетворяют определенным свойствам – аксиомам алгебры.

Операция f называется n-местной, если она связывает n операндов (объектов – участников этой операции).

Совокупность операций алгебры A называется ее сигнатурой, а совокупность элементов алгебры – носителем алгебры.

Утверждение (высказывательная форма) – основная единица, неделимая с точки зрения отражения смысла информации (семантики).

Высказывание – некоторое повествовательное утверждение, про которое можно однозначно сказать ("сразу посмотрев на него"), истинно оно или ложно. Эти два значения всевозможных высказываний обозначаются "истина" и "ложь", "true" и "fаlse" или "1" и "0".

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

Пример. Рассмотрим словосочетания:

1. Москва – столица США.

2. Житель города Москва.

3. 5 – 7 + 8.

4. 5 – 9 + 28 = 4.

5. В пятую неделю зимы было очень холодно.

6. В Антарктиде живут тигры.

Высказывание должно быть однозначно истинным или однозначно ложным, поэтому высказываниями являются только утверждения 1), 4), 6).

Пример. Не является высказыванием и "парадокс лжеца" (Эвбулид, учитель Демосфена, около 350 лет до н.э.): "То, что я сейчас утверждаю, – ложно", ибо если оно истинно – то оно ложно, а если допустить, что оно ложно, то оно истинно. Это неопределенная высказывательная форма. Аналогичный пример принадлежит известному математику, логику Гёделю (1931 г.): "То, что утверждается в этом предложении, не может быть доказано". Если его можно опровергнуть, то его нельзя доказать, а если его можно опровергнуть, то его можно доказать. Предложения такого рода не могут быть доказаны или опровергнуты в пределах того языка (той теории, алгебры), с помощью которой они сформулированы. Известны многие подобные парадоксы.

Рассматривая высказывания, мы не обращаем внимания на их внутреннюю структуру и можем разлагать их на структурные части, равно как и объединять их.

Пример. Построим из ниже заданных простых высказываний составные, сложные высказывания, принимающие значение "истина", "ложь":

1. "Зима – холодное время года".

2. "Пальто – теплая одежда".

3. "Камин – источник тепла".

Истинным будет, например, сложное высказывание: "Зима – холодное время года и зимой носят пальто", а ложным будет, например, высказывание: "Некоторые ходят в пальто, поэтому на улице зима". Придумайте другие примеры.

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

Простые высказывания или предикаты не зависят от других высказываний или предикатов ("не разбиваемых на более простые"), а сложные – зависит хотя бы от двух простых.

Пример. Выражение "х = у" – предикат, "х > 5" – предикат, а "7 > 5" – высказывание. Утверждение "Хорошо" не является высказыванием, утверждение "Оценка студента А по информатике – хорошая" – простое высказывание, утверждение "Вчера была ясная погода, я был вчера на рыбалке" – сложное высказывание, состоящее из двух простых.

Логической (булевой) функцией f(х) называется некоторая функциональная зависимость, в которой аргумент х – логическая переменная с заданным множеством изменений аргумента, а значения функции f(x) берутся из двухэлементного множества R(f) = {1,0}.

Пример. Заданы предикаты вида р = "число х делится нацело на 3" и q = "у – день недели". Найдем множество истинности предикатов р и q, если

принципы организации баз данных 3 страница - student2.ru ,

принципы организации баз данных 3 страница - student2.ru . Получаем, что. принципы организации баз данных 3 страница - student2.ru

Множество логических переменных принципы организации баз данных 3 страница - student2.ru с определенными над ним операциями: принципы организации баз данных 3 страница - student2.ru – отрицания или инверсии (логическое «не»), принципы организации баз данных 3 страница - student2.ru – логического сложения или дизъюнкции (логическое «или»), принципы организации баз данных 3 страница - student2.ru – логического умножения или конъюнкции (логическое «и») называется алгеброй предикатов (и высказываний), если эти операции удовлетворяют следующим аксиомам:

1. Аксиома двойного отрицания:

принципы организации баз данных 3 страница - student2.ru

2. Аксиомы переместительности операндов (относительно операций дизъюнкции и конъюнкции):

принципы организации баз данных 3 страница - student2.ru

3. Аксиомы переместительности операций дизъюнкции и конъюнкции (относительно операндов):

принципы организации баз данных 3 страница - student2.ru

4. Аксиомы одинаковых операндов:

принципы организации баз данных 3 страница - student2.ru

5. Аксиомы поглощения (множителем – множителя-суммы или слагаемым – слагаемого-произведения):

принципы организации баз данных 3 страница - student2.ru

6. Аксиомы распределения операции (дизъюнкции относительно конъюнкции и наоборот):

принципы организации баз данных 3 страница - student2.ru

7. Аксиомы де Моргана (перенесения бинарной операции на операнды):

принципы организации баз данных 3 страница - student2.ru

8. Аксиомы нейтральности (взаимноинверсных множителей или слагаемых):

принципы организации баз данных 3 страница - student2.ru

9. Аксиома существования единицы (истина, true, 1) и нуля (ложь, false, 0), причем,

принципы организации баз данных 3 страница - student2.ru

Из этих аксиом следует ряд полезных соотношений, например:

принципы организации баз данных 3 страница - student2.ru ;

принципы организации баз данных 3 страница - student2.ru .

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

Итак, эти операции определяются совмещенной таблицей значений вида

x y принципы организации баз данных 3 страница - student2.ru принципы организации баз данных 3 страница - student2.ru принципы организации баз данных 3 страница - student2.ru

Такая таблица всех значений некоторой логической функции называется таблицей истинности этой функции.

Пример. Составим таблицу истинности функции принципы организации баз данных 3 страница - student2.ru . Эта таблица имеет вид

x y принципы организации баз данных 3 страница - student2.ru принципы организации баз данных 3 страница - student2.ru принципы организации баз данных 3 страница - student2.ru принципы организации баз данных 3 страница - student2.ru

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

принципы организации баз данных 3 страница - student2.ru

Пример. Заполним таблицу истинности трехместной логической функции принципы организации баз данных 3 страница - student2.ru . Эта таблица имеет вид

x y z принципы организации баз данных 3 страница - student2.ru w

Пример. Изобразим графически множество истинности двухместного предиката вида р(х,у) = "модуль числа х равен модулю числа у", если задана область изменения аргументов: принципы организации баз данных 3 страница - student2.ru . Имеем соотношение

принципы организации баз данных 3 страница - student2.ru

Смысл предикатов р1(х,у) и р2(х,у) очевиден. Множество изображается графиком функции y=|x|, который дан на рисунке.

принципы организации баз данных 3 страница - student2.ru

Рисунок.График функции y = |x|

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

1. импликации: принципы организации баз данных 3 страница - student2.ru ;

2. эквиваленции: принципы организации баз данных 3 страница - student2.ru .

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

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

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

Всегда истинные формулы называют тавтологиями.

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

Задача упрощения логического выражения состоит в преобразовании его к более простому (по числу переменных, операций или операндов) эквивалентному выражению. Наиболее простой вид получается при сведении функции к постоянной – 1 (истина) или 0 (ложь).

Пример. Упростим принципы организации баз данных 3 страница - student2.ru

принципы организации баз данных 3 страница - student2.ru принципы организации баз данных 3 страница - student2.ru

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

Пример. Докажем равенство логических выражений: принципы организации баз данных 3 страница - student2.ru и принципы организации баз данных 3 страница - student2.ru . Используя аксиомы алгебры предикатов, получаем: принципы организации баз данных 3 страница - student2.ru . принципы организации баз данных 3 страница - student2.ru

Левая часть равенства приведена к правой части, то есть данное равенство доказано полностью.

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

- правая часть равенства приводится к левой части;

- левая часть равенства приводится к правой части;

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

Логические функции позволяет эффективно решать так называемые инфологические (информационно-логические) задачи, доказывать утверждения.

Информационно-логическая (инфологическая) задача – это задача, в которой необходимо установить некоторые информационные или логические связи и сделать необходимые причинно-следственные логические выводы. Эти задачи возникают в различных областях и часто являются плохо формализованными и структурированными. Их нужно хорошо формализовать и структурировать. Насколько хорошо будет возможно это сделать – настолько хорошо и полно будет решена рассматриваемая проблема или задача. Рассмотрим пример информационно-логической задачи (например, решаемой следователем, знакомым с алгеброй предикатов).

Пример. Брауну, Джонсу и Смиту предъявлено обвинение в соучастии в ограблении банка. В ходе следствия Браун сказал, что преступники были на синем "Бьюике", Джонс сказал, что это был черный "Крайслер", Смит утверждал, что это был "Форд", но не синий. Каждый указал неправильно либо марку, либо цвет автомобиля. Определим истинный цвет и истинную марку автомобиля. Рассмотрим простые высказывания вида: х = "машина – синяя", у = "машина – Бьюик", z = "машина – черная", u = "машина – Крайслер", v = "машина – Форд". На их основе высказывание Брауна можно записать в виде сложного логического выражения вида принципы организации баз данных 3 страница - student2.ru , высказывание Джонса – в виде принципы организации баз данных 3 страница - student2.ru , а высказывание Смита – в виде принципы организации баз данных 3 страница - student2.ru . Так как в каждом из этих выражений одна из переменных принимает значение "истина", то истинны и дизъюнкции вида: принципы организации баз данных 3 страница - student2.ru . По определению конъюнкции, принципы организации баз данных 3 страница - student2.ru . Это выражение мы взяли из-за однозначности равенства 1 конъюнкции и неоднозначности (многовариантности) его равенства нулю. Упростим выражение:

принципы организации баз данных 3 страница - student2.ru

Мы использовали тот факт, что одновременно не могут быть истинными два высказывания относительно цвета или два высказывания относительно марки машины. Так как конъюнкция истинна только тогда, когда принципы организации баз данных 3 страница - student2.ru , то заключаем, что автомобиль был черным "Бьюиком".

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

Пример. Операции конъюнкции, дизъюнкции, отрицания алгебры высказываний – аналоги союзов "и", "или", приставки "не", используемых (возможно, интуитивно) при выражении мысли человеком.

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

1. Аксиома исключения третьего: либо имеет место высказывание, либо его отрицание.

2. Аксиома противоречия: высказывания и его отрицание не могут иметь места одновременно.

3. Аксиома двойного отрицания: двукратное отрицание какого-либо утверждения равносильно исходному утверждению.

4. Аксиома тождества: всякое высказывание тождественно самому себе.

Если высказывания x и y связаны друг с другом отношением принципы организации баз данных 3 страница - student2.ru , то говорят, что высказывание y следует из высказывания x (или y – следствие x); если множество истинности Х высказывания х содержит множество истинности Y высказывания y, то высказывание x – условие, высказывание y – заключение, а само соотношение принципы организации баз данных 3 страница - student2.ru – вывод.

Наши рекомендации