Искусственный интеллект - Краткое руководство

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

Раздел компьютерных наук под названием « Искусственный интеллект» занимается созданием компьютеров или машин, столь же умных, как люди.

Что такое искусственный интеллект?

По словам отца искусственного интеллекта Джона Маккарти, это «наука и техника создания интеллектуальных машин, особенно интеллектуальных компьютерных программ».

Искусственный интеллект - это способ making a computer, a computer-controlled robot, or a software think intelligentlyподобно тому, как думают разумные люди.

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

Философия ИИ

Эксплуатируя мощь компьютерных систем и любопытство человека, он задался вопросом: «Может ли машина думать и вести себя, как люди?»

Таким образом, разработка ИИ началась с намерения создать в машинах аналогичный интеллект, который мы находим и высоко ценим у людей.

Цели ИИ

  • To Create Expert Systems - Системы, которые демонстрируют разумное поведение, обучаются, демонстрируют, объясняют и советуют своим пользователям.

  • To Implement Human Intelligence in Machines - Создание систем, которые понимают, думают, учатся и ведут себя как люди.

Что способствует ИИ?

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

Из следующих областей одна или несколько областей могут способствовать созданию интеллектуальной системы.

Программирование без ИИ и с ним

Программирование без ИИ и с ИИ отличается следующими способами:

Программирование без ИИ Программирование с ИИ
Компьютерная программа без ИИ может ответить на specific вопросы, которые он призван решать. Компьютерная программа с ИИ может ответить на generic вопросы, которые он призван решать.
Модификация программы приводит к изменению ее структуры. Программы искусственного интеллекта могут впитывать новые модификации, собирая вместе очень независимые фрагменты информации. Следовательно, вы можете изменить даже незначительную часть информации программы, не затрагивая ее структуру.
Модификация не простая и быстрая. Это может отрицательно повлиять на работу программы. Быстрая и простая модификация программы.

Что такое техника ИИ?

В реальном мире у знания есть некоторые нежелательные свойства -

  • Его объем огромен, почти невообразим.
  • Он не очень хорошо организован и не отформатирован.
  • Он постоянно меняется.

Техника ИИ - это способ организовать и эффективно использовать знания таким образом, чтобы:

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

Методы искусственного интеллекта повышают скорость выполнения сложной программы, которой он оснащен.

Приложения ИИ

ИИ доминирует в различных областях, таких как:

  • Gaming - ИИ играет решающую роль в стратегических играх, таких как шахматы, покер, крестики-нолики и т. Д., Где машина может думать о большом количестве возможных позиций на основе эвристических знаний.

  • Natural Language Processing - Можно взаимодействовать с компьютером, который понимает естественный язык, на котором говорят люди.

  • Expert Systems- Есть некоторые приложения, которые объединяют машины, программное обеспечение и специальную информацию для передачи рассуждений и рекомендаций. Они предоставляют объяснения и советы пользователям.

  • Vision Systems- Эти системы понимают, интерпретируют и воспринимают визуальный ввод на компьютере. Например,

    • Самолет-шпион делает фотографии, которые используются для определения пространственной информации или карты местности.

    • Врачи используют клиническую экспертную систему для диагностики пациента.

    • Полиция использует компьютерное программное обеспечение, которое может распознать лицо преступника по сохраненному портрету, сделанному судебно-медицинским экспертом.

  • Speech Recognition- Некоторые интеллектуальные системы способны слышать и понимать язык в терминах предложений и их значений, пока человек разговаривает с ним. Он может обрабатывать различные акценты, сленговые слова, шум на заднем плане, изменение человеческого шума из-за холода и т. Д.

  • Handwriting Recognition- Программа распознавания рукописного ввода считывает текст, написанный на бумаге ручкой или на экране стилусом. Он может распознавать формы букв и преобразовывать их в редактируемый текст.

  • Intelligent Robots- Роботы умеют выполнять задания, поставленные человеком. У них есть датчики для обнаружения физических данных из реального мира, таких как свет, тепло, температура, движение, звук, удары и давление. У них есть эффективные процессоры, несколько датчиков и огромная память, чтобы продемонстрировать интеллект. Кроме того, они могут учиться на своих ошибках и адаптироваться к новой среде.

История ИИ

Вот история искусственного интеллекта в 20 веке -

Год Веха / инновации
1923 г.

В Лондоне открывается спектакль Карела Чапека «Универсальные роботы Россум» (RUR) - первое употребление слова «робот» на английском языке.

1943 г.

Заложены основы нейронных сетей.

1945 г.

Исаак Азимов, выпускник Колумбийского университета, ввел термин « робототехника» .

1950

Алан Тьюринг представил тест Тьюринга для оценки интеллекта и опубликовал Computing Machinery and Intelligence. Клод Шеннон опубликовал « Подробный анализ игры в шахматы» в качестве поискового запроса.

1956 г.

Джон Маккарти ввел термин « искусственный интеллект» . Демонстрация первой работающей программы ИИ в Университете Карнеги-Меллона.

1958 г.

Джон Маккарти изобретает язык программирования LISP для ИИ.

1964 г.

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

1965 г.

Джозеф Вайценбаум из Массачусетского технологического института создал интерактивную задачу ELIZA , которая ведет диалог на английском языке.

1969 г.

Ученые из Стэнфордского научно-исследовательского института разработали Шейки , робота, обладающего способностью к передвижению, восприятию и решению проблем.

1973

Группа сборочной робототехники в Эдинбургском университете построила знаменитого шотландского робота Фредди , способного использовать зрение для поиска и сборки моделей.

1979 г.

Был построен первый автономный автомобиль с компьютерным управлением, Stanford Cart.

1985 г.

Гарольд Коэн создал и продемонстрировал программу рисования Аарон .

1990 г.

Основные достижения во всех областях ИИ -

  • Значительные демонстрации машинного обучения
  • Рассуждения на основе случая
  • Многоагентное планирование
  • Scheduling
  • Интеллектуальный анализ данных, веб-сканер
  • понимание естественного языка и перевод
  • Видение, Виртуальная реальность
  • Games
1997 г.

Программа Deep Blue Chess побеждает тогдашнего чемпиона мира по шахматам Гарри Каспарова.

2000 г.

Интерактивные домашние животные-роботы становятся коммерчески доступными. Массачусетский технологический институт демонстрирует Кисмета , робота с выражающим эмоции лицом. Робот Nomad исследует отдаленные районы Антарктиды и находит метеориты.

Изучая искусственный интеллект, вы должны знать, что такое интеллект. В этой главе рассматривается понятие интеллекта, типы и компоненты интеллекта.

Что такое интеллект?

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

Типы интеллекта

По словам американского психолога-психолога Ховарда Гарднера, интеллект бывает многогранным:

Интеллект Описание пример
Лингвистический интеллект Способность говорить, распознавать и использовать механизмы фонологии (звуки речи), синтаксиса (грамматики) и семантики (значения). Рассказчики, Ораторы
Музыкальный интеллект Способность создавать, общаться и понимать значения звука, понимание высоты звука и ритма. Музыканты, певцы, композиторы
Логико-математический интеллект Способность использовать и понимать отношения при отсутствии действий или объектов. Понимание сложных и абстрактных идей. Математики, ученые
Пространственный интеллект Способность воспринимать визуальную или пространственную информацию, изменять ее и воссоздавать визуальные образы без привязки к объектам, создавать трехмерные изображения, а также перемещать и вращать их. Картографы, Космонавты, Физики
Телесно-кинестетический интеллект Способность использовать все или часть тела для решения проблем или создания изделий, контроля тонкой и грубой моторики и манипулирования объектами. Игроки, танцоры
Внутриличностный интеллект Способность различать собственные чувства, намерения и мотивации. Гаутама Будда
Межличностный интеллект Способность распознавать и различать чувства, убеждения и намерения других людей. Массовые коммуникаторы, интервьюеры

Вы можете сказать, что машина или система artificially intelligent когда в нем есть хотя бы один и максимум все разумные существа.

Из чего состоит интеллект?

Интеллект нематериален. Он состоит из -

  • Reasoning
  • Learning
  • Решение проблем
  • Perception
  • Лингвистический интеллект

