[#30995] [Bug #3523] win32 exception c0000029 on exit using fibers — B Kelly <redmine@...>

Bug #3523: win32 exception c0000029 on exit using fibers

19 messages 2010/07/02

[#31100] [rubysoc] Queue C-extension patch to come — Ricardo Panaggio <panaggio.ricardo@...>

Hello,

26 messages 2010/07/07
[#31148] Re: [rubysoc] Queue C-extension patch to come — Roger Pack <rogerdpack2@...> 2010/07/09

> As this it my first patch to Ruby, I don't know where to begin with.

[#31320] Re: [rubysoc] Queue C-extension patch to come — Ricardo Panaggio <panaggio.ricardo@...> 2010/07/16

Sorry for leaving this thread for so long. I've tried to finish the

[#31322] Re: [rubysoc] Queue C-extension patch to come — Aaron Patterson <aaron@...> 2010/07/16

On Sat, Jul 17, 2010 at 06:55:35AM +0900, Ricardo Panaggio wrote:

[#31324] Re: [rubysoc] Queue C-extension patch to come — Caleb Clausen <vikkous@...> 2010/07/17

NB: I am Ricardo's mentor for this project.

[#31331] Re: [rubysoc] Queue C-extension patch to come — Benoit Daloze <eregontp@...> 2010/07/17

On 17 July 2010 06:00, Caleb Clausen <vikkous@gmail.com> wrote:

[#31332] Re: [rubysoc] Queue C-extension patch to come — Caleb Clausen <vikkous@...> 2010/07/17

On 7/17/10, Benoit Daloze <eregontp@gmail.com> wrote:

[#31138] Why is there no standard way of creating a String from a char *? — Nikolai Weibull <now@...>

Hi!

14 messages 2010/07/08
[#31146] Re: Why is there no standard way of creating a String from a char *? — Urabe Shyouhei <shyouhei@...> 2010/07/09

(2010/07/09 7:04), Nikolai Weibull wrote:

[#31149] Re: Why is there no standard way of creating a String from a char *? — Nikolai Weibull <now@...> 2010/07/09

On Fri, Jul 9, 2010 at 06:20, Urabe Shyouhei <shyouhei@ruby-lang.org> wrote:

[#31150] Re: Why is there no standard way of creating a String from a char *? — Urabe Shyouhei <shyouhei@...> 2010/07/09

(2010/07/09 18:28), Nikolai Weibull wrote:

[#31217] [Bug #3562] regression in respond_to? — Aaron Patterson <redmine@...>

Bug #3562: regression in respond_to?

14 messages 2010/07/12

[#31269] [Bug #3566] memory leak when spawning+joining Threads in a loop — Eric Wong <redmine@...>

Bug #3566: memory leak when spawning+joining Threads in a loop

14 messages 2010/07/13

[#31399] [Backport #3595] Theres no encoding to differentiate a stream of Binary data from an 8-Bit ASCII string — Dreamcat Four <redmine@...>

Backport #3595: Theres no encoding to differentiate a stream of Binary data from an 8-Bit ASCII string

17 messages 2010/07/21

[#31459] [Bug #3607] [trunk/r28731] Gem.path has disappeared? — Ollivier Robert <redmine@...>

Bug #3607: [trunk/r28731] Gem.path has disappeared?

22 messages 2010/07/23

[#31519] [Bug #3622] Net::HTTP does not wait to send request body with Expect: 100-continue — Eric Hodel <redmine@...>

Bug #3622: Net::HTTP does not wait to send request body with Expect: 100-continue

9 messages 2010/07/28

[ruby-core:31333] Re: [rubysoc] Queue C-extension patch to come

From: Ricardo Panaggio <panaggio.ricardo@...>
Date: 2010-07-17 21:00:56 UTC
List: ruby-core #31333
I've done this using the existing test of Queue, modifying it a little
bit (see attached file for the code):

panaggio@phoenix:/tmp$ ./c-queue/bin/ruby queue_benchmark.rb
     user     system      total        real
100  0.270000   0.030000   0.300000 (  0.393703)
1000  3.270000   0.160000   3.430000 (  3.987008)
10000 32.890000   1.910000  34.800000 ( 39.984390)
panaggio@phoenix:/tmp$ ./ruby-queue/bin/ruby queue_benchmark.rb
     user     system      total        real
100  1.280000   0.110000   1.390000 (  1.652816)
1000 13.370000   0.700000  14.070000 ( 16.071673)
10000129.410000   7.680000 137.090000 (160.303117)
panaggio@phoenix:/tmp$

My implementation is almost 4 times faster than the existing one.
Maybe it's enough, maybe it's not. Let me know if it isn't, so that I
can make any extra tuning, if needed.

Just to get it clear: c-queue was generated from queue's branch code
and ruby-queue was generated from trunk's code, both from my fork.

The times on any other machine may be much lower, as my notebook is really old.

>> It is not (for me at least), if you call the "top" Ruby api (which is
>> directly (or almost) bound to Ruby methods (eg: rb_ary_new()), the
>> gain is insignificant. (I imagine you only bypass parsing the Ruby
>> code)
>
> Replacing ruby's dynamic method dispatch with c function calls should
> make a pretty big difference. Executing native instructions instead of
> bytecodes should also help, tho less so I would think.

This little benchmark just shows what Caleb said. By implementing it
in C already, it get measurably faster.

Attachments (1)

queue_benchmark.rb (810 Bytes, application/x-ruby)

In This Thread