Программирование на языке ПРОЛОГ для искуственного интеллекта

aa13d773

Отсечение подавляет перебор. Его применяют


  • Отсечение подавляет перебор. Его применяют как для повышения эффективности программ, так и для повышения выразительности языка.
  • Эффективность повышается путем прямого указания (при помощи отсечения) пролог - системе не проверять альтернативы, про которые нам заранее известно, что они должны потерпеть неудачу.
  • Отсечение дает возможность сформулировать взаимно исключающие утверждения при помощи правил вида:

    если Условие то Утверждение1 иначе Утверждение2
  • Отсечение дает возможность ввести отрицание как неуспех: not( Цель) определяется через неуспех цели Цель.
  • Иногда бывают полезными две особые цели true и fail. true - всегда успешна и fail - всегда терпит неудачу.
  • Существуют ограничения в применении отсечения: его появление может нарушить, соответствие между декларативным и процедурным смыслами программы. Поэтому хороший стиль программирования предполагает осторожное применение отсечений и отказ от их применения без достаточных оснований.
  • Оператор not, определенный через неуспех, не полностью соответствует отрицанию в математической логике. Поэтому not тоже нужно применять с осторожностью.


Содержание раздела