Программный агент. Интеллектуальные агенты

Отправить свою хорошую работу в базу знаний просто. Используйте форму, расположенную ниже

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

Подобные документы

    Анализ и виды интеллектуальных агентов в системе дистанционного обучения и их характеристики. Построение интеллектуального агента глоссария на платформе Jadex с помощью XML формата. Среда разработки и описание интеллектуального агента с помощью BDI.

    курсовая работа , добавлен 10.02.2011

    Технология программных агентов. Форматы метаданных, использующиеся для описания электронных ресурсов. Разработка интеллектуальных агентов. Среда разработки Jadex для построения интеллектуальных агентов. BDI модель интеллектуального агента ресурсов.

    курсовая работа , добавлен 20.02.2011

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

    курсовая работа , добавлен 23.10.2014

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

    презентация , добавлен 25.06.2013

    Apple I как ранний персональный компьютер, первый компьютер Apple Computer. Основные характеристики Rhapsody, Blue Box. История создания Mac OS X, принципы ее работы, значение и направления использования. Существующие типы и формы данной системы.

    курсовая работа , добавлен 26.11.2014

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

    курсовая работа , добавлен 13.04.2015

    Персональный компьютер - инструмент доступа в компьютерные сети. Мобильные (Ноутбук) ПК - работа на небольшом свободном пространстве. Персональный информационный менеджер, архитектура, портативные устройства, функции. Применение органайзеров и КПК.

    Интеллектуальные агенты

    Проблематика интеллектуальных агентов и мультиагентных систем (МАС) имеет почти 40-летнюю историю и сформировалась на основе результатов, полученных в рамках работ по распределенному ИИ (DAI), распределенному решению задач (DPS) и параллельному ИИ (PAI). Данная тематика интегрирует достижения в области компьютерных сетей и открытых систем, ИИ и информационных технологий .

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

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

    Интеллектуальные агенты должны обладать следующими свойствами:

    * автономность – способность функционировать без вмешательства со стороны своего владельца и осуществлять контроль внутреннего состояния и своих действий;

    * социальное поведение – возможность взаимодействия и коммуникации с другими агентами;

    * реактивность – адекватное восприятие среды и соответствующие реакции на ее изменения;

    * активность – способность генерировать цели и действовать рациональным образом для их достижения;

    * базовые знания – знания агента о себе, окружающей среде, включая других агентов, которые не меняются в рамках ЖЦ агента;

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

    * цели – совокупность состояний, на достижение которых направлено текущее поведение агента;

    * желания – состояния или ситуации, достижение которых для агента важно;

    * обязательства – задачи, которые берет на себя агент по просьбе других агентов;

    * намерения – то, что агент должен делать в силу своих обязательств.

    В зависимости от концепций, выбранных для организации МАС, обычно выделяются три базовых класса архитектур:

    * архитектуры, которые базируются на принципах и методах работы со знаниями;

    * архитектуры, основанные на поведенческих моделях типа «стимул–реакция»;

    * гибридные архитектуры.

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

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

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

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

    * расширяемость/масштабируемость (возможность изменения набора составляющих систем);

    * мобильность/переносимость (простота переноса ПС на разные аппаратно-программные платформы);

    * интероперабельность (способность к взаимодействию с другими системами);

    * дружелюбность, легкая управляемость.

    Одним из результатов внедрения концепции открытых систем в практику стало распространение архитектуры «клиент - сервер». В настоящее время выделяются следующие модели клиент-серверного взаимодействия:

    · «толстый клиент – тонкий сервер». Серверная часть реализует только доступ к ресурсам, а основная часть приложения находится на клиенте;

    · «тонкий клиент – толстый сервер». Модель активно используется в связи с распространением интернет-технологий. Клиентское приложение обеспечивает реализацию интерфейса, а сервер объединяет остальные части приложений.

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

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

    С точки зрения разработки и реализации МАС наиболее эффективными системами поддержки распределенных технологий являются DCOM, Java RMI, COBRA.

    Основная ценность DCOM – предоставление возможности интеграции приложений, реализованных в разных системах программирования.

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

    Основным преимуществом COBRA является интерфейс IDL, унифицирующий средства коммуникации между приложениями.

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

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

    В любой конкретный момент времени оценка рациональности действий агента зависит:

    От показателей производительности;

    Знаний агента о среде, приобретенных ранее;

    Действий, которые могут быть выполнены агентом;

    Последовательности актов восприятия агента, которые произошли

    до настоящего времени.

    Рациональный агент должен иметь способность к обучению и быть автономным.

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

    Пример 9.1. Проблемная среда водителя такси

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

    Классификация вариантов проблемной среды:

    Полностью/частично наблюдаемая: полностью наблюдаемая, если

    датчики фиксируют все необходимые данные;

    Детерминированная/стохастическая: если следующее состояние

    среды определяется текущим и действием агента, то среда

    детерминированная;

    Эпизодическая/последовательная: в эпизодической среде опыт агента

    состоит из неразрывных эпизодов. Каждый эпизод включает в себя

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

    (распознавание дефектных деталей), в последовательных средах

    Агенту следует думать наперед (вождение машины, игра в шахматы);

    Статическая/динамическая: если среда может измениться в ходе

    принятия агентом решения, то она является динамической;

    Дискретная/непрерывная: игра в шахматы - дискретная,

    вождение автомобиля – непрерывная;

    Одноагентная/многоагентная (мультиагентная): решение кроссворда,

    диагностика – одноагентная, игра в шахматы, вождение

    автомобиля – многоагентная.

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

    агент = архитектура + программа

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

    Существуют четыре основных вида программных агентов, которые лежат в основе почти всех интеллектуальных систем:

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

    Рефлексивные агенты, основанные на модели;

    Агенты, действующие на основе цели;

    Агенты, действующие на основе полезности.

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

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

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

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

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

    Структура обучающего агента включает четыре концептуальных компонента.

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

    Определение

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

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

    Чем не является агент

    Нет никакого особого смысла в том, чтобы расписать, что является агентом, а что нет. Тем не менее, сопоставление термина с близкими понятиями может прояснить его значение.

    Интуитивное отличие агентов от объектов

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

    Отличие интеллектуальных программных агентов от интеллектуальных агентов в искусственном интеллекте

    История

    Концепцию агента можно проследить начиная с модели акторов Карла Хьюитта: «автономный, интерактивный и одновременно исполнящий несколько функций объект, обладающий внутренним состоянием и информационным обменом».

    Выражаясь более академично, программные агенты являются прямой эволюцией многоагентных систем (МАС), которые в свою очередь развились из распределённого искусственного интеллекта (РИИ), распределённого решателя задач (РРЗ) и параллельного искусственного интеллекта (ПИИ). Таким образом, программные агенты наследует все характеристики (хорошие и плохие) от РИИ и ИИ .

    «Навигатор по знаниям», созданный в 1987 г. Джоном Скалли, представлял собой видеосвязь между конечным пользователем и агентом. Будучи первым в своём роде, он послужил основой для опытной серии неудачных нисходящих реализаций, вместо того, чтобы шаг за шагом подходить к восходящим методам. Диапазон типов агентов в настоящее время (с 1990 г.) довольно широк: WWW, поисковые системы и т. д.

    Примеры

    Интеллектуальные программные агенты

    Агенты по добыче и анализу данных

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

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

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

    Другие примеры

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

    • User agent - для браузеров WWW.
    • Агент передачи почтовых сообщений - для обслуживания электронной почты, например, Microsoft Outlook . Он общается с почтовым сервером POP3, при этом пользователю нет необходимости знать команды протокола POP3 . Он имеет также набор правил, по которым производится фильтрация почты для пользователей, тем самым избавляя их от проблемы того, чтобы делать это самостоятельно.
    • Агент системы простого управления сетями SNMP .
    • Агент разметки в HTML-формате агентства DARPA .
    • Агент палтформы разработки многоагентных систем Jason.
    • Система разработки искусственных автономных агентов 3APL.
    • Язык программирования для разработки рациональных агентов GOAL.
    • Демоны в UNIX-подобных операционных системах .
    • В Unix-подобных сетевых серверах httpd - демон протокола HTTP , который реализует этот протокол в корне всемирной паутины .
    • Агенты управления, используемые в узлах телекоммуникационных сетей.
    • Моделирование толпы для обеспечения безопасности, а также для трёхмерной графики .
    • Java Agent Template - шаблон создания программных агентов в системе Java (JAT).

    Вопросы разработки

    В развитии агенто-ориентированных систем возникают некоторые интересные вопросы, а именно:

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

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

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

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

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

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

    Агент использует свои методы доступа для входа в локальные и удалённые базы данных при поиске контента. К таким методам доступа относятся, в частности, методы доставки агенту потока новостей, чтения доски объявлений или скачивания страниц из интернета с помощью веб-паука . Контент, который извлекается таким образом, возможно, частично фильтруется - отбираются новости или информация из тех баз данных, которые удовлетворяют поисковому запросу. Далее агент может использовать языковые процессоры для нахождения ключевых слов или идентификационных особенностей контента, который был отобран. Этот абстрагированный смысл (или набор событий), затем передаётся «мыслящему» агенту или машине логического вывода для того, чтобы решить, что делать с новым контентом. Этот процесс сопоставляет контент с экспертными данными или базой знаний, предоставленных пользователем. Если этот процесс находит хорошее соответствие нового контента, агент может использовать другие свои возможности, чтобы провести более детальный поиск по контенту. Наконец, агент может принять решение о характере действий по новому контенту, например, послать уведомление пользователю о том, что произошло важное событие. Это действие проверяется системой безопасности, и затем предоставляются те или иные права пользователю. Агент использует доступный пользователю метод доступа для доставки этого сообщения пользователю. Если пользователь подтверждает, что событие важно, быстро реагируя на уведомление, агент может использовать это событие как обучающий фактор для увеличения весовой функции такого рода событий.

    Воздействие программных агентов

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

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

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



    План:

      Введение
    • 1 Определение
    • 2 Чем не является агент
      • 2.1 Отличие агентов от программ
      • 2.2 Интуитивное отличие агентов от объектов
      • 2.3 Отличие агентов от экспертных систем
      • 2.4 Отличие интеллектуальных программных агентов от интеллектуальных агентов в искусственном интеллекте
    • 3 История
    • 4 Примеры
      • 4.1 Интеллектуальные программные агенты
        • 4.1.1 Агенты-покупатели (роботы по закупкам)
        • 4.1.2 Пользовательские агенты (персональные)
        • 4.1.3 Агенты по мониторингу и наблюдению (предиктивные)
        • 4.1.4 Агенты по добыче и анализу данных
      • 4.2 Другие примеры
    • 5 Вопросы разработки
    • 6 Воздействие программных агентов
    • Примечания

    Введение

    В компьютерных науках програ́ммный аге́нт - это программа, которая вступает в отношение посредничества с пользователем или другой программой. Слово «агент» происходит от латинского agere (делать) и означает соглашение выполнять действия от имени кого-либо. Такие «действия от имени» подразумевают право решать, какие действия (если они нужны) являются целесообразными. Идея состоит в том, что агенты не запускаются непосредственно для решения задачи, а активизируются самостоятельно.

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


    1. Определение

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

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

    2. Чем не является агент

    Нет никакого особого смысла в том, чтобы расписать, что является агентом, а что нет. Тем не менее, сопоставление термина с близкими понятиями может прояснить его значение.

    2.1. Отличие агентов от программ

    В работе Франклина и Грауссера обсуждаются четыре ключевых понятия, по которым агенты отличаются от произвольных программ: реакция на окружающую среду, автономность, целевая ориентация и живучесть.

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


    2.2. Интуитивное отличие агентов от объектов

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

    2.3. Отличие агентов от экспертных систем

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

    2.4. Отличие интеллектуальных программных агентов от интеллектуальных агентов в искусственном интеллекте

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

    3. История

    Концепцию агента можно проследить начиная с модели акторов Карла Хьюитта: «автономный, интерактивный и одновременно исполнящий несколько функций объект, обладающий внутренним состоянием и информационным обменом».

    Выражаясь более академично, программные агенты являются прямой эволюцией многоагентных систем (МАС), которые в свою очередь развились из распределённого искусственного интеллекта (РИИ), распределённого решателя задач (РРЗ) и параллельного искусственного интеллекта (ПИИ). Таким образом, программные агенты наследует все характеристики (хорошие и плохие) от РИИ и ИИ.

    «Навигатор по знаниям», созданный в 1987 г. Джоном Скалли, представлял собой видеосвязь между конечным пользователем и агентом. Будучи первым в своём роде, он послужил основой для опытной серии неудачных нисходящих реализаций, вместо того, чтобы шаг за шагом подходить к восходящим методам. Диапазон типов агентов в настоящее время (с 1990 г.) довольно широк: WWW, поисковые системы и т.д.


    4. Примеры

    4.1. Интеллектуальные программные агенты

    Стефен Хааг в своей работе считает, что существуют только четыре основных типа интеллектуальных программных агентов:

    1. Агенты-покупатели или торговые боты
    2. Пользовательские или персональные агенты
    3. Агенты по мониторингу и наблюдению
    4. Агенты по добыче и анализу данных

    4.1.1. Агенты-покупатели (роботы по закупкам)

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

    4.1.2. Пользовательские агенты (персональные)

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

    • Проверяют вашу электронную почту, сортируют её по вашим предпочтениям и извещают о приходе важных писем.
    • Играют в компьютерные игры, когда ваш противник или патрулирующий игру проявляет активность.
    • Собирают заказанные отчеты новостей для вас. Есть несколько версий таких агентов, в том числе newshub и CNN.
    • Делают поиск информации по вашей теме и вашему запросу.
    • Автоматически заполняют веб-формы для вас, сохраняют вашу информацию для использования в будущем.
    • Сканируют веб-страницы для поиска и выделения текста, который представляет собой «важную» часть информации.
    • «Обсуждают» темы с вами в диапазоне от подсознательного страха до спорта.
    • Содействуют онлайн поиску работы путём сканирования известных досок объявлений о работе и отправки резюме с указанием достоинств, которые соответствуют желаемым критериям.
    • Профилируют синхронизацию разнородных социальных сетей.

    4.1.3. Агенты по мониторингу и наблюдению (предиктивные)

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

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

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


    4.1.4. Агенты по добыче и анализу данных

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

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

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


    4.2. Другие примеры

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

    • User agent - для браузеров WWW.
    • Агент передачи почтовых сообщений - для обслуживания электронной почты, например, Microsoft Outlook . Он общается с почтовым сервером POP3, при этом пользователю нет необходимости знать команды протокола POP3. Он имеет также набор правил, по которым производится фильтрация почты для пользователей, тем самым избавляя их от проблемы того, чтобы делать это самостоятельно.
    • Агент системы простого управления сетями SNMP.
    • Агент разметки в HTML-формате агентства DARPA.
    • Агент палтформы разработки многоагентных систем Jason.
    • Система разработки искусственных автономных агентов 3APL.
    • Язык программирования для разработки рациональных агентов GOAL.
    • Язык описания онтологий для семантической паутины OWL.
    • Демоны в UNIX-подобных операционных системах.
    • В Unix-подобных сетевых серверах httpd - демон протокола HTTP, который реализует этот протокол в корне всемирной паутины.
    • Агенты управления, используемые в узлах телекоммуникационных сетей.
    • Моделирование толпы для обеспечения безопасности, а также для трёхмерной графики.
    • Java Agent Template - шаблон создания программных агентов в системе Java (JAT).

    5. Вопросы разработки

    В развитии агенто-ориентированных систем возникают некоторые интересные вопросы, а именно:

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

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

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

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

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

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

    Агент использует свои методы доступа для входа в локальные и удалённые базы данных при поиске контента. К таким методам доступа относятся, в частности, методы доставки агенту потока новостей, чтения доски объявлений или скачивания страниц из интернета с помощью веб-паука. Контент, который извлекается таким образом, возможно, частично фильтруется - отбираются новости или информация из тех баз данных, которые удовлетворяют поисковому запросу. Далее агент может использовать языковые процессоры для нахождения ключевых слов или идентификационных особенностей контента, который был отобран. Этот абстрагированный смысл (или набор событий), затем передаётся «мыслящему» агенту или машине логического вывода для того, чтобы решить, что делать с новым контентом. Этот процесс сопоставляет контент с экспертными данными или базой знаний, предоставленных пользователем. Если этот процесс находит хорошее соответствие нового контента, агент может использовать другие свои возможности, чтобы провести более детальный поиск по контенту. Наконец, агент может принять решение о характере действий по новому контенту, например, послать уведомление пользователю о том, что произошло важное событие. Это действие проверяется системой безопасности, и затем предоставляются те или иные права пользователю. Агент использует доступный пользователю метод доступа для доставки этого сообщения пользователю. Если пользователь подтверждает, что событие важно, быстро реагируя на уведомление, агент может использовать это событие как обучающий фактор для увеличения весовой функции такого рода событий.


    6. Воздействие программных агентов

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

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

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


    Примечания

    1. Нвана Х. Программные агенты: Обзор. Knowledge Engineering Review, Vol.11, No.3, 205-244, Cambridge University Press (англ.)
    2. Шермер Б. Программные агенты, наблюдение и право на неприкосновенность частной жизни: законодательная база для наблюдения с помощью агентов. Leiden University Press, 2007, p.140. (англ.)
    3. 1 2 3 Вулдридж М., Дженнингс Н. Интеллектуальнве агенты: теория и практика. Knowledge Eng. Rev., vol. 10(2), pp. 115–152, 1995 (англ.)
    4. Франклин, Грауссер. Агент или программа? Таксономия автономных агентов. Springer-Verlag, 1996 - www.msci.memphis.edu/~franklin/AgentProg.html (англ.)
    5. Стюарт Рассел, Питер Норвиг. Искусственный интеллект: Современный подход. Prentice Hall, 2009, ISBN 978-0136042594 (англ.)
    6. Carl Hewitt. Viewing Control Structures as Patterns of Passing Messages. Journal of Artificial Intelligence, June 1977.
    7. Стефен Хааг, Управление информационными системами в информационный век, 2006, р 224-228 (англ.)
    8. Harold E. Popplewell Agents & Applicability - www.agentwaresystems.com/publications/agents.html
    9. А. Серенко, Б. Детлор. Интеллектуальные агенты как инновация, Artificial Intelligence & Society, 18(4), 364-381 - foba.lakeheadu.ca/serenko/papers/Serenko_Detlor_AI_and_Society.pdf (англ.)
    10. А. Серенко, У. Руби, М. Кокосила. Незапланированные эффекты интеллектуальных агентов при использовании в Интернете: Социально-информационный подход. Artificial Intelligence & Society, 21(1-2), 141-166. - foba.lakeheadu.ca/serenko/papers/AI_Society_Serenko_Social_Impacts_of_Agents.pdf (англ.)
    скачать , Программный модуль .