Давайте кратко рассмотрим все компоненты -

  • Reasoning- Это набор процессов, которые позволяют нам обеспечивать основу для суждений, принятия решений и прогнозов. В целом есть два типа:

Индуктивное мышление Дедуктивное мышление
Он проводит конкретные наблюдения, чтобы сделать общие заявления. Он начинается с общего утверждения и исследует возможности для достижения конкретного логического вывода.
Даже если в утверждении все предпосылки истинны, индуктивное рассуждение позволяет сделать вывод ложным. Если что-то верно для класса вещей в целом, это также верно для всех членов этого класса.
Пример - «Нита - учитель. Нита прилежна. Поэтому все учителя прилежны». Пример - «Все женщины старше 60 лет - бабушки. Шалини 65 лет. Следовательно, Шалини - бабушка».
  • Learning- Это деятельность по получению знаний или навыков путем изучения, практики, обучения или переживания чего-либо. Обучение повышает осведомленность об изучаемых предметах.

    Способностью к обучению обладают люди, некоторые животные и системы с поддержкой ИИ. Обучение классифицируется как -

    • Auditory Learning- Это обучение через слушание и слушание. Например, студенты слушают записанные аудиолекции.

    • Episodic Learning- Учиться, запоминая последовательность событий, свидетелем которых вы были или пережили. Это линейно и упорядоченно.

    • Motor Learning- Это обучение точным движением мышц. Например, собирать предметы, писать и т. Д.

    • Observational Learning- Учиться, наблюдая за другими и подражая им. Например, ребенок пытается учиться, подражая своему родителю.

    • Perceptual Learning- Это обучение распознаванию стимулов, которые вы видели раньше. Например, определение и классификация объектов и ситуаций.

    • Relational Learning- Он включает в себя обучение различению различных стимулов на основе относительных, а не абсолютных свойств. Например, добавление «чуть меньше» соли во время приготовления картофеля, который в прошлый раз был соленым, например, при приготовлении с добавлением столовой ложки соли.

    • Spatial Learning - Это обучение с помощью визуальных стимулов, таких как изображения, цвета, карты и т. Д. Например, человек может создать дорожную карту в уме, прежде чем фактически следовать по дороге.

    • Stimulus-Response Learning- Это обучение определенному поведению при наличии определенного стимула. Например, собака поднимает ухо, услышав дверной звонок.

  • Problem Solving - Это процесс, в котором человек воспринимает и пытается прийти к желаемому решению из текущей ситуации, выбирая путь, который блокируется известными или неизвестными препятствиями.

    Решение проблем также включает decision making, который представляет собой процесс выбора наиболее подходящей альтернативы из множества доступных альтернатив для достижения желаемой цели.

  • Perception - Это процесс получения, интерпретации, отбора и организации сенсорной информации.

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

  • Linguistic Intelligence- Это способность человека использовать, понимать, говорить и писать на устном и письменном языке. Это важно в межличностном общении.

Разница между человеческим и машинным интеллектом

  • Люди воспринимают по шаблонам, тогда как машины воспринимают по набору правил и данных.

  • Люди хранят и запоминают информацию по шаблонам, машины делают это с помощью поисковых алгоритмов. Например, число 40404040 легко запомнить, сохранить и вспомнить, поскольку его рисунок прост.

  • Люди могут понять объект полностью, даже если какая-то его часть отсутствует или искажена; тогда как машины не могут сделать это правильно.

Область искусственного интеллекта огромна по широте и широте. Продолжая, мы рассматриваем широко распространенные и процветающие области исследований в области ИИ:

Распознавание речи и голоса

Оба эти термина используются в робототехнике, экспертных системах и обработке естественного языка. Хотя эти термины используются как синонимы, их цели различны.

Распознавание речи Распознавание голоса
Распознавание речи направлено на понимание и понимание WHAT было сказано. Цель распознавания голоса - распознать WHO говорит.
Он используется в бесконтактных вычислениях, навигации по карте или меню. Он используется для идентификации человека путем анализа его тона, высоты голоса, акцента и т. Д.
Машине не требуется обучение для распознавания речи, так как она не зависит от говорящего. Эта система распознавания требует обучения, поскольку ориентирована на человека.
Системы распознавания речи, не зависящие от говорящего, сложно разработать. Системы распознавания речи, зависящие от говорящего, сравнительно легко разработать.

Работа систем распознавания речи и голоса

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

Этот текст на исходном языке становится вводом для механизма перевода, который преобразует его в текст на целевом языке. Они поддерживаются интерактивным графическим интерфейсом, большой базой словаря и т. Д.

Реальное применение областей исследований

Существует множество приложений, в которых ИИ помогает простым людям в их повседневной жизни -

Sr.No. Области исследований Применение в реальной жизни
1

Expert Systems

Примеры - системы слежения за полетом, клинические системы.

2

Natural Language Processing

Примеры: функция Google Now, распознавание речи, автоматический вывод голоса.

3

Neural Networks

Примеры - системы распознавания образов, такие как распознавание лиц, распознавание символов, распознавание рукописного ввода.

4

Robotics

Примеры - Промышленные роботы для перемещения, распыления, окраски, проверки точности, сверления, очистки, нанесения покрытий, резьбы и т. Д.

5

Fuzzy Logic Systems

Примеры - бытовая электроника, автомобили и т. Д.

Классификация задач ИИ

Сфера искусственного интеллекта подразделяется на Formal tasks, Mundane tasks, и Expert tasks.

Сферы задач искусственного интеллекта
Обычные (Обычные) Задачи Формальные задачи Экспертные задачи
Восприятие
  • Компьютерное зрение
  • Речь, Голос
  • Mathematics
  • Geometry
  • Logic
  • Интеграция и дифференциация
  • Engineering
  • Поиск ошибок
  • Manufacturing
  • Monitoring
Обработка естественного языка
  • Understanding
  • Генерация языков
  • Языковой перевод
Игры
  • Go
  • Шахматы (Deep Blue)
  • Ckeckers
Научный анализ
Здравый смысл Проверка Финансовый анализ
Рассуждение Доказательство теорем Медицинский диагноз
Строгание Креативность
Робототехника
  • Locomotive

Люди учатся mundane (ordinary) tasksс момента их рождения. Они учатся посредством восприятия, речи, использования языка и локомотивов. Позже они изучают формальные задачи и экспертные задачи в указанном порядке.

Людям легче всего научиться мирским задачам. То же самое считалось верным до того, как пытались реализовать рутинные задачи на машинах. Раньше вся работа ИИ была сосредоточена в сфере повседневных задач.

Позже выяснилось, что машина требует больше знаний, сложного представления знаний и сложных алгоритмов для обработки рутинных задач. Это причинаwhy AI work is more prospering in the Expert Tasks domain теперь, поскольку область экспертных задач требует экспертных знаний без здравого смысла, которые можно легче представить и обработать.

Система ИИ состоит из агента и его среды. Агенты действуют в своей среде. Среда может содержать другие агенты.

Что такое агент и среда?

An agent все, что может воспринимать окружающую среду через sensors и воздействует на эту среду через effectors.

  • А human agent имеет органы чувств, такие как глаза, уши, нос, язык и кожу, параллельные датчикам, и другие органы, такие как руки, ноги, рот, для эффекторов.

  • А robotic agent заменяет камеры и инфракрасные дальномеры для датчиков, а также различные двигатели и исполнительные механизмы для эффекторов.

  • А software agent закодировал битовые строки как свои программы и действия.

Терминология агента

  • Performance Measure of Agent - Это критерии, которые определяют, насколько успешен агент.

  • Behavior of Agent - Это действие, которое агент выполняет после любой заданной последовательности восприятий.

  • Percept - Это перцепционные входы агента в данный момент.

  • Percept Sequence - Это история всего, что агент воспринимал до настоящего времени.

  • Agent Function - Это карта от последовательности предписаний к действию.

Рациональность

Рациональность - это не что иное, как статус разумного, разумного и обладающего здравым смыслом.

Рациональность связана с ожидаемыми действиями и результатами в зависимости от того, что воспринимал агент. Выполнение действий с целью получения полезной информации - важная часть рациональности.

Что такое идеальный рациональный агент?

