Towards practical FPRAS for #NFA: Exploiting the Power of Dependence
Abstract
#NFA refers to the problem of counting the words of length n accepted by a non-deterministic finite automaton. #NFA is #P-hard, and although fully-polynomial-time randomized approximation schemes (FPRAS) exist, they are all impractical. The first FPRAS for #NFA had a running time of O(n17m17-14(δ-1)), where m is the number of states in the automaton, δ ∈ (0,1] is the confidence parameter, and > 0 is the tolerance parameter (typically smaller than 1). The current best FPRAS achieved a significant improvement in the time complexity relative to the first FPRAS and obtained FPRAS with time complexity O((n10m2 + n6m3)-42(δ-1)). The complexity of the improved FPRAS is still too intimidating to attempt any practical implementation. In this paper, we pursue the quest for practical FPRAS for #NFA by presenting a new algorithm with a time complexity of O(n2m3(nm)-2(δ-1)). Observe that evaluating whether a word of length n is accepted by an NFA has a time complexity of O(nm2). Therefore, our proposed FPRAS achieves sub-quadratic complexity with respect to membership checks.
Turn this paper into a full lesson
ArcXiv compiles a staged curriculum from this paper: 8-12 lessons across beginner → advanced, synthesised section guides, visuals, flashcards, a quiz, exercises, and on-demand deep dives per section. Grounded in the abstract, never invented.