Home | History | Annotate | Download | only in comparisons
      1 Subject: Re: What language would you use?
      2 From: Tom Christiansen <tchrist (a] mox.perl.com>
      3 Date: 6 Nov 1994 15:14:51 GMT
      4 Newsgroups: comp.lang.python,comp.lang.tcl,comp.lang.scheme,comp.lang.misc,comp.lang.perl
      5 Message-Id: <39irtb$3t4 (a] csnews.cs.Colorado.EDU>
      6 References: <39b7ha$j9v (a] zeno.nscf.org> <39hhjp$lgn (a] csnews.cs.Colorado.EDU> <39hvsu$dus (a] mathserv.mps.ohio-state.edu>
      7 
      8 [...]
      9 If you're really into benchmarks, I'd love it if someone were to code up
     10 the following problems in tcl, python, and scheme (and whatever else you'd
     11 like).  Separate versions (one optimized for speed, one for beauty :-) are
     12 ok.  Post your code so we can time it on our own systems.
     13 
     14 0)  Factorial Test  (numerics and function calls)
     15 
     16         (we did this already)
     17 
     18 1)  Regular Expressions Test
     19 
     20     Read a file of (extended per egrep) regular expressions (one per line), 
     21     and apply those to all files whose names are listed on the command line.
     22     Basically, an 'egrep -f' simulator.  Test it with 20 "vt100" patterns
     23     against a five /etc/termcap files.  Tests using more elaborate patters
     24     would also be interesting.  Your code should not break if given hundreds
     25     of regular expressions or binary files to scan.  
     26 
     27 2)  Sorting Test
     28 
     29     Sort an input file that consists of lines like this
     30 
     31         var1=23 other=14 ditto=23 fred=2
     32 
     33     such that each output line is sorted WRT to the number.  Order
     34     of output lines does not change.  Resolve collisions using the
     35     variable name.   e.g.
     36 
     37         fred=2 other=14 ditto=23 var1=23 
     38 
     39     Lines may be up to several kilobytes in length and contain
     40     zillions of variables.
     41 
     42 3)  System Test
     43 
     44     Given a list of directories, report any bogus symbolic links contained
     45     anywhere in those subtrees.  A bogus symbolic link is one that cannot
     46     be resolved because it points to a nonexistent or otherwise
     47     unresolvable file.  Do *not* use an external find executable.
     48     Directories may be very very deep.  Print a warning immediately if the
     49     system you're running on doesn't support symbolic links.
     50 
     51 
     52 I'll post perl solutions if people post the others.
     53 
     54 
     55 --tom
     56 -- 
     57 Tom Christiansen      Perl Consultant, Gamer, Hiker      tchrist (a] mox.perl.com
     58 
     59  "But Billy! A *small* allowance prepares you for a lifetime of small
     60  salaries and for your Social Security payments."    --Family Circus
     61