optimization of list comprehensions

Robert Virding robert.virding@REDACTED
Thu Mar 9 22:39:32 CET 2006


You will probably find an even grater usage if you start searching more 
seriously. I, for one, usually do an import on 'lists' so I don't have 
to write the lists: prefix all the time.

Robert

Mats Cronqvist skrev:
> Richard A. O'Keefe wrote:
> 
>  > If you have evidence to back this up, it's publishable.
>  > Please publish it.  Some sort of survey analysing what kind of
>  > programmers use what kind of language features would be most 
> illuminating.
> 
> Ulf Wiger (AL/EAB) wrote:
> 
>> I think it's safe to say that even "average" industrial programmers 
>> rather quickly learn to exploit the virtues
>> of higher-order functions and iterators.
> 
>   not to be outdone by wiger (and since o'keefe said please), i ran a 
> few greps on 1,748,162 lines of erlang sources (comments included). i 
> estimate that some 3-400 people have contributed to the code sample.
>   i counted how many times each of the patterns below appeared per module.
> 
>         "[ (]fun[ (]"  "lists:fold" "lists:map" "lists:foreach"
> never          64%            89%          84%          85%
> <3 times       81%            97%          94%          94%
> 
>   36% of the modules defined at least one fun. however, 15% of all 
> modules had at least one call to mnesia:transaction. so i feel pretty 
> confident stating that  ~80% of all modules have no (non-mnesia related) 
> funs.
>   another observation is that although there were ~2 fun definition per 
> module, 4% of the modules accounts for 50% of the fun definitions.
>   one possible interpretation is that most of this code was produced by 
> programmers that rarely use funs if they don't have to. obviously, the 
> methodology is much too weak to *prove* this. i'm not sure it can be 
> proven, since there's no way to establish who wrote what. most modules 
> have been touched by at least a handful of people, and everyone has 
> worked on more than one module.
>   note also that most of this code sample has been used for years in a 
> very challenging environment, and is part of one of the most stable 
> products in its market.
>   i does seem safe to say that one can write well working Erlang code 
> while rarely, if ever, using funs (excluding mnesia use, as always).
> 
>   mats
> 



More information about the erlang-questions mailing list