diff options
author | Aleksander Sadikov <sasha@fri.uni-lj.si> | 2015-09-10 20:39:02 +0200 |
---|---|---|
committer | Aleksander Sadikov <sasha@fri.uni-lj.si> | 2015-09-10 20:39:02 +0200 |
commit | ee50df2225a974857e74d5ecb7c5f503e1c6b18a (patch) | |
tree | 79143284009f882fde23f799764fbf063dedc588 /prolog/problems/family_relations/father_2 | |
parent | 32b86afb8b11c14779c7e7c30c2e3e90d99de980 (diff) |
Hints for mother, father, brother, and sister added.
Diffstat (limited to 'prolog/problems/family_relations/father_2')
-rw-r--r-- | prolog/problems/family_relations/father_2/common.py | 97 | ||||
-rw-r--r-- | prolog/problems/family_relations/father_2/en.py | 17 | ||||
-rw-r--r-- | prolog/problems/family_relations/father_2/sl.py | 53 |
3 files changed, 167 insertions, 0 deletions
diff --git a/prolog/problems/family_relations/father_2/common.py b/prolog/problems/family_relations/father_2/common.py new file mode 100644 index 0000000..e1b46fd --- /dev/null +++ b/prolog/problems/family_relations/father_2/common.py @@ -0,0 +1,97 @@ +# coding=utf-8 + +id = 999 # TODO: new id has to be defined for this problem +group = 'family_relations' +number = 999 # TODO: this should be problem #2 +visible = True +facts = 'family_relations' + +solution = '''\ +father(X, Y) :- + parent(X, Y), + male(X). +''' + +import prolog.engine +import prolog.util +import server.problems + +def test(session, program): + # TODO: change queries and answers (these are for sister/2) + # Test queries and expected answers (values of X). + queries = [ + ('sister(melanie, X)', set(['andrew'])), + ('sister(X, andrew)', set(['melanie'])), + ('sister(X, _)', set(['michelle', 'daniela', 'patricia', 'luana', 'sally', 'melanie', 'nevia', 'vanessa', 'anna'])), + ] + + code = program + '\n' + server.problems.load_facts('prolog', facts).facts + + engine_id = None + try: + engine_id, output = prolog.engine.create(code=code, timeout=1.0) + if not engine_id: + return 0, len(queries) + + n_correct = 0 + for query, solution in queries: + answers, error = prolog.engine.ask_all(engine_id, query=query, timeout=1.0) + if answers and answers[-1] != 'timed out': + values_x = set([ans.get('X') for ans, constraints in answers]) + if values_x == solution: + n_correct += 1 + finally: + if engine_id: + prolog.engine.destroy(engine_id) + + return n_correct, len(queries) + +def general_hint(): + pass + +def hint(session, program): + tokens = prolog.util.tokenize(program) + + code = program + '\n' + server.problems.load_facts('prolog', facts).facts + engine_id = None + try: + engine_id, output = prolog.engine.create(code=code, timeout=1.0) + if not engine_id: + raise Exception('Prolog engine failed to create.') + + # OR (;) instead of AND (,) + # this hint has to be before the next two + # as otherwise those two would always override it + # and not convey the same (amount of) help/information + if prolog.util.Token('SEMI', ';') in tokens and prolog.engine.ask_truth(engine_id, + 'findall(_, father(X, Y), L1), length(L1, N), \ + findall(_, (parent(X, Y) ; male(X)), L2), length(L2, N)'): + return [{'id': 'or_instead_of_and'}] + + # X must be male + if prolog.engine.ask_truth(engine_id, 'female(X), father(X, _)'): + return [{'id': 'x_must_be_male'}] + + # X must be a parent + if prolog.engine.ask_truth(engine_id, + 'father(X, _), \+ parent(X, _)'): + return [{'id': 'x_must_be_parent'}] + + # Y can be of any gender, incl. female + if prolog.engine.ask_one(engine_id, + 'father(_, Y), female(Y)') == 'false': + return [{'id': 'y_can_be_of_any_gender'}] + + # Y does not necessarily need to be a parent + if prolog.engine.ask_one(engine_id, + 'father(_, Y), \+ parent(Y, _)') == 'false': + return [{'id': 'y_need_not_be_parent'}] + + except socket.timeout as ex: + pass + + finally: + if engine_id: + prolog.engine.destroy(engine_id) + + return None diff --git a/prolog/problems/family_relations/father_2/en.py b/prolog/problems/family_relations/father_2/en.py new file mode 100644 index 0000000..108bb9b --- /dev/null +++ b/prolog/problems/family_relations/father_2/en.py @@ -0,0 +1,17 @@ +# coding=utf-8 + +id = 94 +name = 'mother/2' +slug = 'the mother-child relation' + +description = '''\ +<p><code>mother(M, C)</code>: <code>M</code> is the mother of <code>C</code>.</p> +<pre> + ?- mother(tina, william). + true. + ?- mother(nevia, X). + X = luana ; + X = daniela. +</pre>''' + +hint = {} diff --git a/prolog/problems/family_relations/father_2/sl.py b/prolog/problems/family_relations/father_2/sl.py new file mode 100644 index 0000000..c9c38b7 --- /dev/null +++ b/prolog/problems/family_relations/father_2/sl.py @@ -0,0 +1,53 @@ +# coding=utf-8 + +id = 94 +name = 'mother/2' +slug = 'X je mama od Y' + +description = '''\ +<p><code>mother(X, Y)</code>: <code>X</code> je mama od <code>Y</code>.</p> +<pre> + ?- mother(tina, william). + true. + ?- mother(nevia, X). + X = luana ; + X = daniela. +</pre>''' + +hint = { + 'general_hint_1': '''\ +<p><img src="Father-1.png" /></p> +<p>Loni naj zbriše imena relacij (parent, mother) s te slike!</p> +''', + + 'general_hint_2': '''\ +<p><img src="Father-1.png" /></p> +''', + + 'general_hint_3': '''\ +<p>Če je <code>X</code> ženska in je hkrati <code>X</code> starš od <code>Y</code>, +potem je <code>X</code> mama od <code>Y</code>.</p> +''', + + 'or_instead_of_and': '''\ +<p>Si morda uporabil podpičje (ki pomeni ALI) namesto vejice (ki pomeni IN)?</p> +''', + + 'x_must_be_male': '''\ +<p>Oče je navadno moškega spola.</p> +<p><img src="Father-2.png" /></p> +''', + + 'x_must_be_parent': '''\ +<p>Oče naj bi imel vsaj enega otroka... torej je starš od nekoga.</p> +<p><img src="Father-3.png" /></p> +''', + + 'y_can_be_of_any_gender': '''\ +<p><code>Y</code> je pravzaprav lahko poljubnega spola.</p> +''', + + 'y_need_not_be_parent': '''\ +<p><code>Y</code> pravzaprav ne rabi imeti otrok, da ima očeta...</p> +''', +} |