Compiling Datalog Programs by Interpreting Them

Created on 2022-01-29T22:26:02-06:00

Return to the Index

This card pertains to a resource available on the internet.

This card can also be read via Gemini.

Partial evaluation: evaluating part of a program at compile-time; or, the equivalent of solving an algebra expression with what you know at build time and leaving the remaining formula as the program.

Applying partial evaluation to an interpreter is called the "first Futamura Projection."

Paper "compiles" datalog by having Souffle parse and optimize the query to a plan, then repackages the plan as Scala code to ask the compiler to optimize, then translates the optimized scala back to C.

Part of this process involves abstractions added to make code maintainable; partial evaluation then removes as much of the abstraction as possible.