Further isolated the error and it seems to come in from the sum function in 
numpy. I will probe further later but the code below causes the memory usage to 
go up and up. If you change sum below to some other function there are no 
issues.

   from numpy import arange, sum

   for x in range(10000000):
            inhibVal = sum(arange(15))

   Cheers,
   Jeff

   Message: 3
   Date: Sun, 22 May 2011 09:32:10 -0500
   From: Bruce Southey<bsout...@gmail.com>
   Subject: Re: [Numpy-discussion] Python memory management issues using
        Linux. Maybe Numpy, related.
   To: Discussion of Numerical Python<numpy-discussion@scipy.org>
   Message-ID:<BANLkTinAuFp0o6OTwvP=gdhbknkhkwh...@mail.gmail.com>
   Content-Type: text/plain; charset=ISO-8859-1

   On Sun, May 22, 2011 at 8:42 AM, Ralf Gommers
   <ralf.gomm...@googlemail.com>  wrote:

    >
    >
    >  On Sun, May 22, 2011 at 2:54 PM, Jeffrey Spencer<jeffspenc...@gmail.com>
    >  wrote:
    >>
    >>  Sorry. I attached here the class and script to run it. It is just a
    >>  minimalistic example of what I'm really doing that exhibits the same
    >>  behavior. All the script does is run at.createSpecific after 
instantiating
    >>  the class. I have seen this exhibited on many other cases but it runs 
fine
    >>  in Windows XP. Here is what the script does:
    >>
    >>  import MemoryLeak
    >>  at = MemoryLeak.Model()
    >>  at.createSpecific()
    >>
    >  That manages to eat up all my cpu cycles for about 5 minutes, but no leak
    >  (on OS X). I also don't see anything in the code that can potentially 
give
    >  problems. I suggest you strip this down a lot more so you can isolate the
    >  problem.
    >
    >  If in your original code you were making a lot of figures in one of those
    >  for loops without explicitly closing them, that could perhaps be a 
problem.
    >  But you removed all I/O and matplotlib related code already (except for
    >  imports and some keywords).
    >
    >  Ralf
    >
    >  _______________________________________________
    >  NumPy-Discussion mailing list
    >  NumPy-Discussion@scipy.org
    >  http://mail.scipy.org/mailman/listinfo/numpy-discussion
    >
   A good OS is likely to keep Python module in memory just because it
   knows that it might be requested again. However, from the little I
   know (too much LWN), if Linux needs that memory it will reclaim that
   memory only when it needs it or part of some other process.

   Measuring memory usage using simple tools (like ps or top) are very
   far from sufficient, so exactly how do you know that the memory has
   not been released?

   Bruce



--
________________________
Jeffrey Spencer
jeffspenc...@gmail.com

_______________________________________________
NumPy-Discussion mailing list
NumPy-Discussion@scipy.org
http://mail.scipy.org/mailman/listinfo/numpy-discussion

Reply via email to