次のトランスクリプトは、光を当てることができるかもしれません。
32 ?- Term = (3*_X + 5*_Y = 10), functor(Term,F,A).
Term = 3*_G527+5*_G530=10
F = =
A = 2
33 ?- Term = (3*_X + 5*_Y = 10), arg(Arg,Term,Val).
Term = 3*_G459+5*_G462=10
Arg = 1
Val = 3*_G459+5*_G462 ; % user pressed ';' interactively
Term = 3*_G459+5*_G462=10
Arg = 2
Val = 10 ; % user pressed ';' interactively
No
35 ?- Term = (3*_X + 5*_Y = 10), arg(1,Term,Val1), functor(Val1,F1,A1),
arg(2,Val1,Val12).
Term = 3*_G693+5*_G696=10
Val1 = 3*_G693+5*_G696
F1 = +
A1 = 2
Val12 = 5*_G696
最後のクエリは次のようになります。Term
与えられたように、の1番目arg
は、のファンクターTerm
はアリティを持ち(つまり、args-subparts-それ自体を持ちます)、inの用語の2番目はnameで格納されます。明確にするために、Prologのシンボリックデータは、ファンクターと呼ばれる名前の形式であり、その式の「引数」には、呼び出しを通じてアクセスできます。Val1
Val1
F1
A1
A1
arg
Val1
Val12
fff(aa,bb,cc,...)
fff
arg
つまり、元の式(3*_X + 5*_Y = 10)
は実際にはPrologにとして保存され'='( '+'( '*'(3,_X), '*'(5,_Y)), 10)
ます。アトミック部分(アリティ0のファンクター)に到達したら、それらをさらにチェックできます。
47 ?- arg(1,(3*X),V), functor(V,F,A), number(V).
X = _G441
V = 3
F = 3
A = 0
Yes
編集:(コメントから)あなたの他の質問に答えるために:
1 ?- (3*_X + 5*_Y = 10) = (A*X + B*Y = C).
A = 3
X = _G412
B = 5
Y = _G415
C = 10
Yes
乗算記号を明示的に書き出さないことを主張する場合は*
、用語を文字列として表現し、その文字列を分析する必要があります。それははるかに複雑な作業になります。
編集:試してみるもう1つのことは=..
、「Univ」と呼ばれる述語です。
4 ?- (3*_X + 5*_Y = 10) =.. X.
X = [=, 3*_G454+5*_G457, 10]
Yes
5 ?- (3*_X + 5*_Y = 10) =.. X, X=[X1,X2,X3], X2 =.. Y.
X = [=, 3*_G545+5*_G548, 10]
X1 = =
X2 = 3*_G545+5*_G548
X3 = 10
Y = [+, 3*_G545, 5*_G548]
Yes