Skip to content

Commit

Permalink
docs: document config module
Browse files Browse the repository at this point in the history
  • Loading branch information
jan-ferdinand committed May 27, 2024
1 parent 89cc89a commit f05643f
Show file tree
Hide file tree
Showing 2 changed files with 43 additions and 17 deletions.
19 changes: 19 additions & 0 deletions triton-vm/src/config.rs
Original file line number Diff line number Diff line change
@@ -1,3 +1,22 @@
//! This module contains various configuration options for Triton VM. In
//! general, the configuration options impact performance only. In particular,
//! any configuration provides the same completeness and soundness guarantees.
//!
//! The default configuration is sane and should provide the best performance
//! for most compilation targets. If you are generation Triton VM proofs on some
//! “unusual” system, you might want to try a few different options.
//!
//! # Time / Memory Trade-Offs
//!
//! Parts of the [proof generation](crate::stark::Stark::prove) process can
//! trade time for memory. This module provides ways to control these
//! trade-offs. Additionally, and with lower precedence, they can be controlled
//! via the following environment variables:
//!
//! - `TVM_LDE_TRACE`: Set to `cache` to cache the low-degree extended trace.
//! Set to `no_cache` to not cache it. If unset (or set to anything else),
//! Triton VM will make an automatic decision based on free memory.
use std::cell::RefCell;

use arbitrary::Arbitrary;
Expand Down
41 changes: 24 additions & 17 deletions triton-vm/src/lib.rs
Original file line number Diff line number Diff line change
@@ -1,28 +1,36 @@
//! Triton Virtual Machine is a Zero-Knowledge Proof System (ZKPS) for proving correct execution
//! of programs written in Triton assembly. The proof system is a zk-STARK, which is a
//! state-of-the-art ZKPS.
//! Triton Virtual Machine is a Zero-Knowledge Proof System (ZKPS) for proving
//! correct execution of programs written in Triton assembly. The proof system
//! is a [zk-STARK](Stark), which is a state-of-the-art ZKPS.
//!
//! Generally, all arithmetic performed by Triton VM happens in the prime field with
//! 2^64 - 2^32 + 1 elements. Instructions for u32 operations are provided.
//!
//! For a full overview over all available instructions and their effects, see the
//! [specification](https://triton-vm.org/spec/instructions.html).
//!
//! # Time / Memory Trade-Offs
//! [Triton VM's STARK](Stark) is parametric, but it is highly recommended to
//! use the provided [default](Stark::default). Furthermore, certain runtime
//! characteristics are [configurable](config), and usually don't need changing.
//!
//! Parts of the [proof generation](Stark::prove) process can trade time for memory. The
//! [config] module provides ways to control these trade-offs. Additionally, and with lower
//! precedence, they can be controlled via the following environment variables:
//! # Non-Determinism
//!
//! - `TVM_LDE_TRACE`: Set to `cache` to cache the low-degree extended trace. Set to `no_cache`
//! to not cache it. If unset (or set to anything else), Triton VM will make an automatic decision
//! based on free memory.
//! Triton VM is a non-deterministic machine. That is,
//! 1. Triton VM's random access memory can be initialized arbitrarily, and
//! 1. for a select few instructions (namely `divine` and `merkle_step`),
//! correct state transition is not fully determined by the current state and
//! Triton VM's public input.
//!
//! The input for those non-deterministic instructions use dedicated input
//! streams. Those, together with the initial RAM, are collectively called
//! [`NonDeterminism`].
//!
//! # Examples
//!
//! Convenience function [`prove_program()`] as well as the [`prove()`] and [`verify()`] methods
//! natively operate on [`BFieldElement`]s, _i.e_, elements of the prime field with 2^64 - 2^32 + 1
//! elements.
//! Below are a few examples on how to use Triton VM. They show the instruction
//! set architecture in action and highlight the core methods required to
//! generate & verify a proof of correct execution. Some of these are
//! convenience function [`prove_program()`] as well as the [`prove()`] and
//! [`verify()`] methods.
//!
//! ## Factorial
//!
Expand All @@ -36,7 +44,6 @@
//! the state of the operational stack is shown as a comment after most instructions.
//!
//! ```
//! # use triton_vm::*;
//! # use triton_vm::prelude::*;
//! let factorial_program = triton_program!(
//! read_io 1 // n
Expand All @@ -59,13 +66,13 @@
//! swap 1 // n-1 acc·n
//! recurse
//! );
//! let public_input = PublicInput::from([bfe!(10)]);
//! let public_input = PublicInput::new(bfe_vec![10]);
//! let non_determinism = NonDeterminism::default();
//!
//! let (stark, claim, proof) =
//! prove_program(&factorial_program, public_input, non_determinism).unwrap();
//! triton_vm::prove_program(&factorial_program, public_input, non_determinism).unwrap();
//!
//! let verdict = verify(stark, &claim, &proof);
//! let verdict = triton_vm::verify(stark, &claim, &proof);
//! assert!(verdict);
//!
//! assert_eq!(1, claim.output.len());
Expand Down

0 comments on commit f05643f

Please sign in to comment.