Improving stableKanren’s Backward Compatibilityin-person
We improve the backward compatibility of stableKanren to run miniKanren programs. stableKanren is a miniKanren extension capable of non-monotonic reasoning through stable model semantics. However, standard miniKanren programs that produce infinite results do not run as expected in stableKanren. According to stable model semantics, the contradictions are created by negations. A standard miniKanren’s relations do not involve negation, and the coarse contradictions handling in stableKanren causes this compatibility issue. Therefore, we provide a find-grinded contradiction handling to restrict the checking scope. As a result, standard miniKanren relations can produce answers. We also add a “run-partial” interface so that standard miniKanren’s relations implemented with “define”/“defineo” can generate answers even if they coexist with non-terminating or unsatisfiable stableKanren relations in the same environment. The “run-partial” interface also supports running stratified negation programs faster without checking global unavoidable contradictions. A dependency graph analysis can be applied to the input query in the future, so the “run” interface can implicitly decide whether to perform unavoidable contradictions checking to improve usability.
Fri 6 SepDisplayed time zone: Amsterdam, Berlin, Bern, Rome, Stockholm, Vienna change
16:00 - 17:30 | |||
16:00 30mTalk | Improving stableKanren’s Backward Compatibilityin-person miniKanren | ||
16:30 30mTalk | A Relational Solver for Constraint-based Type Inferenceremote miniKanren |