Идеальный рациональный агент - это тот, который способен выполнять ожидаемые действия, чтобы максимизировать свой показатель эффективности на основе:

  • Его последовательность восприятия
  • Встроенная база знаний

Рациональность агента зависит от следующего -

  • В performance measures, которые определяют степень успеха.

  • Агент Percept Sequence до настоящего времени.

  • Агент prior knowledge about the environment.

  • В actions что агент может выполнить.

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

Структура интеллектуальных агентов

Структуру агента можно рассматривать как -

  • Агент = Архитектура + Агентская программа
  • Архитектура = машина, на которой работает агент.
  • Программа агента = реализация функции агента.

Простые рефлекторные агенты

  • Они выбирают действия только на основе текущего восприятия.
  • Они рациональны только в том случае, если правильное решение принято только на основании действующего предписания.
  • Их окружение полностью наблюдаемо.

Condition-Action Rule - Это правило, которое отображает состояние (условие) на действие.

Рефлекторные агенты на модельной основе

Они используют модель мира для выбора своих действий. Они поддерживают внутреннее состояние.

Model - знания о том, «как все происходит в мире».

Internal State - Это представление ненаблюдаемых аспектов текущего состояния в зависимости от истории восприятия.

Updating the state requires the information about −

  • Как мир развивается.
  • Как действия агента влияют на мир.

Агенты на основе целей

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

Goal - Это описание желаемых ситуаций.

Коммунальные агенты

Они выбирают действия на основе предпочтений (полезности) для каждого состояния.

Цели неадекватны, когда -

  • Есть противоречивые цели, из которых лишь немногие могут быть достигнуты.

  • У целей есть некоторая неопределенность в достижении, и вам нужно сопоставить вероятность успеха с важностью цели.

Природа окружающей среды

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

Напротив, некоторые программные агенты (программные роботы или программные боты) существуют в обширных неограниченных доменах программных ботов. Симулятор имеетvery detailed, complex environment. Программный агент должен выбирать из длинного набора действий в реальном времени. Программный бот, предназначенный для сканирования онлайн-предпочтений покупателя и демонстрации ему интересных вещей, работает вreal а также artificial окружающая обстановка.

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

Тест Тьюринга

Успех разумного поведения системы можно измерить с помощью теста Тьюринга.

В испытании участвуют два человека и машина, подлежащие оценке. Из двух человек один играет роль тестировщика. Каждый из них сидит в разных комнатах. Тестировщик не знает, кто такая машина, а кто человек. Он опрашивает вопросы, печатая и отправляя их обоим разумным существам, на которые он получает печатные ответы.

Цель этого теста - обмануть тестировщика. Если тестировщик не может определить реакцию машины на реакцию человека, то машина считается умной.

Свойства окружающей среды

Окружающая среда обладает множеством свойств -

  • Discrete / Continuous- Если существует ограниченное количество различных, четко определенных состояний среды, среда дискретна (например, шахматы); в противном случае - непрерывный (например, вождение).

  • Observable / Partially Observable- Если возможно определить полное состояние окружающей среды в каждый момент времени с помощью восприятий, это можно наблюдать; в противном случае это наблюдается лишь частично.

  • Static / Dynamic- Если среда не меняется во время действия агента, то она статична; в противном случае это динамично.

  • Single agent / Multiple agents - Окружающая среда может содержать других агентов, которые могут быть того же самого или другого типа, что и агент.

  • Accessible / Inaccessible - Если сенсорный аппарат агента может иметь доступ к полному состоянию окружающей среды, тогда среда доступна этому агенту.

  • Deterministic / Non-deterministic- Если следующее состояние среды полностью определяется текущим состоянием и действиями агента, то среда является детерминированной; в противном случае он недетерминирован.

  • Episodic / Non-episodic- В эпизодической среде каждый эпизод состоит из того, что агент воспринимает, а затем действует. Качество его действия зависит как раз от самого эпизода. Последующие эпизоды не зависят от действий в предыдущих эпизодах. Эпизодические среды намного проще, потому что агенту не нужно думать наперед.

Поиск - универсальный метод решения проблем в ИИ. Есть некоторые однопользовательские игры, такие как игры с плиткой, судоку, кроссворды и т. Д. Алгоритмы поиска помогают вам найти определенную позицию в таких играх.

Проблемы с поиском пути одного агента

Такие игры, как головоломки с восемью плитками 3x3, пятнадцать плиток 4X4 и головоломки с двадцатью четырьмя плитками 5X5, представляют собой задачи поиска пути для одного агента. Они состоят из матрицы плитки с пустой плиткой. Игрок должен расставить плитки, сдвинув плитку вертикально или горизонтально в пустое пространство с целью достижения какой-то цели.

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

Терминология поиска

  • Problem Space- Это среда, в которой происходит поиск. (Набор состояний и набор операторов для изменения этих состояний)

  • Problem Instance - Это исходное состояние + состояние цели.

  • Problem Space Graph- Он представляет состояние проблемы. Состояния показаны узлами, а операторы - краями.

  • Depth of a problem - Длина кратчайшего пути или кратчайшей последовательности операторов от начального состояния до состояния цели.

  • Space Complexity - Максимальное количество узлов, хранящихся в памяти.

  • Time Complexity - Максимальное количество создаваемых узлов.

  • Admissibility - Свойство алгоритма всегда находить оптимальное решение.

  • Branching Factor - Среднее количество дочерних узлов в графе проблемного пространства.

  • Depth - Длина кратчайшего пути от исходного состояния до состояния цели.

Стратегии поиска методом грубой силы

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

Требования -

  • Описание состояния
  • Набор допустимых операторов
  • Начальное состояние
  • Описание состояния цели

Поиск в ширину

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

Если branching factor(среднее количество дочерних узлов для данного узла) = b и глубина = d, тогда количество узлов на уровне d = b d .

Общее количество узлов, созданных в худшем случае, равно b + b 2 + b 3 +… + b d .

Disadvantage- Поскольку каждый уровень узлов сохраняется для создания следующего, он занимает много места в памяти. Требуемое пространство для хранения узлов экспоненциально.

Его сложность зависит от количества узлов. Он может проверять повторяющиеся узлы.

Поиск в глубину

Он реализован в рекурсии со структурой данных стека LIFO. Он создает тот же набор узлов, что и метод Breadth-First, только в другом порядке.

Поскольку узлы на единственном пути сохраняются на каждой итерации от корневого до листового узла, требования к пространству для хранения узлов являются линейными. С коэффициентом ветвления b и глубиной m , объем хранилища равен bm.

Disadvantage- Этот алгоритм не может завершаться и продолжаться бесконечно по одному пути. Решение этого вопроса - выбрать глубину обрезки. Если идеальное отсечение - d , и если выбранное отсечение меньше d , то этот алгоритм может дать сбой. Если выбранная отсечка больше d , время выполнения увеличивается.

Его сложность зависит от количества путей. Он не может проверять повторяющиеся узлы.

Двунаправленный поиск

Он ищет вперед от начального состояния и назад от целевого состояния до тех пор, пока они не встретятся, чтобы определить общее состояние.

Путь от начального состояния объединяется с обратным путем от целевого состояния. Каждый поиск выполняется только до половины общего пути.

Единый поиск стоимости

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

Он исследует пути в порядке возрастания стоимости.

Disadvantage- Может быть несколько длинных путей со стоимостью ≤ C *. Единый поиск стоимости должен изучить их все.

Итеративный поиск в глубину

Он выполняет поиск в глубину до уровня 1, начинает заново, выполняет полный поиск в глубину до уровня 2 и продолжает таким образом, пока не будет найдено решение.

Он никогда не создает узел, пока не будут созданы все нижние узлы. Он сохраняет только стек узлов. Алгоритм завершается, когда находит решение на глубине d . Количество узлов, созданных на глубине d, равно b d, а на глубине d-1 - b d-1.

Сравнение сложности различных алгоритмов

Let us see the performance of algorithms based on various criteria −

Criterion Breadth First Depth First Bidirectional Uniform Cost Interactive Deepening
Time bd bm bd/2 bd bd
Space bd bm bd/2 bd bd
Optimality Yes No Yes Yes Yes
Completeness Yes No Yes Yes Yes

