|
|
@ -1,6 +1,7 @@ |
|
|
|
module Functions where |
|
|
|
module Functions where |
|
|
|
|
|
|
|
|
|
|
|
import Data.Monoid |
|
|
|
import Data.Monoid |
|
|
|
|
|
|
|
import Data.Maybe |
|
|
|
|
|
|
|
|
|
|
|
-- foldMap :: (Monoid m, Foldable t) => (a -> m) -> t a -> m |
|
|
|
-- foldMap :: (Monoid m, Foldable t) => (a -> m) -> t a -> m |
|
|
|
-- foldr :: Foldable t => (a -> b -> b) -> b -> t a -> b |
|
|
|
-- foldr :: Foldable t => (a -> b -> b) -> b -> t a -> b |
|
|
@ -18,11 +19,21 @@ elem' :: (Foldable t, Eq a) => a -> t a -> Bool |
|
|
|
elem' e = getAny . (foldMap (Any . (==e))) |
|
|
|
elem' e = getAny . (foldMap (Any . (==e))) |
|
|
|
|
|
|
|
|
|
|
|
minimum' :: (Foldable t, Ord a) => t a -> Maybe a |
|
|
|
minimum' :: (Foldable t, Ord a) => t a -> Maybe a |
|
|
|
minimum' = foldr (\a b -> |
|
|
|
minimum' = foldr (\a b -> |
|
|
|
case b of |
|
|
|
case b of |
|
|
|
Nothing -> Just a |
|
|
|
Nothing -> Just a |
|
|
|
Just a' -> Just $ min a a') |
|
|
|
Just a' -> Just $ min a a') |
|
|
|
Nothing |
|
|
|
Nothing |
|
|
|
|
|
|
|
-- -- In order to use foldMap we need a monoid instance for smallest value |
|
|
|
|
|
|
|
-- data Smallest a = Smallest { getSmallest :: Maybe a } |
|
|
|
|
|
|
|
-- instance Ord a => Monoid (Smallest a) where |
|
|
|
|
|
|
|
-- mempty = Smallest Nothing |
|
|
|
|
|
|
|
-- mappend (Smallest Nothing) m = m |
|
|
|
|
|
|
|
-- mappend m (Smallest Nothing) = m |
|
|
|
|
|
|
|
-- mappend (Smallest (Just a1)) (Smallest (Just a2)) = |
|
|
|
|
|
|
|
-- Smallest $ Just (min a1 a2) |
|
|
|
|
|
|
|
-- minimum' = getSmallest . foldMap (Smallest . Just) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
maximum' :: (Foldable t, Ord a) => t a -> Maybe a |
|
|
|
maximum' :: (Foldable t, Ord a) => t a -> Maybe a |
|
|
|
maximum' = foldr (\a b -> |
|
|
|
maximum' = foldr (\a b -> |
|
|
@ -30,20 +41,35 @@ maximum' = foldr (\a b -> |
|
|
|
Nothing -> Just a |
|
|
|
Nothing -> Just a |
|
|
|
Just a' -> Just $ max a a') |
|
|
|
Just a' -> Just $ max a a') |
|
|
|
Nothing |
|
|
|
Nothing |
|
|
|
|
|
|
|
-- In order to use foldMap we need a monoid instance for largest value |
|
|
|
|
|
|
|
-- data Largest a = Largest { getLargest :: Maybe a } |
|
|
|
|
|
|
|
-- instance Ord a => Monoid (Largest a) where |
|
|
|
|
|
|
|
-- mempty = Largest Nothing |
|
|
|
|
|
|
|
-- mappend (Largest Nothing) m = m |
|
|
|
|
|
|
|
-- mappend m (Largest Nothing) = m |
|
|
|
|
|
|
|
-- mappend (Largest (Just a1)) (Largest (Just a2)) = |
|
|
|
|
|
|
|
-- Largest $ Just (max a1 a2) |
|
|
|
|
|
|
|
-- maximum' = getLargest . foldMap (Largest . Just) |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
null' :: Foldable t => t a -> Bool |
|
|
|
null' :: Foldable t => t a -> Bool |
|
|
|
null' = foldr (\_ _ -> False) True |
|
|
|
null' = foldr (\_ _ -> False) True |
|
|
|
|
|
|
|
-- Not very pretty, but it works: |
|
|
|
|
|
|
|
-- null' = isNothing . getFirst . foldMap (First . Just) |
|
|
|
|
|
|
|
|
|
|
|
length' :: Foldable t => t a -> Int |
|
|
|
length' :: Foldable t => t a -> Int |
|
|
|
length' = foldr (\_ b -> b + 1) 0 |
|
|
|
length' = foldr (\_ b -> b + 1) 0 |
|
|
|
|
|
|
|
-- length' = getSum . foldMap (Sum . const 1) |
|
|
|
|
|
|
|
|
|
|
|
toList' :: Foldable t => t a -> [a] |
|
|
|
toList' :: Foldable t => t a -> [a] |
|
|
|
toList' = foldr (:) [] |
|
|
|
toList' = foldr (:) [] |
|
|
|
|
|
|
|
-- toList' = foldMap (:[]) |
|
|
|
|
|
|
|
|
|
|
|
fold' :: (Foldable t, Monoid m) => t m -> m |
|
|
|
fold' :: (Foldable t, Monoid m) => t m -> m |
|
|
|
-- fold' = foldMap (mappend mempty) -- mappend mempty = id |
|
|
|
-- fold' = foldMap (mappend mempty) -- mappend mempty = id |
|
|
|
fold' = foldMap id |
|
|
|
fold' = foldMap id |
|
|
|
|
|
|
|
-- fold' = foldr mappend mempty |
|
|
|
|
|
|
|
|
|
|
|
foldMap' :: (Foldable t, Monoid m) => (a -> m) -> t a -> m |
|
|
|
foldMap' :: (Foldable t, Monoid m) => (a -> m) -> t a -> m |
|
|
|
-- foldMap' f = foldr (\a b -> mappend (f a) b) mempty |
|
|
|
-- foldMap' f = foldr (\a b -> mappend (f a) b) mempty |
|
|
|
foldMap' f = foldr (mappend . f) mempty |
|
|
|
foldMap' f = foldr (mappend . f) mempty |
|
|
|