diff --git a/README.md b/README.md
index b8587ce..aaf6f45 100644
--- a/README.md
+++ b/README.md
@@ -1,59 +1,55 @@
Mastic: Private Aggregated Statistics through Fully Linear Proofs
-### WARNING: This is not production-ready code.
+This is a Rust implementation of the ideas presented in the Mastic Verifiable Distributed
+Aggregation Function (VDAF) individual Internet-Draft. You can read the draft on the [Datatracker
+Page](https://datatracker.ietf.org/doc/draft-mouris-cfrg-mastic/).
-This is software for a research prototype. Please do *NOT* use this code in production.
-This repository builds upon [plasma](https://github.com/TrustworthyComputing/plasma) and
-[heavy-hitters](https://github.com/henrycg/heavyhitters).
-
-## Getting started
+## Building
First, make sure that you have a working Rust installation:
-
```bash
❯❯ rustc --version
-rustc 1.72.1
+rustc 1.73.0
❯❯ cargo --version
-cargo 1.72.1
+cargo 1.73.0
```
-### Build from sources
+Next, build from sources using:
```bash
-cargo build --release
+❯❯ cargo build --release
```
-## Heavy Hitters
+## Running
-Server 0:
+#### Server 0:
```bash
cargo run --release --bin server -- --config src/bin/config.json --server_id 0
```
-Server 1:
+#### Server 1:
```bash
cargo run --release --bin server -- --config src/bin/config.json --server_id 1
```
-
-
Now, the servers should be ready to process client requests.
-In a forth shell, run the following command to send 100 client requests to the servers:
-Clients:
+#### Clients:
+In another shell, run the following command to send 100 client requests to the servers.
```bash
cargo run --release --bin leader -- --config src/bin/config.json -n 100
```
-To run with the presence of malicious clients include the `--malicious` flag followed by the percentage of malicious clients to generate ([0.0, 0.9]).
-For instance, to run with 5% malicious clients use:
+To run with the presence of malicious clients include the `--malicious` flag followed by the
+percentage of malicious clients to generate ([0.0, 0.9]). For instance, to run with 5% malicious
+clients use:
```bash
cargo run --release --bin leader -- --config src/bin/config.json -n 100 --malicious 0.05
```
-## The config file
-The client and servers use a common configuration file, which contains the parameters for the system.
-An example of one such file is in `src/bin/config.json`. The contents of that file are here:
+#### The config file
+The client and servers use a common configuration file, which contains the parameters for the
+system. An example of one such file is in `src/bin/config.json`. The contents of that file are here:
```bash
{
@@ -61,7 +57,6 @@ An example of one such file is in `src/bin/config.json`. The contents of that fi
"threshold": 0.01,
"server_0": "0.0.0.0:8000",
"server_1": "0.0.0.0:8001",
- "server_2": "0.0.0.0:8002",
"addkey_batch_size": 100,
"unique_buckets": 10,
"zipf_exponent": 1.03
@@ -69,14 +64,27 @@ An example of one such file is in `src/bin/config.json`. The contents of that fi
```
The parameters are:
-
* `data_bytes`: Number of bytes of each string (x8 for bits).
-* `threshold`: The servers will output the collection of strings that more than a `threshold` of clients hold.
-* `server0`, `server1`, and `server2`: The `IP:port` of tuple for the two servers. The servers can run on different IP addresses, but these IPs must be publicly addressable.
-* `addkey_batch_size`: The number of each type of RPC request to bundle together. The underlying RPC library has an annoying limit on the size of each RPC request, so you cannot set these values too large.
-* `unique_buckets` and `zipf_exponent`: Each simulated client samples its private string from a Zipf distribution over strings with parameter `zipf_exponent` and support `unique_buckets`.
+* `threshold`: The servers will output the collection of strings that more than a `threshold` of
+ clients hold.
+* `server0`, `server1`, and `server2`: The `IP:port` of tuple for the two servers. The servers can
+ run on different IP addresses, but these IPs must be publicly addressable.
+* `addkey_batch_size`: The number of each type of RPC request to bundle together. The underlying RPC
+ library has an annoying limit on the size of each RPC request, so you cannot set these values too
+ large.
+* `unique_buckets` and `zipf_exponent`: Each simulated client samples its private string from a Zipf
+ distribution over strings with parameter `zipf_exponent` and support `unique_buckets`.
+
+
+## Disclaimer
+
+This is software for a research prototype and not production-ready code. This repository builds upon
+[plasma](https://github.com/TrustworthyComputing/plasma),
+[heavy-hitters](https://github.com/henrycg/heavyhitters), and
+[libprio-rs](https://github.com/divviup/libprio-rs/tree/main).
+
-
+
Trustworthy Computing Group