Feature request (was "parallel cell executing and wxmaxima")
Subject: Feature request (was "parallel cell executing and wxmaxima")
From: Richard Hennessy
Date: Sat, 09 Jun 2012 16:51:49 -0400
My original post is a feature request. There is nothing wrong with that.
-----Original Message-----
From: Richard Hennessy
Sent: Saturday, June 09, 2012 4:45 PM
To: Richard Fateman ; Maxima List
Subject: Re: [Maxima] parallel cell executing and wxmaxima
I think it should be done by someone who has experience with multi-core
HPC's, like mainframes(, maybe.) They have been around for longer that
multi-core PC's. I don't have such experience, perhaps someone who does
could step up. I don't think I could do it right.
Rich
-----Original Message-----
From: Steve Haflich
Sent: Saturday, June 09, 2012 2:09 PM
To: Richard Hennessy
Cc: Richard Fateman ; maxima at math.utexas.edu
Subject: Re: [Maxima] parallel cell executing and wxmaxima
Pushback happens to ideas where one person wants others to do the work.
(If you don't understand why, please drop by my house this afternoon --
the lawn needs mowing.)
But there are other good reasons for pushback in this case. The notion
of converting Maxima to Symmetrical Multiprocessing is hugely difficult.
For current purposes, let's define SMP as an implementation where
multiple cores can access and mutate the heap in parallel.
- First, SFAIC only three candidate CL implementations support real SMP:
SBCL, CCL, and Allegro. Their APIs are somewhat different, and the
operations which are SMP safe, and which other datastructures must be
protected by locking.
- It is hellishly difficult to convert an existing body of code to SMP.
It is merely extremely difficult to write a body SMP code from
scratch, but that's another matter.
- Debugging bugs and failures under SMP is extremely difficult and often
requires special expertise that has little to do wuith mathematics.
- In general, speed gain is often not great (except for problems
specially amenable to partitioning) and sometimes is actually
negative, since SMP-safe complers often have to emit code that is
slower than non-SMP code.
Converting Maxima to run under SMP would be a _huge_ project with
perpetual cost. The Maxima developers simply have more urgent tasks.
Now, this isn't to reject the idea that certain specialized calculations
could not be parallelized. (Several approaches have already been
mentioned.) One would be to run several independent Maxima executions,
or even non-Lisp computational processes, all communicating via sockets
or (mapped) files. This is tricky to implement, and laborious to make
portable across multiple platforms, but much more practical.
Another technique, perhaps applicable to specific things like matrix
multiplication, would be to code the parallelization in foreign code.
Again, details of foreign function interface and internal array
representation between patforms would require extensive code
customization to make such code work on all platforms.
_______________________________________________
Maxima mailing list
Maxima at math.utexas.edu
http://www.math.utexas.edu/mailman/listinfo/maxima