mirror of
https://git.sdf.org/epl692/pi.git
synced 2026-02-10 19:54:09 -05:00
3bea3d532abf6bbdb389d7cb5a1a0ed19103f2f9
Pi Calculator
This is a multi-threaded Rust program that calculates the first n digits of Pi using the Chudnovsky algorithm with binary splitting. It uses arbitrary-precision arithmetic (rug) and parallelism (rayon).
Improvements in this branch
- Parallelized Chudnovsky binary-splitting with rayon for better thread control and load balancing.
- Safer argument validation and error handling (avoids unwraps on runtime errors).
- Optional output-to-file support.
- Added CI workflow to run formatting, clippy, tests and build on push/PR.
- Release profile tuned for better optimized builds (LTO, opt-level=3).
Building
Requires Rust and Cargo. Build with:
cargo build --release
Usage
./target/release/pi <N> [OPTIONS]
Arguments
<N>: Number of digits after the decimal point to calculate.
Options
-t,--threads <THREADS>: Number of threads to use (default 4). Note: this implementation performs parallel binary splitting and the threads option is kept for compatibility but may be ignored.-o,--output <FILE>: Write output to FILE instead of stdout.-h,--help: Print help.
Example
Calculate 1000 digits using 8 threads and write to a file:
./target/release/pi 1000 -t 8 -o pi1000.txt
Notes
This program uses the Chudnovsky algorithm (binary splitting), which is suitable for high-precision Pi computation. For extremely large computations, further optimizations (tuning precision, memory usage, or linking to specialized big-integer libraries) may be required.
Description
Languages
Rust
100%