CS 345H: Programming Languages (Honors) Spring 2024

Homework 0: Warmup

Due date: January 30, 6pm
Grading: 5% (CS 345H) or 4% (CS 386L) of your course grade

Coq is an interactive theorem prover or proof assistant widely used for formalizing programming languages, mathematics, and even entire software systems. In an interactive theorem prover, you write your program or model (often as a functional program), and then can write and complete proofs about those programs. These proofs are written as a series of simple deduction steps called tactics, and the proof assistant will automatically check that each deduction step you write is logically sound.

In this course, we'll be using Coq to formalize most of our proofs, including all homework proofs and the final exam. We choose to use a proof assistant instead of pen-and-paper proofs for a few reasons. First, the proof assistant forces us to be precise in our reasoning—Coq will not be amused by hand-waving explanations we might make on paper. Second, the proof assistant helps us check our understanding of a proof—we don't need to worry about having missed a case of a proof, or making some wrong logical step. Finally, I just think proof assistants are pretty neat, and a cool application of programming languages ideas that are worth seeing.

This is a short warmup homework, intended mostly to get you up and running with Coq on your local machine, as well as introducing the GitHub Classroom platform we'll be using for homeworks in this class.

Table of contents

Preparation

First, we'll need to install Coq, as well as a development environment for it. I've tested these instructions on Mac and Linux, but everyone's system is a little different. Our friends at UW have written some very detailed installation instructions that you can try out if the more terse ones here don't work. If you run into trouble, please post on the Ed discussion board, as it's likely others have had the same problem!

Mac

On a Mac with Homebrew installed, installing Coq is as easy as:

brew install coq

Once that's done, skip along to Choosing an IDE.

Linux

I don't recommend using your distribution's package manager to install Coq, as most package managers tend to be several Coq versions behind (it's a fairly niche package). One exception is that on Ubuntu, you'll get a recent version of Coq using Snap:

sudo snap install coq-prover

Otherwise, you should install Opam (the package manager for the OCaml programming language that Coq is implemented in) and then use it to install Coq. On Ubuntu 22.04 (and possibly other versions), this should be enough to get everything you need:

sudo apt install -y build-essential unzip bubblewrap
sh <(curl -sL https://raw.githubusercontent.com/ocaml/opam/master/shell/install.sh)
opam init -a
eval $(opam env)
opam pin add coq 8.18.0

When you set up your IDE, you might need to tell it where Coq is installed. These steps will install it to $HOME/.opam/default/bin.

Coq is also available on the UTCS public Linux hosts, but it's a very outdated version. That should work for this homework, but for later homeworks you'll likely want a newer version.

Windows

You're on your own, sorry! The Windows Subsystem for Linux might work, or you can try the UW installation instructions linked above.

Choosing an IDE

Coq proofs are just text files like any other programming language, so you're free to use whatever text editor you prefer. But proofs are a lot easier to write with IDE support for showing you the proof context, exploring available lemmas, etc. I strongly recommend setting up a good IDE for Coq proofs. I have three suggestions here:

As we saw in lecture, most people write Coq proofs interactively. The core idea is to step backwards and forwards through the Coq definitions using your IDE. For VSCoq, look for "Step Backwards", "Step Forwards", and "Interpret to Point" commands (on my Mac, they're Ctrl+Option and Up, Down, and Right arrows, respectively).

Get the code

We'll be using GitHub Classroom to check out and submit homework and the final exam this semester. I'm assuming you already have some experience with Git as a version control system. If not, Chapters 1 and 2 of the Git book are a good tutorial, as is GitHub's quickstart guide.

To get started, you'll need to create a GitHib account if you don't already have one. Then you need to use the GitHub Classroom URL from Ed to create your own private copy of the homework repository. Along the way, GitHub Classroom will ask you to associate your GitHub account with your UT EID—if you make a mistake here, you'll need my help to undo it, so please get in touch via Ed.

Once you have a repository created by GitHub Classroom, clone it to your machine. For example, the repository it created for me is called hw0-jamesbornholt, so I would do:

git clone git@github.com:utcs345h-24sp/hw0-jamesbornholt.git
cd hw0-jamesbornholt

Complete the homework

In your repository, there's just a single Coq file, Homework.v. That file contains all the tasks you need to complete, and uses comments to explain what's going on.

Just as a cross-reference, here's a list of problems in that file:

  1. (2 points) Fill in the definition for length.
  2. (2 points) Fill in the definition for append.
  3. (4 points) Complete the proof of the append_length_sum theorem.
  4. (1 point extra credit) Define the rev function and write the rev_preserves_length theorem and proof.

Some resources for writing Coq

Coq has a slightly steep learning curve. Here are some resources you could reference if you need help understanding how to write Coq or Coq proofs:

What to submit

Submit your solutions by committing your changes in Git and pushing them to the private repository GitHub Classroom created for you in the Get the code step.

The only file you should need to modify is Homework.v.

GitHub Classroom will automatically select your most recent pushed commit before the deadline as your submission. There's no need to manually submit anything else via Canvas or GitHub.

GitHub Classroom also has a simple autograder for Coq proofs using GitHub Actions. It will pass as long as your Homework.v file compiles. This is only a partial grader, so just because the autograder passes doesn't mean you'll get full points—we will still read your proofs by hand. Also, the autograder does not check the extra credit question.