Paradigm: | logic programming |
Implementations: | golog.lua, IndiGolog |
Influenced By: | Prolog |
File Ext: | .pl |
GOLOG is a high-level logic programming language for the specification and execution of complex actions in dynamical domains. It is based on the situation calculus. It is a first-order logical language for reasoning about action and change. GOLOG was developed at the University of Toronto.[1] [2]
The concept of situation calculus on which the GOLOG programming language is based was first proposed by John McCarthy in 1963.[3]
A GOLOG interpreter automatically maintains a direct characterization of the dynamic world being modeled, on the basis of user supplied axioms about preconditions, effects of actions and the initial state of the world. This allows the application to reason about the condition of the world and consider the impacts of different potential actions before focusing on a specific action.[4]
Golog is a logic programming language and is very different from conventional programming languages. A procedural programming language like C defines the execution of statements in advance. The programmer creates a subroutine which consists of statements, and the computer executes each statement in a linear order. In contrast, fifth-generation programming languages like Golog are working with an abstract model with which the interpreter can generate the sequence of actions. The source code defines the problem and it is up to the solver to find the next action. This approach can facilitate the management of complex problems from the domain of robotics.
A Golog program defines the state space in which the agent is allowed to operate. A path in the symbolic domain is found with state space search. To speed up the process, Golog programs are realized as hierarchical task networks.[5]
Apart from the original Golog language, there are some extensions available. The ConGolog language provides concurrency and interrupts. Other dialects like IndiGolog and Readylog were created for real time applications in which sensor readings are updated on the fly.[6]
Golog has been used to model the behavior of autonomous agents. In addition to a logic-based action formalism for describing the environment and the effects of basic actions, they enable the construction of complex actions using typical programming language constructs.
It is also used for applications in high level control of robots and industrial processes, virtual agents, discrete event simulation etc.[7] It can be also used to develop BDI (Belief Desire Intention)-style agent systems.[8]
In contrast to the Planning Domain Definition Language, Golog supports planning and scripting as well.[9] [10] Planning means that a goal state in the world model is defined, and the solver brings a logical system into this state. Behavior scripting implements reactive procedures, which are running as a computer program.[11]
For example, suppose the idea is to authoring a story. The user defines what should be true at the end of the plot. A solver gets started and applies possible actions to the current situation until the goal state is reached. The specification of a goal state and the possible actions are realized in the logical world model.[12]
In contrast, a hardwired reactive behavior doesn't need a solver but the action sequence is provided in a scripting language.[13] The Golog interpreter, which is written in Prolog,[14] executes the script and this will bring the story into the goal state.