% State of the robot's world = state(RobotLocation, BasketLocation, RubbishLocation)
% action(Action, State, NewState): Action in State produces NewState
% We assume robot never drops rubbish on floor and never pushes rubbish around

action( pickup,						% Pick up rubbish from floor
	state(Pos1, Pos2, floor(Pos1)),			% Before action, robot and rubbish both at Pos1
	state(Pos1, Pos2, held)).			% After action, rubbush held by robot

action( drop,						% Drop rubbish into basket
	state(Pos, Pos, held),				% Before action, robot and basket both at Pos
	state(Pos, Pos, in_basket)).			% After action, rubbish in basket

action( push(Pos, NewPos),				% Push basket from Pos to NewPos
	state(Pos, Pos, Loc),				% Before action, robot and basket both at Pos
	state(NewPos, NewPos, Loc)).			% After action, robot and basket at NewPos

action( go(Pos1, NewPos1),				% Go from Pos1 to NewPos1
	state(Pos1, Pos2, Loc),				% Before action, robot at Pos1
	state(NewPos1, Pos2, Loc)).			% After action, robot at Pos2

% plan(StartState, FinalState, Plan)

plan(State, State, []).				% To achieve State from State itself, do nothing

plan(State1, GoalState, [Action1 | RestofPlan]) :-
	action(Action1, State1, State2),		% Make first action resulting in State2
	plan(State2, GoalState, RestofPlan). 		% Find rest of plan

% Iterative deepening planner
% Backtracking to "append" generates lists of increasing length
% Forces "plan" to ceate fixed length plans

id_plan(Start, Goal, Plan) :-
    append(Plan, _, _),
    plan(Start, Goal, Plan).

% This test should succeed without the neeed for iterative deepening
test1(Plan) :-
	plan(state(door, corner, floor(middle)), state(_, _, in_basket), Plan).

% This test will hit Prolog's stack size limit and cause an error
% The planer gets caught in infinite recursion 
test2(Plan) :-
	plan(state(door, corner, floor(middle)), state(door, corner1, in_basket), Plan).

% Iterative deeepning allows the planner to find a shortest length plan.
test3(Plan) :-
	id_plan(state(door, corner, floor(middle)), state(door, corner1, in_basket), Plan).

Resource created Friday 26 February 2021, 04:16:45 PM, last modified Friday 26 February 2021, 04:23:42 PM.

file: simple_planner.pl


Back to top

COMP3411/COMP9814 21T1 (Artificial Intelligence) is powered by WebCMS3
CRICOS Provider No. 00098G