regex-reexamined-coq
regex-reexamined-coq copied to clipboard
This learning exercise has come to an end. We are continuing work in this area here
Derivatives for Regular reexamined with Coq
This repo reexamines a few papers on regular expressions using Coq as a learning exercise. We try to prove some things that are mentioned in the papers as a way to teach ourselves some Coq.
- Brzozowski In this folder we explore proving theorems from the original paper Derivatives of Regular Expressions - Janusz A Brzozowski We have retyped and modified it a bit to aid readability.
- Coinduction In this folder we explore using coinduction to prove regular expressions are equivalent.
- Reexamined In this folder we explore a modern version of derivatives defined in the paper Regular-expression derivatives reexamined This paper is a great introduction to using derivatives for regular expressions, since it has been not only been updated, but is also one of the easier papers to read.
- CoqStock standard library.
Background
Brzozowski's Derivatives of Regular Expressions
If you are unfamiliar with Brzozowski's Derivatives you can watch this video.
data:image/s3,"s3://crabby-images/3d793/3d7933b607f15534f7ad8567ace2949791a04226" alt="Watch the video"
Setup
- Install Coq 8.13.0
- Remember to set coq in your PATH. For example, in your
~/.bash_profile
addPATH="/Applications/CoqIDE_8.13.0.app/Contents/Resources/bin/:${PATH}"
and run$ source ~/.bash_profile
. - Run make in this folder.
Note:
-
make cleanall
cleans all files even.aux
files.
Contributing
Please read the contributing guidelines. They are short and shouldn't be surprising.
Regenerate Makefile
Coq version upgrade requires regenerating the Makefile with the following command:
$ coq_makefile -f _CoqProject -o Makefile
Pair Programming
We used to pair program. The schedule was posted as meetups events on meetup.com