This module provides the iterator combinator IterM.take.
@[unbox]
The internal state of the IterM.take iterator combinator.
- remaining : NatInternal implementation detail of the iterator library 
- inner : IterM m βInternal implementation detail of the iterator library 
Instances For
@[inline]
def
Std.Iterators.IterM.take
{α : Type w}
{m : Type w → Type w'}
{β : Type w}
(n : Nat)
(it : IterM m β)
 :
IterM m β
Given an iterator it and a natural number n, it.take n is an iterator that outputs
up to the first n of it's values in order and then terminates.
Marble diagram:
it          ---a----b---c--d-e--⊥
it.take 3   ---a----b---c⊥
it          ---a--⊥
it.take 3   ---a--⊥
Termination properties:
- Finiteinstance: only if- itis productive
- Productiveinstance: only if- itis productive
Performance:
This combinator incurs an additional O(1) cost with each output of it.
Equations
- Std.Iterators.IterM.take n it = Std.Iterators.toIterM { remaining := n, inner := it } m β
Instances For
inductive
Std.Iterators.Take.PlausibleStep
{α : Type w}
{m : Type w → Type w'}
{β : Type w}
[Iterator α m β]
(it : IterM m β)
(step : IterStep (IterM m β) β)
 :
- yield {α : Type w} {m : Type w → Type w'} {β : Type w} [Iterator α m β] {it : IterM m β} {it' : IterM m β} {out : β} {k : Nat} : it.internalState.inner.IsPlausibleStep (IterStep.yield it' out) → it.internalState.remaining = k + 1 → PlausibleStep it (IterStep.yield (IterM.take k it') out)
- skip {α : Type w} {m : Type w → Type w'} {β : Type w} [Iterator α m β] {it : IterM m β} {it' : IterM m β} {k : Nat} : it.internalState.inner.IsPlausibleStep (IterStep.skip it') → it.internalState.remaining = k + 1 → PlausibleStep it (IterStep.skip (IterM.take (k + 1) it'))
- done {α : Type w} {m : Type w → Type w'} {β : Type w} [Iterator α m β] {it : IterM m β} : it.internalState.inner.IsPlausibleStep IterStep.done → PlausibleStep it IterStep.done
- depleted {α : Type w} {m : Type w → Type w'} {β : Type w} [Iterator α m β] {it : IterM m β} : it.internalState.remaining = 0 → PlausibleStep it IterStep.done
Instances For
theorem
Std.Iterators.Take.rel_of_remaining
{α : Type w}
{m : Type w → Type w'}
{β : Type w}
[Monad m]
[Iterator α m β]
[Productive α m]
{it it' : IterM m β}
(h : it'.internalState.remaining < it.internalState.remaining)
 :
Rel m it' it
theorem
Std.Iterators.Take.rel_of_inner
{α : Type w}
{m : Type w → Type w'}
{β : Type w}
[Monad m]
[Iterator α m β]
[Productive α m]
{remaining : Nat}
{it it' : IterM m β}
(h : it'.finitelyManySkips.Rel it.finitelyManySkips)
 :
Rel m (IterM.take remaining it') (IterM.take remaining it)
instance
Std.Iterators.Take.instIteratorLoopPartial
{α : Type w}
{m : Type w → Type w'}
{β : Type w}
{n : Type w → Type u_1}
[Monad m]
[Monad n]
[Iterator α m β]
[MonadLiftT m n]
 :
IteratorLoopPartial (Take α m β) m n
instance
Std.Iterators.instIteratorSizeTakeOfFiniteOfIteratorLoop
{m : Type w → Type w'}
{β α : Type w}
[Monad m]
[Iterator α m β]
[Finite α m]
[IteratorLoop α m m]
 :
IteratorSize (Take α m β) m
instance
Std.Iterators.instIteratorSizePartialTakeOfIteratorLoopPartial
{m : Type w → Type w'}
{β α : Type w}
[Monad m]
[Iterator α m β]
[IteratorLoopPartial α m m]
 :
IteratorSizePartial (Take α m β) m