Does Haskell optimizer utilize memoization for repeated function calls in a scope?

后端 未结 3 1835
醉梦人生
醉梦人生 2021-01-17 12:04

Consider this function:

f as = if length as > 100 then length as else 100

Since the function is pure it\'s obvious that the length will

3条回答
  •  臣服心动
    2021-01-17 12:41

    Even in such a local setting, it is still the case that it is not obvious that the introduction of sharing is always an optimization. Consider this example definition

    f = if length [1 .. 1000000] > 0 then head [1 .. 1000000] else 0
    

    vs. this one

    f = let xs = [1 .. 1000000] in if length xs > 0 then head xs else 0
    

    and you'll find that in this case, the first behaves much better, as each of the computations performed on the list is cheap, whereas the second version will cause the list to be unfolded completely in memory by length, and it can only be discarded after head has been reduced.

提交回复
热议问题