问题:无法同时对所有变量进行内处理
变量之间存在依赖(子句)
同一个子句中的变量可能同时尝试更改这个子句
方法:最少约束变量选择(LCVE)算法
问题:在之前的实现中,添加子句使用了两个原子指令:添加新子句;添加新文字。
方法:类似于GC的思想,将添加子句分为三个阶段。
使用阶段间同步代替原子指令。
论文贡献:
个人评价:
SAT问题是数学中的一个基础问题,而逻辑学、图论、计算机科学和运筹学等领域中的众多问题都可以转化为SAT问题。提高SAT求解器的性能,也就相当于提高了一大类问题的求解效率。在本论文中,作者希望通过GPU实现一个性能更高的SAT求解器,但GPU有限的存储空间成为了实现过程中的第一个阻碍。所以作者提出了一种并行回收垃圾存储空间的算法,相较于线性的垃圾回收算法具有极大的性能提升。作者还设计了一种在内处理过程中消除变量依赖的任务分配算法,使得内处理过程具有了一定的并行性。结合三阶段变量消去优化,并行内处理部分有平均1.8倍的性能提升。但是,可能由于该论文没有对CDCL SAT求解器的关键部分——冲突分析过程进行优化,导致GPU求解器对比CPU版本的整体提升并不大。