ChengsongTanPhdThesis/example.bib
author Chengsong
Sun, 18 Dec 2022 18:17:52 +0000
changeset 634 b079aaee5e10
parent 628 7af4e2420a8c
child 636 0bcb4a7cb40c
permissions -rwxr-xr-x
more

%% This BibTeX bibliography file was created using BibDesk.
%% https://bibdesk.sourceforge.io/

%% Created for CS TAN at 2022-11-20 17:26:32 +0000 


%% Saved with string encoding Unicode (UTF-8) 
@inproceedings{Doczkal2013,
author = {C.~Doczkaland J.O.~Kaiser and G.~Smolka},
title = {A Constructive Theory of Regular Languages in Coq},
year = {2013},
isbn = {9783319035444},
publisher = {Springer-Verlag},
address = {Berlin, Heidelberg},
url = {https://doi.org/10.1007/978-3-319-03545-1_6},
doi = {10.1007/978-3-319-03545-1_6},
abstract = {We present a formal constructive theory of regular languages consisting of about 1400 lines of Coq/Ssreflect. As representations we consider regular expressions, deterministic and nondeterministic automata, and Myhill and Nerode partitions. We construct computable functions translating between these representations and show that equivalence of representations is decidable. We also establish the usual closure properties, give a minimization algorithm for DFAs, and prove that minimal DFAs are unique up to state renaming. Our development profits much from Ssreflect's support for finite types and graphs.},
booktitle = {Proceedings of the Third International Conference on Certified Programs and Proofs - Volume 8307},
pages = {82–97},
numpages = {16},
keywords = {finite automata, regular expressions, Myhill-Nerode, Ssreflect, Coq, regular languages}
}

@inproceedings{Lammich2012,
author = {P.~Lammichand T.~Tuerk},
year = {2012},
month = {08},
pages = {166-182},
title = {Applying Data Refinement for Monadic Programs to Hopcroft's Algorithm},
isbn = {978-3-642-32346-1},
doi = {10.1007/978-3-642-32347-8_12}
}

@article{Krauss2012,
	author={A.~Krauss and T.~Nipkow},
title={Proof Pearl: Regular Expression Equivalence and Relation Algebra},
journal={J. Automated Reasoning},volume=49,pages={95--106},year=2012,note={published online March 2011}}



@article{kleene1956,
  title={Representation of events in nerve nets and finite automata},
  author={S.C.~Kleene and others},
  journal={Automata studies},
  volume={34},
  pages={3--41},
  year={1956},
  publisher={Princeton, NJ}
}

@inproceedings{Paulson2015,
	author = {L.~C.~Paulson},
	booktitle = {Proc.~of the 25th International Conference on Automated Deduction (CADE)},
	pages = {231--245},
	series = {LNAI},
	title = {{A} {F}ormalisation of {F}inite {A}utomata {U}sing {H}ereditarily {F}inite {S}ets},
	volume = {9195},
	year = {2015}}


@article{Murugesan2014,
	author = {N.~Murugesan and O.~V.~Shanmuga Sundaram},
	journal = {International Journal of Computer Trends and Technology},
	number = {1},
	pages = {29--33},
	title = {{S}ome {P}roperties of {B}rzozowski {D}erivatives of {R}egular {E}xpressions},
	url = {http://arxiv.org/abs/1407.5902},
	volume = {13},
	year = {2014},
	bdsk-url-1 = {http://arxiv.org/abs/1407.5902}}

@phdthesis{Ausaf,
	author = {F.~Ausaf},
	school = {King's College London},
	title = {{V}erified {L}exing and {P}arsing},
	year = {2018}}

@inproceedings{Okui10,
	abstract = {This paper offers a new efficient regular expression matching algorithm which follows the POSIX-type leftmost-longest rule. The algorithm basically emulates the subset construction without backtracking, so that its computational cost even in the worst case does not explode exponentially; the time complexity of the algorithm is O(mn(n{\thinspace}+{\thinspace}c)), where m is the length of a given input string, n the number of occurrences of the most frequently used letter in a given regular expression and c the number of subexpressions to be used for capturing substrings. A formalization of the leftmost-longest semantics by using parse trees is also discussed.},
	address = {Berlin, Heidelberg},
	author = {S.~Okui and T.~Suzuki},
	booktitle = {Implementation and Application of Automata},
	editor = {Domaratzki, Michael and Salomaa, Kai},
	isbn = {978-3-642-18098-9},
	pages = {231--240},
	publisher = {Springer Berlin Heidelberg},
	title = {Disambiguation in Regular Expression Matching via Position Automata with Augmented Transitions},
	year = {2011}}

@article{Berglund14,
	author = {M.~Berglund, F.~Drewes and B.~Van Der Merwe},
	doi = {10.4204/EPTCS.151.7},
	journal = {Electronic Proceedings in Theoretical Computer Science},
	month = {05},
	title = {Analyzing Catastrophic Backtracking Behavior in Practical Regular Expression Matching},
	volume = {151},
	year = {2014},
	bdsk-url-1 = {https://doi.org/10.4204/EPTCS.151.7}}

@inproceedings{Berglund18,
	abstract = {Whereas Perl-compatible regular expression matchers typically exhibit some variation of leftmost-greedy semantics, those conforming to the posix standard are prescribed leftmost-longest semantics. However, the posix standard leaves some room for interpretation, and Fowler and Kuklewicz have done experimental work to confirm differences between various posix matchers. The Boost library has an interesting take on the posix standard, where it maximises the leftmost match not with respect to subexpressions of the regular expression pattern, but rather, with respect to capturing groups. In our work, we provide the first formalisation of Boost semantics, and we analyse the complexity of regular expression matching when using Boost semantics.},
	address = {Cham},
	author = {M.~Berglund and W.~Bester and B.~Van Der Merwe},
	booktitle = {Theoretical Aspects of Computing -- ICTAC 2018},
	editor = {Fischer, Bernd and Uustalu, Tarmo},
	isbn = {978-3-030-02508-3},
	pages = {99--115},
	publisher = {Springer International Publishing},
	title = {Formalising Boost POSIX Regular Expression Matching},
	year = {2018}}

@inproceedings{Chen12,
	author = {H.~Chenand S.~Yu},
	doi = {10.1007/978-3-642-27654-5_27},
	month = {01},
	pages = {343-356},
	title = {Derivatives of Regular Expressions and an Application},
	volume = {7160},
	year = {2012},
	bdsk-url-1 = {https://doi.org/10.1007/978-3-642-27654-5_27}}

@article{Takayuki2019,
	author = {T.~Miyazaki and Y.~Minamide},
	doi = {10.2197/ipsjjip.27.422},
	journal = {Journal of Information Processing},
	pages = {422-430},
	title = {Derivatives of Regular Expressions with Lookahead},
	volume = {27},
	year = {2019},
	bdsk-url-1 = {https://doi.org/10.2197/ipsjjip.27.422}}

@article{FERNAU2015287,
	abstract = {A pattern α, i.e., a string that contains variables and terminals, matches a terminal word w if w can be obtained by uniformly substituting the variables of α by terminal words. Deciding whether a given terminal word matches a given pattern is NP-complete and this holds for several natural variants of the problem that result from whether or not variables can be erased, whether or not the patterns are required to be terminal-free or whether or not the mapping of variables to terminal words must be injective. We consider numerous parameters of this problem (i.e., number of variables, length of w, length of the words substituted for variables, number of occurrences per variable, cardinality of the terminal alphabet) and for all possible combinations of the parameters (and variants described above), we answer the question whether or not the problem is still NP-complete if these parameters are bounded by constants.},
	author = {H.~Fernau and M.L.~Schmid},
	doi = {https://doi.org/10.1016/j.ic.2015.03.006},
	issn = {0890-5401},
	journal = {Information and Computation},
	keywords = {Parameterised pattern matching, Function matching, NP-completeness, Membership problem for pattern languages, Morphisms},
	pages = {287-305},
	title = {Pattern matching with variables: A multivariate complexity analysis},
	url = {https://www.sciencedirect.com/science/article/pii/S0890540115000218},
	volume = {242},
	year = {2015},
	bdsk-url-1 = {https://www.sciencedirect.com/science/article/pii/S0890540115000218},
	bdsk-url-2 = {https://doi.org/10.1016/j.ic.2015.03.006}}

@inproceedings{Schmid2012,
	abstract = {We study different possibilities of combining the concept of homomorphic replacement with regular expressions in order to investigate the class of languages given by extended regular expressions with backreferences (REGEX). It is shown in which regard existing and natural ways to do this fail to reach the expressive power of REGEX. Furthermore, the complexity of the membership problem for REGEX with a bounded number of backreferences is considered.},
	address = {Berlin, Heidelberg},
	author = {M.L.~Schmid},
	booktitle = {Proceedings of the 16th International Conference on Developments in Language Theory},
	doi = {10.1007/978-3-642-31653-1_8},
	isbn = {9783642316524},
	keywords = {extended regular expressions, pattern languages, REGEX, pattern expressions, homomorphic replacement},
	location = {Taipei, Taiwan},
	numpages = {12},
	pages = {73--84},
	publisher = {Springer-Verlag},
	series = {DLT'12},
	title = {Inside the Class of REGEX Languages},
	url = {https://doi.org/10.1007/978-3-642-31653-1_8},
	year = {2012},
	bdsk-url-1 = {https://doi.org/10.1007/978-3-642-31653-1_8}}

@article{BERGLUND2022,
	abstract = {Most modern regular expression matching libraries (one of the rare exceptions being Google's RE2) allow backreferences, operations which bind a substring to a variable, allowing it to be matched again verbatim. However, both real-world implementations and definitions in the literature use different syntactic restrictions and have differences in the semantics of the matching of backreferences. Our aim is to compare these various flavors by considering the classes of formal languages that each can describe, establishing, as a result, a hierarchy of language classes. Beyond the hierarchy itself, some complexity results are given, and as part of the effort on comparing language classes new pumping lemmas are established, old classes are extended to new ones, and several incidental results on the nature of these language classes are given.},
	author = {M.~Berglund and B.~Van Der Merwe},
	doi = {https://doi.org/10.1016/j.tcs.2022.10.041},
	issn = {0304-3975},
	journal = {Theoretical Computer Science},
	keywords = {Regular expressions, Backreferences},
	title = {Re-examining regular expressions with backreferences},
	url = {https://www.sciencedirect.com/science/article/pii/S0304397522006570},
	year = {2022},
	bdsk-url-1 = {https://www.sciencedirect.com/science/article/pii/S0304397522006570},
	bdsk-url-2 = {https://doi.org/10.1016/j.tcs.2022.10.041}}

@article{FREYDENBERGER20191,
	abstract = {Most modern libraries for regular expression matching allow back-references (i.e., repetition operators) that substantially increase expressive power, but also lead to intractability. In order to find a better balance between expressiveness and tractability, we combine these with the notion of determinism for regular expressions used in XML DTDs and XML Schema. This includes the definition of a suitable automaton model, and a generalization of the Glushkov construction. We demonstrate that, compared to their non-deterministic superclass, these deterministic regular expressions with back-references have desirable algorithmic properties (i.e., efficiently solvable membership problem and some decidable problems in static analysis), while, at the same time, their expressive power exceeds that of deterministic regular expressions without back-references.},
	author = {D.D.~Freydenberger and M.L.~Schmid},
	doi = {https://doi.org/10.1016/j.jcss.2019.04.001},
	issn = {0022-0000},
	journal = {Journal of Computer and System Sciences},
	keywords = {Deterministic regular expression, Regex, Glushkov automaton},
	pages = {1-39},
	title = {Deterministic regular expressions with back-references},
	url = {https://www.sciencedirect.com/science/article/pii/S0022000018301818},
	volume = {105},
	year = {2019},
	bdsk-url-1 = {https://www.sciencedirect.com/science/article/pii/S0022000018301818},
	bdsk-url-2 = {https://doi.org/10.1016/j.jcss.2019.04.001}}

@inproceedings{Frey2013,
	address = {Dagstuhl, Germany},
	annote = {Keywords: extended regular expressions, regex, decidability, non-recursive tradeoffs},
	author = {D.D.~Freydenberger},
	booktitle = {28th International Symposium on Theoretical Aspects of Computer Science (STACS 2011)},
	doi = {10.4230/LIPIcs.STACS.2011.507},
	editor = {Thomas Schwentick and Christoph D{\"u}rr},
	isbn = {978-3-939897-25-5},
	issn = {1868-8969},
	pages = {507--518},
	publisher = {Schloss Dagstuhl--Leibniz-Zentrum fuer Informatik},
	series = {Leibniz International Proceedings in Informatics (LIPIcs)},
	title = {{Extended Regular Expressions: Succinctness and Decidability}},
	url = {http://drops.dagstuhl.de/opus/volltexte/2011/3039},
	urn = {urn:nbn:de:0030-drops-30396},
	volume = {9},
	year = {2011},
	bdsk-url-1 = {http://drops.dagstuhl.de/opus/volltexte/2011/3039},
	bdsk-url-2 = {https://doi.org/10.4230/LIPIcs.STACS.2011.507}}

@article{campeanu2003formal,
	author = {C.~C{\^a}mpeanu and K.~Salomaa and S.~Yu},
	journal = {International Journal of Foundations of Computer Science},
	number = {06},
	pages = {1007--1018},
	publisher = {World Scientific},
	title = {A formal study of practical regular expressions},
	volume = {14},
	year = {2003}}

@article{campeanu2009patterns,
	author = {C.~C{\^a}mpeanu and N.~Santean},
	doi = {10.1007/s00236-009-0090-y},
	journal = {Acta Inf.},
	month = {05},
	pages = {193-207},
	title = {On the closure of pattern expressions languages under intersection with regular languages},
	volume = {46},
	year = {2009},
	bdsk-url-1 = {https://doi.org/10.1007/s00236-009-0090-y}}

@article{CAMPEANU2009Intersect,
	abstract = {In this paper we revisit the semantics of extended regular expressions (regex), defined succinctly in the 90s [A.V. Aho, Algorithms for finding patterns in strings, in: Jan van Leeuwen (Ed.), Handbook of Theoretical Computer Science, in: Algorithms and Complexity, vol. A, Elsevier and MIT Press, 1990, pp. 255--300] and rigorously in 2003 by C{\^a}mpeanu, Salomaa and Yu [C. C{\^a}mpeanu, K. Salomaa, S. Yu, A formal study of practical regular expressions, IJFCS 14 (6) (2003) 1007--1018], when the authors reported an open problem, namely whether regex languages are closed under the intersection with regular languages. We give a positive answer; and for doing so, we propose a new class of machines --- regex automata systems (RAS) --- which are equivalent to regex. Among others, these machines provide a consistent and convenient method of implementing regex in practice. We also prove, as a consequence of this closure property, that several languages, such as the mirror language, the language of palindromes, and the language of balanced words are not regex languages.},
	author = {C.~C{\^a}mpeanu and N.~Santean},
	doi = {https://doi.org/10.1016/j.tcs.2009.02.022},
	issn = {0304-3975},
	journal = {Theoretical Computer Science},
	keywords = {Extended regular expression, Regex automata system, Regex},
	note = {Formal Languages and Applications: A Collection of Papers in Honor of Sheng Yu},
	number = {24},
	pages = {2336-2344},
	title = {On the intersection of regex languages with regular languages},
	url = {https://www.sciencedirect.com/science/article/pii/S0304397509001789},
	volume = {410},
	year = {2009},
	bdsk-url-1 = {https://www.sciencedirect.com/science/article/pii/S0304397509001789},
	bdsk-url-2 = {https://doi.org/10.1016/j.tcs.2009.02.022}}

@incollection{Aho1990,
	abstract = {Publisher Summary
This chapter discusses the algorithms for solving string-matching problems that have proven useful for text-editing and text-processing applications. String pattern matching is an important problem that occurs in many areas of science and information processing. In computing, it occurs naturally as part of data processing, text editing, term rewriting, lexical analysis, and information retrieval. Many text editors and programming languages have facilities for matching strings. In biology, string-matching problems arise in the analysis of nucleic acids and protein sequences, and in the investigation of molecular phylogeny. String matching is also one of the central and most widely studied problems in theoretical computer science. The simplest form of the problem is to locate an occurrence of a keyword as a substring in a sequence of characters, which is called the input string. For example, the input string queueing contains the keyword ueuei as a substring. Even for this problem, several innovative, theoretically interesting algorithms have been devised that run significantly faster than the obvious brute-force method.},
	address = {Amsterdam},
	author = {A.V.~Aho},
	booktitle = {Algorithms and Complexity},
	doi = {https://doi.org/10.1016/B978-0-444-88071-0.50010-2},
	editor = {JAN {VAN LEEUWEN}},
	isbn = {978-0-444-88071-0},
	pages = {255-300},
	publisher = {Elsevier},
	series = {Handbook of Theoretical Computer Science},
	title = {CHAPTER 5 - Algorithms for Finding Patterns in Strings},
	url = {https://www.sciencedirect.com/science/article/pii/B9780444880710500102},
	year = {1990},
	bdsk-url-1 = {https://www.sciencedirect.com/science/article/pii/B9780444880710500102},
	bdsk-url-2 = {https://doi.org/10.1016/B978-0-444-88071-0.50010-2}}

@inproceedings{Might2011,
	abstract = {We present a functional approach to parsing unrestricted context-free grammars based on Brzozowski's derivative of regular expressions. If we consider context-free grammars as recursive regular expressions, Brzozowski's equational theory extends without modification to context-free grammars (and it generalizes to parser combinators). The supporting actors in this story are three concepts familiar to functional programmers - laziness, memoization and fixed points; these allow Brzozowski's original equations to be transliterated into purely functional code in about 30 lines spread over three functions.Yet, this almost impossibly brief implementation has a drawback: its performance is sour - in both theory and practice. The culprit? Each derivative can double the size of a grammar, and with it, the cost of the next derivative.Fortunately, much of the new structure inflicted by the derivative is either dead on arrival, or it dies after the very next derivative. To eliminate it, we once again exploit laziness and memoization to transliterate an equational theory that prunes such debris into working code. Thanks to this compaction, parsing times become reasonable in practice.We equip the functional programmer with two equational theories that, when combined, make for an abbreviated understanding and implementation of a system for parsing context-free languages.},
	address = {New York, NY, USA},
	author = {M.~Might and D.~Darais and D.~Spiewak},
	booktitle = {Proceedings of the 16th ACM SIGPLAN International Conference on Functional Programming},
	doi = {10.1145/2034773.2034801},
	isbn = {9781450308656},
	keywords = {derivative, parsing, context-free grammar, parser combinator, formal languages, regular expressions},
	location = {Tokyo, Japan},
	numpages = {7},
	pages = {189--195},
	publisher = {Association for Computing Machinery},
	series = {ICFP '11},
	title = {Parsing with Derivatives: A Functional Pearl},
	url = {https://doi.org/10.1145/2034773.2034801},
	year = {2011},
	bdsk-url-1 = {https://doi.org/10.1145/2034773.2034801}}



@inproceedings{Adams2016,
  title={On the complexity and performance of parsing with derivatives},
  author={M.D.~Adams and C.~Hollenbeck and M.~MightMatthew},
  booktitle={Proceedings of the 37th ACM SIGPLAN Conference on Programming Language Design and Implementation},
  pages={224--236},
  year={2016}
}
@article{Huet1997,
author = {G.~Huet},
title = {The Zipper},
year = {1997},
issue_date = {September 1997},
publisher = {Cambridge University Press},
address = {USA},
volume = {7},
number = {5},
issn = {0956-7968},
url = {https://doi.org/10.1017/S0956796897002864},
doi = {10.1017/S0956796897002864},
abstract = {Almost every programmer has faced the problem of representing a tree together with a subtree that is the focus of attention, where that focus may move left, right, up or down the tree. The Zipper is Huet's nifty name for a nifty data structure which fulfills this need. I wish I had known of it when I faced this task, because the solution I came up with was not quite so efficient or elegant as the Zipper.},
journal = {J. Funct. Program.},
month = {sep},
pages = {549–554},
numpages = {6}
}

@article{Darragh2020,
	abstract = {Parsing with Derivatives (PwD) is an elegant approach to parsing context-free grammars (CFGs). It takes the equational theory behind Brzozowski's derivative for regular expressions and augments that theory with laziness, memoization, and fixed points. The result is a simple parser for arbitrary CFGs. Although recent work improved the performance of PwD, it remains inefficient due to the algorithm repeatedly traversing some parts of the grammar. In this functional pearl, we show how to avoid this inefficiency by suspending the state of the traversal in a zipper. When subsequent derivatives are taken, we can resume the traversal from where we left off without retraversing already traversed parts of the grammar. However, the original zipper is designed for use with trees, and we want to parse CFGs. CFGs can include shared regions, cycles, and choices between alternates, which makes them incompatible with the traditional tree model for zippers. This paper develops a generalization of zippers to properly handle these additional features. Just as PwD generalized Brzozowski's derivatives from regular expressions to CFGs, we generalize Huet's zippers from trees to CFGs. Abstract The resulting parsing algorithm is concise and efficient: it takes only 31 lines of OCaml code to implement the derivative function but performs 6,500 times faster than the original PwD and 3.24 times faster than the optimized implementation of PwD.},
	address = {New York, NY, USA},
	articleno = {108},
	author = {P.~Darragh and M.D.~Adams},
	doi = {10.1145/3408990},
	issue_date = {August 2020},
	journal = {Proc. ACM Program. Lang.},
	keywords = {Derivatives, Zippers, Parsing with Derivatives, Parsing},
	month = {aug},
	number = {ICFP},
	numpages = {28},
	publisher = {Association for Computing Machinery},
	title = {Parsing with Zippers (Functional Pearl)},
	url = {https://doi.org/10.1145/3408990},
	volume = {4},
	year = {2020},
	bdsk-url-1 = {https://doi.org/10.1145/3408990}}

@article{Edelmann2021,
	abstract = {Parsing is the process that enables a computer system to  make sense of raw data. Parsing is common to almost all  computer systems: It is involved every time sequential data  is read and elaborated into structured data. The theory of  parsing usually focuses on the binary recognition aspect of  parsing and eschews this essential data-elaboration aspect.  In this thesis, I present a declarative framework for  value-aware parsing that explicitly integrates data  elaboration.
Within the framework of the thesis, I present  parsing algorithms that are based on the concept of  Brzozowski's derivatives. Derivative-based parsing  algorithms present several advantages: they are elegant,  amenable to formal reasoning, and easy to implement.  Unfortunately, the performance of these algorithms in  practice is often not competitive with other approaches. In  this thesis, I show a general technique inspired by Huet's  Zipper to greatly enhance the performance of  derivative-based algorithms, and I do so without  compromising their elegance, amenability to formal  reasoning, or ease of implementation.
First, I present a  technique for building efficient tokenisers that is based  on Brzozowski's derivatives and Huet's zipper and that does  not require the usual burdensome explicit conversion to  automata. I prove the technique is correct in Coq and  present SILEX, a Scala lexing library based on the  technique. I demonstrate that the approach is competitive  with state-of-the-art solutions.
Then, I present a  characterisation of LL(1) languages based on the concept of  should-not-follow sets. I present an algorithm for parsing  LL(1) languages with derivatives and zippers. I show a  formal proof of the algorithm's correctness and prove its  worst-case linear-time complexity. I show how the LL(1)  parsing with derivatives and zippers algorithm corresponds  to the traditional LL(1) parsing algorithm.
I then present  SCALL1ON, a Scala parsing combinators library for LL(1)  languages that incorporates the LL(1) parsing with  derivatives and zippers algorithm. I present an expressive  and familiar combinator-based interface for describing  LL(1) languages. I present techniques that help precisely  locate LL(1) conflicts in user code. I discuss several  advantages of the parsing with derivatives approach within  the context of a parsing library. I also present SCALL1ON's  enumeration and pretty-printing features and discuss their  implementation. Through a series of benchmarks, I  demonstrate the good performance and practicality of the  approach. Finally, I present how to adapt the LL(1) parsing  with derivatives and zippers algorithm to support arbitrary  context-free languages. I show how the adapted algorithm  corresponds to general parsing algorithms, such as Earley's  parsing algorithm.},
	address = {Lausanne},
	author = {R.~Edelmann},
	doi = {10.5075/epfl-thesis-7357},
	institution = {IINFCOM},
	pages = {246},
	publisher = {EPFL},
	title = {Efficient Parsing with Derivatives and Zippers},
	url = {http://infoscience.epfl.ch/record/287059},
	year = {2021},
	bdsk-url-1 = {http://infoscience.epfl.ch/record/287059},
	bdsk-url-2 = {https://doi.org/10.5075/epfl-thesis-7357}}




@inproceedings{Zippy2020,
	abstract = {In this paper, we present an efficient, functional, and formally verified parsing algorithm for LL(1) context-free expressions based on the concept of derivatives of formal languages. Parsing with derivatives is an elegant parsing technique, which, in the general case, suffers from cubic worst-case time complexity and slow performance in practice. We specialise the parsing with derivatives algorithm to LL(1) context-free expressions, where alternatives can be chosen given a single token of lookahead. We formalise the notion of LL(1) expressions and show how to efficiently check the LL(1) property. Next, we present a novel linear-time parsing with derivatives algorithm for LL(1) expressions operating on a zipper-inspired data structure. We prove the algorithm correct in Coq and present an implementation as a part of Scallion, a parser combinators framework in Scala with enumeration and pretty printing capabilities.},
	address = {New York, NY, USA},
	author = {R.~Edelmann and H.~Jad and K.~Viktor},
	booktitle = {Proceedings of the 41st ACM SIGPLAN Conference on Programming Language Design and Implementation},
	doi = {10.1145/3385412.3385992},
	isbn = {9781450376136},
	keywords = {Parsing, Zipper, Formal proof, LL(1), Derivatives},
	location = {London, UK},
	numpages = {16},
	pages = {1036--1051},
	publisher = {Association for Computing Machinery},
	series = {PLDI 2020},
	title = {Zippy LL(1) Parsing with Derivatives},
	url = {https://doi.org/10.1145/3385412.3385992},
	year = {2020},
	bdsk-url-1 = {https://doi.org/10.1145/3385412.3385992}}

@article{fowler2003,
	author = {G.~Fowler},
	journal = {URL: https://web. archive. org/web/20050408073627/http://www. research. att. com/\~{} gsf/testregex/re-interpretation. html},
	title = {An interpretation of the POSIX regex standard},
	year = {2003}}

@inproceedings{Snort1999,
	abstract = {Network intrusion detection systems (NIDS) are an important part of any network security architecture. They provide a layer of defense which monitors network traffic for predefined suspicious activity or patterns, and alert system administrators when potential hostile traffic is detected. Commercial NIDS have many differences, but Information Systems departments must face the commonalities that they share such as significant system footprint, complex deployment and high monetary cost. Snort was designed to address these issues.},
	address = {USA},
	author = {M.~Roesch},
	booktitle = {Proceedings of the 13th USENIX Conference on System Administration},
	location = {Seattle, Washington},
	numpages = {10},
	pages = {229--238},
	publisher = {USENIX Association},
	series = {LISA '99},
	title = {Snort - Lightweight Intrusion Detection for Networks},
	year = {1999}}


@article{Reps1998,
author = {T.~Reps},
title = {“Maximal-Munch” Tokenization in Linear Time},
year = {1998},
issue_date = {March 1998},
publisher = {Association for Computing Machinery},
address = {New York, NY, USA},
volume = {20},
number = {2},
issn = {0164-0925},
url = {https://doi.org/10.1145/276393.276394},
doi = {10.1145/276393.276394},
abstract = {The lexical-analysis (or scanning) phase of a compiler attempts to partition an input string into a sequence of tokens. The convention in most languages is that the input is scanned left to right, and each token identified is a “maximal munch” of the remaining input—the longest prefix of the remaining input that is a token of the language. Although most of the standard compiler textbooks present a way to perform maximal-munch tokenization, the algorithm they describe is one that, for certain sets of token definitions, can cause the scanner to exhibit quadratic behavior in the worst case. In the article, we show that maximal-munch tokenization can always be performed in time linear in the size of the input.},
journal = {ACM Trans. Program. Lang. Syst.},
month = {mar},
pages = {259–273},
numpages = {15},
keywords = {backtracking, tokenization, tabulation, dynamic programming, memoization}
}

@inproceedings{Bro,
author = {V.~Paxson},
title = {Bro: A System for Detecting Network Intruders in Real-Time},
year = {1998},
publisher = {USENIX Association},
address = {USA},
abstract = {We describe Bro, a stand-alone system for detecting network intruders in real-time by passively monitoring a network link over which the intruder's traffic transits. We give an overview of the system's design, which emphasizes high-speed (FDDI-rate) monitoring, real-time notification, clear separation between mechanism and policy, and extensibility. To achieve these ends, Bro is divided into an "event engine" that reduces a kernel-filtered network traffic stream into a series of higher-level events, and a "policy script interpreter" that interprets event handlers written in a specialized language used to express a site's security policy. Event handlers can update state information, synthesize new events, record information to disk, and generate real-time notifications via syslog. We also discuss a number of attacks that attempt to subvert passive monitoring systems and defenses against these, and give particulars of how Bro analyzes the four applications integrated into it so far: Finger, FTP, Portmapper and Telnet. The system is publicly available in source code form.},
booktitle = {Proceedings of the 7th Conference on USENIX Security Symposium - Volume 7},
pages = {3},
numpages = {1},
location = {San Antonio, Texas},
series = {SSYM'98}
}

@INPROCEEDINGS{Sidhu2001,
  author={R.~Sidhu and V.K.~Prasanna},
  booktitle={The 9th Annual IEEE Symposium on Field-Programmable Custom Computing Machines (FCCM'01)}, 
  title={Fast Regular Expression Matching Using FPGAs}, 
  year={2001},
  volume={},
  number={},
  pages={227-238},
  doi={}
}
@article{Turonova2020,
author = {L.~Turo\v{n}ov\'{a} and L.~Hol\'{\i}k  and O.~Leng\'{a}l and O.~Saarikivi and M.~Veanes and T.~Vojnar },
title = {Regex Matching with Counting-Set Automata},
year = {2020},
issue_date = {November 2020},
publisher = {Association for Computing Machinery},
address = {New York, NY, USA},
volume = {4},
number = {OOPSLA},
url = {https://doi.org/10.1145/3428286},
doi = {10.1145/3428286},
abstract = {We propose a solution to the problem of efficient matching regular expressions (regexes) with bounded repetition, such as (ab){1,100}, using deterministic automata. For this, we introduce novel counting-set automata (CsAs), automata with registers that can hold sets of bounded integers and can be manipulated by a limited portfolio of constant-time operations. We present an algorithm that compiles a large sub-class of regexes to deterministic CsAs. This includes (1) a novel Antimirov-style translation of regexes with counting to counting automata (CAs), nondeterministic automata with bounded counters, and (2) our main technical contribution, a determinization of CAs that outputs CsAs. The main advantage of this workflow is that the size of the produced CsAs does not depend on the repetition bounds used in the regex (while the size of the DFA is exponential to them). Our experimental results confirm that deterministic CsAs produced from practical regexes with repetition are indeed vastly smaller than the corresponding DFAs. More importantly, our prototype matcher based on CsA simulation handles practical regexes with repetition regardless of sizes of counter bounds. It easily copes with regexes with repetition where state-of-the-art matchers struggle.},
journal = {Proc. ACM Program. Lang.},
month = {nov},
articleno = {218},
numpages = {30},
keywords = {counting-set automata, counting automata, bounded repetition, ReDos, Antimirov's derivatives, regular expression matching, determinization}
}

@inproceedings{Kumar2006,
author = {S.~Kumar and S.~Dharmapurikar and F.~Yu and P.~Crowley and J.~Turner},
title = {Algorithms to Accelerate Multiple Regular Expressions Matching for Deep Packet Inspection},
year = {2006},
isbn = {1595933085},
publisher = {Association for Computing Machinery},
address = {New York, NY, USA},
url = {https://doi.org/10.1145/1159913.1159952},
doi = {10.1145/1159913.1159952},
abstract = {There is a growing demand for network devices capable of examining the content of data packets in order to improve network security and provide application-specific services. Most high performance systems that perform deep packet inspection implement simple string matching algorithms to match packets against a large, but finite set of strings. owever, there is growing interest in the use of regular expression-based pattern matching, since regular expressions offer superior expressive power and flexibility. Deterministic finite automata (DFA) representations are typically used to implement regular expressions. However, DFA representations of regular expression sets arising in network applications require large amounts of memory, limiting their practical application.In this paper, we introduce a new representation for regular expressions, called the Delayed Input DFA (D2FA), which substantially reduces space equirements as compared to a DFA. A D2FA is constructed by transforming a DFA via incrementally replacing several transitions of the automaton with a single default transition. Our approach dramatically reduces the number of distinct transitions between states. For a collection of regular expressions drawn from current commercial and academic systems, a D2FA representation reduces transitions by more than 95%. Given the substantially reduced space equirements, we describe an efficient architecture that can perform deep packet inspection at multi-gigabit rates. Our architecture uses multiple on-chip memories in such a way that each remains uniformly occupied and accessed over a short duration, thus effectively distributing the load and enabling high throughput. Our architecture can provide ostffective packet content scanning at OC-192 rates with memory requirements that are consistent with current ASIC technology.},
booktitle = {Proceedings of the 2006 Conference on Applications, Technologies, Architectures, and Protocols for Computer Communications},
pages = {339–350},
numpages = {12},
keywords = {regular expressions, DFA, deep packet inspection},
location = {Pisa, Italy},
series = {SIGCOMM '06}
}





@inproceedings{Becchi2007,
author = {M.~Becchi and P.~Crowley},
title = {An Improved Algorithm to Accelerate Regular Expression Evaluation},
year = {2007},
isbn = {9781595939456},
publisher = {Association for Computing Machinery},
address = {New York, NY, USA},
url = {https://doi.org/10.1145/1323548.1323573},
doi = {10.1145/1323548.1323573},
abstract = {Modern network intrusion detection systems need to perform regular expression matching at line rate in order to detect the occurrence of critical patterns in packet payloads. While deterministic finite automata (DFAs) allow this operation to be performed in linear time, they may exhibit prohibitive memory requirements. In [9], Kumar et al. propose Delayed Input DFAs (D2FAs), which provide a trade-off between the memory requirements of the compressed DFA and the number of states visited for each character processed, which corresponds directly to the memory bandwidth required to evaluate regular expressions.In this paper we introduce a general compression technique that results in at most 2N state traversals when processing a string of length N. In comparison to the D2FA approach, our technique achieves comparable levels of compression, with lower provable bounds on memory bandwidth (or greater compression for a given bandwidth bound). Moreover, our proposed algorithm has lower complexity, is suitable for scenarios where a compressed DFA needs to be dynamically built or updated, and fosters locality in the traversal process. Finally, we also describe a novel alphabet reduction scheme for DFA-based structures that can yield further dramatic reductions in data structure size.},
booktitle = {Proceedings of the 3rd ACM/IEEE Symposium on Architecture for Networking and Communications Systems},
pages = {145–154},
numpages = {10},
keywords = {regular expressions, DFA, deep packet inspection},
location = {Orlando, Florida, USA},
series = {ANCS '07}
}

@inproceedings{Becchi08,
	author = {M.~Becchi and , Patrick},
	doi = {10.1145/1544012.1544037},
	month = {01},
	pages = {25},
	title = {Extending finite automata to efficiently match Perl-compatible regular expressions},
	year = {2008},
	bdsk-url-1 = {https://doi.org/10.1145/1544012.1544037}}

@book{Sakarovitch2009,
	author = {J.~Sakarovitch},
	doi = {10.1017/CBO9781139195218},
	editor = {Thomas, ReubenTranslator},
	place = {Cambridge},
	publisher = {Cambridge University Press},
	title = {Elements of Automata Theory},
	year = {2009},
	bdsk-url-1 = {https://doi.org/10.1017/CBO9781139195218}}

@unpublished{FoSSaCS2023,
	author = {C.~Tan and C.~Urban},
	note = {submitted},
	title = {POSIX Lexing with Bitcoded Derivatives}}

@inproceedings{Verbatim,
	author = {D.~Egolf and S.~Lasser and K.~Fisher},
	booktitle = {2021 IEEE Security and Privacy Workshops (SPW)},
	doi = {10.1109/SPW53761.2021.00022},
	pages = {92-100},
	title = {Verbatim: A Verified Lexer Generator},
	year = {2021},
	bdsk-url-1 = {https://doi.org/10.1109/SPW53761.2021.00022}}


@inproceedings{Nipkow1998,
  author    = {T.~Nipkow},
  editor    = {Jim Grundy and
               Malcolm C. Newey},
  title     = {Verified Lexical Analysis},
  booktitle = {Theorem Proving in Higher Order Logics, 11th International Conference,
               TPHOLs'98, Canberra, Australia, September 27 - October 1, 1998, Proceedings},
  series    = {Lecture Notes in Computer Science},
  volume    = {1479},
  pages     = {1--15},
  publisher = {Springer},
  year      = {1998},
  url       = {https://doi.org/10.1007/BFb0055126},
  doi       = {10.1007/BFb0055126},
  timestamp = {Tue, 14 May 2019 10:00:48 +0200},
  biburl    = {https://dblp.org/rec/conf/tphol/Nipkow98.bib},
  bibsource = {dblp computer science bibliography, https://dblp.org}
}


@inproceedings{Verbatimpp,
	abstract = {Lexers and parsers are attractive targets for attackers because they often sit at the boundary between a software system's internals and the outside world. Formally verified lexers can reduce the attack surface of these systems, thus making them more secure. One recent step in this direction is the development of Verbatim, a verified lexer based on the concept of Brzozowski derivatives. Two limitations restrict the tool's usefulness. First, its running time is quadratic in the length of its input string. Second, the lexer produces tokens with a simple "tag and string" representation, which limits the tool's ability to integrate with parsers that operate on more expressive token representations. In this work, we present a suite of extensions to Verbatim that overcomes these limitations while preserving the tool's original correctness guarantees. The lexer achieves effectively linear performance on a JSON benchmark through a combination of optimizations that, to our knowledge, has not been previously verified. The enhanced version of Verbatim also enables users to augment their lexical specifications with custom semantic actions, and it uses these actions to produce semantically rich tokens---i.e., tokens that carry values with arbitrary, user-defined types. All extensions were implemented and verified with the Coq Proof Assistant.},
	address = {New York, NY, USA},
	author = {D.~Egolf and S.~Lasser and K.~Fisher}, 
	booktitle = {Proceedings of the 11th ACM SIGPLAN International Conference on Certified Programs and Proofs},
	doi = {10.1145/3497775.3503694},
	isbn = {9781450391825},
	keywords = {Brzozowski derivatives, formal verification, lexical analysis, semantic actions},
	location = {Philadelphia, PA, USA},
	numpages = {13},
	pages = {27--39},
	publisher = {Association for Computing Machinery},
	series = {CPP 2022},
	title = {Verbatim++: Verified, Optimized, and Semantically Rich Lexing with Derivatives},
	url = {https://doi.org/10.1145/3497775.3503694},
	year = {2022},
	bdsk-url-1 = {https://doi.org/10.1145/3497775.3503694}}

@article{Turo_ov__2020,
	author = {L.~Turo{\v{n}}ov{\'{a}} and L.~Hol{\'{\i}}k and  O.~Leng{\'{a}}l and O.~Saarikivi and M.~Veanes and T.~Vojnar},
	date-added = {2022-05-23 18:43:04 +0100},
	date-modified = {2022-05-23 18:43:04 +0100},
	doi = {10.1145/3428286},
	journal = {Proceedings of the {ACM} on Programming Languages},
	month = {nov},
	number = {{OOPSLA}},
	pages = {1--30},
	publisher = {Association for Computing Machinery ({ACM})},
	title = {Regex matching with counting-set automata},
	url = {https://doi.org/10.1145%2F3428286},
	volume = {4},
	year = 2020,
	bdsk-url-1 = {https://doi.org/10.1145%2F3428286},
	bdsk-url-2 = {https://doi.org/10.1145/3428286}}

@article{Rathnayake2014StaticAF,
	author = {A.~Rathnayake and H.~Thielecke},
	journal = {ArXiv},
	title = {Static Analysis for Regular Expression Exponential Runtime via Substructural Logics},
	volume = {abs/1405.7058},
	year = {2014}}

@inproceedings{Weideman2017Static,
	author = {N.~Weideman},
	title = {Static analysis of regular expressions},
	year = {2017}}

@inproceedings{RibeiroAgda2017,
	abstract = {We describe the formalization of a regular expression (RE) parsing algorithm that produces a bit representation of its parse tree in the dependently typed language Agda. The algorithm computes bit-codes using Brzozowski derivatives and we prove that produced codes are equivalent to parse trees ensuring soundness and completeness w.r.t an inductive RE semantics. We include the certified algorithm in a tool developed by us, named verigrep, for regular expression based search in the style of the well known GNU grep. Practical experiments conducted with this tool are reported.},
	address = {New York, NY, USA},
	articleno = {4},
	author = {R.~Ribeiro and A.~D.~Bois},
	booktitle = {Proceedings of the 21st Brazilian Symposium on Programming Languages},
	date-modified = {2022-03-16 16:38:47 +0000},
	doi = {10.1145/3125374.3125381},
	isbn = {9781450353892},
	keywords = {Certified algorithms, regular expressions, dependent types, bit-codes},
	location = {Fortaleza, CE, Brazil},
	numpages = {8},
	publisher = {Association for Computing Machinery},
	series = {SBLP 2017},
	title = {Certified Bit-Coded Regular Expression Parsing},
	url = {https://doi.org/10.1145/3125374.3125381},
	year = {2017},
	bdsk-url-1 = {https://doi.org/10.1145/3125374.3125381}}

@article{Thompson_1968,
	author = {Ken Thompson},
	date-added = {2022-02-23 13:44:42 +0000},
	date-modified = {2022-02-23 13:44:42 +0000},
	doi = {10.1145/363347.363387},
	journal = {Communications of the {ACM}},
	month = {jun},
	number = {6},
	pages = {419--422},
	publisher = {Association for Computing Machinery ({ACM})},
	title = {Programming Techniques: Regular expression search algorithm},
	url = {https://doi.org/10.1145%2F363347.363387},
	volume = {11},
	year = 1968,
	bdsk-url-1 = {https://doi.org/10.1145%2F363347.363387},
	bdsk-url-2 = {https://doi.org/10.1145/363347.363387}}

@article{17Bir,
	author = {Asiri Rathnayake and Hayo Thielecke},
	date-added = {2019-08-18 17:57:30 +0000},
	date-modified = {2019-08-18 18:00:13 +0000},
	journal = {arXiv:1405.7058},
	title = {Static Analysis for Regular Expression Exponential Runtime via Substructural Logics},
	year = {2017}}

@article{alfred2014algorithms,
	author = {Alfred, V},
	journal = {Algorithms and Complexity},
	pages = {255},
	publisher = {Elsevier},
	title = {Algorithms for finding patterns in strings},
	volume = {1},
	year = {2014}}

@article{nielson11bcre,
	author = {Lasse Nielsen, Fritz Henglein},
	date-added = {2019-07-03 21:09:39 +0000},
	date-modified = {2019-07-03 21:17:33 +0000},
	journal = {LATA},
	title = {Bit-coded Regular Expression Parsing},
	year = {2011},
	bdsk-file-1 = {YnBsaXN0MDDSAQIDBFxyZWxhdGl2ZVBhdGhZYWxpYXNEYXRhXxA1Li4vLi4vLi4vTXkgTWFjIChNYWNCb29rLVBybykvRGVza3RvcC9mcml0ei1wYXBlci5wZGZPEQF+AAAAAAF+AAIAAAxNYWNpbnRvc2ggSEQAAAAAAAAAAAAAAAAAAAAAAAAAQkQAAf////8PZnJpdHotcGFwZXIucGRmAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA/////wAAAAAAAAAAAAAAAAADAAMAAAogY3UAAAAAAAAAAAAAAAAAB0Rlc2t0b3AAAAIAQi86VXNlcnM6Y3N0YW46RHJvcGJveDpNeSBNYWMgKE1hY0Jvb2stUHJvKTpEZXNrdG9wOmZyaXR6LXBhcGVyLnBkZgAOACAADwBmAHIAaQB0AHoALQBwAGEAcABlAHIALgBwAGQAZgAPABoADABNAGEAYwBpAG4AdABvAHMAaAAgAEgARAASAEBVc2Vycy9jc3Rhbi9Ecm9wYm94L015IE1hYyAoTWFjQm9vay1Qcm8pL0Rlc2t0b3AvZnJpdHotcGFwZXIucGRmABMAAS8AABUAAgAM//8AAAAIAA0AGgAkAFwAAAAAAAACAQAAAAAAAAAFAAAAAAAAAAAAAAAAAAAB3g==}}

@software{regexploit2021,
	author = {B.~Caller, L.~Carettoni},
	date-added = {2020-11-24 00:00:00 +0000},
	date-modified = {2021-05-07 00:00:00 +0000},
	keywords = {ReDos static analyser},
	month = {May},
	title = {regexploit},
	url = {https://github.com/doyensec/regexploit},
	year = {2021},
	bdsk-url-1 = {https://github.com/doyensec/regexploit}}

@software{pcre,
	author = {P.~Hazel},
	date-added = {1997-01-01 00:00:00 +0000},
	date-modified = {2021-06-14 00:00:00 +0000},
	keywords = {Perl Compatible Regular Expressions},
	month = {June},
	title = {PCRE},
	url = {https://www.pcre.org/original/doc/html/},
	year = {2021},
	bdsk-url-1 = {https://www.pcre.org/original/doc/html/}}

@misc{communityRules,
	howpublished = {\url{https://www.snort.org/faq/what-are-community-rules}},
	note = {[Online; last accessed 19-November-2022]},
	title = {{Snort Community Rules}},
	year = {2022}}

@misc{KuklewiczHaskell,
	author = {C.~Kuklewicz},
	keywords = {Buggy C POSIX Lexing Libraries},
	title = {Regex Posix},
	url = {https://wiki.haskell.org/Regex_Posix},
	year = {2017},
	bdsk-url-1 = {https://wiki.haskell.org/Regex_Posix}}

@misc{regex101,
	author = {D.~Firas},
	keywords = {regex tester debugger},
	title = {regex101},
	url = {https://regex101.com/},
	year = {2011},
	bdsk-url-1 = {https://regex101.com/}}

@misc{atomEditor,
	author = {N.~Sobo},
	keywords = {text editor},
	title = {Atom Editor},
	url = {https://atom.io},
	year = {2022},
	bdsk-url-1 = {https://atom.io}}

@techreport{grathwohl2014crash,
	author = {N.~B.~B.~Grathwohl and F.~Henglein and U.~T.~Rasmussen},
	institution = {Technical report, University of Copenhagen},
	title = {A Crash-Course in Regular Expression Parsing and Regular Expressions as Types},
	year = {2014}}

@inproceedings{xml2015,
	abstract = {Regular expressions are omnipresent in database applications. They form the structural core of schema languages for XML, they are a fundamental ingredient for navigational queries in graph databases, and are being considered in languages for upcoming technologies such as schema- and transformation languages for tabular data on the Web. In this paper we study the usage and effectiveness of the counting operator (or: limited repetition) in regular expressions. The counting operator is a popular extension which is part of the POSIX standard and therefore also present in regular expressions in grep, Java, Python, Perl, and Ruby. In a database context, expressions with counting appear in XML Schema and languages for querying graphs such as SPARQL 1.1 and Cypher.We first present a practical study that suggests that counters are extensively used in practice. We then investigate evaluation methods for such expressions and develop a new algorithm for efficient incremental evaluation. Finally, we conduct an extensive benchmark study that shows that exploiting counting operators can lead to speed-ups of several orders of magnitude in a wide range of settings: normal and incremental evaluation on synthetic and real expressions.},
	address = {New York, NY, USA},
	author = {H~.Bj\"{o}rklund and W.~Martens and T.~Timm},
	booktitle = {Proceedings of the 24th ACM International on Conference on Information and Knowledge Management},
	doi = {10.1145/2806416.2806434},
	isbn = {9781450337946},
	keywords = {regular expressions, schema, regular path queries, xml},
	location = {Melbourne, Australia},
	numpages = {10},
	pages = {1541--1550},
	publisher = {Association for Computing Machinery},
	series = {CIKM '15},
	title = {Efficient Incremental Evaluation of Succinct Regular Expressions},
	url = {https://doi.org/10.1145/2806416.2806434},
	year = {2015},
	bdsk-url-1 = {https://doi.org/10.1145/2806416.2806434}}

@misc{SE16,
	author = {StackStatus},
	date-added = {2019-06-26 11:28:41 +0000},
	date-modified = {2019-06-26 16:07:31 +0000},
	keywords = {ReDos Attack},
	month = {July},
	rating = {5},
	read = {1},
	title = {Stack Overflow Outage Postmortem},
	url = {https://stackstatus.net/post/147710624694/outage-postmortem-july-20-2016},
	year = {2016},
	bdsk-url-1 = {https://stackstatus.net/post/147710624694/outage-postmortem-july-20-2016}}

@article{HosoyaVouillonPierce2005,
	author = {H.~Hosoya and J.~Vouillon and B.~C.~Pierce},
	journal = {ACM Transactions on Programming Languages and Systems (TOPLAS)},
	number = 1,
	pages = {46--90},
	title = {{R}egular {E}xpression {T}ypes for {XML}},
	volume = 27,
	year = {2005}}

@misc{POSIX,
	note = {\url{http://pubs.opengroup.org/onlinepubs/009695399/basedefs/xbd_chap09.html}},
	title = {{T}he {O}pen {G}roup {B}ase {S}pecification {I}ssue 6 {IEEE} {S}td 1003.1 2004 {E}dition},
	year = {2004}}

@inproceedings{AusafDyckhoffUrban2016,
	author = {F.~Ausaf and R.~Dyckhoff and C.~Urban},
	booktitle = {Proc.~of the 7th International Conference on Interactive Theorem Proving (ITP)},
	pages = {69--86},
	series = {LNCS},
	title = {{POSIX} {L}exing with {D}erivatives of {R}egular {E}xpressions ({P}roof {P}earl)},
	volume = {9807},
	year = {2016}}

@article{aduAFP16,
	author = {F.~Ausaf and R.~Dyckhoff and C.~Urban},
	issn = {2150-914x},
	journal = {Archive of Formal Proofs},
	note = {\url{http://www.isa-afp.org/entries/Posix-Lexing.shtml}, Formal proof development},
	title = {{POSIX} {L}exing with {D}erivatives of {R}egular {E}xpressions},
	year = 2016}

@techreport{CrashCourse2014,
	annote = {draft report},
	author = {N.~B.~B.~Grathwohl and F.~Henglein and U.~T.~Rasmussen},
	institution = {University of Copenhagen},
	title = {{A} {C}rash-{C}ourse in {R}egular {E}xpression {P}arsing and {R}egular {E}xpressions as {T}ypes},
	year = {2014}}

@inproceedings{Sulzmann2014,
	author = {M.~Sulzmann and K.~Lu},
	booktitle = {Proc.~of the 12th International Conference on Functional and Logic Programming (FLOPS)},
	pages = {203--220},
	series = {LNCS},
	title = {{POSIX} {R}egular {E}xpression {P}arsing with {D}erivatives},
	volume = {8475},
	year = {2014}}

@inproceedings{Sulzmann2014b,
	author = {M.~Sulzmann and P.~van Steenhoven},
	booktitle = {Proc.~of the 23rd International Conference on Compiler Construction (CC)},
	pages = {174--191},
	series = {LNCS},
	title = {{A} {F}lexible and {E}fficient {ML} {L}exer {T}ool {B}ased on {E}xtended {R}egular {E}xpression {S}ubmatching},
	volume = {8409},
	year = {2014}}

@book{Pierce2015,
	author = {B.~C.~Pierce and C.~Casinghino and M.~Gaboardi and M.~Greenberg and C.~Hri\c{t}cu and V.~Sj\"{o}berg and B.~Yorgey},
	note = {\url{http://www.cis.upenn.edu/~bcpierce/sf}},
	publisher = {Electronic textbook},
	title = {{S}oftware {F}oundations},
	year = {2015}}

@misc{Kuklewicz,
	author = {C.~Kuklewicz},
	howpublished = {\url{https://wiki.haskell.org/Regex_Posix}},
	title = {{R}egex {P}osix}}

@article{Vansummeren2006,
	author = {S.~Vansummeren},
	journal = {ACM Transactions on Programming Languages and Systems},
	number = {3},
	pages = {389--428},
	title = {{T}ype {I}nference for {U}nique {P}attern {M}atching},
	volume = {28},
	year = {2006}}

@inproceedings{Asperti12,
	author = {A.~Asperti},
	booktitle = {Proc.~of the 3rd International Conference on Interactive Theorem Proving (ITP)},
	pages = {283--298},
	series = {LNCS},
	title = {{A} {C}ompact {P}roof of {D}ecidability for {R}egular {E}xpression {E}quivalence},
	volume = {7406},
	year = {2012}}

@inproceedings{Frisch2004,
	author = {A.~Frisch and L.~Cardelli},
	booktitle = {Proc.~of the 31st International Conference on Automata, Languages and Programming (ICALP)},
	pages = {618--629},
	series = {LNCS},
	title = {{G}reedy {R}egular {E}xpression {M}atching},
	volume = {3142},
	year = {2004}}

@article{Antimirov95,
	author = {V.~Antimirov},
	journal = {Theoretical Computer Science},
	pages = {291--319},
	title = {{P}artial {D}erivatives of {R}egular {E}xpressions and {F}inite {A}utomata {C}onstructions},
	volume = {155},
	year = {1995}}

@inproceedings{Nipkow98,
	author = {T.~Nipkow},
	booktitle = {Proc.~of the 11th International Conference on Theorem Proving in Higher Order Logics (TPHOLs)},
	pages = {1--15},
	series = {LNCS},
	title = {{V}erified {L}exical {A}nalysis},
	volume = 1479,
	year = 1998}

@article{Brzozowski1964,
	author = {J.~A.~Brzozowski},
	journal = {Journal of the {ACM}},
	number = {4},
	pages = {481--494},
	title = {{D}erivatives of {R}egular {E}xpressions},
	volume = {11},
	year = {1964}}

@article{Leroy2009,
	author = {X.~Leroy},
	journal = {Communications of the ACM},
	number = 7,
	pages = {107--115},
	title = {{F}ormal {V}erification of a {R}ealistic {C}ompiler},
	volume = 52,
	year = 2009}


@article{Wu2014,
	author = {C.~Wu and X.~Zhang and C.~Urban},
	journal = {Journal of Automatic Reasoning},
	number = {4},
	pages = {451--480},
	title = {{A} {F}ormalisation of the {M}yhill-{N}erode {T}heorem based on {R}egular {E}xpressions},
	volume = {52},
	year = {2014}}

@inproceedings{Regehr2011,
	author = {X.~Yang and Y.~Chen and E.~Eide and J.~Regehr},
	booktitle = {Proc.~of the 32nd ACM SIGPLAN Conference on Programming Language Design and Implementation (PLDI)},
	pages = {283--294},
	title = {{F}inding and {U}nderstanding {B}ugs in {C} {C}ompilers},
	year = {2011}}

@article{Norrish2014,
	author = {A.~Barthwal and M.~Norrish},
	journal = {Journal of Computer and System Sciences},
	number = {2},
	pages = {346--362},
	title = {{A} {M}echanisation of {S}ome {C}ontext-{F}ree {L}anguage {T}heory in {HOL4}},
	volume = {80},
	year = {2014}}

@article{Thompson1968,
	author = {K.~Thompson},
	issue_date = {June 1968},
	journal = {Communications of the ACM},
	number = {6},
	pages = {419--422},
	title = {{P}rogramming {T}echniques: {R}egular {E}xpression {S}earch {A}lgorithm},
	volume = {11},
	year = {1968}}

@article{Owens2009,
	author = {S.~Owens and J.~H.~Reppy and A.~Turon},
	journal = {Journal of Functinal Programming},
	number = {2},
	pages = {173--190},
	title = {{R}egular-{E}xpression {D}erivatives {R}e-{E}xamined},
	volume = {19},
	year = {2009}}

@inproceedings{Sulzmann2015,
	author = {M.~Sulzmann and P.~Thiemann},
	booktitle = {Proc.~of the 9th International Conference on Language and Automata Theory and Applications (LATA)},
	pages = {275--286},
	series = {LNCS},
	title = {{D}erivatives for {R}egular {S}huffle {E}xpressions},
	volume = {8977},
	year = {2015}}

@inproceedings{Chen2012,
	author = {H.~Chen and S.~Yu},
	booktitle = {Proc.~in the International Workshop on Theoretical Computer Science (WTCS)},
	pages = {343--356},
	series = {LNCS},
	title = {{D}erivatives of {R}egular {E}xpressions and an {A}pplication},
	volume = {7160},
	year = {2012}}

@article{Krauss2011,
	author = {A.~Krauss and T.~Nipkow},
	journal = {Journal of Automated Reasoning},
	pages = {95--106},
	title = {{P}roof {P}earl: {R}egular {E}xpression {E}quivalence and {R}elation {A}lgebra},
	volume = 49,
	year = 2012}

@inproceedings{Traytel2015,
	author = {D.~Traytel},
	booktitle = {Proc.~of the 24th Annual Conference on Computer Science Logic (CSL)},
	pages = {487--503},
	series = {LIPIcs},
	title = {{A} {C}oalgebraic {D}ecision {P}rocedure for {WS1S}},
	volume = {41},
	year = {2015}}

@inproceedings{Traytel2013,
	author = {D.~Traytel and T.~Nipkow},
	booktitle = {Proc.~of the 18th ACM SIGPLAN International Conference on Functional Programming (ICFP)},
	pages = {3-12},
	title = {{A} {V}erified {D}ecision {P}rocedure for {MSO} on {W}ords {B}ased on {D}erivatives of {R}egular {E}xpressions},
	year = 2013}

@inproceedings{Coquand2012,
	author = {T.~Coquand and V.~Siles},
	booktitle = {Proc.~of the 1st International Conference on Certified Programs and Proofs (CPP)},
	pages = {119--134},
	series = {LNCS},
	title = {{A} {D}ecision {P}rocedure for {R}egular {E}xpression {E}quivalence in {T}ype {T}heory},
	volume = {7086},
	year = {2011}}

@inproceedings{Almeidaetal10,
	author = {J.~B.~Almeida and N.~Moriera and D.~Pereira and S.~M.~de Sousa},
	booktitle = {Proc.~of the 15th International Conference on Implementation and Application of Automata (CIAA)},
	pages = {59-68},
	series = {LNCS},
	title = {{P}artial {D}erivative {A}utomata {F}ormalized in {C}oq},
	volume = {6482},
	year = {2010}}

@article{Owens2008,
	author = {S.~Owens and K.~Slind},
	journal = {Higher-Order and Symbolic Computation},
	number = {4},
	pages = {377--409},
	title = {{A}dapting {F}unctional {P}rograms to {H}igher {O}rder {L}ogic},
	volume = {21},
	year = {2008}}

@article{Owens2,
	author = {S.~Owens and K.~Slind},
	bibsource = {dblp computer science bibliography, http://dblp.org},
	biburl = {http://dblp.uni-trier.de/rec/bib/journals/lisp/OwensS08},
	doi = {10.1007/s10990-008-9038-0},
	journal = {Higher-Order and Symbolic Computation},
	number = {4},
	pages = {377--409},
	timestamp = {Wed, 16 Dec 2009 13:51:02 +0100},
	title = {Adapting functional programs to higher order logic},
	url = {http://dx.doi.org/10.1007/s10990-008-9038-0},
	volume = {21},
	year = {2008},
	bdsk-url-1 = {http://dx.doi.org/10.1007/s10990-008-9038-0}}

@misc{PCRE,
	title = {{PCRE - Perl Compatible Regular Expressions}},
	url = {http://www.pcre.org},
	bdsk-url-1 = {http://www.pcre.org}}

@inproceedings{Davis18,
	author = {J.~C.~Davis and C.~.A.~Coghlan and F.~Servant and D.~Lee},
	booktitle = {Proc.~of the 26th ACM Joint Meeting on European Software Engineering Conference and Symposium on the Foundations of Software Engineering (ESEC/FSE)},
	numpages = {11},
	pages = {246--256},
	title = {{T}he {I}mpact of {R}egular {E}xpression {D}enial of {S}ervice ({ReDoS}) in {P}ractice: {A}n {E}mpirical {S}tudy at the {E}cosystem {S}cale},
	year = {2018}}


@misc{grep,
	title = {GNU grep},
	url = {https://www.gnu.org/software/grep/manual/grep.html},
}