I have to pick a language to commit to for general purpose
scientific/statistical/utility/database programming at my office and
have pretty much narrowed it down to R or Python. Problem: none of
the various Python books I have looked into has had much to say about
memory. I will be operating on some big arrays, probably with Numpy;
if I run out of space and upgrade a Win 2000 or Win XP pro machine
from 256 Meg to 500Meg or even 1G will Python automatically recognize
and take advantage of the increase? Where are questionss such as this
discussed in the documentation?
Thanks for any suggestions,
Ben Fairbank 7 5757
On Thu, Oct 02, 2003 at 04:59:15AM +0000, Ben Fairbank wrote: I have to pick a language to commit to for general purpose scientific/statistical/utility/database programming at my office and have pretty much narrowed it down to R or Python. Problem: none of the various Python books I have looked into has had much to say about memory. I will be operating on some big arrays, probably with Numpy;
Python isn't terribly memory-efficient. Every int, for example, takes all
the overhead of an object plus any allocator overheads. But if the bulk
of the data is going to be numpy arrays this isn't a problem. An array
object has a small one-time overhead and then each item takes exactly its
native size in bytes. Make sure you use in-place operations as much as
possible on arrays so you don't force numpy to allocate large temporary
arrays.
if I run out of space and upgrade a Win 2000 or Win XP pro machine from 256 Meg to 500Meg or even 1G will Python automatically recognize and take advantage of the increase? Where are questionss such as this discussed in the documentation?
Python can immediately use any memory expansion. It also runs on 64 bit
platforms if you ever need more than 4GB of data.
Oren ba*@texas.antispam.net (Ben Fairbank) writes: I have to pick a language to commit to for general purpose scientific/statistical/utility/database programming at my office and have pretty much narrowed it down to R or Python. Problem: none of the various Python books I have looked into has had much to say about memory. I will be operating on some big arrays, probably with Numpy;
Hmm. Python is not *amazingly* memory efficient. But if you're
dealing with relatively few Numpy arrays, the memory consumption will
probably not be that much more than any other language you use
(unlike, say, using a list of floats).
if I run out of space and upgrade a Win 2000 or Win XP pro machine from 256 Meg to 500Meg or even 1G will Python automatically recognize and take advantage of the increase?
This is more a question about the OS than Python. I would be amazed
if Python couldn't use the extra memory.
Where are questionss such as this discussed in the documentation?
I don't think they are, really. The numpy manual might have a few
words to say on the subject.
Cheers,
mwh
--
Famous remarks are very seldom quoted correctly.
-- Simeon Strunsky
Ben Fairbank wrote: I have to pick a language to commit to for general purpose scientific/statistical/utility/database programming at my office and have pretty much narrowed it down to R or Python. Problem: none of the various Python books I have looked into has had much to say about memory. I will be operating on some big arrays, probably with Numpy; if I run out of space and upgrade a Win 2000 or Win XP pro machine from 256 Meg to 500Meg or even 1G will Python automatically recognize and take advantage of the increase? Where are questionss such as this discussed in the documentation?
Python gets its information about memory (and allocates its memory)
from the operating system. This is not discussed in the documentation
because it's more or less taken for granted -- that's what one should
assume of any app or language unless other behavior is documented. If
your Win/2K, Win/XP, or whatever, is able to see your new memory and
make it available to apps (and I see no reason why not), Python, like
any other normal app, should be able to use it just fine.
Alex
In article <3f***************@news.houston.sbcglobal.net>,
Ben Fairbank <ba*@texas.antispam.net> wrote: I have to pick a language to commit to for general purpose scientific/statistical/utility/database programming at my office and have pretty much narrowed it down to R or Python. Problem: none of the various Python books I have looked into has had much to say about memory. I will be operating on some big arrays, probably with Numpy; if I run out of space and upgrade a Win 2000 or Win XP pro machine from 256 Meg to 500Meg or even 1G will Python automatically recognize and take advantage of the increase? Where are questionss such as this discussed in the documentation?
Ben Fairbank wrote: I have to pick a language to commit to for general purpose scientific/statistical/utility/database programming at my office and have pretty much narrowed it down to R or Python.
In a previous life, I went for R and Python and eventually
stayed in python (with numeric, of course) because, in my case,
moving data over to R and then operating there was always more
expensive than simply doing the calculations in python. These
days I'd check if numarray did the trick. If you want to play
in this world, check out the enthought packaging of python: http://www.enthought.com/python/
They've got most of the goodies in there that you'd be likely
to want to run out and add to your python in the first months.
-Scott David Daniels Sc***********@Acm.Org
In article <vn************@corp.supernews.com>, I offered: In article <3f***************@news.houston.sbcglobal.net>, Ben Fairbank <ba*@texas.antispam.net> wrote:I have to pick a language to commit to for general purpose scientific/statistical/utility/database programming at my office and have pretty much narrowed it down to R or Python. Problem: none of . . . Tough choice. As your research apparently has already disclosed, both R and Python are quite capable in the role you're contemplating. The differences between them are likely to be the deep sort that are difficult to determine beforehand. Are you aware that, at least within limits, you don't *have* to choose? <URL: http://www.togaware.com/linux/survivor/Python_R.html >?
I apparently misled some readers. I want to emphasize: both
R and Python are wonderful for the sort of scientific program-
ming under consideration here. Anyone who has narrowed down
his choices to these two has already done all the hard work.
It's reasonably safe to choose either, without regrets; there
is no need in general to learn both.
<URL: http://phaseit.net/claird/comp.progr...e_science.html >
provides reading of related interest.
--
Cameron Laird <Ca*****@Lairds.com>
Business: http://www.Phaseit.net
Personal: http://phaseit.net/claird/home.html
Ben Fairbank wrote: I have to pick a language to commit to for general purpose scientific/statistical/utility/database programming at my office and have pretty much narrowed it down to R or Python. Problem: none of the various Python books I have looked into has had much to say about memory. I will be operating on some big arrays, probably with Numpy; if I run out of space and upgrade a Win 2000 or Win XP pro machine from 256 Meg to 500Meg or even 1G will Python automatically recognize and take advantage of the increase? Where are questionss such as this discussed in the documentation?
Thanks for any suggestions,
For large arrays, look into numarray (next-gen Numeric). That's where most of
the effort of numarray has gone: being a _lot_ smarter than Numeric in memory
management for large arrays. It's also cleaner and nicer than numeric in many
ways, and already mature enough that many people are using it for production
work. Its only big stumbling block right now is that small array performance
is pretty poor, and this one will take a bit of time to fix.
I'd personally stick to python (with the scipy libraries, as was already
suggested), and would add the RPy interface for those cases when you need a
routine which R provides, which you need NOW, and which would be more work to
write in python.
Cheers,
f. This thread has been closed and replies have been disabled. Please start a new discussion. Similar topics
by: lebo |
last post by:
Hi
I'm trying to understand how Python handles memory usage and dynamic
object loading and unloading. Problem to solve? Build a very low
memory footprint (non-GUI) Python application for...
|
by: Saravanan |
last post by:
Hello,
Im running Python Application as a Windows Service (using windows
extensions). But, sporadically the application crashes (crash in
Python23.dll) and this stops the service. This...
|
by: Robby Dermody |
last post by:
Hey guys (thus begins a book of a post :),
I'm in the process of writing a commercial VoIP call monitoring and
recording application suite in python and pyrex. Basically, this
software sits in a...
|
by: abhinav |
last post by:
Hello guys,
I am a novice in python.I have to implement a full fledged mail server
..But i am not able to choose the language.Should i go for C(socket API)
or python for this project? What are the...
|
by: mariano.difelice |
last post by:
Hi,
I've a big memory problem with my application.
First, an example:
If I write:
a = range(500*1024)
I see that python process allocate approximately 80Mb of memory.
|
by: frederic.pica |
last post by:
Greets,
I've some troubles getting my memory freed by python, how can I force
it to release the memory ?
I've tried del and gc.collect() with no success.
Here is a code sample, parsing an XML...
|
by: vishnu |
last post by:
Hi there,
I am embedding python 2.5 on embedded system running on RTOS where I
had strict memory constraints.
As python is a huge malloc intensive application, I observed huge
memory...
|
by: WaterWalk |
last post by:
I've just read an article "Building Robust System" by Gerald Jay
Sussman. The article is here:
http://swiss.csail.mit.edu/classes/symbolic/spring07/readings/robust-systems.pdf
In it there is a...
|
by: Kemmylinns12 |
last post by:
Blockchain technology has emerged as a transformative force in the business world, offering unprecedented opportunities for innovation and efficiency. While initially associated with cryptocurrencies...
|
by: antdb |
last post by:
Ⅰ. Advantage of AntDB: hyper-convergence + streaming processing engine
In the overall architecture, a new "hyper-convergence" concept was proposed, which integrated multiple engines and...
|
by: Arjunsri |
last post by:
I have a Redshift database that I need to use as an import data source. I have configured the DSN connection using the server, port, database, and credentials and received a successful connection...
|
by: WisdomUfot |
last post by:
It's an interesting question you've got about how Gmail hides the HTTP referrer when a link in an email is clicked. While I don't have the specific technical details, Gmail likely implements measures...
|
by: Matthew3360 |
last post by:
Hi,
I have been trying to connect to a local host using php curl. But I am finding it hard to do this. I am doing the curl get request from my web server and have made sure to enable curl. I get a...
|
by: Oralloy |
last post by:
Hello Folks,
I am trying to hook up a CPU which I designed using SystemC to I/O pins on an FPGA.
My problem (spelled failure) is with the synthesis of my design into a bitstream, not the C++...
|
by: Rahul1995seven |
last post by:
Introduction:
In the realm of programming languages, Python has emerged as a powerhouse. With its simplicity, versatility, and robustness, Python has gained popularity among beginners and experts...
|
by: ezappsrUS |
last post by:
Hi,
I wonder if someone knows where I am going wrong below. I have a continuous form and two labels where only one would be visible depending on the checkbox being checked or not. Below is the...
|
by: jack2019x |
last post by:
hello, Is there code or static lib for hook swapchain present?
I wanna hook dxgi swapchain present for dx11 and dx9.
| |