Informed (Heuristic) Search Strategies

To solve large problems with large number of possible states, problem-specific knowledge needs to be added to increase the efficiency of search algorithms.

Heuristic Evaluation Functions

They calculate the cost of optimal path between two states. A heuristic function for sliding-tiles games is computed by counting number of moves that each tile makes from its goal state and adding these number of moves for all tiles.

Pure Heuristic Search

It expands nodes in the order of their heuristic values. It creates two lists, a closed list for the already expanded nodes and an open list for the created but unexpanded nodes.

In each iteration, a node with a minimum heuristic value is expanded, all its child nodes are created and placed in the closed list. Then, the heuristic function is applied to the child nodes and they are placed in the open list according to their heuristic value. The shorter paths are saved and the longer ones are disposed.

A * Search

It is best-known form of Best First search. It avoids expanding paths that are already expensive, but expands most promising paths first.

f(n) = g(n) + h(n), where

  • g(n) the cost (so far) to reach the node
  • h(n) estimated cost to get from the node to the goal
  • f(n) estimated total cost of path through n to goal. It is implemented using priority queue by increasing f(n).

Greedy Best First Search

It expands the node that is estimated to be closest to goal. It expands nodes based on f(n) = h(n). It is implemented using priority queue.

Disadvantage − It can get stuck in loops. It is not optimal.

Local Search Algorithms

They start from a prospective solution and then move to a neighboring solution. They can return a valid solution even if it is interrupted at any time before they end.

Hill-Climbing Search

It is an iterative algorithm that starts with an arbitrary solution to a problem and attempts to find a better solution by changing a single element of the solution incrementally. If the change produces a better solution, an incremental change is taken as a new solution. This process is repeated until there are no further improvements.

function Hill-Climbing (problem), returns a state that is a local maximum.

inputs: problem, a problem
local variables: current, a node
                 neighbor, a node
current <-Make_Node(Initial-State[problem])
loop
   do neighbor <- a highest_valued successor of current
      if Value[neighbor] ≤ Value[current] then
      return State[current]
      current <- neighbor				  
	
end

Disadvantage − This algorithm is neither complete, nor optimal.

Local Beam Search

In this algorithm, it holds k number of states at any given time. At the start, these states are generated randomly. The successors of these k states are computed with the help of objective function. If any of these successors is the maximum value of the objective function, then the algorithm stops.

Otherwise the (initial k states and k number of successors of the states = 2k) states are placed in a pool. The pool is then sorted numerically. The highest k states are selected as new initial states. This process continues until a maximum value is reached.

function BeamSearch( problem, k), returns a solution state.

start with k randomly generated states
loop
   generate all successors of all k states
   if any of the states = solution, then return the state
   else select the k best successors
end

Simulated Annealing

Annealing is the process of heating and cooling a metal to change its internal structure for modifying its physical properties. When the metal cools, its new structure is seized, and the metal retains its newly obtained properties. In simulated annealing process, the temperature is kept variable.

We initially set the temperature high and then allow it to ‘cool' slowly as the algorithm proceeds. When the temperature is high, the algorithm is allowed to accept worse solutions with high frequency.

Start

  • Initialize k = 0; L = integer number of variables;
  • From i → j, search the performance difference Δ.
  • If Δ <= 0 then accept else if exp(-Δ/T(k)) > random(0,1) then accept;
  • Repeat steps 1 and 2 for L(k) steps.
  • k = k + 1;

Repeat steps 1 through 4 till the criteria is met.

End

Travelling Salesman Problem

In this algorithm, the objective is to find a low-cost tour that starts from a city, visits all cities en-route exactly once and ends at the same starting city.

Start
   Find out all (n -1)! Possible solutions, where n is the total number of cities.
   Determine the minimum cost by finding out the cost of each of these (n -1)! solutions.
   Finally, keep the one with the minimum cost.
end

Fuzzy Logic Systems (FLS) produce acceptable but definite output in response to incomplete, ambiguous, distorted, or inaccurate (fuzzy) input.

What is Fuzzy Logic?

Fuzzy Logic (FL) is a method of reasoning that resembles human reasoning. The approach of FL imitates the way of decision making in humans that involves all intermediate possibilities between digital values YES and NO.

The conventional logic block that a computer can understand takes precise input and produces a definite output as TRUE or FALSE, which is equivalent to human’s YES or NO.

The inventor of fuzzy logic, Lotfi Zadeh, observed that unlike computers, the human decision making includes a range of possibilities between YES and NO, such as −

CERTAINLY YES
POSSIBLY YES
CANNOT SAY
POSSIBLY NO
CERTAINLY NO

The fuzzy logic works on the levels of possibilities of input to achieve the definite output.

Implementation

  • It can be implemented in systems with various sizes and capabilities ranging from small micro-controllers to large, networked, workstation-based control systems.

  • It can be implemented in hardware, software, or a combination of both.

Why Fuzzy Logic?

Fuzzy logic is useful for commercial and practical purposes.

  • It can control machines and consumer products.
  • It may not give accurate reasoning, but acceptable reasoning.
  • Fuzzy logic helps to deal with the uncertainty in engineering.

Fuzzy Logic Systems Architecture

It has four main parts as shown −

  • Fuzzification Module − It transforms the system inputs, which are crisp numbers, into fuzzy sets. It splits the input signal into five steps such as −

LP x is Large Positive
MP x is Medium Positive
S x is Small
MN x is Medium Negative
LN x is Large Negative
  • Knowledge Base − It stores IF-THEN rules provided by experts.

  • Inference Engine − It simulates the human reasoning process by making fuzzy inference on the inputs and IF-THEN rules.

  • Defuzzification Module − It transforms the fuzzy set obtained by the inference engine into a crisp value.

The membership functions work on fuzzy sets of variables.

Membership Function

Membership functions allow you to quantify linguistic term and represent a fuzzy set graphically. A membership function for a fuzzy set A on the universe of discourse X is defined as μA:X → [0,1].

Here, each element of X is mapped to a value between 0 and 1. It is called membership value or degree of membership. It quantifies the degree of membership of the element in X to the fuzzy set A.

  • x axis represents the universe of discourse.
  • y axis represents the degrees of membership in the [0, 1] interval.

There can be multiple membership functions applicable to fuzzify a numerical value. Simple membership functions are used as use of complex functions does not add more precision in the output.

All membership functions for LP, MP, S, MN, and LN are shown as below −

The triangular membership function shapes are most common among various other membership function shapes such as trapezoidal, singleton, and Gaussian.

Here, the input to 5-level fuzzifier varies from -10 volts to +10 volts. Hence the corresponding output also changes.

Example of a Fuzzy Logic System

Let us consider an air conditioning system with 5-level fuzzy logic system. This system adjusts the temperature of air conditioner by comparing the room temperature and the target temperature value.

Algorithm

  • Define linguistic Variables and terms (start)
  • Construct membership functions for them. (start)
  • Construct knowledge base of rules (start)
  • Convert crisp data into fuzzy data sets using membership functions. (fuzzification)
  • Evaluate rules in the rule base. (Inference Engine)
  • Combine results from each rule. (Inference Engine)
  • Convert output data into non-fuzzy values. (defuzzification)

Development

Step 1 − Define linguistic variables and terms

Linguistic variables are input and output variables in the form of simple words or sentences. For room temperature, cold, warm, hot, etc., are linguistic terms.

Temperature (t) = {very-cold, cold, warm, very-warm, hot}

Every member of this set is a linguistic term and it can cover some portion of overall temperature values.

Step 2 − Construct membership functions for them

The membership functions of temperature variable are as shown −

Step3 − Construct knowledge base rules

Create a matrix of room temperature values versus target temperature values that an air conditioning system is expected to provide.

RoomTemp. /Target Very_Cold Cold Warm Hot Very_Hot
Very_Cold No_Change Heat Heat Heat Heat
Cold Cool No_Change Heat Heat Heat
Warm Cool Cool No_Change Heat Heat
Hot Cool Cool Cool No_Change Heat
Very_Hot Cool Cool Cool Cool No_Change

Build a set of rules into the knowledge base in the form of IF-THEN-ELSE structures.

