开发者

Generating an infinite sequence in Haskell

开发者 https://www.devze.com 2022-12-12 12:52 出处:网络
I know that infinite sequences are possible in Haskell - however, I\'m not entirely sure how to generate one

I know that infinite sequences are possible in Haskell - however, I'm not entirely sure how to generate one

Given a method

generate::Integer->Integer

which take an integer and produces the next integer in the sequence, how would I build an infinite se开发者_如何学JAVAquence out of this?


If you want your sequence to start from 1 then it is -

iterate generate 1

Please notice that first letter of function is lowercase, not uppercase. Otherwise it would be data type, not function.

//edit: I just realized not just data types start with capital, it could be data constructor or type class as well, but that wasn't the point. :)


Adding to Matajon's answer: a way to discover the iterate function other than asking here would be to use Hoogle.

Hoogle's first answer for the query (a -> a) -> [a] is iterate.


There are several ways to do it, but one is:

gen :: (a -> a) -> a -> [a]
gen f s = s : gen f (f s)

This function takes a functon f and some valus s and returns s, after wich it calls itself with that same f, and the result of f s. Demonstration:

Prelude> :t succ
succ :: (Enum a) => a -> a
Prelude> let gen f s = s : gen f (f s)
Prelude> take 10 $ gen succ 3
[3,4,5,6,7,8,9,10,11,12]

In the above example succ acts as the function generate :: Integer -> Integer which you mention. But observe that gen will work with any function of type a -> a.

Edit: and indeed, gen is identical to the function iterate from the Prelude (and Data.List).

0

精彩评论

暂无评论...
验证码 换一张
取 消