Wednesday, August 8, 2007

The problem of internet

Probably, it is too fast for me to share about the problem of agent-based technology in internet before I explain more detail about agent-based technology itself. However, I have already written :D. So, this is my view about this problem.

Currently, internet is almost entirely driven by human interaction; human decide when to buy something, how much they are willing to pay, and so on. But in principle there is no reason why some internet process can not be automated by intelligent agent as the non-web based application. It means that some decision making of users can be placed in the hands of agents.

An agent is capable of flexible and autonomous action in a dynamic environment. In the sense that the new agent-based technology paradigm causes a re-evaluation of the very nature of computing, computation and computational system through concepts. It means that agents need to be able to engage in interaction, to negotiate, to make pro-active run-time decision and to allocate and schedule resources across the diverse competing demands places on infrastructure and systems. A truly effective internet agent needs to be able to work for the user when the user isn't directly in control. In such systems the internet agent varies its autonomy based on factors like costs, the resources needed, or other variables such as softgoal or non-functional requirements that the user might wish to control.

However, enabling autonomy is a difficult programming task, particularly because it is very dependent on features of the area in which a program is operating. For human agents the level of autonomy is clearly defined, sometimes by law, sometimes by customs that have grown up over many years. For internet agents it is much less clear. It is even unclear whether the variation among tasks will be high or low for internet agents. For example, it seems unlikely that an agent helping find, order and download physics papers would be much different from one in biology.
In the current situation, an internet agent with predetermined pages to visit is quite limited. Thus, a truly useful agent should be able to adapt its behavior based on a combination of user feedback and environmental factors.

For an agent to be capable, it must be able to take action in some sort of world. The difference between an agent and an (internet) advisor, is that the agent not only provides advice, but also provides a service, the ability to do things on the Web without you needing to know the details. Unfortunately, the current state of the art is limited by the need to know much about the specifics of the internet sources the agent will interact with. For example, suppose you want a paper from some particular physics journal, but the journal charges for it. If you want an internet agent to be able to download this paper for you, it would need to know where on the page the price is, where it communicates your credit card number, in what formats the various pieces of information about you need to be put, etc.

Many researches believe that the contents of the websites should be understood by the machine just like we understand how to read the meaning of the websites so then the agent should work in the higher level based on the information that machine understands about the website.Then, I believe that there is no way agent-based technology will work properly if there are no such machines that intelligently be able to reason the knowledge described in the websites.

Tuesday, August 7, 2007

the agent-based technology

Agent-based technology is one of the most vibrant and important areas of research and development to have emerged in information technology in recent years. The prove can be seen in the AgentLink, the Europe community of many major universities and companies in Europe researching about agent-based technology.Alos, among the USA’s 16 “Grand Challenges” are the following relevant to agent technologies: knowledge environments for science and engineering; collaborating intelligence; integrating human with intelligent technologies; and managing knowledge intensive organization in dynamic environment (Interagency working group,2003)

Intelligent agent represents a new way of analyzing, designing and implementing complex software system. For agent-based technologies, the objectives are to create systems situated in dynamic and open environments, able to adapt to these environments and capable of incorporating autonomous and self-interested components. Agent-based systems provides concrete advantages such as :improving operational robustness with intelligent failure recovery, reducing sourcing costs by computing the most beneficial acquisition policies in online market and improving efficiency of manufacturing processes in dynamic environments. In particular, the characteristic of dynamic in which for example, heterogonous systems must interact, span, organizational boundaries and operate effectively within rapidly changing circumstances and with dramatically increasing quantities of available information. .

An agent is simply another kind of software abstraction, an abstraction in the same way that methods, functions, and objects are software abstractions. Let’s compare it, an object is a high-level abstraction that describes methods and attributes of a software component. An agent, however, is an extremely high-level software abstraction which provides a convenient and powerful way to describe a complex software entity. Rather than being defined in terms of methods and attributes, an agent is defined in terms of its behavior. This is important because programming an agent-based system is primarily a matter of specifying agent behavior instead of identifying classes, methods and attributes. It is much easier and more natural to specify behavior than to write code. Below is the explanation on how agents can be distinguished to objects.

The first difference between agents and objects is in the degree to which agents and objects are autonomous. They decide for themselves whether or not to perform an action on request from another entity. An object must make methods available to other objects to invoke, then they can do whenever they wish so then the object has no control over whether or not that method is executed. An object has to make methods available to other objects, or else we would be unable to build a system out of them. It means that if we build a system then we design an object and this object makes method available for other then we assumed that they share a “common goal”. However, in agent-based system no such common goal can be assumed. We can not say that because agent j execute action a then agent i will also execute action a because of the action of agent j – a may not be in the best interest of i. One must think that agent is more like requesting actions to be perform. If j request I to perform a, then I may perform the action or it may not. In object-orientation, the decision lies with the object that invokes the method where in the agent case the decision lies with the agent that receives the request. So, it can be summarized in the following slogan : Object do it for free; agents do it for money.

