Prologの宿題片付けます 第二編

このエントリーをはてなブックマークに追加
1?-
Prologの宿題あるいは演習の課題を掲載して、ソースプログラムを
書く契機を作るスレです。大学等でどんなProlog教育が試みられて
いるかを知る機会にもしたいと思います。

[1] 課題は # から始まる行表現でお願いします。それでソースコードと区別します。
[2] できるだけインデント表現になるように工夫してください。
[3] コードの途中または後での質問は % から始まるコメントの形式を取ってください。
[4] Prologは一つ仕様から多様なプログラム表現が生まれる言語です。先に答えを
書かれてしまっても、別の正解は無限といってよいほどあります。少しでも、味のある
部分を見つけたらどしどし上げてみましょう。
2デフォルトの名無しさん:2012/10/22(月) 17:32:49.74
>>1
最近は2chを眺めてみる人は減ってしまったから、twitterでスレが
立ったことを宣伝した方がいい。
3デフォルトの名無しさん:2012/10/22(月) 17:37:53.95
おちんちん
4デフォルトの名無しさん:2012/10/22(月) 17:49:58.83
現時点では、「Prologの宿題片付けます」つまり第一編は、
http://logstar.jp/toro.2ch.net/tech/1272006124/
でログを見ることができるようです。
5デフォルトの名無しさん:2012/10/22(月) 18:02:31.53
早速に昨日twitterで扱った問題を載せてみましょう。
#
# 「Prologへの入門」 I.Bratko著 安部憲広訳 1990年 近代科学社刊 ISBN4-7649-0165-X
# より、http://www.amazon.co.jp/dp/476490165X
#
# 3.13 次のような節が書けて,その後以下の質問ができるように,(was,of,the)に対して適切なオペレータの定義を考えよ.
#  diana wa the secretary of the department.
#  ?- Who was the secretary of the department.
#  Who = diana
#  ?- diana was What.
#  What = the secretary of the department

6デフォルトの名無しさん:2012/10/22(月) 18:10:34.05
申し訳ない。肝心の文が一ヶ所間違っていた。wa -> was
#
#  diana was the secretary of the department.
#
#  ?- Who was the secretary of the department.
#  Who = diana
#  ?- diana was What.
#  What = the secretary of the department
7デフォルトの名無しさん:2012/10/22(月) 18:15:34.43
>>5
#  diana was the secretary of the department.
#  ?- Who was the secretary of the department.
#  Who = diana
#  ?- diana was What.
#  What = the secretary of the department

:- op(600,xfx,was).
:- op(500,xfx,of).
:- op(400,fx,the).

diana was the secretary of the department.

8デフォルトの名無しさん:2012/10/22(月) 18:41:54.04

  ァ  ∧_∧ ァ,、
 ,、'` ( ´∀`) ,、'`
  '`  ( ⊃ ⊂)  '`
9デフォルトの名無しさん:2012/10/22(月) 18:51:09.43
# C/C++の宿題片付けます 141代 #323 より
# [1] 授業単元:
# [2] 問題文(含コード&リンク):
# 西暦年数を与えて、その年の干支を求めるプログラムを作成せよ。
# 干支は、十干と十二支とをそろぞれサイクリックに変えながら組み合わせることによって60(10と12の最小公倍数)通りが得られる。
# 例:1989年は己巳。
#
# 以下の述語を前提にしてください。

基準年(2010).

基準年の干(庚).

基準年の支(寅).
10デフォルトの名無しさん:2012/10/22(月) 19:10:35.36
>>5 と同様の問題です。
# 後京極摂政前太政大臣といえば、九条良経。清冽な作風で知られ、新古今和歌集でも
# 最多の歌が採集された天才歌人ですが、その和歌から。
#
# 恋し と は 便り に 付けて 言ひやりき 年 は 還りぬ 人 は 歸らず
#
# と形態素解析できたとして、適宜オペレータを定義して以下の述語がエラーにならず
# 定義可能となるようにしなさい。
#

恋し と は 便り に 付けて 言ひやりき 年 は 還りぬ 人 は 歸らず.
11デフォルトの名無しさん:2012/10/22(月) 19:21:46.59
>>10
句構造的な配慮は必要?
12デフォルトの名無しさん:2012/10/22(月) 19:23:51.08
>>11
さあw
13デフォルトの名無しさん:2012/10/22(月) 20:19:15.39
# それでは私も、もう一問。
# JR山手線の駅の連環を示す述語を定義しなさい。
#
# どのような構造でも構いません。
#
14デフォルトの名無しさん:2012/10/22(月) 21:06:00.29
>>13

