CS 6100 MultiAgent Systems Lecture 1: Introduction Slides adapted from Sobah Abbas Petersen (with permission)
2 Programming has progressed through procedures & functions (no context) abstract data types (data and operations combined) objects to agents
3 The word 'agent' is widely used. Everyone knows what it means. We have press agents, travel agents, real estate agents, FBI agents, secret agents, double agents. Tom Cruise has an agent. So does Margaret Atwood. Sometimes the word 'broker' refers to a kind of agent, for example, a stock broker. But to actually define what the word, agent, means is not so easy. (Similar problems occur with other concepts such as intelligence, or life.) There seem to be almost as many definitions of agent, or agency as there are people trying to define these concepts! So we will look at a few of these attempts at definition. Take your pick or make up your own.
4 Why Agents? When a space probe makes its long flight from Earth to the outer planets, a ground crew is usually required to continually track its progress and decide how to deal with unexpected occurrences. Expensive if quick decisions needed, not practical Nasa: make probes more autonomous Not fiction! NASA’s DS1 is doing it now!
How do we wish we could specify? Google Search Trip to Disney World Hire Faculty for CS at USU Make recommendations for class schedule How would you communicate to system what you want it to do? 5
6 Example ”After a wet and cold winter, you are in need of a last minute holiday somewhere warm. After specifying your requirements to your Personal Digital Assistant (PDA), it converses with a number of different web sites which sell services such as flights and hotel rooms. After hard negotiation on your behalf with a range of sites, your PDA presents you with a package holiday.”
7 Overview Five ongoing trends have marked the history of computing: 1.Ubiquity – everywhere at once Reduction in the cost of computing capability 2.Interconnection Computer systems are networked into large distributed systems 3.Intelligence (MAS) The complexity of tasks that can be automated and delegated to computers 4.Delegation (MAS) Judgment of computer systems are frequently accepted 5.Human-orientation Use concepts and metaphors that reflect how we understand the world. Examples?
8 Concerns Need for computer systems to act in our best interests “The issues addressed in Multiagent systems have profound implications for our understanding of ourselves.” Wooldridge
9 Trends… These trends present major challenges to software developers. e.g. –Delegation – act independently. –Intelligence – act in a way that represents our best interests while interacting with other humans or systems. Need systems that can act effectively on our behalf. Systems must have the ability to cooperate and reach agreements with other systems. New field: Multi-agent Systems
10 Two Key Problems 1.How do we build agents that are capable of independent, autonomous action in order to successfully carry out the tasks that we delegate to them? (Micro aspects) 2.How do we build agents that are capable of interacting (cooperating, coordinating, negotiating) with other agents in order to successfully carry out the tasks we delegate to them? (Macro aspects)
Problems How many of you play games to take advantage of the novice? (Cousin – chess) The other agent is as smart as you 11
12 Example – Market for Lemons Suppose I have five candy bars of varying quality. Only the seller knows its true value. The buyer cannot tell by looking. Incentives exist for the seller to pass off a low-quality good as a higher-quality one. But buyer is as smart as you!!! The buyer, however, takes this incentive into consideration, and takes the quality of the good to be uncertain. Only the average quality of the good will be considered, which in turn will have the side effect that goods that are above average in terms of quality will be driven out of the market. This mechanism is repeated until a no-trade equilibrium is reached. Note the different perspectives of the negotiation
13 Fields that inspired agents Artificial Intelligence –Agent intelligence, micro aspects Software Engineering –Agent as an abstraction Distributed systems and Computer Networks –Agent architectures, multi-agent systems, coordination There are many definitions of agents – often too narrow or too general.
14 Definitions of Agents American Heritage Dictionary: ”... One that acts or has the power or authority to act... or represent another” Russel and Norvig: ”An agent is anything that can be viewed as perceiving its environment through sensors and acting upon that environment through effectors.” Maes, Pattie: ”Autonomous Agents are computational systems that inhabit some complex dynamic environment, sense and act autonomously in this environment, and by doing so realize a set of goals or tasks for which they are designed”.
15 Definitions of Agents... IBM: ”Intelligent agents are software entities that carry out some set of operations on behalf of a user or another program with some degree of independence or autonomy, and in doing so, employ some knowledge or representations of the user’s goals or desires”.
16 Definitions of Agents... An agent is autonomous: capable of acting independently, exhibiting control over its internal state. An agent is a computer system capable of autonomous action in some environment. System Environment InputOutput
17 “An agent is a persistent software entity dedicated to a specific purpose. 'Persistent' distinguishes agents from subroutines; agents have their own ideas about how to accomplish tasks, their own agendas. 'Special purpose' distinguishes them from entire multifunction applications; agents are typically much smaller. (Smith, Cypher and Spohrer 1994) It is widely recognized that interaction is probably the most important single characteristic of complex systems. “Agents are programs that engage in dialogs, [and] negotiate and coordinate transfer of information.” (Michael Cohen)
At your seats What is the difference between negotiate and coordinate? 18
19 “Agent enjoys the following properties: autonomy - agents operate without the direct intervention of humans or others, and have some kind of control over their actions and internal state; social ability - agents interact with other agents (and possibly humans) via some kind of agent-communication language; reactivity: agents perceive their environment and respond in a timely fashion to changes that occur in it; pro-activeness: agents do not simply act in response to their environment, they are able to exhibit goal-directed behaviour by taking initiative.” (Wooldridge and Jennings, 1995)
20 Definition of Agent... Examples of trivial/non-interesting agents are: –Thermostat, UNIX daemon, e.g. biff Need flexibility: -Reactive -Pro-active -Social
21 Properties of Agents Mentalistic notions, such as beliefs and intentions are often referred to as properties of strong agents. Other properties are: –Mobility: the ability of an agent to move around a network. –Veracity: agent will not knowingly communicate false information. –Benevolence: agents do not have conflicting goals and always try to do what is asked of it. –Rationality: an agent will act in order to achieve its goals and will not act in such a way as to prevent its goals being achieved.
22 Agents and Objects Remember the previous slide: procedures & functions (no context) abstract data types (data and operations combined) objects to agents Are agents just objects by another name?
23 Agents and Objects Agents do it because they want to! Agents do it for money! Objects do it for free…
24 Agents and Objects... Main differences: –Agents are autonomous: agents embody a stronger notion of autonomy than objects, in particular, agents decide for themselves whether or not to perform an action. –Agents are smart: capable of flexible (reactive, pro-active social) behaviour; standard object models do not have such behaviour. –Agents are active: a multi-agent system is inherently multi- threaded in that each agent is assumed to have at least one thread of active control.
25 Why agents? Today, we have a distributed environment that cannot be completely specified – open environments. Former paradigms, such as OOP, cannot completely satisfy our needs: –They were designed for constructing systems in a completely specified environment - a closed world.
26 In the following examples, what is “open”? lawn mowing agent to search for miners travel agent (cheaptickets.com) ebay auction agent
Open Environment Lawn mowing – environment can change Going to WalMart in an open environment 27
28 How can we work in an Open Environment By copying human behaviour: –Perceive the environment –Affect the environment –Have a model of behaviour –Have intentions and motivations to be fulfilled by implementing corresponding goals Environment Agent
29 Decentralization An important concept –No central control; control is distributed –Knowledge or information sources may also be distributed. Why?
30 Multi-agent Systems (MAS) Contains a number of agents which interact with one another through communication. The agents are able to act in an environment; where each agent will act upon or influence different parts of the environment. Reference: Wooldridge, An Introduction to Multiagent Systems, p. 105 Environment Multi-agent System
31 Motivation for MAS At seats: Explain or argue against? To solve problems that are too large for a centralized agent To allow interconnection and interoperation of multiple legacy systems To provide a solution to inherently distributed problems To provide solutions which draw from distributed information sources To provide solutions where expertise is distributed (Why is expertise distributed?) To offer conceptual clarity and simplicity of design To be able to hide strategies from competition
32 Benefits of MAS Why? Faster problem solving Decrease in communication Flexibility Increased reliability - fault tolerant Natural to Application
33 Summary An agent is a system that is capable of independent action on behalf of its user or owner. A multi-agent system is one that consists of a number of agents which interact with one another. In order to successfully interact, agents need ability to cooperate, coordinate and negotiate.