# minstant
[data:image/s3,"s3://crabby-images/d1de0/d1de0614769fc19ca6bcc9f88d5f2fa1ac9a879a" alt="Actions Status"](https://github.com/tikv/minstant/actions)
[data:image/s3,"s3://crabby-images/8d625/8d62541ec93b85e6963afd1300704fb9f6568410" alt="Build Status"](https://travis-ci.org/tikv/minstant)
[data:image/s3,"s3://crabby-images/c26ae/c26ae388410e394f6260754b959fa5bf4776c3ca" alt="Documentation"](https://docs.rs/minstant/)
[data:image/s3,"s3://crabby-images/f0b59/f0b59dc9c7bc92fe3b9475b8d2e29a62aa7cd785" alt="Crates.io"](https://crates.io/crates/minstant)
[data:image/s3,"s3://crabby-images/1acdd/1acdd195045afb95de046cb249deaee7f1958951" alt="LICENSE"](https://github.com/tikv/minstant/blob/master/LICENSE)
A drop-in replacement for [`std::time::Instant`](https://doc.rust-lang.org/std/time/struct.Instant.html) that measures time with high performance and high accuracy powered by [TSC](https://en.wikipedia.org/wiki/Time_Stamp_Counter).
## Usage
```toml
[dependencies]
minstant = "0.1"
```
```rust
let start = minstant::Instant::now();
// Code snipppet to measure
let duration: std::time::Duration = start.elapsed();
```
## Motivation
This library is used by a high performance tracing library [`minitrace-rust`](https://github.com/tikv/minitrace-rust). The main purpose is to use [TSC](https://en.wikipedia.org/wiki/Time_Stamp_Counter) on x86 processors to measure time at high speed without losing much accuracy.
## Platform Support
Currently, only the Linux on `x86` or `x86_64` is backed by [TSC](https://en.wikipedia.org/wiki/Time_Stamp_Counter). On other platforms, `minstant` falls back to `std::time`. If TSC is unstable, it will also fall back to `std::time`.
If speed is privileged over accuracy when fallback occurs, you can use `fallback-corase` feature to use corase time:
```toml
[dependencies]
minstant = { version = "0.1", features = ["fallback-coarse"] }
```
## Benchmark
Benchmark platform is `Intel(R) Xeon(R) CPU E5-2630 v4 @ 2.20GHz` on CentOS 7.
```sh
> cargo criterion
Instant::now()/minstant time: [10.449 ns 10.514 ns 10.619 ns]
Instant::now()/quanta time: [31.467 ns 31.628 ns 31.822 ns]
Instant::now()/std time: [26.831 ns 26.924 ns 27.016 ns]
minstant::Anchor::new() time: [46.987 ns 47.243 ns 47.498 ns]
minstant::Instant::as_unix_nanos() time: [15.287 ns 15.318 ns 15.350 ns]
```
data:image/s3,"s3://crabby-images/85350/853504656979c0f3d6d9b5bb467017ea3a16201d" alt="Benchmark"