山手線(品川,大崎).
山手線(大崎,五反田).
山手線(五反田,目黒).
山手線(目黒,恵比寿).
山手線(恵比寿,渋谷).
山手線(渋谷,原宿).
山手線(原宿,代々木).
山手線(代々木,新宿).
山手線(新宿,新大久保).
山手線(新大久保,高田馬場).
山手線(高田馬場,目白).
山手線(目白,池袋).
山手線(池袋,大塚).
山手線(大塚,巣鴨).
山手線(巣鴨,駒込).
山手線(駒込,田端).
山手線(田端,西日暮里).
山手線(西日暮里,日暮里).
山手線(日暮里,鶯谷).
山手線(鶯谷,上野).
山手線(上野,御徒町).
山手線(御徒町,秋葉原).
山手線(秋葉原,神田).
山手線(神田,東京).
山手線(東京,有楽町).
山手線(有楽町,新橋).
山手線(新橋,浜松町).
山手線(浜松町,田町).
山手線(田町,品川).
15デフォルトの名無しさん:2012/10/23(火) 03:23:09.67
「C/C++の宿題片付けます 160代目」からの借用問題です。
http://toro.2ch.net/test/read.cgi/tech/1349527750/338
# 7個のデータを入力し、中央地を表示するプログラムを作成して下さい
#
# 例
# 1番目の数字を入力してください: 13
# 2番目の数字を入力してください: 22
# ・・・
# 中央値は 22 です。
#
16デフォルトの名無しさん:2012/10/23(火) 03:45:12.47
>>15 の応用問題です。
#
# 1から99までを値域とする7つの整数を乱数を使って発生させて、中央値が22となるようにしなさい
#

17デフォルトの名無しさん:2012/10/23(火) 06:53:27.78
>>10
「言ひやりき」を xfx で定義しなくてはならず、相当に不自然だ。
上の句と下の句でばっさりと分断されている歌で出題に問題があるなぁ。
18デフォルトの名無しさん:2012/10/23(火) 08:08:11.10
>>17
オペレータ定義するには最も難しい歌の一つだったかな。そこをなんとか。
19デフォルトの名無しさん:2012/10/23(火) 08:45:17.88
>>18 これでどうだ。

:- op(300,xf,と).
:- op(500,xfy,は).
:- op(300,xf,に).
:- op(400,xf,付けて)
:- op(700,xfy,言ひやりき).
:- op(600,xfx,還りぬ).
:- op(300,xf,は).

恋し と は 便り に 付けて 言ひやりき 年 は 還りぬ 人 は 歸らず.
20デフォルトの名無しさん:2012/10/23(火) 09:22:46.38
>>14
# まあ、そうなりますね。
#
# それでは、駅間距離と乗り換え案内を追加してください。
#

21デフォルトの名無しさん:2012/10/23(火) 09:36:18.43
>>9
これはいろんな述語定義が出てきそうだ。いい問題かも。
22デフォルトの名無しさん:2012/10/23(火) 18:51:17.71
>>20
山手線(秋葉原,神田,0.7).
山手線(神田,東京,1.3).
山手線(東京,有楽町,0.8).
山手線(有楽町,新橋,1.2).
山手線(新橋,浜松町,1.1).
山手線(浜松町,田町,1.2).
山手線(田町,品川,1.5).

