A sliding block puzzle, whose solution is found using A* Search.
author : happystick
mail-id : sai.sasank.yadati@gmail.com
last mod. : 03/01/2017
Note : The distinction between a state and a node is crucial to the understanding of A* Search, which is used to solve the 8Puzzle problem. However, the terms node & state are used interchangebly in this document. In fact, this distinction is important to understand any AI search algorithm.
In this puzzle, we have a 3x3 grid containing 9 squares containing 8 tiles and 1 blank. The 8 tiles are numbered 1 to 8. The blank can move up, down, left or right depending on it's position.
Given an arbitrary initial configuration of the grid, the problem solving agent needs to find an optimal sequence of actions that lead to the goal state, if there is one.
The intial state can be any possible configuration of the 3x3 grid. On the other hand, the goal state has a definite order that is discussed later.
1.State Description
2.Initial State & Goal State
3.Actions as function of states
4.Transition Model
5.Goal Test
6.Step Costs & Path Costs
A state is described by the positions of the tiles and blank in a state array.
[0] [1] [2]
[3] [4] [5]
[6] [7] [8]
Fig. All the squares in the grid are indicated by the positions shown above.
Basic terminolgy :
square x - location in the grid, x ϵ [0,8]
tile x - a square occupied by the number x ϵ [1,8]
blank - unoccupied square.
Clearly, there are finite no. of states in this problem.
Initial state is taken as an input. It can be any possible configuration of the grid i.e., any possible state of the problem.
Goal state for 8-Puzzle is defined differently by various authors. We will consider the following state as the goal state.
1 2 3
4 5 6
7 8
Fig. Goal state.
Set of all possible actions in the 8 puzzle problem : { UP, LEFT, DOWN, RIGHT }
All of them represent the possible physical movements of the blank in the grid.
We need a function ACTIONS that takes in state of the problem as an argument and returns all the possible actions that are valid in the given state.
For example, consider the following state :
2 4 1
3 5
6 7 8
Fig. A state instance.
When ACTIONS is called on the above state, it returns UP,LEFT & DOWN.
To make the representation much simpler, let us quantify the actions.
UP : 1
LEFT : 2
DOWN : 4
RIGHT : 8
Now, if ACTIONS is called on the same state, it returns 1+2+4, i.e., 7.
We need a transition model that describes how the grid evolves with different actions taken by the agent.
2 4 1 2 4 1
3 5 on applying LEFT 3 5
6 7 8 6 7 8
The transition function takes current state and an action as arguments and returns the resulting state.
This function GOALTEST takes in a state as an argument and returns a boolean by checking if the state is the goal or not.
1 2 3
4 5 6
7 8
Fig. A goal state instance.
The goal test function returns True for the above state.
Every action is associated with some cost. Here, we consider step cost to be 1 for each action. Path cost is the sum of all the step costs in the path(sequence of states).
Whenever there is a transition, we find the path cost recursively.
Consider a transition from state a to state b:
path-cost(b) = path-cost(a) + step-cost(a,b)
Path cost for the initial state is taken as zero.
- Algorithm
- Heuristics
- Structure of node
We use A* Search to find an optimal sequence of actions that lead to the goal state.
A* Search is a well known informed search algorithm. An informed search algorithm has additional knowledge given to it, that is not provided by the problem description itself. This additional knowledge is known as heuristics.
Check out the following link to know more about A* Search.
http://web.mit.edu/eranki/www/tutorials/search/
Given a state, heuristics of that state indicates an estimated cost to reach the goal state.
A good heuristic function is admissible and consistent.
Check out the following link to know more about heurisitcs.
http://theory.stanford.edu/~amitp/GameProgramming/Heuristics.html
For a node n, h(n) = #misplaced tiles and blank in the grid
The above heuristic is both admissible and consistent.
We define a node as a structure that holds following information.
state
holds state description
actions()
member function, returns a set of actions as a number
parent
a pointer to the parent node
path-cost
the cost of the path to the current node.
g++ astar.cpp puzzle.cpp problem.cpp main.cpp -o excutable-name.exe
executable-name.exe
Consider the following state as the initial state.
4 5 3
6 8
2 1 7
The input is space separated integers representing the positions of the tiles from 0 to 8.
The input for the above initial state is,
4 7 6 2 0 1 3 8 5
The goal state is for this problem is,
1 2 3
4 5 6
7 8
The output sequence is a series of states showing the optimal path to the goal state.
8 0 1 2 3 4 5 6 7
.
.
.
4 7 6 2 0 1 3 8 5