[#390749] Why are there so many similar/identical methods in core classes — Kassym Dorsel <k.dorsel@...>

Let's look at the Array class and start with method aliases.

14 messages 2011/12/02

[#390755] Inverse Operation of Module#include — Su Zhang <su.comp.lang.ruby@...>

Hi list,

21 messages 2011/12/02
[#390759] Re: Inverse Operation of Module#include — Ryan Davis <ryand-ruby@...> 2011/12/02

[#390764] Re: Inverse Operation of Module#include — Isaac Sanders <isaacbfsanders@...> 2011/12/02

I would suggest an Adapter pattern use here. IF there is something that has

[#390876] black magical hash element vivification — Chad Perrin <code@...>

Ruby (1.9.3p0 to be precise, installed with RVM) is not behaving as I

12 messages 2011/12/05

[#390918] WEB SURVEY about Ruby Community — Intransition <transfire@...>

Did any one else get this survey request?

14 messages 2011/12/07

[#390976] Confusing results from string multiplication — Rob Marshall <robmarshall@...>

Hi,

19 messages 2011/12/08

[#391019] How can I do h["foo"] += "bar" if h["foo"] does not exist? — "Andrew S." <andrewinfosec@...>

Hi there,

13 messages 2011/12/09

[#391027] reading from file without end-of-lines — Janko Muzykant <umrzykus@...>

hi,

20 messages 2011/12/09
[#391028] Re: reading from file without end-of-lines — Gavin Sinclair <gsinclair@...> 2011/12/09

> i'm trying to read a few text values from single file:

[#391031] Re: reading from file without end-of-lines — Robert Klemme <shortcutter@...> 2011/12/09

On Fri, Dec 9, 2011 at 9:58 AM, Gavin Sinclair <gsinclair@gmail.com> wrote:

[#391042] Re: reading from file without end-of-lines — Gavin Sinclair <gsinclair@...> 2011/12/09

On Fri, Dec 9, 2011 at 8:18 PM, Robert Klemme

[#391135] I need advice on what to do next. — Nathan Kossaeth <system_freak_2004@...>

I am new to programming. I read the ebook "Learn to Program" by Chris

23 messages 2011/12/12

[#391216] perf optimization using profile results — Chuck Remes <cremes.devlist@...>

I need some help with optimizing a set of libraries that I use. They are ffi-rzmq, zmqmachine and rzmq_brokers (all up on github).

13 messages 2011/12/13
[#391218] Re: perf optimization using profile results — Chuck Remes <cremes.devlist@...> 2011/12/13

On Dec 13, 2011, at 9:57 AM, Chuck Remes wrote:

[#391234] Re: perf optimization using profile results — Charles Oliver Nutter <headius@...> 2011/12/14

A couple quick observations.

[#391238] Re: perf optimization using profile results — Chuck Remes <cremes.devlist@...> 2011/12/14

On Dec 13, 2011, at 7:03 PM, Charles Oliver Nutter wrote:

[#391324] ruby 1.9 threading performance goes non-linear — Joel VanderWerf <joelvanderwerf@...>

12 messages 2011/12/16
[#391325] Re: ruby 1.9 threading performance goes non-linear — Eric Wong <normalperson@...> 2011/12/16

Joel VanderWerf <joelvanderwerf@gmail.com> wrote:

[#391420] Accessing class instance variables from an instance? — "Shareef J." <shareef@...>

Hi there,

26 messages 2011/12/20
[#391454] Re: Accessing class instance variables from an instance? — Khat Harr <myphatproxy@...> 2011/12/21

Actually, now that I'm thinking about it the existing behavior sort of

[#391456] Re: Accessing class instance variables from an instance? — Josh Cheek <josh.cheek@...> 2011/12/21

On Tue, Dec 20, 2011 at 9:42 PM, Khat Harr <myphatproxy@hotmail.com> wrote:

[#391545] Kernel#exit raises an exception? — Khat Harr <myphatproxy@...>

While I was working on embedding an interpreter I wrote a function to

13 messages 2011/12/24

[#391618] rvmsh: An easy installer for RVM — Bryan Dunsmore <dunsmoreb@...>

I have recently begun work on a project called [rvmsh]

12 messages 2011/12/29

[#391783] Mailspam — Gunther Diemant <g.diemant@...>

Is there a way to stop this mailspam of Luca (Mail)?

12 messages 2011/12/29

[#391790] What’s the standard way of implementing #hash for value objects in Ruby? — Nikolai Weibull <now@...>

Hi!

23 messages 2011/12/29
[#391792] Re: What’s the standard way of implementing #hash for value objects in Ruby? — Gunther Diemant <g.diemant@...> 2011/12/29

I think you can't access instance variables from a class method, so

[#391793] Re: What’s the standard way of implementing #hash for value objects in Ruby? — Nikolai Weibull <now@...> 2011/12/29

On Thu, Dec 29, 2011 at 15:52, Gunther Diemant <g.diemant@gmx.net> wrote:

[#391811] Re: What’s the standard way of implementing #hash for value objects in Ruby? — Robert Klemme <shortcutter@...> 2011/12/29

On Thu, Dec 29, 2011 at 4:06 PM, Nikolai Weibull <now@bitwi.se> wrote:

[#391812] Re: What’s the standard way of implementing #hash for value objects in Ruby? — Nikolai Weibull <now@...> 2011/12/29

On Fri, Dec 30, 2011 at 00:26, Robert Klemme <shortcutter@googlemail.com> w=

[#391816] Re: What’s the standard way of implementing #hash for value objects in Ruby? — Josh Cheek <josh.cheek@...> 2011/12/30

On Thu, Dec 29, 2011 at 5:47 PM, Nikolai Weibull <now@bitwi.se> wrote:

[#391833] Re: What’s the standard way of implementing #hash for value objects in Ruby? — Robert Klemme <shortcutter@...> 2011/12/30

On Fri, Dec 30, 2011 at 12:47 AM, Nikolai Weibull <now@bitwi.se> wrote:

Re: perf optimization using profile results

From: Charles Oliver Nutter <headius@...>
Date: 2011-12-14 01:03:57 UTC
List: ruby-talk #391234
A couple quick observations.

* I assume it's expected that the majority of time is spent in
zmq_poll, which is an FFI Call to zmq. Excluding that from
consideration...

* This is bad:

 16.57        0.76       15.81     3079083  Class#new

Three million new classes created. I'm sure it's singleton somewhere,
but that's often a big perf sink...not necessarily because it impacts
straight-line code a lot, but because a class object is a nontrivial
thing to be creating three million of.

* Going down the list, I don't see anything obvious to optimize in
most of the hot methods. Usually when you have normalish-looking code
that's really hot, the next thing to optimize is reducing object
allocation as much as possible. In fact, that more than anything often
improves perf on JRuby...but I'm not sure the effect on other impls.

- Charlie

On Tue, Dec 13, 2011 at 10:32 AM, Chuck Remes <cremes.devlist@mac.com> wrot=
e:
> On Dec 13, 2011, at 9:57 AM, Chuck Remes wrote:
>
>> I need some help with optimizing a set of libraries that I use. They are=
 ffi-rzmq, zmqmachine and rzmq_brokers (all up on github).
>>
>> I ran a 'latency' test using the highest-level library (rzmq_brokers) an=
d noticed that, as I add each network client to the test, each iteration ta=
kes another 300 microseconds to complete. From my testing, JRuby is far and=
 away the fastest runtime executing my code so I have used it to gather som=
e profile statistics. Right now I have some local changes in my zmqmachine =
and rzmq_brokers repositories that haven't been pushed to github, so anothe=
r party can't currently reproduce what I am seeing. I am working right now =
to clean up those commits so that I can push them out.
>>
>> I did two runs with JRuby using the --server option. The first run was w=
ith --profile to produce a flat profile results. The second run was with --=
profile.grah to produce the graph profile results.
>>
>> https://gist.github.com/1472608
>>
>> I would be grateful if another set (or several sets) of eyes could take =
a look at the profile results and suggest places I should focus on for redu=
cing that 300 usec latency per client. I have already reduced it from 700 u=
sec to 300 usec by replacing a regular Array with a SortedArray (where data=
 is stored sorted so that lookups are fast). I'm hoping to get another 50% =
reduction.
>>
>> Thanks!
>
>
>
> In case someone wants to try and duplicate what I am doing, all of the co=
de has been pushed up to github. I'm really hoping someone can look at the =
profile results and suggest 2-3 places that are ripe for optimization, but =
in the event you are feeling frisky now you can reproduce the whole shebang=
 on your own machine.
>
> The aforementioned code repositories are:
>
> git://github.com/chuckremes/ffi-rzmq.git
>
> git://github.com/chuckremes/zmqmachine.git
>
> git://github.com/chuckremes/rzmq_brokers.git
>
> In rzmq_brokers/test, run:
>
> =C2=A0ruby test_consensus.rb <any open port number, e.g. 5556>
>
> The test adds a new network client for each 10_000 iterations and prints =
the average round-trip latency of those 10k messages. As each client is add=
ed, latency goes up about 300 usec (on my machine, YMMV). I would like to r=
educe that number.
>
> cr
>

In This Thread