% のような感じでいいのかな。
23デフォルトの名無しさん:2012/10/23(火) 22:30:00.51
>>20 全部は大変!
乗り換え案内(浜松町,東日本旅客鉄道京浜東北線).
乗り換え案内(浜松町,東京モノレール).
乗り換え案内(浜松町,都営地下鉄浅草線).
乗り換え案内(浜松町,'都営地下鉄大江戸線(大門駅)').
24デフォルトの名無しさん:2012/10/23(火) 23:08:58.23
>>20 追加
乗り換え案内(新橋,東日本旅客鉄道京浜東北線).
乗り換え案内(新橋,東日本旅客鉄道東海道線).
乗り換え案内(新橋,東日本旅客鉄道横須賀線).
乗り換え案内(新橋,ゆりかもめ東京臨海新交通臨海線).
乗り換え案内(新橋,東京地下鉄銀座線).
乗り換え案内(新橋,都営地下鉄浅草線).
2520:2012/10/24(水) 08:49:55.79
>>23 >>24
乗り換え案内をRDBとして定義してくるか、リストで定義してくるか、
の興味があったので出題しました。ありがとう。
26デフォルトの名無しさん:2012/10/24(水) 10:38:02.68
#
# あるProlog処理系で冪集合を定義し、その結果が
#
# ?- 冪集合([a,b,c,d],X).
#
# X = [[],[a],[b],[c],[d],[a,b],[a,c],[a,d],[b,c],[b,d],[c,d],[a,b,c],[a,b,d],[a,
c,d],[b,c,d],[a,b,c,d]].
#
# となったとします。
# それでは、このXの要素の出現順序を崩さず、しかも、一旦冪集合を完全に生成すること
もなく、最初からn個目まで生成したらそこで打ち切って部分解として、
# その時点まで生成されたリストを返すプログラムを生成しなさい。
#
2726:2012/10/24(水) 10:41:06.76
最後、
リストを返すプログラムを「作成しなさい。」
です
28デフォルトの名無しさん:2012/10/24(水) 14:46:07.35
29デフォルトの名無しさん:2012/10/24(水) 15:15:01.06
>>28
いかにもPrologらしいプログラムだな。
30デフォルトの名無しさん:2012/10/24(水) 16:16:29.49
# 10分程前にtwitter上に問題として出したもの。
#
# 問題: 「目に遮り、形あるものは切り給まふべくが、もし、無形の陰鬼陽魔亡霊は
#     何を以って切り給まふや」 --勧進帳--
# この台詞は富樫が弁慶を問い詰めた難問ですが、弁慶の答を調べ
# Prolog述語として定義した上で、質問してみてください。
#
31デフォルトの名無しさん:2012/10/25(木) 08:09:35.39
32 忍法帖【Lv=2,xxxP】(2+0:5) :2012/10/26(金) 08:34:51.76
>>30
結構難しいねw
33 忍法帖【Lv=4,xxxP】(2+0:5) :2012/10/31(水) 10:35:15.99
>>22
Prologの述語定義で、情報の出所も別に述語定義するべきかな?
34デフォルトの名無しさん:2012/10/31(水) 12:56:25.79
>>33
Prologの述語定義の場合、著作物に極めて近い表記が現れる
可能性があるという意味かな。
35 忍法帖【Lv=4,xxxP】(1+0:5) :2012/10/31(水) 13:12:21.50
>>22 のようなものだって、マニアは暗記していたとしても、自分で
メジャー持って測って回った人はほとんどいなかった。
しかし、今では、Webサイトでメートル単位で測ることができる。この例
からも現在の情報源は極めて多様で、一筋縄ではいかない問題だと言える。
36 忍法帖【Lv=7,xxxP】(1+0:5) :2012/11/08(木) 18:17:49.76
切り給まふべく(X) :- 目に遮り(X),形ある(X).

% なのかなぁ。どうもよく分からない。
37 忍法帖【Lv=7,xxxP】(1+0:5) :2012/11/09(金) 08:22:36.80
% 無形の陰鬼陽魔亡霊は九字真言を以って之を切断せむに何の難きことやあらん

切断せむに易し(剣,_之) :- 目に遮り(_之).
切断せむに易し(剣,_之) :- 形ある(_之).
切断せむに易し(九字真言,_之) :- 無形(_之),(陰鬼(_之);陽魔(_之),亡霊(_之)).

% 「切断せむに何の難きことやあらん」をどう記述してよいかわかりません。
38デフォルトの名無しさん:2012/11/09(金) 08:27:06.22
>>37
切断せむに易し(九字真言,_之) :- 無形(_之),(陰鬼(_之);陽魔(_之);亡霊(_之)).

でしょ。
39デフォルトの名無しさん:2012/11/09(金) 08:33:23.17
句を述語にする方法では重文が苦しいね
40 忍法帖【Lv=7,xxxP】(1+0:5) :2012/11/09(金) 08:51:14.00
>>39
切断せむに易し(九字真言,陽魔).

