[#389739] Ruby Challenge — teresa nuagen <unguyen90@...>

Here is a ruby challenge for all you computer science lovers out there,

22 messages 2011/11/05
[#389769] Re: Ruby Challenge — "Jonan S." <jonanscheffler@...> 2011/11/05

Totally unrelated to any husker computer science programs right? Like

[#389905] Re: Ruby Challenge — Stephen Ramsay <sramsay.unl@...> 2011/11/09

Jonan S. wrote in post #1030330:

[#389907] Re: Ruby Challenge — aseret nuagen <unguyen90@...> 2011/11/09

> You mean like the professor for the course? Because that would be me .

[#389915] Re: Ruby Challenge — Robert Klemme <shortcutter@...> 2011/11/09

On Wed, Nov 9, 2011 at 4:52 AM, aseret nuagen <unguyen90@aim.com> wrote:

[#389792] Tricky DSL, how to do it? — Intransition <transfire@...>

I'd want to write a DSL such that a surface method_missing catches

18 messages 2011/11/06

[#389858] Compiling Ruby Inline C code - resolving errors — Martin Hansen <mail@...>

I am trying to get this Ruby inline C code http://pastie.org/2825882 to

12 messages 2011/11/08

[#389928] Forming a Ruby meetup group... — "Darryl L. Pierce" <mcpierce@...>

Where I work we have a local Ruby group that used to meet up, until the

12 messages 2011/11/09

[#389950] The faster way to read files — "Noé Alejandro" <casanejo@...>

Does anybody know which is the fastest way to read a file? Lets say

18 messages 2011/11/09

[#390064] referring to version numbers in a gem — Chad Perrin <code@...>

How do I specify and access a gem's version number within the code of the

28 messages 2011/11/11

[#390238] RVM problem, plz help — Misha Ognev <b1368810@...>

Hi, I have this problem:

15 messages 2011/11/16

[#390308] any command line tools for querying yaml files — Rahul Kumar <sentinel1879@...>

(Sorry, this is not exactly a ruby question).

11 messages 2011/11/18

[#390338] Newbie - cmd question — Otto Dydakt <ottodydakt@...>

I've literally JUST downloaded ruby from rubyinstaller.org.

21 messages 2011/11/19
[#390342] Re: Newbie - cmd question — Otto Dydakt <ottodydakt@...> 2011/11/19

OK thank you, I uninstalled & reinstalled, checking the three boxes at

[#390343] Re: Newbie - cmd question — "Ian M. Asaff" <ian.asaff@...> 2011/11/19

did you type "irb" first to bring up the ruby command prompt?

[#391154] Re: Newbie - cmd question — "Hussain A." <hahmad@...> 2011/12/12

Hi all,

[#391165] Re: Newbie - cmd question — Luis Lavena <luislavena@...> 2011/12/12

Hussain A. wrote in post #1036281:

[#390374] Principle of Best Principles — Intransition <transfire@...>

I seem to run into a couple of design issue a lot and I never know what is

16 messages 2011/11/20

[#390396] how to call Function argument into another ruby script. — hari mahesh <harismahesh@...>

Consider I have a ruby file called library.rb.

10 messages 2011/11/21

[#390496] How to make 1.9.2 my default version using RVM — Fily Salas <fs_tigre@...>

Hi,

25 messages 2011/11/24

[#390535] Is high-speed sorting impossible with Ruby? — "Gaurav C." <chande.gaurav@...>

Well, first of all, I'm new to Ruby, and to this forum. So, hello. :)

39 messages 2011/11/25
[#390580] Re: Is high-speed sorting impossible with Ruby? — Joao Pedrosa <joaopedrosa@...> 2011/11/27

Hi,

[#390593] Re: Is high-speed sorting impossible with Ruby? — "Gaurav C." <chande.gaurav@...> 2011/11/27

Joao Pedrosa wrote in post #1033884:

[#390600] Re: Is high-speed sorting impossible with Ruby? — Douglas Seifert <doug@...> 2011/11/27

A big gain can be had by disabling the garbage collector. Here is my best

[#390601] Re: Is high-speed sorting impossible with Ruby? — Douglas Seifert <doug@...> 2011/11/27

I've thrown various solutions up on github here:

[#390650] Loading a faulty ruby file - forcing this — Marc Heiler <shevegen@...>

Hi.

10 messages 2011/11/29

[#390689] Stupid question — James Gallagher <lollyproductions@...>

Hi everyone.

22 messages 2011/11/30

Re: Is high-speed sorting impossible with Ruby?

From: Matthias Wächter <matthias@...>
Date: 2011-11-28 23:21:33 UTC
List: ruby-talk #390633
Just playing with the code a little, more education than speed.

On 28.11.2011 09:05, Ryan Davis wrote:
>    $stdin.gets
>    puts $stdin.readlines.map(&:to_i).sort

Your solution could be written like

> $stdin.gets
>
> a = $stdin.readlines
> b = a.map(&:to_i)
> c = b.sort
>
> puts c

while processing of a, b, and c is completely sequential. All three 
objects created are arrays full of data: a contains all string lines 
read in, b makes all these entries into integers, c is the same sorted. 
Three large arrays. All sequentially processed.

A similar solution, at first glance only marginally different, is the 
following:

> $stdin.gets
> puts $stdin.each_line.sort_by(&:to_i)

Besides the fact that this solution is slower than yours, it uses a neat 
little technique of Ruby 1.9, Enumerators. Here, only a single big array 
is created, which is the result array. IO#each_line() does not read in 
the whole file at once but provides an Enumerator – iteration fiber – 
that passes each read line to the .sort_by() call _while they are read_. 
Only sort_by will exhaustively fetch the items and eventually sort them 
based on the sorting criteria.

Driving pipelining with the Enumerators to the max, we need a filter 
chain. Let’s set up a generic filter (which is still not there in 
Enumerator?) similar to the one described ages ago in issue #707 
[http://redmine.ruby-lang.org/issues/707]

> class Enumerator
>   def filter1(&blk)
>     self.class.new do |y|
>       each do |*input|
>         y << blk.call(*input)
>       end
>     end
>   end
> end
>
> $stdin.gets
> puts $stdin.each_line.filter1(&:to_i).sort

Let’s expand the last line into smaller chunks, similar to the 
explanation of your code:

> a = $stdin.each_line
> b = a.filter1(&:to_i)
> c = b.sort
>
> puts c

Now, walking the code, nothing really happens until we hit b.sort – the 
creation of the objects a and b will just setup the filter chain and not 
yet pull any data from $stdin. Once called on an Enumerator, #sort 
cannot perform its action and return even a single entry before knowing 
all entries, so it will call up b.next until it receives a 
»StopIteration« exception. But for b to return a new value, it first has 
to apply .to_i to the next value on its input, which is again an 
iterator, a. So next is the call to a.next which will return the first 
line read from $stdin. Finally we can walk our way back to sort: The 
vaue is returned to the filter so it can be converted (to_i) and 
returned from b.next. Finally the number can take part in the sorting 
process.

In theory, if all these operations were considered non-destructive, 
.each_line, .filter1 and .sort could run in three different threads 
asynchronously, with buffers in between, utilizing the whole CPU and 
probably reducing the overall execution time. But this is not the case: 
There must not be any read-ahead by any of these designated threads, 
drastically limiting their achievable concurrency performance from the 
beginning.

End of the Enumerator lesson. :)

– Matthias

In This Thread