Struct progress_observer::Observer
source · pub struct Observer { /* private fields */ }Expand description
Regular progress update observer.
Implementations§
source§impl Observer
impl Observer
sourcepub fn new_with_max_checkpoint_size(
frequency_target: Duration,
max_checkpoint_size: u64
) -> Self
pub fn new_with_max_checkpoint_size( frequency_target: Duration, max_checkpoint_size: u64 ) -> Self
Create an Observer with a maximum checkpoint size.
In some instances, such as during particularly chaotic computations, the observer could erroneously derive an exceedingly large size for the next potential checkpoint. In those situations, you might want to specify a maximum number of ticks between progress reports, so that the observer doesn’t get stuck waiting indefinitely after a bad next checkpoint estimate.
use std::time::Duration;
use std::iter::once;
use progress_observer::prelude::*;
// compute the ratio of prime numbers between 1 and n
fn is_prime(n: u64) -> bool {
once(2)
.chain((3..=((n as f32).sqrt() as u64)).step_by(2))
.find(|i| n % i == 0)
.is_none()
}
let mut primes = 0;
for (n, should_print) in
Observer::new_with_max_checkpoint_size(Duration::from_secs(1), 300_000)
.take(10_000_000)
.enumerate()
{
if is_prime(n as u64) {
primes += 1;
}
if should_print {
println!("{primes} / {n} = {:.4}", (primes as f64) / (n as f64));
}
}sourcepub fn new_with_checkpoint_size(
frequency_target: Duration,
checkpoint_size: u64
) -> Self
pub fn new_with_checkpoint_size( frequency_target: Duration, checkpoint_size: u64 ) -> Self
Create an Observer with a custom starting checkpoint size.
The checkpoint size represents the number of ticks until the next progress update is emitted.
It is adjusted automatically each printout based on the duration of the work performed, and thus it is typically not necessary to set manually; the default starting checkpoint size of 1 is sufficient for almost any workload, and the checkpoint size will adjust automatically within 1-3 prints to adapt to the workload you’re performing. Specify only if you both have a strong estimate for how many iterations will pass within the timeframe of your specified frequency target, and you actually care about the frequency of those first couple printouts.
use std::time::Duration;
use std::iter::once;
use progress_observer::prelude::*;
// compute the ratio of prime numbers between 1 and n
fn is_prime(n: u64) -> bool {
once(2)
.chain((3..=((n as f32).sqrt() as u64)).step_by(2))
.find(|i| n % i == 0)
.is_none()
}
let mut primes = 0;
for (n, should_print) in
Observer::new_with_checkpoint_size(Duration::from_secs(1), 500_000)
.take(10_000_000)
.enumerate()
{
if is_prime(n as u64) {
primes += 1;
}
if should_print {
println!("{primes} / {n} = {:.4}", (primes as f64) / (n as f64));
}
}sourcepub fn new(frequency_target: Duration) -> Self
pub fn new(frequency_target: Duration) -> Self
Create a new Observer with the specified frequency target.
The observer will attempt to adjust its reports to match the specified target; if you specify 1 second, it will attempt to display progress updates in 1 second intervals.
use std::time::Duration;
use std::iter::once;
use progress_observer::prelude::*;
// compute the ratio of prime numbers between 1 and n
fn is_prime(n: u64) -> bool {
once(2)
.chain((3..=((n as f32).sqrt() as u64)).step_by(2))
.find(|i| n % i == 0)
.is_none()
}
let mut primes = 0;
for (n, should_print) in
Observer::new(Duration::from_secs(1))
.take(10_000_000)
.enumerate()
{
if is_prime(n as u64) {
primes += 1;
}
if should_print {
println!("{primes} / {n} = {:.4}", (primes as f64) / (n as f64));
}
}sourcepub fn tick_n(&mut self, n: u64) -> bool
pub fn tick_n(&mut self, n: u64) -> bool
Tick the observer by n iterations at once.
use std::time::Duration;
use std::iter::once;
use progress_observer::prelude::*;
// compute the ratio of prime numbers between 1 and n
fn is_prime(n: u64) -> bool {
once(2)
.chain((3..=((n as f32).sqrt() as u64)).step_by(2))
.find(|i| n % i == 0)
.is_none()
}
let mut primes = 0;
let mut observer = Observer::new(Duration::from_secs(1));
for n in 0..10_000_000 {
if is_prime(n as u64) {
primes += 1;
}
if observer.tick_n(1) {
println!("{primes} / {n} = {:.4}", (primes as f64) / (n as f64));
}
}sourcepub fn tick(&mut self) -> bool
pub fn tick(&mut self) -> bool
Tick the observer by 1 iteration.
The tick method will report a true value every time it thinks a progress update
should occur. This is based on the passed frequency_target when the observer is created.
use std::time::Duration;
use std::iter::once;
use progress_observer::prelude::*;
// compute the ratio of prime numbers between 1 and n
fn is_prime(n: u64) -> bool {
once(2)
.chain((3..=((n as f32).sqrt() as u64)).step_by(2))
.find(|i| n % i == 0)
.is_none()
}
let mut primes = 0;
let mut observer = Observer::new(Duration::from_secs(1));
for n in 0..10_000_000 {
if is_prime(n as u64) {
primes += 1;
}
if observer.tick() {
println!("{primes} / {n} = {:.4}", (primes as f64) / (n as f64));
}
}Trait Implementations§
source§impl Iterator for Observer
impl Iterator for Observer
source§fn next(&mut self) -> Option<Self::Item>
fn next(&mut self) -> Option<Self::Item>
source§fn next_chunk<const N: usize>(
&mut self
) -> Result<[Self::Item; N], IntoIter<Self::Item, N>>where
Self: Sized,
fn next_chunk<const N: usize>(
&mut self
) -> Result<[Self::Item; N], IntoIter<Self::Item, N>>where
Self: Sized,
iter_next_chunk)N values. Read more1.0.0 · source§fn size_hint(&self) -> (usize, Option<usize>)
fn size_hint(&self) -> (usize, Option<usize>)
1.0.0 · source§fn count(self) -> usizewhere
Self: Sized,
fn count(self) -> usizewhere
Self: Sized,
1.0.0 · source§fn last(self) -> Option<Self::Item>where
Self: Sized,
fn last(self) -> Option<Self::Item>where
Self: Sized,
source§fn advance_by(&mut self, n: usize) -> Result<(), NonZero<usize>>
fn advance_by(&mut self, n: usize) -> Result<(), NonZero<usize>>
iter_advance_by)n elements. Read more1.0.0 · source§fn nth(&mut self, n: usize) -> Option<Self::Item>
fn nth(&mut self, n: usize) -> Option<Self::Item>
nth element of the iterator. Read more1.28.0 · source§fn step_by(self, step: usize) -> StepBy<Self>where
Self: Sized,
fn step_by(self, step: usize) -> StepBy<Self>where
Self: Sized,
1.0.0 · source§fn chain<U>(self, other: U) -> Chain<Self, <U as IntoIterator>::IntoIter>
fn chain<U>(self, other: U) -> Chain<Self, <U as IntoIterator>::IntoIter>
1.0.0 · source§fn zip<U>(self, other: U) -> Zip<Self, <U as IntoIterator>::IntoIter>where
Self: Sized,
U: IntoIterator,
fn zip<U>(self, other: U) -> Zip<Self, <U as IntoIterator>::IntoIter>where
Self: Sized,
U: IntoIterator,
source§fn intersperse(self, separator: Self::Item) -> Intersperse<Self>
fn intersperse(self, separator: Self::Item) -> Intersperse<Self>
iter_intersperse)separator between adjacent
items of the original iterator. Read moresource§fn intersperse_with<G>(self, separator: G) -> IntersperseWith<Self, G>
fn intersperse_with<G>(self, separator: G) -> IntersperseWith<Self, G>
iter_intersperse)separator
between adjacent items of the original iterator. Read more1.0.0 · source§fn map<B, F>(self, f: F) -> Map<Self, F>
fn map<B, F>(self, f: F) -> Map<Self, F>
1.0.0 · source§fn filter<P>(self, predicate: P) -> Filter<Self, P>
fn filter<P>(self, predicate: P) -> Filter<Self, P>
1.0.0 · source§fn filter_map<B, F>(self, f: F) -> FilterMap<Self, F>
fn filter_map<B, F>(self, f: F) -> FilterMap<Self, F>
1.0.0 · source§fn enumerate(self) -> Enumerate<Self>where
Self: Sized,
fn enumerate(self) -> Enumerate<Self>where
Self: Sized,
1.0.0 · source§fn skip_while<P>(self, predicate: P) -> SkipWhile<Self, P>
fn skip_while<P>(self, predicate: P) -> SkipWhile<Self, P>
1.0.0 · source§fn take_while<P>(self, predicate: P) -> TakeWhile<Self, P>
fn take_while<P>(self, predicate: P) -> TakeWhile<Self, P>
1.57.0 · source§fn map_while<B, P>(self, predicate: P) -> MapWhile<Self, P>
fn map_while<B, P>(self, predicate: P) -> MapWhile<Self, P>
1.0.0 · source§fn skip(self, n: usize) -> Skip<Self>where
Self: Sized,
fn skip(self, n: usize) -> Skip<Self>where
Self: Sized,
n elements. Read more1.0.0 · source§fn take(self, n: usize) -> Take<Self>where
Self: Sized,
fn take(self, n: usize) -> Take<Self>where
Self: Sized,
n elements, or fewer
if the underlying iterator ends sooner. Read more1.0.0 · source§fn flat_map<U, F>(self, f: F) -> FlatMap<Self, U, F>
fn flat_map<U, F>(self, f: F) -> FlatMap<Self, U, F>
source§fn map_windows<F, R, const N: usize>(self, f: F) -> MapWindows<Self, F, N>
fn map_windows<F, R, const N: usize>(self, f: F) -> MapWindows<Self, F, N>
iter_map_windows)f for each contiguous window of size N over
self and returns an iterator over the outputs of f. Like slice::windows(),
the windows during mapping overlap as well. Read more1.0.0 · source§fn inspect<F>(self, f: F) -> Inspect<Self, F>
fn inspect<F>(self, f: F) -> Inspect<Self, F>
1.0.0 · source§fn by_ref(&mut self) -> &mut Selfwhere
Self: Sized,
fn by_ref(&mut self) -> &mut Selfwhere
Self: Sized,
source§fn collect_into<E>(self, collection: &mut E) -> &mut E
fn collect_into<E>(self, collection: &mut E) -> &mut E
iter_collect_into)1.0.0 · source§fn partition<B, F>(self, f: F) -> (B, B)
fn partition<B, F>(self, f: F) -> (B, B)
source§fn is_partitioned<P>(self, predicate: P) -> bool
fn is_partitioned<P>(self, predicate: P) -> bool
iter_is_partitioned)true precede all those that return false. Read more1.27.0 · source§fn try_fold<B, F, R>(&mut self, init: B, f: F) -> R
fn try_fold<B, F, R>(&mut self, init: B, f: F) -> R
1.27.0 · source§fn try_for_each<F, R>(&mut self, f: F) -> R
fn try_for_each<F, R>(&mut self, f: F) -> R
1.0.0 · source§fn fold<B, F>(self, init: B, f: F) -> B
fn fold<B, F>(self, init: B, f: F) -> B
1.51.0 · source§fn reduce<F>(self, f: F) -> Option<Self::Item>
fn reduce<F>(self, f: F) -> Option<Self::Item>
source§fn try_reduce<F, R>(
&mut self,
f: F
) -> <<R as Try>::Residual as Residual<Option<<R as Try>::Output>>>::TryType
fn try_reduce<F, R>( &mut self, f: F ) -> <<R as Try>::Residual as Residual<Option<<R as Try>::Output>>>::TryType
iterator_try_reduce)1.0.0 · source§fn all<F>(&mut self, f: F) -> bool
fn all<F>(&mut self, f: F) -> bool
1.0.0 · source§fn any<F>(&mut self, f: F) -> bool
fn any<F>(&mut self, f: F) -> bool
1.0.0 · source§fn find<P>(&mut self, predicate: P) -> Option<Self::Item>
fn find<P>(&mut self, predicate: P) -> Option<Self::Item>
1.30.0 · source§fn find_map<B, F>(&mut self, f: F) -> Option<B>
fn find_map<B, F>(&mut self, f: F) -> Option<B>
source§fn try_find<F, R>(
&mut self,
f: F
) -> <<R as Try>::Residual as Residual<Option<Self::Item>>>::TryType
fn try_find<F, R>( &mut self, f: F ) -> <<R as Try>::Residual as Residual<Option<Self::Item>>>::TryType
try_find)1.0.0 · source§fn position<P>(&mut self, predicate: P) -> Option<usize>
fn position<P>(&mut self, predicate: P) -> Option<usize>
1.0.0 · source§fn max(self) -> Option<Self::Item>
fn max(self) -> Option<Self::Item>
1.0.0 · source§fn min(self) -> Option<Self::Item>
fn min(self) -> Option<Self::Item>
1.6.0 · source§fn max_by_key<B, F>(self, f: F) -> Option<Self::Item>
fn max_by_key<B, F>(self, f: F) -> Option<Self::Item>
1.15.0 · source§fn max_by<F>(self, compare: F) -> Option<Self::Item>
fn max_by<F>(self, compare: F) -> Option<Self::Item>
1.6.0 · source§fn min_by_key<B, F>(self, f: F) -> Option<Self::Item>
fn min_by_key<B, F>(self, f: F) -> Option<Self::Item>
1.15.0 · source§fn min_by<F>(self, compare: F) -> Option<Self::Item>
fn min_by<F>(self, compare: F) -> Option<Self::Item>
1.0.0 · source§fn unzip<A, B, FromA, FromB>(self) -> (FromA, FromB)
fn unzip<A, B, FromA, FromB>(self) -> (FromA, FromB)
1.36.0 · source§fn copied<'a, T>(self) -> Copied<Self>
fn copied<'a, T>(self) -> Copied<Self>
source§fn array_chunks<const N: usize>(self) -> ArrayChunks<Self, N>where
Self: Sized,
fn array_chunks<const N: usize>(self) -> ArrayChunks<Self, N>where
Self: Sized,
iter_array_chunks)N elements of the iterator at a time. Read more1.11.0 · source§fn product<P>(self) -> P
fn product<P>(self) -> P
source§fn cmp_by<I, F>(self, other: I, cmp: F) -> Ordering
fn cmp_by<I, F>(self, other: I, cmp: F) -> Ordering
iter_order_by)Iterator with those
of another with respect to the specified comparison function. Read more1.5.0 · source§fn partial_cmp<I>(self, other: I) -> Option<Ordering>
fn partial_cmp<I>(self, other: I) -> Option<Ordering>
PartialOrd elements of
this Iterator with those of another. The comparison works like short-circuit
evaluation, returning a result without comparing the remaining elements.
As soon as an order can be determined, the evaluation stops and a result is returned. Read moresource§fn partial_cmp_by<I, F>(self, other: I, partial_cmp: F) -> Option<Ordering>where
Self: Sized,
I: IntoIterator,
F: FnMut(Self::Item, <I as IntoIterator>::Item) -> Option<Ordering>,
fn partial_cmp_by<I, F>(self, other: I, partial_cmp: F) -> Option<Ordering>where
Self: Sized,
I: IntoIterator,
F: FnMut(Self::Item, <I as IntoIterator>::Item) -> Option<Ordering>,
iter_order_by)Iterator with those
of another with respect to the specified comparison function. Read moresource§fn eq_by<I, F>(self, other: I, eq: F) -> bool
fn eq_by<I, F>(self, other: I, eq: F) -> bool
iter_order_by)1.5.0 · source§fn lt<I>(self, other: I) -> bool
fn lt<I>(self, other: I) -> bool
Iterator are lexicographically
less than those of another. Read more1.5.0 · source§fn le<I>(self, other: I) -> bool
fn le<I>(self, other: I) -> bool
Iterator are lexicographically
less or equal to those of another. Read more1.5.0 · source§fn gt<I>(self, other: I) -> bool
fn gt<I>(self, other: I) -> bool
Iterator are lexicographically
greater than those of another. Read more1.5.0 · source§fn ge<I>(self, other: I) -> bool
fn ge<I>(self, other: I) -> bool
Iterator are lexicographically
greater than or equal to those of another. Read moresource§fn is_sorted(self) -> bool
fn is_sorted(self) -> bool
is_sorted)source§fn is_sorted_by<F>(self, compare: F) -> bool
fn is_sorted_by<F>(self, compare: F) -> bool
is_sorted)source§fn is_sorted_by_key<F, K>(self, f: F) -> bool
fn is_sorted_by_key<F, K>(self, f: F) -> bool
is_sorted)