Я новичок в прологе, поэтому для меня это довольно сложная задача. Я должен реализовать простой C-подобный язык в Prolog.
the ultimate goal is to be able to execute something like this:
?- run([begin,a,:=,10,while,a,>,5,begin,write,a,a,:=,a,-,1,end,end]).
and get:
10
9
8
7
6
yes
Однако я застрял на первом шаге. Это то, чего я достиг до сих пор. вне локального стека!
statement(Vars,_Vars) --> assign(Vars,_Vars).
statement(Vars,Vars2) --> statement(Vars,Vars1), statement(Vars1,Vars2).
assign(Vars,_Vars) --> default_assign(Vars,_Vars).
assign(Vars,_Vars) --> simple_assign(Vars,_Vars).
% a //default value 0
default_assign(Vars,_Vars) -->
var_name(Var_Name),
{update_vars([Var_Name,0],Vars,_Vars)}.
% a = 0
simple_assign(Vars,_Vars) -->
var_name(Var_Name),[=],var_value(Var_Value),
{update_vars([Var_Name,Var_Value],Vars,_Vars)}.
% a = b
simple_assign(Vars,_Vars) -->
var_name(Var_Name1),[=],var_name(Var_Name2),
{
update_vars([Var_Name1,Var_Value],Vars,_Vars)
}.
var_name(Var_Name) --> [Var_Name],{\+number(Var_Name2)}.
var_value(Var_Value) -->[Var_Value],{number(Var_Value)}.
% found match, update
update_vars(Var,Vars,_Vars):-
member(Var,Vars),
update(Var,Vars,_Vars),
_Vars\==[].
% no match, append
update_vars(Var,Vars,_Vars):-
\+member(Var,Vars),
append(Var,Vars,_Vars).
update([Name,Value],[],[]).
update([Name,Value],[[Name,Old_Value]|T1],[[Name,Value]|T2]):-
update([Name,Value],T1,T2).
update([Name,Value],[[Name1,Value1]|T1],[[Name1,Value1]|T2]):-
[Name,Value]\=[Name1,Value1],
update([Name,Value],T1,T2).
append([Name,Value],[],[[Name,Value]]).
append([Name,Value],[H|T1],[H|T2]):-
append([Name,Value],T1,T2).
Вот моя логика. Во-первых, я хочу иметь возможность использовать список (вот как я его интерпретирую - -!), поэтому структура грамматики действительно очень важна. И я также думаю об использовании списка переменных «Vars» в формах [[Name, Value], [a, 1], [b, 2]...], и обновленной версии - «_Vars». Поэтому я могу передать его другим операторам, таким как цикл while и запись.
statement(Vars,Vars2) --> statement(Vars,Vars1), statement(Vars1,Vars2).
% this seems wrong...
Но... Похоже, логика неверна с самого начала. :\ ниже приведена упрощенная версия. Я был бы очень признателен, если бы вы могли помочь мне здесь. И я очень надеюсь, что не возьму это с собой на Рождество. Т.Т.
statement --> assign.
statement --> statement, statement.
assign --> simple_assign.
assign --> default_assign.
default_assign -->
var_name(Var_Name).
simple_assign -->
var_name,[=],var_value.
var_name -->
[Var_Name],{\+number(Var_Name)}.
var_value -->
[Var_Value],{number(Var_Value)}.