[#398788] Constructor or a Method — Rubyist Rohit <lists@...>

Take for instance this code:

13 messages 2012/09/01

[#398896] how to sum element of array — Edward QU <lists@...>

dear all

19 messages 2012/09/04

[#398936] best coding for limiting a value — Regis d'Aubarede <lists@...>

A) result=value<min ? min : (value > max ? max : value)

17 messages 2012/09/04

[#398962] Long calculation & time limit — toto tartemolle <lists@...>

Hello,

17 messages 2012/09/05

[#398964] Compiling ruby from source on windows — GPad <peterpan105105@...>

Hi to all,=0AI'm trying to compile ruby on my windows 7. I have already a r=

10 messages 2012/09/05

[#398997] OpenURI open method problem — "Derek T." <lists@...>

The code I am referring to looks like this:

12 messages 2012/09/05

[#399002] Parsing through downloaded html — Sybren Kooistra <lists@...>

Hi all,

28 messages 2012/09/06

[#399012] "Hiding" pictures(and source code if it's possible) — "Damián M. González" <lists@...>

Ey guys, how are you?

11 messages 2012/09/06

[#399083] regix in grep or something like this — Ferdous ara <lists@...>

Hi

12 messages 2012/09/07

[#399206] please help me with making script — Charmaine Willemsen <lists@...>

In this example i like to parse birthday and sexe

11 messages 2012/09/11

[#399218] Pathname#to_str withdrawn in 1.9? — matt@... (Matt Neuburg)

Just getting started experimenting with Ruby 1.9 (1.9.3) and my scripts

13 messages 2012/09/12

[#399227] Breaking Down the Block — incag neato <lists@...>

Can someone please explain in plain english how this block treats the

20 messages 2012/09/13

[#399244] ruby Range to array that acts like time objects? — "Jermaine O." <lists@...>

Hello everybody,

15 messages 2012/09/13

[#399293] Ruby on Ubuntu 12.04 LST — Bojan Jordanovski <lists@...>

Hello everybody,

13 messages 2012/09/14

[#399298] wow, YAML / Psych in 1.9.3 is *slow*! — matt@... (Matt Neuburg)

I just started trying Ruby 1.9.3, coming from Ruby 1.8.7, and was

12 messages 2012/09/14

[#399304] Ruby 1.9.3 and OS X Mountain Lion — sto.mar@...

Hi all,

16 messages 2012/09/14

[#399343] Class variables or Class singleton variables? — "Damián M. González" <lists@...>

Guys, how are you?

18 messages 2012/09/15

[#399386] Ruby - is it worth the effort? — neomex <neomex@...>

Hello,

19 messages 2012/09/17
[#399406] Re: Ruby - is it worth the effort? — Roger Pack <lists@...> 2012/09/17

Unfortunately with Ruby for me it's typically "fun and fast development"

[#399409] Re: Ruby - is it worth the effort? — Peter Zotov <whitequark@...> 2012/09/17

Roger Pack писал 17.09.2012 22:06:

[#399491] Re: Ruby - is it worth the effort? — Robert Klemme <shortcutter@...> 2012/09/19

On Mon, Sep 17, 2012 at 8:20 PM, Peter Zotov <whitequark@whitequark.org> wr=

[#399421] Encoding question — Thomas Bednarz <lists@...>

I am new to ruby and play around with it a little bit at the moment. I

17 messages 2012/09/17

[#399441] Bug or feature — Damjan Rems <lists@...>

There has probably been some discussion about this problem so sorry if I

13 messages 2012/09/18

[#399451] Class variables — Aleksander Ciesielski <neomex@...>

Is it obligatory to use instance variables in classes? Can't we just

17 messages 2012/09/18

[#399479] Ruby SQL Select Sum 2 Columns? — Courtney Fay <lists@...>

I have the following definition which is looking at an apache database,

12 messages 2012/09/18

[#399556] still learning by doing - connecting rooms in a game — "Sebastjan H." <lists@...>

Hi,

28 messages 2012/09/20
[#399570] Re: still learning by doing - connecting rooms in a game — Henry Maddocks <hmaddocks@...> 2012/09/20

[#399574] Re: still learning by doing - connecting rooms in a game — "Sebastjan H." <lists@...> 2012/09/21

Henry Maddocks wrote in post #1076876:

[#399575] Re: still learning by doing - connecting rooms in a game — Henry Maddocks <hmaddocks@...> 2012/09/21

[#399576] Re: still learning by doing - connecting rooms in a game — "Sebastjan H." <lists@...> 2012/09/21

Could you be so kind as to suggest another book? I mean there are many

[#399585] Re: still learning by doing - connecting rooms in a game — "Sebastjan H." <lists@...> 2012/09/21

Sebastjan H. wrote in post #1076909:

[#399572] How would you allow variable from specific list of Fixnum? — Eliezer Croitoru <eliezer@...>

I have:

11 messages 2012/09/21

[#399623] Very important question - survey — Marc Heiler <lists@...>

Is matz more like a ninja or more like a samurai?

11 messages 2012/09/22

[#399695] inject problem — Roelof Wobben <rwobben@...>

26 messages 2012/09/25

[#399714] could initialize return an existing object instead of a new instance? — Gary Weaver <lists@...>

Is it possible for initialize to return an existing object instead of a

9 messages 2012/09/25

[#399811] Good book for getting started with Ruby? [I code Python!] — Alec Taylor <alec.taylor6@...>

I've learned programming in C++, Python and PHP at University. (also

12 messages 2012/09/28

[#399815] calcaulation with unknown numbers of numbers and options fail — Roelof Wobben <rwobben@...>

11 messages 2012/09/28

Re: Ruby - is it worth the effort?

From: Robert Klemme <shortcutter@...>
Date: 2012-09-19 11:29:37 UTC
List: ruby-talk #399498
On Wed, Sep 19, 2012 at 11:41 AM, Peter Hickman
<peterhickman386@googlemail.com> wrote:
> On 19 September 2012 10:09, Carlos Agarie <carlos.agarie@gmail.com> wrote:
>> I'd like to know, too. I stumbled upon a similar problem, but it was long
>> ago.
>
> Ok here is a quick test that I hacked up. The data is a 2,659,800 line
> 639Mb text file. Some lines contain the string "FRED", count them

Let's see: that are 252 chars per line on average.

Here's how I generated the file:

$ ruby -e 'x="X"*243; 2_600_000.times {|i| printf
"%7d%s%s\n",i,x,rand(1000)==0 ? "FRED" : "OOOO" }' >results201101.dat

> To be honest I suspect that it is more an issue with the regexes than
> file io and the real regexes are much more complicated than just match
> a string. I was a bit surprised that the index() wasn't faster.

Darn!  Maybe encoding plays a role here.  The pure IO is pretty fast
(see last test):

RUN 2
2659

real    0m3.520s
user    0m3.213s
sys     0m0.249s
./perl.pl
2659

real    0m2.220s
user    0m1.950s
sys     0m0.249s
./ruby-1.rb
2659

real    0m4.912s
user    0m4.383s
sys     0m0.498s
./ruby-2.rb

real    0m5.032s
user    0m4.336s
sys     0m0.639s
./ruby-3.rb

real    0m3.610s
user    0m3.276s
sys     0m0.312s
./ruby-4.rb
2659

real    0m5.004s
user    0m4.399s
sys     0m0.467s
./ruby-5.rb
2659

real    0m4.980s
user    0m4.430s
sys     0m0.451s
./ruby-6.rb
0

real    0m2.495s
user    0m2.012s
sys     0m0.420s

$ head -200 *.pl *.rb
==> perl.pl <==
#!/usr/bin/env perl

use strict;
use warnings;

my $logfile = 'results201101.dat';
my $counter = 0;
open FILE, "<$logfile" or die $!;
while(my $line = <FILE>) {
  if($line =~ /FRED/) {
    $counter++;
  }
}
close(FILE);
print "$counter\n";

==> ruby-1.rb <==
#!/usr/bin/env ruby

counter = 0
File.open("results201101.dat").each do |line|
  if line =~ /FRED/
    counter += 1
  end
end

puts counter


==> ruby-2.rb <==
#!/usr/bin/env ruby

r = Regexp.new('FRED')

counter = 0
File.open("results201101.dat").each do |line|
  if r.match(line)
    counter += 1
  end
end


==> ruby-3.rb <==
#!/usr/bin/env ruby

counter = 0
File.open("results201101.dat").each do |line|
  if line.index("FRED")
    counter += 1
  end
end


==> ruby-4.rb <==
#!/usr/bin/env ruby

count = 0

File.foreach "results201101.dat" do |line|
  count += 1 if /FRED/ =~ line
end

puts count


==> ruby-5.rb <==
#!/usr/bin/env ruby

count = 0

File.foreach "results201101.dat", encoding: "ASCII" do |line|
  count += 1 if /FRED/ =~ line
end

puts count


==> ruby-6.rb <==
#!/usr/bin/env ruby

count = 0

File.foreach "results201101.dat", encoding: "ASCII" do |line|
  # count += 1 if /FRED/ =~ line
end

puts count


And here's the test run

$ for i in {1..2}; do echo "RUN $i"; time fgrep -c FRED
results201101.dat; for f in ./*.pl ./*.rb; do echo "$f"; time "$f";
done; done

This was all on cygwin on a machine with plenty memory => likely no real IO.

Ah, it get's a tad better without regexp:

$ time ./ruby-7.rb
2659

real    0m3.432s
user    0m2.869s
sys     0m0.529s
$ cat ruby-7.rb
#!/usr/bin/env ruby

count = 0
f = 'FRED'

File.foreach "results201101.dat", encoding: "BINARY" do |line|
  count += 1 if line.include? f
end

puts count


Kind regards

robert

-- 
remember.guy do |as, often| as.you_can - without end
http://blog.rubybestpractices.com/

In This Thread