plan(B,g(F),G,l(C,D)):-move(C,E,F),condition_met(E,A),change_state(A,g(F)),plan(B,A,G,D),starth(B).
plan(B,g(F),G,r(C,D)):-move(C,E,F),condition_met(E,A),change_state(A,g(F)),plan(B,A,G,D),starth(B).
plan(B,g(F),G,u(C,D)):-move(C,E,F),condition_met(E,A),change_state(A,g(F)),plan(B,A,G,D),startv(B).
plan(B,g(F),G,d(C,D)):-move(C,E,F),condition_met(E,A),change_state(A,g(F)),plan(B,A,G,D),startv(B).
planf(B,G,H):-plan(B,F,G,H),equal(F,G).

bfs(Start, Goal) :-
    bfs_queue([[Start]], Goal).

bfs_queue([Path | _], Goal) :-
    Path = [Goal | _],
    reverse(Path, FinalPath),
    writeln(FinalPath).  % Print the final path

bfs_queue([Path | Others], Goal) :-
    Path = [Current | _],
    findall([Next | Path],
            (edge(Current, Next), \+ member(Next, Path)),
            NewPaths),
    append(Others, NewPaths, UpdatedQueue),
    bfs_queue(UpdatedQueue, Goal).


bfs_queue(f(g(A,B),f(C,D)),E) :-
    findall(g(K,g(A,B)),
            (edge(A, K), \+ member(K, g(A,B))),
            F),
    append(f(C,D), F, f(g(G,H),f(I,J))),
    bfs_queue(f(g(G,H),f(I,J)), E).


bfs_queue([Path | Others], Goal) :-
    Path = [Current | _],
    findall([Next | Path],
            (edge(Current, Next), \+ member(Next, Path)),
            NewPaths),
    append(Others, NewPaths, UpdatedQueue),
    bfs_queue(UpdatedQueue, Goal).
















% Meta-interpreter BFS Planner
meta_bfs(StartState, GoalState, Path) :-
    retractall(visited(_)), % Clear visited states
    bfs([[StartState]], GoalState, [], Path).
% Base case: Goal state reached
bfs([[GoalState|Path]|_], GoalState, _, FinalPath) :-
    reverse([GoalState|Path], FinalPath).

% Recursive case: Expand current state
bfs([CurrentState|Path],Rest, GoalState, Visited, FinalPath) :-
    findall(CurrentState, NextStates， Visited),
    add_paths(NextStates, [CurrentState|Path], NewPaths),
    bfs(Rest, NewPaths, GoalState, [Visited|NextStates], FinalPath).

%find all
find(CurrentState,[Nextstate], Visited):-action(CurrentState, NextState), notmemberchk(NextState, Visited).
find(CurrentState,[Nextstate, Nextstates],Visited):-find(CurrentState，[Nextstate],Visited)，find(CurrentState，Nextstates, Visited).


% Helper to add paths
add_paths([], _, []).
add_paths([State|States], Path, [[State|Path]|Paths]) :-
    add_paths(States, Path, Paths).