CS 345H: Programming Languages (Honors) Spring 2024

Homework 3: Dafny and Lambda Calculus

Due date: April 4, 6pm
Grading: 15% (CS 345H) or 9% (CS 386L) of your course grade

In this homework, we'll do two separate and mostly unrelated things:

Table of contents

Preparation

Make sure you have Coq installed and working, following the instructions from Homework 0.

For Part 1, you'll also need to install Dafny. I strongly suggest using Visual Studio Code to complete this homework, as it has a full-featured Dafny integration with many nice features. Regardless of operating system, install Visual Studio Code before going any further.

Now install the Dafny VSCode extension by clicking the Install button on its homepage or by searching for dafny-lang.ide-vscode in VSCode's extension pane. Make sure you get the right extension, as there are some deprecated ones still available—the one you're looking for is authored by "dafny-lang" rather than "Correctness Lab". (It's the only one with a blue checkmark).

Next, follow the appropriate instructions below for your system to get the extension fully set up. If any of the instructions are unclear, see the official Dafny installation instructions for more detailed help.

macOS

Install the .NET 6.0 SDK using Homebrew:

brew install dotnet-sdk

That should be all you need to do. The first time you open a .dfy file in VSCode, the Dafny extension will automatically download and install the latest Dafny release.

Linux

Install the .NET 6.0 SDK by following the instructions for your distribution.

That should be all you need to do. The first time you open a .dfy file in VSCode, the Dafny extension will automatically download and install the latest Dafny release.

Windows

Nothing more to do! The first time you open a .dfy file in VSCode, the Dafny extension will automatically download and install the latest Dafny release.

Get the code

We'll be using GitHub Classroom to check out and submit this homework. Follow the GitHub Classroom URL on Ed to create your private copy of the homework repository, and then clone that repository to your machine. For example, the repository it created for me is called hw3-jamesbornholt, so I would do:

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

Complete the homework

In your repository, there are two files you need to edit:

These files uses comment to explain what's going on and list the problems you need to solve. A few of the problems ask for English answers rather than code; for those questions, you should just add your answer in the file as a comment.

There is a total of 99 points available across the two files, plus 2 points of extra credit in Part 1 (Problem 6).

Resources for writing Dafny

Dafny is a "verification-ready" programming language. To a first approximation, it's like C# but with some weird syntactic differences, and then with pre/postconditions and assertions added to the language.

There's a good collection of Dafny resources on the Dafny website. In particular, the cheatsheet is good as a quick reference for syntax, and the Getting Started tutorial, while long, shows everything you'll need for this homework. Our lecture notes for Dafny also cover most of what you'll need for this homework.

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 files you should need to modify are Part1.dfy and Part2.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 Dafny and Coq using GitHub Actions. It will pass as long as your files compile, your Dafny file verifies, and your Coq file has no remaining admit or Admitted statements. This is only a partial grader, and we're using it only to give you early feedback on your submissions—we will still be reading and grading your code by hand. Just because the autograder passes doesn't mean you'll get full points; just because the autograder fails doesn't mean you won't get full points.