3. ВЫЧИСЛЕНИЕ ПОРЯДКОВЫХ
ЛОГИЧЕСКИХ ОПРЕДЕЛИТЕЛЕЙ И ЕГО СЛОЖНОСТЬ
3.1. Вводные замечания
При практическом применении порядковой логики для исследования сложных систем возникает необходимость вычисления достаточно больших, т. е. содержащих много элементов, порядковых ЛО. Здесь и ниже под вычислением ЛО понимается отыскание численного значения ЛО по заданным численным значениям его элементов. Будем оценивать сложность вычисления ЛО количеством элементарных двухместных операций БЛ, необходимых для получения численного значения ЛО. Для вычисления ЛО методически проще всего использовать готовые формулы раскрытия ЛО (§ 2.5 - 2.7). При этом вычисление ЛО сводится к вычислению значения соответствующей функции БЛ, полученной в результате раскрытия данного ЛО. Вместо указанных формул для раскрытия ЛО можно использовать процедуры их последовательного разложения на меньшие ЛО (§ 2.8 — 2.12). Однако в связи с этим возникают такие вопросы: 1) какова сложность указанных процедур вычисления ЛО; 2) в каких случаях эти процедуры можно рекомендовать как приемлемые по сложности;
3) что делать, если эти процедуры неприемлемы по сложности. Ответам на эти вопросы посвящена настоящая глава.
3.2. Сложность вычисления логических определителей по формулам раскрытия
Начнем с процедур вычисления ЛО-столбца по готовым формулам раскрытия (2.26), (2.27). Каждая конъюнкция в (2.26) для своего вычисления требует п - r элементарных операций сравнения двух чисел, а общее количество конъюнкций равно
где
- числo
сочетаний из а элементов по b. Далее, для вычисления дизъюнкции в (2.26) требуется
элементарных операций. Суммируя, найдем, что сложность
вычисления ЛО-столбца
ранга r с п элементами по формуле (2.26) равна
(3.1)
Каждая дизъюнкция (2.27) для вычисления требует r - 1 элементарных oпераций сравнения двух чисел, а число всех дизъюнкций
Для вычисления конъюнкции требуется
элементарных операций. Отсюда сложность вычисления ЛО-столбца
с п элементами ранга r по формуле (2.27)
(3.2)
Легко убедиться (например, выразив
через факториалы), что выражения (3.1), (3.2) тождественно равны. С помощью формулы Стерлинга можно получить асимптотику выражения (3.1) при
(см. § 3.9)
фиксировано;(3.3)
фиксировано. (3.4)
Из (3.2), (3.4) следует, что при фиксированном n/r сложность вычисления ЛО-столбца по формулам (2.26), (2.27) растет экспоненциально по п, что делает нереальными вычисления при больших п: при фиксированном r эта сложность растет как степенная функция пr, что дает возможность вычисления даже больших ЛО невысокого ранга r.
Оценим сложность вычислений общего бесконечного ЛО по формуле (2.29) и общего конечного ЛО по формуле (2.30). Сложность вычисления одной конъюнкции в (2.29) равна q — 1 элементарных операций сравнения. Подсчитаем общее число L (q, r) таких конъюнкций. В образовании этих конъюнкций в силу леммы 2.14 участвуют лишь r первых элементов каждой строки ЛО. Зафиксируем некоторый элемент q-й строки
Соответствующих ему конъюнкций в (2.29) столько, сколько есть конъюнкций
удовлетворяющих условию
т. е.
Отсюда, суммируя по k от 1 до r, получаем общее число конъюнкций в (2.29)
(3.5)
Теперь для отыскания функции L(q, r) надо решить уравнение (3.5). Используем с этой целью рекуррентную по q процедуру. Во-первых,
L (1, r) = 1, так как при q = 1 формула (2.29) имеет вид
Далее,
с помощью (3.5) последовательно находим

Полученные формулы подсказывают общее выражение
(3.6)
Докажем (3.6) индукцией по q. Справедливость (3.6) при q = 1, 2, 3, 4 уже доказана. Допустим, что (3.6) верно при некотором q = р. Докажем, что тогда оно верно и при q = р + 1. Имеем, согласно (3.5) и нашему предположению,
![]()
Таким образом, выражение (3.6) осталось справедливо и при q = р + 1, следовательно, оно справедливо при любом q.
Сложность
вычисления общего бесконечного ЛО.
r-го ранга
q-гo порядка по формуле (2.29) равна произведению сложности q — 1 вычисления одной конъюнкции в (2.29) на число L(q, r) конъюнкций плюс сложность L(q, r) - 1 вычисления дизъюнкции (2.29). Отсюда с учетом (3.6) находим
(3.7)
Выражение (3.7) определяет также оценку сверху сложности вычисления общего конечного ЛО
r-го ранга q-гo порядка по формуле (2.30). Действительно, вычисление общего конечного ЛО по формуле (2.30) отличается от вычисления общего бесконечного ЛО по формуле (2.29) отсутствием части операций.
Асимптотика выражения (3.7) при ![]()
фиксировано, (3.8)
отсюда
s фиксировано. (3.9)
Соотношение (3.8) находим, заменив в формуле (3.72) n на q + r - 2 и получив в результате оценку для
которую подставляем в (3.7).
Соотношение (3.9) находим, заменив в формуле (3.73) п на q + r — 2 и подставив получившуюся оценку
в (3.7). Из (3.8), (3.9) видно,
что при фиксированном q/r сложность вычисления общего ЛО по формулам (2.29), (2.30) растет экспоненциально по q; однако при фиксированном r эта сложность растет как степенная функция qr, и потому процедура приемлема для вычисления больших ЛО низкого ранга r .
3.3. Сложность вычисления логических определителей методом последовательного разложения
Оценим сложность
вычисления ЛО-столбца
с помощью последовательного оптимального разложения ЛО по элементам (2.54). Вычисление правой части (2.54) требует
элементарных операций при отыскании каждого ЛО-столбца
далее r операций при отыскании всех конъюнкций и r —1 операций при отыскании дизъюнкции. Отсюда
(3.10)
Формула (3.10) позволяет находить
для последовательно возрастающих r. Положив в (3.10) r = 1, получим
откуда при очевидном начальном условии
следует
(3.11)
Далее, положив в (3.10) r = 2, получим
или с учетом (3.11)
Решая уравнение в соответствии с очевидным начальным условием
получим
(3.12)
При r = 3 из (3.10) получаем
откуда после подстановки значений
и
из (3.11) и (3.12) и необходимых действий следует уравнение
Решая его (начальное условие
найдем
|
Из за большого объема этот материал размещен на нескольких страницах:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 |


