I have modified a generic alpha-beta from a book to be depth limited. When printing out the best position search results it sometimes works and sometimes I get a nuisance result such a the number 8.
This is a very generic alpha-beta from "prolog for artificial intelligence". I'm trying to narrow down to whether the issue is with the alpha-beta or somewhere else in my code.
Can someone please tell me if this depth limited alpha-beta seems ok?
Here is the code:
alphabeta(Pos, Alpha, Beta, GoodPos, Val, Depth):-
Depth > 0,
moves(Pos, PosList), !,
boundedbest(PosList, Alpha, Beta, GoodPos, Val, Depth);
get_pos_value(Pos,Val). % static value of position
boundedbest([Pos | PosList], Alpha, Beta, GoodPos, GoodVal, Depth):-
NewDepth is Depth - 1,
alphabeta(Pos, Alpha, Beta,_,Val, NewDepth),
goodenough(PosList, Alpha, Beta, Pos, Val, GoodPos, GoodVal, Depth).
goodenough([],_,_,Pos, Val, Pos, Val,_):- !. % no other candidate
goodenough(_,Alpha,Beta, Pos, Val, Pos, Val,_) :-
min_to_move(Pos), Val > Beta, !; % Maximizer attainded upper bound
max_to_move(Pos), Val < Alpha,!. % Minimizer attained lower bound
goodenough(PosList, Alpha, Beta, Pos, Val, GoodPos, GoodVal, Depth):-
newbounds(Alpha, Beta, Pos, Val, NewAlpha, NewBeta), % refine bounds
boundedbest(PosList, NewAlpha, NewBeta, Pos1, Val1, Depth),
betterof(Pos,Val, Pos1, Val1, GoodPos, GoodVal).
newbounds(Alpha, Beta, Pos, Val, Val, Beta):-
min_to_move(Pos), Val > Alpha, !. % Maximizer increased lower bound
newbounds(Alpha, Beta, Pos, Val, Alpha, Val):-
max_to_move(Pos), Val < Beta, !. % Minimizer decreased upper bound
newbounds(Alpha, Beta, _, _ , Alpha, Beta). % otherwise bounds unchanged
betterof(Pos, Val,Pos1, Val1, Pos, Val):- % Pos better than Pos1
min_to_move(Pos), Val > Val1,!;
max_to_move(Pos), Val < Val1,!.
betterof(_,_,Pos1,Val1,Pos1,Val1). % Otherwise Pos1 better
Here's some comments on these predicates goodenough and betterof which are written in the same way. I suppose when Val > Val1 or Beta, you want min_to_move and in the case Val < Alpha or Val1, you want max_to_move.
Perhaps more explicitly written:
This code shows that there are cases not handled by your disjunction in goodenough, which interprets as fail. Is this intentional ?
In goodenough/8, if argument 5 Val is different from argument 7 Val, the predicate fails. Is this intentional ?
I have the impression you are optimizing the code before time!