Search code examples
clojureschemelogicminikanren

Understanding Mini-Kanren's Execution Model


Chapter 5 of SICP explains the scheme meta circular evaluator interns of a register machine.

Is there anything that provides a similar type of Mini-Kanren in terms of Scheme primitives?

I know that there is a Thesis written on Mini-Kanren (however, I only care about building a mental model; not all the gory optimizations details). I also know that there is the reasoned-schemer -- however, I'm not looking for a bunch of examples -- I just want to understand Mini-kanren in its' very very basic form, much like how one can understand scheme by understanding: eval, apply, if, set!, env

Thanks!


Solution

  • I think reading The Reasoned Schemer is actually the right way to learn the basics. You could also try watching Dan Friedman and William Byrd's miniKanren talk from Clojure Conj.

    Since miniKanren only has seven forms total, understanding the basic forms is really just understanding the whole thing. The implementation is only about a page of macros, so you could try to understand that. You could also try reading the introductory parts of William Byrd's PhD thesis.