Sr. No. Condition Action
1 IF temperature=(Cold OR Very_Cold) AND target=Warm THEN Heat
2 IF temperature=(Hot OR Very_Hot) AND target=Warm THEN Cool
3 IF (temperature=Warm) AND (target=Warm) THEN No_Change

Step 4 − Obtain fuzzy value

Fuzzy set operations perform evaluation of rules. The operations used for OR and AND are Max and Min respectively. Combine all results of evaluation to form a final result. This result is a fuzzy value.

Step 5 − Perform defuzzification

Defuzzification is then performed according to membership function for output variable.

Application Areas of Fuzzy Logic

The key application areas of fuzzy logic are as given −

Automotive Systems

  • Automatic Gearboxes
  • Four-Wheel Steering
  • Vehicle environment control

Consumer Electronic Goods

  • Hi-Fi Systems
  • Photocopiers
  • Still and Video Cameras
  • Television

Domestic Goods

  • Microwave Ovens
  • Refrigerators
  • Toasters
  • Vacuum Cleaners
  • Washing Machines

Environment Control

  • Air Conditioners/Dryers/Heaters
  • Humidifiers

Advantages of FLSs

  • Mathematical concepts within fuzzy reasoning are very simple.

  • You can modify a FLS by just adding or deleting rules due to flexibility of fuzzy logic.

  • Fuzzy logic Systems can take imprecise, distorted, noisy input information.

  • FLSs are easy to construct and understand.

  • Fuzzy logic is a solution to complex problems in all fields of life, including medicine, as it resembles human reasoning and decision making.

Disadvantages of FLSs

  • There is no systematic approach to fuzzy system designing.
  • They are understandable only when simple.
  • They are suitable for the problems which do not need high accuracy.

Natural Language Processing (NLP) refers to AI method of communicating with an intelligent systems using a natural language such as English.

Processing of Natural Language is required when you want an intelligent system like robot to perform as per your instructions, when you want to hear decision from a dialogue based clinical expert system, etc.

The field of NLP involves making computers to perform useful tasks with the natural languages humans use. The input and output of an NLP system can be −

  • Speech
  • Written Text

Components of NLP

There are two components of NLP as given −

Natural Language Understanding (NLU)

Understanding involves the following tasks −

  • Отображение заданного ввода на естественном языке в полезные представления.
  • Анализируем разные аспекты языка.

Генерация естественного языка (NLG)

Это процесс создания значимых фраз и предложений в форме естественного языка из некоторого внутреннего представления.

Это включает в себя -

  • Text planning - Это включает в себя получение соответствующего контента из базы знаний.

  • Sentence planning - Включает в себя выбор необходимых слов, формирование значимых фраз, настройку тона предложения.

  • Text Realization - Это отображение плана предложения в структуру предложения.

NLU сложнее, чем NLG.

Трудности в НЛУ

NL имеет чрезвычайно богатую форму и структуру.

Это очень неоднозначно. Могут быть разные уровни двусмысленности -

  • Lexical ambiguity - Это на очень примитивном уровне, например, на уровне слов.

  • Например, рассматривать слово «доска» как существительное или глагол?

  • Syntax Level ambiguity - Предложение можно разбирать по-разному.

  • Например: «Жук с красной шапкой поднял». - Поднимал ли он жука колпаком или он поднимал жука с красной шляпкой?

  • Referential ambiguity- Обращение к чему-либо с использованием местоимений. Например, Римма пошла к Гаури. Она сказала: «Я устала». - Кто именно устал?

  • Один вход может означать разные значения.

  • Многие входные данные могут означать одно и то же.

Терминология НЛП

  • Phonology - Это систематическое изучение организации звука.

  • Morphology - Это исследование построения слов из примитивных значимых единиц.

  • Morpheme - Это примитивная единица значения в языке.

  • Syntax- Это относится к составлению предложения из слов. Это также включает определение структурной роли слов в предложении и во фразах.

  • Semantics - Это касается значения слов и того, как объединять слова в значимые фразы и предложения.

  • Pragmatics - Он касается использования и понимания предложений в различных ситуациях и того, как это влияет на интерпретацию предложения.

  • Discourse - Это касается того, как предыдущее предложение может повлиять на интерпретацию следующего предложения.

  • World Knowledge - Включает в себя общие знания о мире.

Шаги в НЛП

Есть пять общих шагов -

  • Lexical Analysis- Он включает выявление и анализ структуры слов. Лексика языка означает совокупность слов и фраз на языке. Лексический анализ разделяет весь текстовый текст на абзацы, предложения и слова.

  • Syntactic Analysis (Parsing)- Он включает анализ слов в предложении на предмет грамматики и расположение слов таким образом, чтобы показать взаимосвязь между словами. Такое предложение, как «Школа идет мальчику», отклоняется синтаксическим анализатором английского языка.

  • Semantic Analysis- Он извлекает точное значение или словарное значение из текста. Текст проверяется на осмысленность. Это делается путем сопоставления синтаксических структур и объектов в области задач. Семантический анализатор игнорирует такие предложения, как «горячее мороженое».

  • Discourse Integration- Значение любого предложения зависит от значения предложения непосредственно перед ним. Кроме того, это также приводит к значению сразу следующего за ним предложения.

  • Pragmatic Analysis- При этом сказанное интерпретируется по-новому, исходя из того, что на самом деле означает. Он включает в себя получение тех аспектов языка, которые требуют знания реального мира.

Аспекты реализации синтаксического анализа

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

  • Контекстно-свободная грамматика
  • Парсер сверху вниз

Давайте посмотрим на них подробно -

Контекстно-свободная грамматика

Это грамматика, которая состоит из правил с одним символом в левой части правил перезаписи. Давайте создадим грамматику для анализа предложения -

«Птица клюет зерна»

Articles (DET)- а | ан | в

Nouns- птица | птицы | зерно | зерна

Noun Phrase (NP)- Артикул + Существительное | Артикль + прилагательное + существительное

= DET N | DET ADJ N

Verbs- клюет | клевание | клюнул

Verb Phrase (VP)- НП В | V НП

Adjectives (ADJ)- красиво | маленький | щебетание

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

Эти правила говорят, что определенный символ может быть расширен в дереве последовательностью других символов. Согласно логическому правилу первого порядка, если есть две строки Noun Phrase (NP) и Verb Phrase (VP), то строка, объединенная с NP, за которым следует VP, является предложением. Правила перезаписи предложения следующие:

S → NP VP

NP → DET N | DET ADJ N

VP → V NP

Lexocon −

DET → а | в

ADJ → красиво | усаживаться

N → птица | птицы | зерно | зерна

V → клевать | клюет | клевание

Дерево синтаксического анализа может быть создано, как показано -

Теперь рассмотрим приведенные выше правила перезаписи. Так как V можно заменить на оба слова: «клевать» или «клевать», такие предложения, как «Птица клюет зерна», могут быть ошибочно разрешены. т.е. ошибка согласования подлежащего и глагола считается правильной.

Merit - Самый простой стиль грамматики, поэтому широко используемый.

Demerits −

  • Они не очень точны. Например, «Зерна клюют птицу» синтаксически правильно согласно синтаксическому анализатору, но даже если это не имеет смысла, синтаксический анализатор принимает это как правильное предложение.

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

Парсер сверху вниз

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

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

Merit - Просто реализовать.

Demerits −

  • Это неэффективно, так как в случае ошибки процесс поиска придется повторить.
  • Медленная скорость работы.

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

Что такое экспертные системы?

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

Характеристики экспертных систем

  • Высокая производительность
  • Understandable
  • Reliable
  • Очень отзывчивый

Возможности экспертных систем

Экспертные системы способны:

  • Advising
  • Инструктаж и помощь людям в принятии решений
  • Demonstrating
  • Получение решения
  • Diagnosing
  • Explaining
  • Устный ввод
  • Прогнозирование результатов
  • Обоснование вывода
  • Предлагаем альтернативные варианты решения проблемы

Они неспособны -

  • Замена людей, принимающих решения
  • Обладая человеческими способностями
  • Получение точных результатов для неадекватной базы знаний
  • Уточнение собственных знаний

Компоненты экспертных систем

