Column-Oriented Datalog on the GPU
Abstract
Datalog is a logic programming language widely used in knowledge representation and reasoning (KRR), program analysis, and social media mining due to its expressiveness and high performance. Traditionally, Datalog engines use either row-oriented or column-oriented storage. Engines like VLog and Nemo favor column-oriented storage for efficiency on limited-resource machines, while row-oriented engines like Soufflé use advanced datastructures with locking to perform better on multi-core CPUs. The advent of modern datacenter GPUs, such as the NVIDIA H100 with its ability to run over 16k threads simultaneously and high memory bandwidth, has reopened the debate on which storage layout is more effective. This paper presents the first column-oriented Datalog engines tailored to the strengths of modern GPUs. We present VFLog, a CUDA-based Datalog runtime library with a column-oriented GPU datastructure that supports all necessary relational algebra operations. Our results demonstrate over 200x performance gains over SOTA CPU-based column-oriented Datalog engines and a 2.5x speedup over GPU Datalog engines in various workloads, including KRR.
Cite
Text
Sun et al. "Column-Oriented Datalog on the GPU." AAAI Conference on Artificial Intelligence, 2025. doi:10.1609/AAAI.V39I14.33665Markdown
[Sun et al. "Column-Oriented Datalog on the GPU." AAAI Conference on Artificial Intelligence, 2025.](https://mlanthology.org/aaai/2025/sun2025aaai-column/) doi:10.1609/AAAI.V39I14.33665BibTeX
@inproceedings{sun2025aaai-column,
title = {{Column-Oriented Datalog on the GPU}},
author = {Sun, Yihao and Kumar, Sidharth and Gilray, Thomas and Micinski, Kristopher K.},
booktitle = {AAAI Conference on Artificial Intelligence},
year = {2025},
pages = {15177-15185},
doi = {10.1609/AAAI.V39I14.33665},
url = {https://mlanthology.org/aaai/2025/sun2025aaai-column/}
}