序言 : Divide word on syllables using predicate "Name"

标签 prolog dcg

我需要从用户那里读一个词,然后把它分成音节 基于 2 个规则之一:元音-辅音-元音,或 元音-辅音-辅音-元音。

看起来谓词“name”不起作用,输出中应该是单词,而不是列表
你能帮忙吗?

vowel(a).
vowel(e).
vowel(i).
vowel(o).
vowel(u).
vowel(y).

consonant(L) :- not(vowel(L)).

ssplit(A,B) :- atom_chars(A,K),ssplit(K,B,-1). %convert atom to list
test(A,B) :- append(A,[],F), name(N,F).

ssplit([],[],0) :- append(L,[],F), name(N,F), writeln(N).
ssplit([H1|T1],[H1|T2],-1) :- ssplit(T1,T2,0).

ssplit([H1|T1],[H1|T2],0) :- consonant(H1), ssplit(T1,T2,0). %split to syllables
ssplit([H1|T1],[H1|T2],0) :- vowel(H1), ssplit(T1,T2,1).

ssplit([H1|T1],[H1|T2],1) :- vowel(H1), ssplit(T1,T2,1).   %split to syllables
ssplit([H1|[]],[H1|T2],1) :- consonant(H1), ssplit([],T2,0).
ssplit([H1,H2|[]],[H1,H2|T2],1) :- consonant(H1), vowel(H2), ssplit([],T2,1).
ssplit([H1,H2|T1],['-',H1,H2|T2],1) :- consonant(H1), vowel(H2), ssplit(T1,T2,1).
ssplit([H1,H2|T1],T2,1) :- consonant(H1), consonant(H2), ssplit([H1,H2|T1],T2,2).

ssplit([H1,H2|[]],[H1,H2|T2],2) :- ssplit([],T2,0).       %split to syllables
ssplit([H1,H2,H3|[]],[H1,H2,H3|T2],2) :- vowel(H3), ssplit([],T2,1).
ssplit([H1,H2,H3|T1],[H1,'-',H2,H3|T2],2) :- vowel(H3), ssplit(T1,T2,1).
ssplit([H1,H2,H3|T1],[H1,H2,H3|T2],2) :- consonant(H3), ssplit(T1,T2,0).



/*
ssplit(analog,L).
ssplit(ruler,L).
ssplit(prolog,L).


*/

最佳答案

DCG 在处理输入时更实用:

split_name(N, L) :-
    atom_codes(N, Cs),
    phrase(split_v(L), Cs, []).

split_v([]) --> [].

split_v([S|Syllables]) -->
  vowel(X),
  consonant(Y),
  vowel(Z),
  {atom_codes(S, [X,Y,Z])},
  split_v(Syllables).

split_v([S|Syllables]) -->
  vowel(V1),
  consonant(C1),
  consonant(C2),
  vowel(V2),
  {atom_codes(S, [V1,C1,C2,V2])},
  split_v(Syllables).

% catch all unhandled
split_v([S|Syllables]) -->
    [C], {atom_codes(S, [C])},
    split_v(Syllables).

vowel(C) --> [C], {vowel(C)}.
consonant(C) --> [C], {\+vowel(C)}.

vowel(C) :- memberchk(C, "aeiou").

测试:

?- split_name(stackoverflow,L).
L = [s, t, acko, v, e, r, f, l, o|...] ;
L = [s, t, a, c, k, ove, r, f, l|...] ;
L = [s, t, a, c, k, o, v, e, r|...] ;
false.

关于序言 : Divide word on syllables using predicate "Name",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9343950/

相关文章:

parsing - Prolog DCG 中的可选或重复项

database - Prolog 数据库 : Why is program only running once?

prolog跟踪如何使用

Prolog - 对于所有暗示

parsing - (Prolog) 将 Lisp s-表达式解析为 Prolog 术语

list - 在 Prolog 中展平列表

prolog - Prolog 中 Cut 算子的交换性

Prolog动态算术表达式

list - Prolog回文

prolog - 二叉树 T 的叶节点中的值列表