Компоненты ES включают в себя -

  • База знаний
  • Механизм логического вывода
  • Пользовательский интерфейс

Давайте кратко рассмотрим их по очереди -

База знаний

Он содержит предметные и высококачественные знания.

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

Что такое знания?

Данные - это набор фактов. Информация организована в виде данных и фактов о предметной области.Data, information, и past experience вместе взятые, называются знаниями.

Компоненты базы знаний

База знаний ES - это хранилище фактических и эвристических знаний.

  • Factual Knowledge - Это информация, широко используемая инженерами знаний и учеными в данной области.

  • Heuristic Knowledge - Речь идет о практике, точном суждении, способности оценивать и предполагать.

Представление знаний

Это метод, используемый для организации и формализации знаний в базе знаний. Это в форме правил IF-THEN-ELSE.

Приобретение знаний

Успех любой экспертной системы во многом зависит от качества, полноты и точности информации, хранящейся в базе знаний.

База знаний формируется на основе чтения различных экспертов, ученых и Knowledge Engineers. Инженер по знаниям - это человек с качествами сочувствия, быстрого обучения и анализа кейсов.

Он получает информацию от предметного эксперта путем записи, интервью и наблюдения за ним на работе и т. Д. Затем он классифицирует и систематизирует информацию значимым образом в форме правил IF-THEN-ELSE для использования машиной вмешательства. Инженер по знаниям также следит за развитием ES.

Механизм логического вывода

Использование эффективных процедур и правил механизмом вывода необходимо для получения правильного и безупречного решения.

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

В случае ES, основанного на правилах, это -

  • Повторно применяет правила к фактам, полученным в результате более раннего применения правил.

  • При необходимости добавляет новые знания в базу знаний.

  • Устраняет конфликт правил, когда к конкретному случаю применимо несколько правил.

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

  • Прямая цепочка
  • Обратная цепочка

Прямая цепочка

Это стратегия экспертной системы, чтобы ответить на вопрос, “What can happen next?”

Здесь механизм вывода следует цепочке условий и выводов и, наконец, выводит результат. Он рассматривает все факты и правила и сортирует их, прежде чем прийти к решению.

Эта стратегия используется для работы над выводом, результатом или эффектом. Например, прогнозирование состояния рынка акций в результате изменения процентных ставок.

Обратная цепочка

С помощью этой стратегии экспертная система находит ответ на вопрос, “Why this happened?”

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

Пользовательский интерфейс

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

Он объясняет, как ES пришел к конкретной рекомендации. Объяснение может появиться в следующих формах -

  • На экране отображается естественный язык.
  • Устные повествования на естественном языке.
  • Список номеров правил, отображаемых на экране.

Пользовательский интерфейс позволяет легко отслеживать достоверность удержаний.

Требования к эффективному пользовательскому интерфейсу ES

  • Это должно помочь пользователям в кратчайшие сроки достичь своих целей.

  • Он должен быть разработан таким образом, чтобы соответствовать существующим или желаемым методам работы пользователя.

  • Его технология должна быть адаптирована к требованиям пользователя; а не наоборот.

  • Он должен эффективно использовать вводимые пользователем данные.

Ограничения экспертных систем

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

  • Ограничения технологии
  • Сложное получение знаний
  • ES сложно поддерживать
  • Высокие затраты на разработку

Приложения экспертной системы

В следующей таблице показано, где можно применить ES.

заявка Описание
Область дизайна Дизайн объектива камеры, автомобильный дизайн.
Медицинский домен Системы диагностики для определения причины заболевания по наблюдаемым данным, проведения медицинских операций на людях.
Системы мониторинга Непрерывное сравнение данных с наблюдаемой системой или с предписанным поведением, таким как мониторинг утечек в длинном нефтепроводе.
Системы управления процессами Управление физическим процессом на основе мониторинга.
Область знаний Выявление неисправностей в автомобилях, компьютерах.
Финансы / Торговля Обнаружение возможного мошенничества, подозрительных транзакций, биржевой торговли, планирования авиаперевозок, планирования грузовых перевозок.

Технология экспертных систем

Доступны несколько уровней ES-технологий. Технологии экспертных систем включают -

  • Expert System Development Environment- Среда разработки ES включает оборудование и инструменты. Они -

    • Рабочие станции, миникомпьютеры, мэйнфреймы.

    • Символьные языки программирования высокого уровня, такие как LISт Pпрограммирование (LISP) и PROграмматика ru LOGique (ПРОЛОГ).

    • Большие базы данных.

  • Tools - Они значительно сокращают усилия и затраты на разработку экспертной системы.

    • Мощные редакторы и инструменты для отладки с несколькими окнами.

    • Они обеспечивают быстрое прототипирование

    • Имейте встроенные определения модели, представления знаний и дизайна вывода.

  • Shells- Оболочка - это не что иное, как экспертная система без базы знаний. Оболочка предоставляет разработчикам возможность получения знаний, механизма вывода, пользовательского интерфейса и объяснения. Например, несколько снарядов приведены ниже -

    • Оболочка экспертной системы Java (JESS), которая предоставляет полностью разработанный Java API для создания экспертной системы.

    • Vidwan , оболочка, разработанная в Национальном центре программных технологий в Мумбаи в 1993 году. Она позволяет кодировать знания в форме правил IF-THEN.

Разработка экспертных систем: общие шаги

Процесс разработки ЭС повторяется. Шаги по разработке ES включают:

Определить проблемный домен

  • Проблема должна быть подходящей для решения экспертной системы.
  • Найдите экспертов в области задач для проекта ES.
  • Определите рентабельность системы.

Разработка системы

  • Определите технологию ES

  • Знать и устанавливать степень интеграции с другими системами и базами данных.

  • Поймите, как концепции могут лучше всего отражать знания предметной области.

Разработать прототип

Из базы знаний: инженер по знаниям работает, чтобы -

  • Получите знания предметной области от эксперта.
  • Представьте это в виде правил If-THEN-ELSE.

Протестируйте и доработайте прототип

  • Инженер по знаниям использует примеры для проверки прототипа на наличие недостатков в производительности.

  • Конечные пользователи тестируют прототипы ES.

Разработайте и завершите ES

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

  • Хорошо задокументируйте проект ES.

  • Обучите пользователя пользоваться ES.

Поддерживайте систему

  • Регулярно просматривайте и обновляйте базу знаний в актуальном состоянии.

  • Участвуйте в новых интерфейсах с другими информационными системами по мере их развития.

Преимущества экспертных систем

  • Availability - Они легко доступны благодаря массовому производству программного обеспечения.

  • Less Production Cost- Стоимость изготовления разумная. Это делает их доступными.

  • Speed- Они предлагают большую скорость. Они сокращают объем работы, которую выполняет человек.

  • Less Error Rate - Уровень ошибок низкий по сравнению с человеческими ошибками.

  • Reducing Risk - Они могут работать в опасной для человека среде.

  • Steady response - Они работают стабильно, без движения, напряжения и утомления.

Робототехника - это область искусственного интеллекта, которая занимается исследованием создания интеллектуальных и эффективных роботов.

Что такое роботы?

Роботы - это искусственные агенты, действующие в реальном мире.

Задача

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

Что такое робототехника?

Робототехника - это отрасль искусственного интеллекта, которая состоит из электротехники, машиностроения и информатики для проектирования, конструирования и применения роботов.

Аспекты робототехники

  • У роботов есть mechanical construction, форма или форма, предназначенная для выполнения конкретной задачи.

  • У них есть electrical components которые приводят в действие и управляют оборудованием.

  • Они содержат некоторый уровень computer program это определяет, что, когда и как робот что-то делает.

Разница в системе роботов и других программах искусственного интеллекта

Вот разница между ними -

Программы ИИ Роботы
Обычно они действуют в мирах, стимулированных компьютером. Они действуют в реальном физическом мире
Вход в программу AI находится в символах и правилах. Входами для роботов является аналоговый сигнал в форме речевого сигнала или изображений.
Им нужны компьютеры общего назначения для работы. Им нужно специальное оборудование с датчиками и эффекторами.

Движение роботов

Локомоция - это механизм, который делает робота способным перемещаться в окружающей среде. Есть разные типы движений -

  • Legged
  • Wheeled
  • Комбинация движения на ногах и на колесах
  • Гусеничное скольжение / занос

