Pattern Discovery in Colored Strings
Zsuzsanna Lipták, Simon J. Puglisi, Massimiliano Rossi
TL;DR
This work introduces colored strings to model embedded-system traces and studies pattern discovery where substrings are guaranteed to be followed by the same color after a fixed delay. It develops suffix-tree–based algorithms to enumerate minimally $(y,d)$-unique substrings for a fixed color and for all colors, with a baseline approach running in $O(n^2)$ time and a skipping variant achieving $O(n^2\log n)$ in the worst case. The methods are extended to all colors and augmented with output-restriction variants (real-type outputs) and a fast-h optimization, yielding practical speedups on simulated data and competitive results on real RTL traces. Experimental results confirm the approaches' viability for assertion mining in embedded systems, and the code is made available for integration into verification pipelines.
Abstract
In this paper, we consider the problem of identifying patterns of interest in colored strings. A colored string is a string where each position is assigned one of a finite set of colors. Our task is to find substrings of the colored string that always occur followed by the same color at the same distance. The problem is motivated by applications in embedded systems verification, in particular, assertion mining. The goal there is to automatically find properties of the embedded system from the analysis of its simulation traces. We show that, in our setting, the number of patterns of interest is upper-bounded by $\mathcal{O}(n^2)$, where $n$ is the length of the string. We introduce a baseline algorithm, running in $\mathcal{O}(n^2)$ time, which identifies all patterns of interest satisfying certain minimality conditions, for all colors in the string. For the case where one is interested in patterns related to one color only, we also provide a second algorithm which runs in $\mathcal{O}(n^2\log n)$ time in the worst case but is faster than the baseline algorithm in practice. Both solutions use suffix trees, and the second algorithm also uses an appropriately defined priority queue, which allows us to reduce the number of computations. We performed an experimental evaluation of the proposed approaches over both synthetic and real-world datasets, and found that the second algorithm outperforms the first algorithm on all simulated data, while on the real-world data, the performance varies between a slight slowdown (on half of the datasets) and a speedup by a factor of up to 11.
