1. Automata Size Reduction by Procedure Finding
- Author
-
Šedý, Michal and Holík, Lukáš
- Subjects
Computer Science - Formal Languages and Automata Theory ,Computer Science - Networking and Internet Architecture - Abstract
We introduce a novel paradigm for reducing the size of finite automata by compressing repeating sub-graphs. These repeating sub-graphs can be viewed as invocations of a single procedure. Instead of representing each invocation explicitly, they can be replaced by a single procedure that uses a small runtime memory to remember the call context. We elaborate on the technical details of a basic implementation of this idea, where the memory used by the procedures is a simple finite-state register. We propose methods for identifying repetitive sub-graphs, collapsing them into procedures, and measuring the resulting reduction in automata size. Already, this basic implementation of reduction by procedure finding yields practically relevant results, particularly in the context of FPGA-accelerated pattern matching, where automata size is a primary bottleneck. We achieve up-to 70% size reduction on automata that had already been minimized using the most advanced existing methods.
- Published
- 2024