Ноги передвижение

  • Этот тип передвижения потребляет больше энергии при демонстрации ходьбы, прыжка, рыси, прыжка, подъема или спуска и т. Д.

  • Для совершения движения требуется большее количество двигателей. Он подходит как для пересеченной, так и для гладкой местности, где неровная или слишком гладкая поверхность заставляет потреблять больше энергии для передвижения на колесах. Это немного сложно реализовать из-за проблем со стабильностью.

  • Он поставляется с одной, двумя, четырьмя и шестью ножками. Если у робота несколько ног, для передвижения необходима координация ног.

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

Если у робота k ног, то количество возможных событий N = (2k-1) !.

В случае двуногого робота (k = 2) количество возможных событий N = (2k-1)! = (2 * 2-1)! = 3! = 6.

Следовательно, есть шесть возможных различных событий -

  • Подъем левой ноги
  • Освобождение левой ноги
  • Подъем правой ноги
  • Освобождение правой ноги
  • Подъем обеих ног вместе
  • Сдвинуть обе ноги вместе

В случае k = 6 этапов возможны 39916800 событий. Следовательно, сложность роботов прямо пропорциональна количеству ног.

Колесное движение

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

  • Standard wheel - Вращается вокруг оси колеса и вокруг контакта

  • Castor wheel - Вращается вокруг оси колеса и смещенного рулевого шарнира.

  • Swedish 45o and Swedish 90o wheels - Омни-колесо, вращается вокруг точки контакта, вокруг оси колеса и вокруг роликов.

  • Ball or spherical wheel - Всенаправленное колесо, технически сложно реализовать.

Скольжение / скольжение

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

Компоненты робота

Роботы построены со следующим:

  • Power Supply - Роботы питаются от батарей, солнечной энергии, гидравлических или пневматических источников энергии.

  • Actuators - Они превращают энергию в движение.

  • Electric motors (AC/DC) - Они необходимы для вращательного движения.

  • Pneumatic Air Muscles - Они сокращаются почти на 40%, когда в них всасывается воздух.

  • Muscle Wires - Они сокращаются на 5% при пропускании электрического тока.

  • Piezo Motors and Ultrasonic Motors - Лучшее для промышленных роботов.

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

Компьютерное зрение

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

Компьютерное зрение автоматически извлекает, анализирует и воспринимает полезную информацию из одного изображения или массива изображений. Этот процесс включает в себя разработку алгоритмов для достижения автоматического визуального восприятия.

Оборудование системы компьютерного зрения

Это включает в себя -

  • Источник питания
  • Устройство получения изображения, такое как камера
  • Процессор
  • Программное обеспечение
  • Устройство отображения для мониторинга системы
  • Аксессуары, такие как стойки для камеры, кабели и разъемы

Задачи компьютерного зрения

  • OCR - В области компьютеров Optical Character Reader - программное обеспечение для преобразования отсканированных документов в редактируемый текст, прилагаемое к сканеру.

  • Face Detection- Многие современные камеры оснащены этой функцией, которая позволяет читать по лицам и делать снимки с идеальным выражением лица. Он используется, чтобы позволить пользователю получить доступ к программному обеспечению при правильном совпадении.

  • Object Recognition - Они устанавливаются в супермаркетах, фотоаппаратах, автомобилях высокого класса, таких как BMW, GM и Volvo.

  • Estimating Position - Оценивает положение объекта относительно камеры как положение опухоли в теле человека.

Области приложений компьютерного зрения

  • Agriculture
  • Автономные автомобили
  • Biometrics
  • Распознавание символов
  • Криминалистика, безопасность и наблюдение
  • Инспекция промышленного качества
  • Распознавание лица
  • Анализ жестов
  • Geoscience
  • Медицинские изображения
  • Мониторинг загрязнения
  • Контроль над процессом
  • Дистанционное зондирование
  • Robotics
  • Transport

Применение робототехники

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

  • Industries - Роботы используются для обработки материалов, резки, сварки, цветного покрытия, сверления, полировки и т. Д.

  • Military- Автономные роботы могут достигать труднодоступных и опасных зон во время войны. Робот по имени Дакш , разработанный Организацией оборонных исследований и разработок (DRDO), предназначен для безопасного уничтожения опасных для жизни объектов.

  • Medicine - Роботы способны одновременно проводить сотни клинических испытаний, реабилитировать людей с постоянной инвалидностью и выполнять сложные операции, такие как опухоли головного мозга.

  • Exploration - Роботы-скалолазы, используемые для исследования космоса, подводные дроны, используемые для исследования океана, - это лишь некоторые из них.

  • Entertainment - Инженеры Disney создали сотни роботов для создания фильмов.

Еще одна область исследований в области искусственного интеллекта, нейронные сети, основана на естественной нейронной сети нервной системы человека.

Что такое искусственные нейронные сети (ИНС)?

Изобретатель первого нейрокомпьютера доктор Роберт Хехт-Нильсен определяет нейронную сеть как

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

Базовая структура ИНС

Идея ИНС основана на вере в то, что работу человеческого мозга, устанавливая правильные соединения, можно имитировать, используя кремний и провода в качестве живых. neurons и dendrites.

Человеческий мозг состоит из 86 миллиардов нервных клеток, называемых neurons. Они связаны с другими тысячами ячеек посредством Axons.Стимулы внешней среды или сигналы органов чувств воспринимаются дендритами. Эти входы создают электрические импульсы, которые быстро проходят через нейронную сеть. Затем нейрон может отправить сообщение другому нейрону для решения проблемы или не отправлять его вперед.

ИНС состоят из нескольких nodes, имитирующие биологические neuronsчеловеческого мозга. Нейроны связаны связями и взаимодействуют друг с другом. Узлы могут принимать входные данные и выполнять простые операции с данными. Результат этих операций передается другим нейронам. Выход на каждом узле называется егоactivation или же node value.

Каждая ссылка связана с weight.ИНС способны к обучению, которое происходит путем изменения значений веса. На следующем рисунке показана простая ИНС -

Типы искусственных нейронных сетей

Есть две топологии искусственной нейронной сети - FeedForward и Feedback.

FeedForward ANN

В этой ИНС информационный поток является однонаправленным. Блок отправляет информацию другому блоку, от которого он не получает никакой информации. Петли обратной связи отсутствуют. Они используются при генерации / распознавании / классификации образов. У них есть фиксированные входы и выходы.

FeedBack ANN

Здесь разрешены петли обратной связи. Они используются в адресной памяти.

Работа ИНС

На представленных схемах топологии каждая стрелка представляет соединение между двумя нейронами и указывает путь для потока информации. Каждое соединение имеет вес, целое число, которое контролирует сигнал между двумя нейронами.

Если сеть дает «хороший или желаемый» результат, нет необходимости корректировать веса. Однако, если сеть генерирует «плохой или нежелательный» результат или ошибку, то система изменяет веса, чтобы улучшить последующие результаты.

Машинное обучение в ИНС

ИНС способны учиться, и их нужно обучать. Есть несколько стратегий обучения -

  • Supervised Learning- В нем участвует учитель, более ученый, чем сама ИНС. Например, учитель подает пример данных, ответы на которые учитель уже знает.

    Например, распознавание образов. ИНС делает предположения при распознавании. Затем учитель предоставляет ответы в ИНС. Затем сеть сравнивает свои догадки с «правильными» ответами учителя и вносит корректировки в соответствии с ошибками.

  • Unsupervised Learning- Требуется, когда нет примерного набора данных с известными ответами. Например, поиск скрытого узора. В этом случае кластеризация, т.е. разделение набора элементов на группы в соответствии с каким-то неизвестным шаблоном, выполняется на основе существующих наборов данных.

  • Reinforcement Learning- Эта стратегия построена на наблюдении. ИНС принимает решение, наблюдая за своим окружением. Если наблюдение отрицательное, сеть корректирует свои веса, чтобы в следующий раз иметь возможность принять другое требуемое решение.

Алгоритм обратного распространения

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

Сети обратного распространения идеальны для простых задач по распознаванию образов и отображению.

Байесовские сети (BN)

