File: heuristic_search1.lgt

package info (click to toggle)
yap 5.1.1-3
  • links: PTS
  • area: main
  • in suites: lenny
  • size: 16,124 kB
  • ctags: 14,650
  • sloc: ansic: 122,796; perl: 22,545; sh: 3,768; java: 1,277; makefile: 1,191; xml: 739; tcl: 624; lisp: 142; awk: 9
file content (48 lines) | stat: -rw-r--r-- 1,096 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48

:- object(heuristic_search(_),
	instantiates(class),
	specializes(search_strategy)).


	:- info([
		version is 1.0,
		author is 'Paulo Moura',
		date is 1998/3/23,
		comment is 'Heuristic state space search strategies.',
		parnames is ['Threshold']]).


	:- public(threshold/1).
	:- mode(threshold(?number), one).
	:- info(threshold/1,
		[comment is 'Search cost threshold.',
		 argnames is ['Threshold']]).

	:- public(solve/4).
	:- mode(solve(+object, +nonvar, -list, -number), zero_or_more).
	:- info(solve/4,
		[comment is 'State space search solution.',
		 argnames is ['Space', 'State', 'Path', 'Cost']]).


	:- protected(search/5).
	:- mode(search(+object, +nonvar, +number, -list, -number), zero_or_more).
	:- info(search/5,
		[comment is 'State space search solution.',
		 argnames is ['Space', 'State', 'Threshold', 'Path', 'Cost']]).


	solve(Space, State, Path) :-
		::solve(Space, State, Path, _).


	solve(Space, State, Path, Cost) :-
		::threshold(Threshold),
		::search(Space, State, Threshold, Path, Cost).


	threshold(Threshold) :-
		parameter(1, Threshold).


:- end_object.