Executes a monadic action on all the numbers less than some bound, in decreasing order.
Example:
#eval Nat.forRevM 5 fun i _ => IO.println i
4
3
2
1
0
Equations
- n.forRevM f = Nat.forRevM.loop n f n ⋯
Iterates the application of a monadic function f
to a starting value init
, n
times. At each
step, f
is applied to the current value and to the next natural number less than n
, in
increasing order.
Equations
- n.foldM f init = Nat.foldM.loop n f n ⋯ init
Iterates the application of a monadic function f
to a starting value init
, n
times. At each
step, f
is applied to the current value and to the next natural number less than n
, in
decreasing order.
Equations
- n.foldRevM f init = Nat.foldRevM.loop n f n ⋯ init
Equations
- Nat.foldRevM.loop n f 0 h x = pure x
- Nat.foldRevM.loop n f i.succ h x = f i ⋯ x >>= Nat.foldRevM.loop n f i ⋯
Checks whether the monadic predicate p
returns true
for all numbers less that the given bound.
Numbers are checked in increasing order until p
returns false, after which no further are checked.
Equations
- n.allM p = Nat.allM.loop n p n ⋯
Equations
- Nat.allM.loop n p 0 x_2 = pure true
- Nat.allM.loop n p i.succ h = do let __do_lift ← p (n - i - 1) ⋯ match __do_lift with | true => Nat.allM.loop n p i ⋯ | false => pure false
Checks whether there is some number less that the given bound for which the monadic predicate p
returns true
. Numbers are checked in increasing order until p
returns true, after which
no further are checked.
Equations
- n.anyM p = Nat.anyM.loop n p n ⋯
Equations
- Nat.anyM.loop n p 0 x_2 = pure false
- Nat.anyM.loop n p i.succ h = do let __do_lift ← p (n - i - 1) ⋯ match __do_lift with | true => pure true | false => Nat.anyM.loop n p i ⋯