Committing to the bit: Relational programming with semiring arrays and SAT solving

Dmitri Volkov, Yafei Yang, Chung-chieh Shan

公開日: 2025/9/26

Abstract

We propose semiringKanren, a relational programming language where each relation expression denotes a semiring array. We formalize a type system that restricts the arrays to finite size. We then define a semantics that is parameterized by the semiring that the arrays draw their elements from. We compile semiringKanren types to bitstring representations. For the Boolean semiring, this compilation enables us to use an SAT solver to run semiringKanren programs efficiently. We compare the performance of semiringKanren and faster miniKanren for solving Sudoku puzzles. Our experiment shows that semiringKanren can be a more efficient variant of miniKanren.

Committing to the bit: Relational programming with semiring arrays and SAT solving | SummarXiv | SummarXiv