Это графические структуры, используемые для представления вероятностной взаимосвязи между набором случайных величин. Байесовские сети также называютBelief Networks или же Bayes Nets. BNs рассуждают о неопределенной области.

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

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

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

BN могут одновременно обрабатывать многозначные переменные. Переменные BN состоят из двух измерений -

  • Диапазон предлогов
  • Вероятность, присвоенная каждому из предлогов.

Рассмотрим конечное множество X = {X 1 , X 2 ,…, X n } дискретных случайных величин, где каждая переменная X i может принимать значения из конечного набора, обозначенного Val (X i ). Если существует направленная ссылка от переменной X i к переменной X j , тогда переменная X i будет родительской для переменной X j, показывающей прямые зависимости между переменными.

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

Построение байесовской сети

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

Example problem- Рак легких. Больной страдает одышкой. Он посещает врача, подозревая, что у него рак легких. Врач знает, что, кроме рака легких, у пациента могут быть и другие заболевания, например туберкулез и бронхит.

Gather Relevant Information of Problem

  • Пациент курит? Если да, то высоки шансы на рак и бронхит.
  • Подвержен ли пациент загрязнению воздуха? Если да, то какое загрязнение воздуха?
  • Положительный рентгеновский снимок указывает на туберкулез или рак легких.

Identify Interesting Variables

Инженер по знаниям пытается ответить на вопросы -

  • Какие узлы представлять?
  • Какие ценности они могут принять? В каком состоянии они могут быть?

А пока давайте рассмотрим узлы только с дискретными значениями. Переменная должна принимать только одно из этих значений за раз.

Common types of discrete nodes are -

  • Boolean nodes - Они представляют предложения, принимающие двоичные значения ИСТИНА (T) и ЛОЖЬ (F).

  • Ordered values- Узел « Загрязнение» может представлять и принимать значения от {низкий, средний, высокий}, описывающие степень воздействия загрязнения на пациента.

  • Integral values- Узел под названием « Возраст» может представлять возраст пациента с возможными значениями от 1 до 120. Даже на этой ранней стадии делается выбор моделирования.

Возможные узлы и значения для примера рака легких -

Имя узла Тип Значение Создание узлов
Polution Двоичный {НИЗКИЙ, ВЫСОКИЙ, СРЕДНИЙ}
Курильщик Булево {ИСТИНА, ФАСЛ}
Рак легких Булево {ИСТИНА, ФАСЛ}
Рентгеновский снимок Двоичный {Позитивный негативный}

Create Arcs between Nodes

Топология сети должна отражать качественные отношения между переменными.

Например, что вызывает у пациента рак легких? - Загрязнение и курение. Затем добавьте дуги от узла Загрязнение и узла Смокера к узлу Рак легких.

Точно так же, если у пациента рак легких, результат рентгена будет положительным. Затем добавьте дуги от узла Lung-Cancer к узлу X-Ray.

Specify Topology

Традиционно БС раскладывают так, чтобы дуги смотрели сверху вниз. Набор родительских узлов узла X задается Родителями (X).

Узел Рак легких имеет двух родителей (причины или причины): Загрязнение и Курильщик , а узел Курильщик -ancestorузла X-Ray . Точно так же рентген является дочерним (следствием или следствием) узла рака легкого иsuccessorузлов Smoker и Pollution.

Conditional Probabilities

Теперь количественно оцените отношения между подключенными узлами: это делается путем определения условного распределения вероятностей для каждого узла. Поскольку здесь рассматриваются только дискретные переменные, это принимает формуConditional Probability Table (CPT).

Во-первых, для каждого узла нам нужно просмотреть все возможные комбинации значений этих родительских узлов. Каждая такая комбинация называетсяinstantiationродительского набора. Для каждого отдельного экземпляра значений родительского узла нам нужно указать вероятность, которую примет дочерний элемент.

Например, родители узла рака легких - Загрязнение и курение. Они принимают возможные значения = {(H, T), (H, F), (L, T), (L, F)}. CPT определяет вероятность рака для каждого из этих случаев как <0,05, 0,02, 0,03, 0,001> соответственно.

Каждый узел будет иметь условную вероятность, связанную следующим образом:

Приложения нейронных сетей

Они могут выполнять задачи, которые легки для человека, но трудны для машины -

  • Aerospace - Самолеты с автопилотом, обнаружение неисправностей воздушных судов.

  • Automotive - Автомобильные системы наведения.

  • Military - Ориентация и управление оружием, отслеживание цели, распознавание объектов, распознавание лиц, идентификация сигнала / изображения.

  • Electronics - Предсказание кодовой последовательности, компоновка микросхемы, анализ отказов микросхемы, машинное зрение, синтез голоса.

  • Financial - Оценка недвижимости, кредитный консультант, проверка ипотечных кредитов, рейтинг корпоративных облигаций, программа торговли портфелем, корпоративный финансовый анализ, прогнозирование стоимости валюты, программы для чтения документов, оценщики кредитных заявок.

  • Industrial - Контроль производственного процесса, проектирование и анализ продукции, системы контроля качества, анализ качества сварки, прогнозирование качества бумаги, анализ конструкции химической продукции, динамическое моделирование систем химического процесса, анализ технического обслуживания оборудования, тендеры по проектам, планирование и управление

  • Medical - Анализ раковых клеток, анализ ЭЭГ и ЭКГ, дизайн протезов, оптимизатор времени трансплантации.

  • Speech - Распознавание речи, классификация речи, преобразование текста в речь.

  • Telecommunications - Сжатие изображений и данных, автоматизированные информационные услуги, устный перевод в реальном времени.

  • Transportation - Диагностика тормозной системы грузовика, планирование транспортных средств, системы маршрутизации.

  • Software - Распознавание образов в распознавании лиц, оптическом распознавании символов и т. Д.

  • Time Series Prediction - ИНС используются для прогнозирования запасов и стихийных бедствий.

  • Signal Processing - Нейронные сети можно обучить обрабатывать звуковой сигнал и соответствующим образом фильтровать его в слуховых аппаратах.

  • Control - ИНС часто используются для принятия решений по управлению физическими транспортными средствами.

  • Anomaly Detection - Поскольку ИНС являются экспертами в распознавании шаблонов, их также можно обучить генерировать выходные данные, когда происходит что-то необычное, не совпадающее с шаблоном.

ИИ развивается с такой невероятной скоростью, что иногда кажется волшебной. Среди исследователей и разработчиков существует мнение, что ИИ может стать настолько сильным, что людям будет трудно его контролировать.

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

Угроза конфиденциальности

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

Угроза человеческому достоинству

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

Угроза безопасности

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

Вот список часто используемых терминов в области ИИ -

Старший Нет Термин и значение
1

Agent

Агенты - это системы или программное обеспечение, способные работать автономно, целенаправленно и рассуждать, направленные на достижение одной или нескольких целей. Их также называют помощниками, брокерами, ботами, дроидами, интеллектуальными агентами и программными агентами.

2

Autonomous Robot

Робот свободен от внешнего управления или влияния и может самостоятельно управлять собой.

3

Backward Chaining

Стратегия работы в обратном направлении по причине / причине проблемы.

4

Blackboard

Это внутренняя память компьютера, которая используется для связи между взаимодействующими экспертными системами.

5

Environment

Это часть реального или вычислительного мира, в которой живет агент.

6

Forward Chaining

Стратегия продвижения вперед для вывода / решения проблемы.

7

Heuristics

Это знания, основанные на пробах и ошибках, оценках и экспериментах.

8

Knowledge Engineering

Получение знаний от специалистов-кадров и других ресурсов.

9

Percepts

Это формат, в котором агент получает информацию о среде.

10

Pruning

Отказ от ненужных и не относящихся к делу соображений в системах ИИ.

11

Rule

Это формат представления базы знаний в Экспертной системе. Это в форме IF-THEN-ELSE.

12

Shell

Оболочка - это программное обеспечение, которое помогает в разработке механизма вывода, базы знаний и пользовательского интерфейса экспертной системы.

13

Task

Это цель, которую пытается достичь агент.

14

Turing Test

Тест, разработанный Алланом Тьюрингом для проверки интеллекта машины по сравнению с интеллектом человека.