[#7500] Re: how to introduce reference objects into ruby — "Geert Fannes" <Geert.Fannes@...>

The problem with the code you sent is that you have to go through ALL

16 messages 2006/03/10

[#7553] "not" operator used in expression that is a method parameter can generate syntax error — noreply@...

Bugs item #3843, was opened at 2006-03-15 22:09

27 messages 2006/03/16
[#7554] Re: [ ruby-Bugs-3843 ] "not" operator used in expression that is a method parameter can generate syntax error — nobu@... 2006/03/16

Hi,

[#7557] Re: [ ruby-Bugs-3843 ] "not" operator used in expression that is a method parameter can generate syntax error — 卜部昌平 <shyouhei@...> 2006/03/16

Nobu, you are not answering to the question.... You have to unveil why

[#7559] Re: [ ruby-Bugs-3843 ] "not" operator used in expression that is a method parameter can generate syntax error — Yukihiro Matsumoto <matz@...> 2006/03/16

Hi,

[#7560] Rant about keyword logical operators was : (Re: [ ruby-Bugs-3843 ] "not" operator used in expression that is a method parameter can generate syntax error) — "Zev Blut" <rubyzbibd@...> 2006/03/16

Hello,

[#7565] Re: [ ruby-Bugs-3843 ] "not" operator used in expression that is a method parameter can generate syntax error — mathew <meta@...> 2006/03/16

Yukihiro Matsumoto wrote:

[#7566] Re: [ ruby-Bugs-3843 ] "not" operator used in expression that is a method parameter can generate syntax error — "Brian Mitchell" <binary42@...> 2006/03/16

On 3/16/06, mathew <meta@pobox.com> wrote:

[#7567] Re: [ ruby-Bugs-3843 ] "not" operator used in expression that is a method parameter can generate syntax error — mathew <meta@...> 2006/03/16

Brian Mitchell wrote:

[#7568] Re: [ ruby-Bugs-3843 ] "not" operator used in expression that is a method parameter can generate syntax error — "Brian Mitchell" <binary42@...> 2006/03/16

On 3/16/06, mathew <meta@pobox.com> wrote:

[#7614] PATCH: A subclassable Pathname — "Evan Phoenix" <evanwebb@...>

A simply change (changing all references of "Pathname.new" to

19 messages 2006/03/27
[#7618] Re: PATCH: A subclassable Pathname — Tanaka Akira <akr@...17n.org> 2006/03/27

In article <92f5f81d0603262350k796fe48fp2224b9f2108ac507@mail.gmail.com>,

[#7619] Re: PATCH: A subclassable Pathname — "Evan Phoenix" <evan@...> 2006/03/27

Quite right on the .glob and .getwd. I guess the tests don't test hit

[#7620] Re: PATCH: A subclassable Pathname — Tanaka Akira <akr@...17n.org> 2006/03/27

In article <92f5f81d0603270903g2fb02244i6a395be708dfffa3@mail.gmail.com>,

Re: how to introduce reference objects into ruby

From: "Evan Phoenix" <evan@...>
Date: 2006-03-10 16:31:56 UTC
List: ruby-core #7502
See below.

On 3/10/06, Geert Fannes <Geert.Fannes@ikanconsulting.com> wrote:
> The problem with the code you sent is that you have to go through ALL
> your matrix elements to get a certain row or column, which takes too
> long. Remember that this is a LARGE matrix (my current C implementation
> can handle 100M row and cols and 800M elements). Of course this will be
> too much for Ruby since its memory footprint is larger and its garbage
> collecter will burn a lot of cpu with this number of elements, but
> still, I want the Ruby implementation to contain also a lot of elements.
> It is not feasible to iterate through all elements for retrieving just
> one row or col. What I want looks more like:
>
> class SparseMatrix
>   def initialize()
>     @rows=Hash.new{|hash,key|hash[key]=Hash.new}
>     @columns=Hash.new{|hash,key|hash[key]=Hash.new}
>   end
>   def []=(i,j,value)
>     @rows[i][j]=value
>     @columns[j][i]=value
>   end
>   def getRow(i)
>     return @rows[i]
>   end
>   def getCol(j)
>     return @columns[j]
>   end
> end
>
> m=SparseMatrix.new
> m[10000,200000]=12.01
> m[10000,400000]=12.02
> p m.getRow(10000)
> p m.getCol(200000)
>
> Unfortunately, this code duplicates the content values of the matrix, it
> has a copy inside the @columns and one inside the @rows and these need
> to be maintained so they stay the same, which is programming and
> execution overhead.

This is sort of wrong. Remember that in ruby, like java, most things
are just pointers to objects. The only difference is Fixnums, Symbols,
and the boolean primitives. When you assign a Fixnum, the value is
encoded directly into the pointer. This saves everyone from having to
have thousands of instances of the object which represents the number
1.

You want a reference object because when you assign a Fixnum as the
element in the matrix, it gets stored directly in 2 pointers and
therefore are unrelated.

To get around this, as you stated, you could make, say a Call class
and store the call duration in an instance, and store the object the 2
places in the Hash's (really just storing 2 references to the same
object). Then when you update, say, information from the row, the
information at the column is also updated. Thats how ruby works.

Your statement about Ruby not being able to handle many different
references to the same object is blatantly incorrect. What made you
say it?

All in all, if you believe that you MUST use Fixnums only for memory
reasons, then, as Caleb stated, maybe you should just wrap your C
extension. All high level languages are going to give you the same
trouble (actually others probably even more trouble) when it comes to
how much memory is used to store an object.

I personally think you are just guessing that it will take up too much
room in ruby and that if you try and write it and test it, you'll be
pleasantly surprised.

 - Evan

>
> Geert.
>
> -----Original Message-----
> From: Hugh Sasse [mailto:hgs@dmu.ac.uk]
> Sent: Friday, March 10, 2006 3:32 PM
> To: ruby-core@ruby-lang.org
> Subject: Re: how to introduce reference objects into ruby
>
> On Fri, 10 Mar 2006, Geert Fannes wrote:
>
> > But things change when you want to implement a SPARSE matrix, i.e., a
> > matrix for which most of its elements are empty. E.g., I am analyzing
> > call-networks, data from a telecom firm that contains the call
> durations
> > for its customers, which can be represented with a matrix: element
> (i,j)
> > is the duration that j calls i. Since not everybody calls to
> everybody,
>
> # Untested code.
> # There may well be a faster way, but you don't need pointers to do
> # this.
> class Durations
>   def initialize()
>     @matrix = Hash.new
>   end
>
>   def insert(i,j,duration)
>     @matrix[[i,j]] = duration
>   end
>
>   def getrow(i)
>     return getline(0,1,i)
>   end
>
>   def getcol(i)
>     return getline(1,0,i)
>   end
>
>   private
>
>   # get horizontal or vertical line
>   def getline(a,b,i)
>     line = []
>     linehash = {}
>     @matrix.keys.each do |k|
>       linehash[k[b]] = @matrix[k] if k[a] == i
>     end
>     linehash.keys.sort.each do |index|
>       line << linehas[index]
>     end
>     return line
>   end
>
> end
>
> #       HTH
> #       Hugh
>
>
>


--
When I do good, I feel good;  when I do bad, I feel bad,
and that is my religion.
    -- Abraham Lincoln (1809 - 1865)


In This Thread