Created
June 12, 2019 18:05
-
-
Save stephen-lazaro/2ef3e8efed5b98989f12529859910c9b to your computer and use it in GitHub Desktop.
Naperian Functors
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
trait Naperian[F[_]] { | |
val F: Distributive[F] | |
def hdistribute[W[?[_], _]: HFunctor]: W[F, ?] ~> Nested[F, W[Id, ?], ?] | |
def ncotraverse[W[?[_], _]: HFunctor, A, B](f: W[Id, A] => B)(wf: W[F, A]): F[B] = | |
F.lift(f).apply(hdistribute[W].apply[A](wf).value) | |
def ncollect[W[?[_], _]: HFunctor, G[_]](f: G ~> F): W[G, ?] ~> Nested[F, W[Id, ?], ?] = | |
new (W[G, ?] ~> Nested[F, W[Id, ?], ?]) { | |
override def apply[A](fa: W[G, A]): Nested[F, W[Id, ?], A] = | |
hdistribute.apply(HFunctor[W].hmap(f)(fa)) | |
} | |
def ntwiddle[W[?[_], _]: HFunctor, G[_], A, B](f: W[Id, A] => B)(ff: G ~> F)(wg: W[G, A]): F[B] = | |
F.map(hdistribute.apply(HFunctor[W].hmap(ff)(wg)).value)(f) | |
def ntabulate[A](f: (F ~> Id) => A): F[A] = ncotraverse[Tabulation, A, A]( | |
(h: Tabulation[Id, A]) => h(FunctionK.id[Id]) | |
)(f) | |
} |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment