展开然后折叠融合
将程序构建为构建数据结构然后将其折叠为单个值是很常见的。这就是所谓的 hylomorphism 或复性。为了提高效率,可以完全忽略中间结构。
hylo::Functor f => (a -> f a) -> (f b -> b) -> a -> b
hylo f g = g . fmap (hylo f g) . f -- no mention of Fix!
推导:
hylo f g = cata g . ana f
= g . fmap (cata g) . unFix . Fix . fmap (ana f) . f -- definition of cata and ana
= g . fmap (cata g) . fmap (ana f) . f -- unfix . Fix = id
= g . fmap (cata g . ana f) . f -- Functor law
= g . fmap (hylo f g) . f -- definition of hylo