From df8c0b864281e448498cc244cac8fdcf985b373c Mon Sep 17 00:00:00 2001 From: Timotej Lazar Date: Sat, 19 Mar 2016 10:05:37 +0100 Subject: Prolog: add triggers for evenlen+oddlen hints --- .../lists_advanced/evenlen_1_+_oddlen_1/common.py | 26 +++++++++++++++++++++- .../lists_advanced/evenlen_1_+_oddlen_1/sl.py | 16 +++++++++++++ 2 files changed, 41 insertions(+), 1 deletion(-) diff --git a/prolog/problems/lists_advanced/evenlen_1_+_oddlen_1/common.py b/prolog/problems/lists_advanced/evenlen_1_+_oddlen_1/common.py index 828b742..3b997dd 100644 --- a/prolog/problems/lists_advanced/evenlen_1_+_oddlen_1/common.py +++ b/prolog/problems/lists_advanced/evenlen_1_+_oddlen_1/common.py @@ -25,6 +25,10 @@ hint_type = { 'eq_instead_of_equ': Hint('eq_instead_of_equ'), 'predicate_always_false': Hint('predicate_always_false'), 'base_case': Hint('base_case'), + 'extra_base_case': Hint('extra_base_case'), + 'arbitrary_base_case': Hint('arbitrary_base_case'), + 'arithmetics_used': Hint('arithmetics_used'), + 'odd_and_even_mixed_up': Hint('odd_and_even_mixed_up'), 'recursive_case': Hint('recursive_case'), 'timeout': Hint('timeout'), } @@ -76,9 +80,29 @@ def hint(code, aux_code): [{'id': 'eq_instead_of_equ'}] # missing/failed base case - if not prolog.engine.ask_truthTO(engine_id, 'evenlen([]), oddlen([a])'): + if not prolog.engine.ask_truthTO(engine_id, 'evenlen([])'): return [{'id': 'base_case'}] + # redundant base case when evenlen and oddlen call each other + if prolog.engine.ask_truthTO(engine_id, + 'findall(q, (oddlen([a, b, c, d, e]) ; evenlen([a, b, c, d, e, f])), [q, q, q, q])'): + return [{'id': 'extra_base_case'}] + + # arbitrary base case + if prolog.engine.ask_truthTO(engine_id, + 'evenlen(qQ), evenlen(parent(X, q)) ; oddlen(qQ), oddlen(parent(X, q))'): + return [{'id': 'arbitrary_base_case'}] + + # arithmetics used + if any(t.val in ('is', 'len', 'length') for t in tokens): + return [{'id': 'arithmetics_used'}] + + # odd and even mixed up + # TODO base_case will typically fire first when this is true + if prolog.engine.ask_truthTO(engine_id, + 'oddlen([]), evenlen([q]), ! ; oddlen([q, q]), evenlen([q, q, q])'): + return [{'id': 'odd_and_even_mixed_up'}] + # target predicate seems to always be false if not prolog.engine.ask_truthTO(engine_id, 'evenlen(_) ; oddlen(_)'): return [{'id': 'predicate_always_false'}] diff --git a/prolog/problems/lists_advanced/evenlen_1_+_oddlen_1/sl.py b/prolog/problems/lists_advanced/evenlen_1_+_oddlen_1/sl.py index d56cc10..8600c55 100644 --- a/prolog/problems/lists_advanced/evenlen_1_+_oddlen_1/sl.py +++ b/prolog/problems/lists_advanced/evenlen_1_+_oddlen_1/sl.py @@ -29,6 +29,22 @@ implicitno že kar v argumentih predikata (glavi stavka).

'base_case': '''\

Si pomislil na robni pogoj? Kaj je najbolj enostaven primer, ko je element v seznamu? Do katerega elementa najlažje prideš?

+''', + + 'extra_base_case': '''\ +

extra_base_case

+''', + + 'arbitrary_base_case': '''\ +

arbitrary_base_case

+''', + + 'arithmetics_used': '''\ +

arithmetics_used

+''', + +'odd_and_even_mixed_up': '''\ +

odd_and_even_mixed_up

''', 'recursive_case': '''\ -- cgit v1.2.1