のように定義するものだろうか。無形であって陽魔とでも呼ぶしかないものと
いうニュアンスが出ないけど。
41デフォルトの名無しさん:2012/11/09(金) 19:47:10.89
一階述語論理だからなあ。
文構造全体を構造項で表すしかないのではないか。
42デフォルトの名無しさん:2012/12/21(金) 20:16:48.85
Prologで書いた詰将棋の例ってどこかに
アップしてありますか。
ググってみたのですが、見つからないもので
御存じのかたがいらっしゃったらご教示ください
43デフォルトの名無しさん:2013/10/03(木) 16:01:04.89
一つの述語が非常に長くなって、
その述語の中ではバックトラックする部分があってもバックトラックが必要ないとする。
この場合、その述語にカットを大量に入れることは処理効率向上に寄与するか。
という問題にぶちあたったのですが。
カットはどの程度入れればいいのか目安をお願いします。
44デフォルトの名無しさん:2013/10/03(木) 17:56:07.58
>>43
述語は出来る限り分割する方がよい。言い換え、言い換え、また言い換えて。
ひたすら言い換える。
一つの述語の本体の副目標数の総計を四つか五つくらいに抑えるように。
append([],L,L).
append([U|X],Y,[U|Z]) :- append(X,Y,Z).
の本体の副目標は第一節の :- true. が省略されていると考えて、二つである。
こうした上で、カットをどうするか。これなら見通しがたつだろう。
45デフォルトの名無しさん:2013/10/04(金) 17:21:23.24
p :- p1,p2,p3,p4,(p5,p6,p7;p8,p9,p10,p11,p12). だとすると、例えば、
p :- q1,q2,q3. のようなまとめ方をする。
q1 :- p1,p2.
q2 :- p3,p4.
q3 :- p5,p6,p7.
q3 :- q4,q5.
q4 :- p8,p9.
q5 :- p10,p11,p12.
46デフォルトの名無しさん:2013/10/05(土) 03:29:22.37
逆にq系列の述語名を使わずに、すべて長い述語名で定義するとしたら、
'p1,p2,p3,p4,(p5,p6,p7;p8,p9,p10,p11,p12' :-
 'p1,p2','p3,p4','(p5,p6,p7:p8,p9,p10,p11,p12)'.
'p1,p2' :- p1,p2.
'p3,p4' :- p3,p4.
'(p5,p6,p7;p8,p9,p10,p11,p12)' :- 'p5,p6,p7'.
'(p5,p6,p7;p8,p9,p10,p11,p12)' :- 'p8,p9','p10,p11,p12'.
'p5,p6,p7' :- p5,p6,p7.
'p8,p9' :- p8,p9.
'p10,p11,p12' :- p10,p11,p12.
47デフォルトの名無しさん:2013/10/05(土) 03:41:42.68
実際には、最終行の
'p10,p11,p12' :- p10,p11,p12. は例えば、以下のようなことになる。

'トランザクションファイルを開き,マスターファイルを更新し,トランザクションファイルを閉じる' :-
 'トランザクションファイルを開き',
 'マスターファイルを更新し',
 'トランザクションファイルを閉じる'.
4846:2013/10/05(土) 06:35:42.86
>>46 二行目訂正 ) が一つ落ちていた。
'p1,p2,p3,p4,(p5,p6,p7;p8,p9,p10,p11,p12)' :-
49デフォルトの名無しさん:2013/10/05(土) 12:49:57.28
カットについて大事な点は、p6とp7に間に!があるとして、
p :- p1,p2,p3,p4,(p5,p6,!,p7;p8,p9,p10,p11,p12). と

p :- q1,q2,q3.
 ・・・
q3 :- p5,p6,!,p7.
q3 :- q4,q5.
 ・・・
のp6とp7の間の!の意味(影響範囲)は全く異なるということですね。
50デフォルトの名無しさん:2014/04/09(水) 05:37:54.10 ID:i/ZHdrIw
>>10
すみません。これ「最多」ではなかったでしたね。三番目かな。
51デフォルトの名無しさん:2014/06/16(月) 08:29:34.77 ID:rWx9LAWU
>>45 >>46 は両方共、私が書いたのですが、
実はこれは、Prologで最も必要な知識であり、技術だと思っています。ところがどういう訳か、
このことを触れた書物はほとんどない。ましてネット上では皆無、私のものは孤立無援。
52デフォルトの名無しさん:2014/06/16(月) 08:31:25.58 ID:rWx9LAWU
>>51
「ほとんどない。」ではなくて、「滅多にお目にかかれない。」に変えて読んでください。
53デフォルトの名無しさん:2014/06/22(日) 15:52:02.46 ID:l+hcNyaT
>>51
ウンコジャップが使う日本のイントラネットには糞資料しかないけれど、
海外には、そこそこの資料が沢山あるよ。
54デフォルトの名無しさん
日本でディプロマミルを発酵している糞教授たちは、給料で何をしているんだろうね。