15 releases
Uses new Rust 2024
new 0.3.11 | Apr 16, 2025 |
---|---|
0.3.10 | Apr 15, 2025 |
0.2.1 | Apr 3, 2025 |
0.1.2 | Apr 1, 2025 |
#196 in Math
1,393 downloads per month
27KB
236 lines
fib-rs
A highly optimized Fibonacci number calculator for Rust that efficiently computes arbitrarily large Fibonacci numbers.
Table of Contents
Features
- Fast doubling algorithm: Calculates Fibonacci numbers in O(log n) time
- Handles massive inputs: Compute Fibonacci numbers up to F(10,000,000) and beyond
- Range calculation: Generate sequences of consecutive Fibonacci numbers with parallel processing
- CLI application: Simple command-line interface for quick calculations of single values or ranges
Installation
Library
To use as a dependency in your project:
cargo add fib-rs --no-default-features
CLI Tool
To install the command-line tool:
cargo install fib-rs
Usage
As a library
use fib_rs::{fib, fib_range};
// Calculate F(100)
let i = 100;
let result = fib(i);
// Print the result
println!("F({}) = {}", i, result);
// Calculate a range of Fibonacci numbers (F(3) through F(10))
let range = 3..=10;
let results = fib_range(range.clone());
// Print the results
range
.zip(results.iter())
.for_each(|(i, result)| println!("F({}) = {}", i, result));
Command-line application
Single
fib single 100
F(100) = 354224848179261915075
Range
fib range 6 10
F(6) = 8
F(7) = 13
F(8) = 21
F(9) = 34
F(10) = 55
Performance
Specifications:
- 15-inch MacBook Air (2025)
- M4 Chip, 10C CPU, 10C GPU
- 32GB Unified Memory
- macOS Sequoia 15.4
Single | Computation Time |
---|---|
F(1,000) | ~876ns |
F(10,000) | ~8μs |
F(100,000) | ~332μs |
F(1,000,000) | ~10ms |
F(10,000,000) | ~326ms |
Range | Computation Time |
---|---|
F(0) -> F(1,000) | ~57.6μs |
F(0) -> F(10,000) | ~729μs |
F(0) -> F(100,000) | ~45ms |
Algorithm Details
Single Fibonacci Number
For computing a single Fibonacci number, this implementation uses the fast doubling algorithm with logarithmic time complexity:
For even n: F(2k) = F(k) (2F(k+1) - F(k))
For odd n: F(2k+1) = F(k+1)^2 + F(k)^2
This divide-and-conquer approach is vastly more efficient than naive recursive or iterative methods for large inputs.
Fibonacci Range
The range implementation combines two approaches for optimal performance:
- Parallel processing: Divides the requested range into optimal chunks based on available CPU threads
- Smart initialization: Uses the fast doubling algorithm to efficiently find the starting values for each chunk
- Iterative calculation: After finding starting values, computes subsequent Fibonacci numbers iteratively within each chunk
This hybrid approach provides excellent performance for generating sequences of consecutive Fibonacci numbers, especially for large ranges, by leveraging multi-core processing while maintaining mathematical efficiency.
Web Demo
Try the interactive web demo to calculate Fibonacci numbers directly in your browser. The demo showcases the library's performance and capabilities through a WebAssembly implementation.
License
This project is licensed under the MIT License.
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
Dependencies
~1–13MB
~146K SLoC