Don Stewart schrieb:
> alexey.skladnoy:
>> Hello
>>
>> I found that there is no monadic map for vector. It's possible to define to 
>> define such map using conversion to list, but I suppose it's not efficient. 
>> I 
>> didn't make any measurements.
>>
>>> mapM' :: Monad m => (a -> m b) -> V.Vector a -> m (V.Vector b)
>>> mapM' f = return . V.fromList <=< mapM f . V.toList
>> Any suggestions about implementation of such function? 
>> Specifically I want to use Random monad.
>>
> 
> 
> There's a tutorial here on usving vectors,
> 
>     
> http://haskell.org/haskellwiki/Numeric_Haskell:_A_Vector_Tutorial#Random_numbers
> 
> mapM is available via Fusion.Stream.Monadic.mapM

But can it be efficient? It must handle cases like  m = []  and thus
creation of the (V.Vector b) result means a lot of copying, right?

_______________________________________________
Haskell-Cafe mailing list
Haskell-Cafe@haskell.org
http://www.haskell.org/mailman/listinfo/haskell-cafe

Reply via email to