More Data.Set and Data.Map operations

Ivan Lazar Miljenovic ivan.miljenovic at gmail.com
Sun Aug 7 03:31:14 UTC 2016


On 7 August 2016 at 13:15, David Feuer <david.feuer at gmail.com> wrote:
> Cale Gibbard and Ryan Trinkle are interested in adding some more
> operations they say will be useful in their work. Note that
> unionWithMapping is intended to enable an efficient implementation of
> alignWith in Data.Align in the `these` package.
>
> Set:
>
> filterIncreasing :: Ord a => (a -> Bool) -> Set a -> Set a
> filterDecreasing :: Ord a => (a -> Bool) -> Set a -> Set a
> partitionIncreasing :: Ord a => (a -> Bool) -> Set a -> (Set a, Set a)

I'm not sure what the difference between the first two functions are,
or even how they differ from a generic filter function.

>
> Map:
>
> filterKeysIncreasing :: Ord k => (k -> Bool) -> Map k a -> Map k a
> filterKeysDecreasing :: Ord k => (k -> Bool) -> Map k a -> Map k a
> partitionKeysIncreasing :: Ord k => (k -> Bool) -> Map k a -> (Map k a, Map k a)
>
> traverseMaybe :: Applicative f => (a -> f (Maybe b)) -> Map k a -> f (Map k b)
>
> alterMany :: Ord k => (a -> Maybe b -> Maybe b) -> Map k a -> Map k b -> Map k b
>
> alterManyA :: (Applicative f, Ord k) => (a -> Maybe b -> f (Maybe b))
> -> Map k a -> Map k b -> f (Map k b)
>
> unionWithMapping :: Ord k => (a -> c) -> (b -> c) -> (a -> b -> c) ->
> Map k a -> Map k b -> Map k c
>
> unionWithKeyMapping :: Ord k => (k -> a -> c) -> (k -> b -> c) -> (k
> -> a -> b -> c)
> -> Map k a -> Map k b -> Map k c
> _______________________________________________
> Libraries mailing list
> Libraries at haskell.org
> http://mail.haskell.org/cgi-bin/mailman/listinfo/libraries



-- 
Ivan Lazar Miljenovic
Ivan.Miljenovic at gmail.com
http://IvanMiljenovic.wordpress.com


More information about the Libraries mailing list