The second difference is with respect to the notion of flexible autonomous behavior such as reactive, pro-active, and social. The standard object-oriented programming model does not integrate about how to build system that combine these types of behavior. The third distinction is that agents are each considered to have their own thread of control where in the standard object model there is a single thread of control in the system. The standard object oriented programming do not include the idea of autonomous entities such as agent.

For the usage of its usage in the application, the agent-based technology can be grouped into three categories, according to the scale which they apply :

- organizational-level : The technologies and techniques relates to agent societies as a whole and also the issues of the organizational structure, trust, norms and obligations and self-organization.

- Interaction-level : technologies and techniques that concern the communications between agents for example communication language, interaction protocol, coordination, negotiation and resource allocation mechanism

- Agent-level : The technologies and techniques concerned only with individual agents for example procedures for agent reasoning and learning. In detail, the concern relates to heterogeneity of agents, failure handling and recovery and societal change.

Sophisticated software agents can be very difficult to build if we are building them from scratch. One will need specialized skills and knowledge in a variety of areas including agent architecture, communications technology, reasoning systems, knowledge representation, agent communication languages and protocols. If we want to add machine learning or machine planning capabilities, we will also need skill in these areas as well. If we don't possess these specialized skills and knowledge, we should use an agent construction toolkit. Agent construction toolkits allow software developers without agent expertise to quickly and easily build software agents. With the agent-based approach, we can implement agents with sophisticated intellectual capabilities such as the ability to reason, learn, or plan. In addition, intelligent software agents can utilize extensive amounts of knowledge about their problem domain. This means that the underlying agent architecture must support sophisticated reasoning, learning, planning, and knowledge representation.

Monday, August 6, 2007

Agent versus Object

Hi, everybody.

I read about how the impact of the agent-based technology probably will be not as much as the impact in the object orientation in the terms of the mainstream. The article with the title "Agent Technology: Computing as Interaction" described the challanging problems that agent-based technology will have to handle. This article was written by Michael Luck, Peter McBurney, Onn Shehory, Steve Willmott and the agentlink community . Below is what they said about the problems.

In attempting to understand the likely future development of agent-based computing, and its pathway to adoption, one might usefully consider the history of object-oriented technologies. It started from the Simula languages in 1962 when the term of "object oriented" itself was introduced by Alan Kay in 1970. Then there came the development of Smalltalk in 1973 and C++ in 1983. Furthermore, the developments were followed with the Object Management Group being formed in 1989, then the Java was announced in 1991, CORBA in 1991, UML in 1994 and ANSI C++ in 1998. This is an extended period over which the technologies and techniques involved came to maturity and to wide scale adoption.

Agent and object technologies are both essentially disruptive technologies that provide more effective and flexible techniques for software and its development. To understand how the future of agent-based technology may progress, we need to look to the differences between these technologies. Firstly, object technology began in an era in which computing as a discipline and as an industry was relatively immature, and limited in scope. The techniques, technologies, and standard were still not common for the development of the software as is the case now. The changes required for the object to be existed was far less substantial and challenging than it is now for agent technologies.

Secondly, while there are still many problems to be tackled in computing, the degree of improvement, in terms of productivity or efficiency, to be realized from specific advances decreases as the general level of maturity in computing increases. Thus, while there was no step change arising through object orientation, the gradual improvement in the state of software is likely to be even less marked with agent technologies. Thirdly, the current environment is much more heterogeneous also more distributed and diverse than at any point in the previous software development, and it will continue to more evolve in this manner. The result is a further development of standards, techniques, methodologies and multiple vested interests and corporate initiatives that must be integrated, overcome or otherwise addressed for broad acceptance of new paradigms. Investment in new technologies at this point of the IT adoption cycle presents a much more challenging problem than ever before. For all these reasons, it is likely that no technology in the near future will have anything like the impact of object orientation.

Does the article above just tell us that agent-based technology will fail in the future? From what I believe , it will definetely not true. Agent-based technology will bring us to the more efficient and more machine readable system. It will make the less intervention of human in processing a problem in order to achieve its certain goals. However, the article above told us that it will be more challenging problem to be solved when we want to have our system with agent-based capabilities in it. One obvious example is by imagining how huge and the semi-structured data in the internet will be processed using the agent-based technology. It will be a very challenging work to do that. Later, I will discuss also about many researchers who also think about how to include the agent in the internet.