- 浏览: 135088 次
- 性别:
- 来自: 福建省莆田市
文章分类
最新评论
-
houruiming:
tks for your info which helps m ...
setcontent和setcontentobject用的是同一片内存 -
turingfellow:
in.tftpd -l -s /home/tmp -u ro ...
commands -
turingfellow:
LINUX下的网络设置 ifconfig ,routeLINU ...
commands -
turingfellow:
安装 linux loopbackyum install um ...
commands
¥£§¤?|¨§¨
This paper presents a methodology for agent-oriented analysis and
design.The methodology is general,in that it is applicable to
a wide range of multi-agent systems,and comprehensive,in that
it deals with both the macro-level(societal)and the micro-level
(agent)aspects of systems.The methodology is founded on the
view of a system as a computational organisation consisting of var-
ious interacting roles.We illustrate the methodology through a case
study(an agent-based business process management system).
¨"$!&#%')¨(!
Progress in software engineering over the past two decades has pri-
marily been made through the development of increasingly power-
ful and natural abstractions with which to model and develop com-
plex systems.Procedural abstraction,abstract data types,and,most
recently,objects,are all examples of such abstractions.It is our
belief that agents represent a similar advance in abstraction:they
may be used by software developers to more naturally understand,
model,and develop an important class of complex distributed sys-
tems.
If agents are to realise their potential as a software engineer-
ing paradigm,then it is necessary to develop software engineering
techniques that are specifically tailored to them.Existing software
development techniques(for example,object-oriented analysis and
design[1,5])will simply be unsuitable for this task.There is a fun-
damental mismatch between the concepts used by object-oriented
developers(and indeed,by other mainstream software engineer-
ing paradigms)and the agent-oriented view[20,22].In particular,
extant approaches fail to adequately capture an agent’s flexible,au-
tonomous problem-solving behaviour,the richness of an agent’s in-
teractions,and the complexity of an agent system’s organisational
structures.For these reasons,this paper outlines a methodology
that has been specifically tailored to the analysis and design of
agent-based systems.
The remainder of this paper is structured as follows.We begin,
in the following sub-section,by discussing the characteristics of
applications for which we believe our analysis and design method-
ology is appropriate.Section 2 gives an overview of the main con-
cepts used by the methodology.Agent-based analysis is discussed
in section 3,and design in section 4.The methodology is demon-
strated by means of a case study in section 5,where we show how
it was applied to the design of a real-world agent-based system for
business process management[13].Related work is discussed in
section 6,and some conclusions are presented in section 7.
10&!23§(
5746
89@?¨A9B(?|¨)(@|
Before proceeding,it is worth commenting on the scope of our
work,and in particular,on the characteristics of domains for which
we believe the methodology is appropriate.It is intended that the
methodology be appropriate for the development of systems such
as ADEPT[13]and ARCHON[12].These are large-scale real-world
applications,with the following main characteristics:
C
Agents are coarse-grained computational systems,each mak-
ing use of significant computational resources(think of each
agent as having the resources of a UNIX process.)
C
It is assumed that the goal is to obtain a system that max-
imises some global quality measure,but which may be sub-
optimal from the point of view of the system components.
Our methodology is not intended for systems that admit the
possibility of true conflict.
C
Agents are heterogeneous,in that different agents may be im-
plemented using different programming languages and tech-
niques.We make no assumptions about the delivery plat-
form.
C
The overall system contains a comparatively small number
of agents(less than 100).
The methodology we propose is comprehensive,in that it deals
with both the macro(societal)level and the micro(agent)level
aspects of design.It represents an advance over previous agent-
oriented methodologies in that it is neutral with respect to both the
target domain and the agent architecture(see section 6 for a more
detailed comparison).
D
£
4
!
E9A§F¨§%HPGIH§32A81QH!SR
Our methodology is intended to allow an analyst to go systemat-
ically from a statement of requirements to a design that is suffi-
ciently detailed that it can be implemented directly.In applying
the methodology,the analyst moves from abstract to increasingly
concrete concepts.Each successive move introduces greater imple-
mentation bias,and shrinks the space of possible systems that could
be implemented to satisfy the original requirements statement.
The methodology borrows some terminology and notation from
object-oriented analysis and design,(specifically,FUSION[5]).How-
ever,it is not simply a naive attempt to apply such methods to
agent-oriented development.Rather,our methodology provides an
agent-specific set of concepts through which a software engineer
can understand and model a complex system.In particular,the
methodology encourages a developer to think of building agent-
based systems as a process of organisational design.
The main concepts can be divided into two categories:abstract
and concrete.Abstract entities are those used during analysis to
conceptualise the system,but which do not necessarily have any
direct realisation within the system.Concrete entities,in contrast,
are used within the design process,and will typically have direct
counterparts in the run-time system.
The most abstract entity in our concept hierarchy is the system
—see Figure 1.Although the term“system”is used in its stan-
dard sense,it also has a related meaning when talking about an
agent-based system,to mean“society”or“organisation”.That is,
we think of an agent-based system as an artificial society or organ-
isation.
The idea of a system as a society is useful when thinking about
the next level in the concept hierarchy:roles.It may seem strange
to think of a computer system as being defined by a set of roles,but
the idea is quite natural when adopting an organisational view of the
world.Consider a human organisation such as a typical company.
The company has roles such as“president”,“vice president”,and
so on.Note that in a concrete realisation of a company,these roles
will be instantiated with actual individuals:there will be an indi-
vidual who takes on the role of president,an individual who takes
on the role of vice president,and so on.However,the instantiation
is not necessarily static.Throughout the company’s lifetime,many
individuals may take on the role of company president,for exam-
ple.Also,there is not necessarily a one-to-one mapping between
roles and individuals.It is not unusual(particularly in small or in-
formally defined organisations)for one individual to take on many
roles.For example,a single individual might take on the role of
“tea maker”,“mail fetcher”,and so on.Conversely,there may be
many individuals that take on a single role,e.g.,“salesman”.
A role is defined by three attributes:responsibilities,permis-
sions,and protocols.Responsibilities determine functionality and,
as such,are perhaps the key attribute associated with a role.An ex-
ample responsibility associated with the role of company president
might be calling the shareholders meeting every year.Responsi-
bilities are divided into two types:liveness properties and safety
properties[18].Liveness properties intuitively state that“some-
thing good happens”.They describe those states of affairs that an
agent must bring about,given certain environmental conditions.In
contrast,safety properties are invariants.Intuitively,a safety prop-
erty states that“nothing bad happens”(i.e.,that an acceptable state
of affairs is maintained across all states of execution).An exam-
ple might be“ensure the reactor temperature always remains in the
range 0-100”.
In order to realise responsibilities,a role is usually associated
with a set of permissions.Permissions are the“rights”associated
with a role.The permissions of a role thus identify the resources
that are available to that role in order to realise its responsibilities.
In the kinds of system that we have typically modelled,permissions
tend to be information resources.For example,a role might have
associated with it the ability to read a particular item of informa-
tion,or to modify another piece of information.A role can also
have the ability to generate information.
Finally,a role is also identified with a number of protocols,
which define the way that it can interact with other roles.For ex-
ample,a“seller”role might have the protocols“Dutch auction”and
“English auction”associated with it.
In summary,analysis and design can be thought of as a process
of developing increasingly detailed models of the system to be con-
structed.The main models used in our approach are summarised in
Figure 2,and elaborated in sections 3 and 4.
T
£
HG UE|(|
The objective of the analysis stage is to develop an understanding
of the system and its structure(without reference to any implemen-
tation detail).In our case,this understanding is captured in the
system’s organisation.In more detail,we view an organisation as
a collection of roles,that stand in certain relationships to one an-
other,and that take part in systematic,institutionalised patterns of
interactions with other roles.To define an organisation,it therefore
suffices to define the roles in the organisation,how these roles re-
late to one another,and how a role can interact with other roles.
The aim of the analysis stage is,therefore,to model the system as
a multi-agent organisation in precisely this way.Thus,the organi-
sation model is comprised of two further models:the roles model
(section 3.1)and the interaction model(section 3.2).
$TWVY¥X6
5Aa`!&G bA|3dc$!#H§AG
The roles model identifies the key roles in the system.Here a role
can be viewed as an abstract description of an entity’s expected
function.In other terms,a role is more or less identical to the notion
of an office in the sense that“prime minister”,“attorney general
This paper presents a methodology for agent-oriented analysis and
design.The methodology is general,in that it is applicable to
a wide range of multi-agent systems,and comprehensive,in that
it deals with both the macro-level(societal)and the micro-level
(agent)aspects of systems.The methodology is founded on the
view of a system as a computational organisation consisting of var-
ious interacting roles.We illustrate the methodology through a case
study(an agent-based business process management system).
¨"$!&#%')¨(!
Progress in software engineering over the past two decades has pri-
marily been made through the development of increasingly power-
ful and natural abstractions with which to model and develop com-
plex systems.Procedural abstraction,abstract data types,and,most
recently,objects,are all examples of such abstractions.It is our
belief that agents represent a similar advance in abstraction:they
may be used by software developers to more naturally understand,
model,and develop an important class of complex distributed sys-
tems.
If agents are to realise their potential as a software engineer-
ing paradigm,then it is necessary to develop software engineering
techniques that are specifically tailored to them.Existing software
development techniques(for example,object-oriented analysis and
design[1,5])will simply be unsuitable for this task.There is a fun-
damental mismatch between the concepts used by object-oriented
developers(and indeed,by other mainstream software engineer-
ing paradigms)and the agent-oriented view[20,22].In particular,
extant approaches fail to adequately capture an agent’s flexible,au-
tonomous problem-solving behaviour,the richness of an agent’s in-
teractions,and the complexity of an agent system’s organisational
structures.For these reasons,this paper outlines a methodology
that has been specifically tailored to the analysis and design of
agent-based systems.
The remainder of this paper is structured as follows.We begin,
in the following sub-section,by discussing the characteristics of
applications for which we believe our analysis and design method-
ology is appropriate.Section 2 gives an overview of the main con-
cepts used by the methodology.Agent-based analysis is discussed
in section 3,and design in section 4.The methodology is demon-
strated by means of a case study in section 5,where we show how
it was applied to the design of a real-world agent-based system for
business process management[13].Related work is discussed in
section 6,and some conclusions are presented in section 7.
10&!23§(
5746
89@?¨A9B(?|¨)(@|
Before proceeding,it is worth commenting on the scope of our
work,and in particular,on the characteristics of domains for which
we believe the methodology is appropriate.It is intended that the
methodology be appropriate for the development of systems such
as ADEPT[13]and ARCHON[12].These are large-scale real-world
applications,with the following main characteristics:
C
Agents are coarse-grained computational systems,each mak-
ing use of significant computational resources(think of each
agent as having the resources of a UNIX process.)
C
It is assumed that the goal is to obtain a system that max-
imises some global quality measure,but which may be sub-
optimal from the point of view of the system components.
Our methodology is not intended for systems that admit the
possibility of true conflict.
C
Agents are heterogeneous,in that different agents may be im-
plemented using different programming languages and tech-
niques.We make no assumptions about the delivery plat-
form.
C
The overall system contains a comparatively small number
of agents(less than 100).
The methodology we propose is comprehensive,in that it deals
with both the macro(societal)level and the micro(agent)level
aspects of design.It represents an advance over previous agent-
oriented methodologies in that it is neutral with respect to both the
target domain and the agent architecture(see section 6 for a more
detailed comparison).
D
£
4
!
E9A§F¨§%HPGIH§32A81QH!SR
Our methodology is intended to allow an analyst to go systemat-
ically from a statement of requirements to a design that is suffi-
ciently detailed that it can be implemented directly.In applying
the methodology,the analyst moves from abstract to increasingly
concrete concepts.Each successive move introduces greater imple-
mentation bias,and shrinks the space of possible systems that could
be implemented to satisfy the original requirements statement.
The methodology borrows some terminology and notation from
object-oriented analysis and design,(specifically,FUSION[5]).How-
ever,it is not simply a naive attempt to apply such methods to
agent-oriented development.Rather,our methodology provides an
agent-specific set of concepts through which a software engineer
can understand and model a complex system.In particular,the
methodology encourages a developer to think of building agent-
based systems as a process of organisational design.
The main concepts can be divided into two categories:abstract
and concrete.Abstract entities are those used during analysis to
conceptualise the system,but which do not necessarily have any
direct realisation within the system.Concrete entities,in contrast,
are used within the design process,and will typically have direct
counterparts in the run-time system.
The most abstract entity in our concept hierarchy is the system
—see Figure 1.Although the term“system”is used in its stan-
dard sense,it also has a related meaning when talking about an
agent-based system,to mean“society”or“organisation”.That is,
we think of an agent-based system as an artificial society or organ-
isation.
The idea of a system as a society is useful when thinking about
the next level in the concept hierarchy:roles.It may seem strange
to think of a computer system as being defined by a set of roles,but
the idea is quite natural when adopting an organisational view of the
world.Consider a human organisation such as a typical company.
The company has roles such as“president”,“vice president”,and
so on.Note that in a concrete realisation of a company,these roles
will be instantiated with actual individuals:there will be an indi-
vidual who takes on the role of president,an individual who takes
on the role of vice president,and so on.However,the instantiation
is not necessarily static.Throughout the company’s lifetime,many
individuals may take on the role of company president,for exam-
ple.Also,there is not necessarily a one-to-one mapping between
roles and individuals.It is not unusual(particularly in small or in-
formally defined organisations)for one individual to take on many
roles.For example,a single individual might take on the role of
“tea maker”,“mail fetcher”,and so on.Conversely,there may be
many individuals that take on a single role,e.g.,“salesman”.
A role is defined by three attributes:responsibilities,permis-
sions,and protocols.Responsibilities determine functionality and,
as such,are perhaps the key attribute associated with a role.An ex-
ample responsibility associated with the role of company president
might be calling the shareholders meeting every year.Responsi-
bilities are divided into two types:liveness properties and safety
properties[18].Liveness properties intuitively state that“some-
thing good happens”.They describe those states of affairs that an
agent must bring about,given certain environmental conditions.In
contrast,safety properties are invariants.Intuitively,a safety prop-
erty states that“nothing bad happens”(i.e.,that an acceptable state
of affairs is maintained across all states of execution).An exam-
ple might be“ensure the reactor temperature always remains in the
range 0-100”.
In order to realise responsibilities,a role is usually associated
with a set of permissions.Permissions are the“rights”associated
with a role.The permissions of a role thus identify the resources
that are available to that role in order to realise its responsibilities.
In the kinds of system that we have typically modelled,permissions
tend to be information resources.For example,a role might have
associated with it the ability to read a particular item of informa-
tion,or to modify another piece of information.A role can also
have the ability to generate information.
Finally,a role is also identified with a number of protocols,
which define the way that it can interact with other roles.For ex-
ample,a“seller”role might have the protocols“Dutch auction”and
“English auction”associated with it.
In summary,analysis and design can be thought of as a process
of developing increasingly detailed models of the system to be con-
structed.The main models used in our approach are summarised in
Figure 2,and elaborated in sections 3 and 4.
T
£
HG UE|(|
The objective of the analysis stage is to develop an understanding
of the system and its structure(without reference to any implemen-
tation detail).In our case,this understanding is captured in the
system’s organisation.In more detail,we view an organisation as
a collection of roles,that stand in certain relationships to one an-
other,and that take part in systematic,institutionalised patterns of
interactions with other roles.To define an organisation,it therefore
suffices to define the roles in the organisation,how these roles re-
late to one another,and how a role can interact with other roles.
The aim of the analysis stage is,therefore,to model the system as
a multi-agent organisation in precisely this way.Thus,the organi-
sation model is comprised of two further models:the roles model
(section 3.1)and the interaction model(section 3.2).
$TWVY¥X6
5Aa`!&G bA|3dc$!#H§AG
The roles model identifies the key roles in the system.Here a role
can be viewed as an abstract description of an entity’s expected
function.In other terms,a role is more or less identical to the notion
of an office in the sense that“prime minister”,“attorney general
发表评论
-
protocols
2011-04-03 19:22 924<!-- The protocols capabilit ... -
dfcap
2011-04-03 19:15 874<!-- The df capability has a ... -
booktrading /seller
2011-03-29 23:19 927<html><head><tit ... -
booktrading / manager
2011-03-29 23:18 1086<html><head><tit ... -
booktrading / common
2011-03-29 23:17 985<html><head><tit ... -
booktrading / buyer
2011-03-29 23:13 843<!-- <H3>The buyer age ... -
tomcat的context说明书
2011-03-20 17:39 803http://tomcat.apache.org/tomcat ... -
msyql的select语法
2010-09-13 22:52 107513.2.7. SELECT语法 13.2.7.1. ... -
zotero与word集成
2010-09-11 08:50 1765Manually Installing the Zotero ... -
university 2/n
2010-08-24 07:54 896Chapter 1.Introduction of regis ... -
university 1/n
2010-08-24 07:53 938chapter? Introduction ?.?The st ... -
Sun Java Bugs that affect lucene
2010-08-23 08:59 734Sometimes Lucene runs amok of b ... -
Snowball分词
2010-08-22 13:07 1222using System; using Lucene.Net. ... -
penn tree bank 6/6
2010-08-20 07:09 91711 This use of 12 Contact the - ... -
penn tree bank 5/n
2010-08-19 07:40 920always errs on the side of caut ... -
penn tree bank 4/n
2010-08-19 07:39 8164. Bracketing 4.1 Basic Methodo ... -
penn tree bank 3/n
2010-08-15 23:31 8182.3.1 Automated Stage. During t ... -
penn tree bank 2/n
2010-08-15 23:30 1503Mitchell P Marcus et al. Buildi ... -
capabilities 3/3
2010-08-11 22:58 77401<capability xmlns="ht ... -
capabilities 2/3
2010-08-11 22:57 737Fig.3.Element creation cases:a) ...
相关推荐
2. **80-cf063-1_aa_qcc300x_gaia_command_reference_manual.pdf**:这是 QCC300x 系列芯片的 GAIA 命令参考手册。GAIA 是 CSR 的一种二进制命令接口,用于在应用处理器和蓝牙芯片之间进行通信。手册中会列出所有...
1. GAIA插件概述: GAIA是一款Unity引擎中使用的地形生成插件,它的主要功能是帮助用户创建和管理游戏中的地形。GAIA插件版本1.9.2提供了一个系统,使开发者能够构建外观统一且美观的地形环境。这个系统按照程序化的...
Gaia是一套完整的互动网站制作框架。它定义了网站的基本数据流,采用xml进行结构配置和资源管理。各个页面之间以transitionIn,transitionInComplete,transitionOut,transitionOutComplete等步骤串联在一起。Gaia...
获得Unity的“最佳艺术工具”奖,基于向导的Gaia简化了地形,纹理和风格化到逼真世界的放置。Gaia使生成详细的场景和水平变得简单和快速,消除了数周的手工工作。 新的模块化2023版本允许您选择安装哪些组件以节省...
安卓APK,支持安卓4.4版本以上,支持CSRA63120/CSRA63220/CSRA63210/CSRA63225/CSRA64110/CSRA64210/CSRA64215/CSRA8670/CSRA8675蓝牙模块的GAIA控制。
Gaia是一套完整的互动网站制作框架。它定义了网站的基本数据流,采用xml进行结构配置和资源管理。各个页面之间以transitionIn,transitionInComplete,transitionOut,transitionOutComplete等步骤串联在一起。Gaia...
1. **地形生成**:Gaia Pro的核心功能之一是其强大的地形生成引擎。它允许用户通过简单的点击和拖拽操作,自动生成具有复杂地貌特征的大型场景。你可以调整山峰的高度、河流的走势、森林的分布等,生成多样且真实的...
##### 1. **GAIA概述** - **目标与功能**:GAIA旨在构建一个端到端、主机无关的生态系统,支持主机应用程序访问设备功能。通过GAIA,用户能够通过移动应用个性化配置配件,并且能够控制那些无法通过设备人机界面...
Go-Gaia是一个创新的开源自动化平台,专为开发者设计,允许他们使用各种编程语言轻松构建强大、高效的处理管道。这个平台的核心理念是简化复杂的自动化流程,让开发人员能够更专注于他们的核心业务逻辑,而不是底层...
1. **蓝牙技术**:蓝牙是一种短距离无线通信技术,分为经典蓝牙和蓝牙低功耗两种类型。经典蓝牙主要应用于音频流传输和数据交换,而蓝牙低功耗则适用于物联网设备,如健康监测、智能家居等,具有低功耗、低成本和...
Gaia ajax 感觉不错
Gaia Pro主要功能: -多瓦片地形支持; -强大的生物群落创建和混合系统; -无损编辑的大规模世界创作; -大规模的世界流,剔除和浮点修复支持; -模块化向导驱动的设计,可随意使用或少用; -具有位置和季节变化,SS...
unity地形插件Gaia Pro - Terrain Scene Generator v2.2.4
gaia, 一种分散的高性能存储系统 :分布式高性能存储系统开发人员注意:这个文档描述了 Gaia,只能处理单个读者和作者( 例如 。 没有数据共享。这里的文档将被Gaia的文档取代,它允许多个读者。 Gaia是一个完全不同...
1. **固件升级**:通过Android GAIA Control,用户可以方便地检查设备当前的固件版本,并下载并安装最新的固件更新。这通常涉及到通过Wi-Fi或蓝牙连接设备,然后安全地传输和安装新的固件包。 2. **设备诊断**:...
在提供的压缩包中,除了主应用文件"android_gaiaclient_1_0_55_release.apk"外,还有一个名为"notice.txt"的文件。这个文件通常包含软件的使用许可协议、更新日志或重要通知等内容,用户在安装和使用前应当仔细阅读...
"GAIA_Client.SRC_IOS.7z"这个压缩包文件,正是针对这些芯片的官方iOS版APP的源代码。由于苹果App Store的上架政策,我们无法直接下载到预编译的IPA安装包,因此,这份源代码对于开发者来说就显得尤为珍贵,它为我们...
Unity 地形工具 Gaia
1. **Gaia 的核心概念** - **用户界面(UI)**:Gaia 负责设计和实现 Firefox OS 的前端界面,包括系统设置、应用启动器、电话、短信等所有用户直接交互的部分。 - **HTML5 应用**:由于 Gaia 是基于 HTML5、CSS ...