What are generally the things that change through release cycles?<br>
<br>
our experience with very simple MPI parallelization is that it can be
incorporated in a code relatively easily. The module may be compiled
and run sequentially, but with some IFDEF conditions, the sequential
loop maybe osculted and another version of the loop maybe compiled with
MPI if configured with it. So in that case, the code is holding (though
a bit longer) both types of infrastructures. People may port the
sequential anytime, and if happens to have a "parallel" user, most
likely the compilation trouble shooting will be limited to MPI code.<br>
we did not try that IFDEF trick yet but it is something we want to end up doing with our MPI and NinfG GRASS modules.<br><br>
0.02 cents<br>
<br><div><span class="gmail_quote">On 11/26/05, <b class="gmail_sendername">Helena Mitasova</b> <<a href="mailto:hmitaso@unity.ncsu.edu">hmitaso@unity.ncsu.edu</a>> wrote:</span><blockquote class="gmail_quote" style="border-left: 1px solid rgb(204, 204, 204); margin: 0pt 0pt 0pt 0.8ex; padding-left: 1ex;">
You must have missed a lot in your search - numerous parallel versions<br>of interpolation and other modules<br>have been written since 1993, there should be a link to parallel idw on<br>the grass web site and a parallel<br>
version of the s.surf.rst module is here:<br><a href="http://skagit.meas.ncsu.edu/~helena/grasswork/grasscontrib/">http://skagit.meas.ncsu.edu/~helena/grasswork/grasscontrib/</a><br>rstmods2fixed.tar.gz<br><br>The problem with these implementations is that unless the developer is
<br>committed to keeping them up to date<br>they die pretty quickly (e.g. the rst works with GRASS5 but not GRASS6).<br>So I have been begging everybody who tries to do parallel stuff for<br>grass to do the parallelization
<br>on top of the modules rather than within the modules so that they are<br>minimally dependent on changes<br>within the modules. For example, v.surf.rst can be run efficiently by<br>splitting region into smaller overlapping subregions
<br>and sending each subregion to a different processor and then patch the<br>results together. Same can be<br>done for r.mapcalc , r.slope.aspect and many other modules (there are<br>some exceptions such as modules<br>that include flow routing). This may have its own problems but it is
<br>definitely more general and has much better<br>chance of surviving beyond one release cycle than writing a parallel<br>version of a module.<br><br>I have plenty of large data sets (tens to hundreds of millions of<br>points) but you need to get GRASS read them first.
<br><br>Helena<br><br><br><br>On Nov 25, 2005, at 12:33 PM, Muzaffer Ayvaz wrote:<br><br>> Hi;<br>> <br>> Some modules in GRASS, especially surface generation modules, takes<br>> long times according to the our data and our
parameters.I am trying to<br>> write parallel versions of theese modules via MPI library, to be able<br>> to run GRASS in high performance parallel machines..<br>> <br>> I have looked mailing list archives, and there is a people who is
<br>> trying to do also same thing. But this mail was in 1993. I couldnt<br>> reach this person.<br>> <br>> Now, I want to hear about your experiences. Does anybody try<br>> samething? or Does anybody can give me knowledge about the compilation
<br>> of GRASS with this library (MPI), -mpcc must be used to compile-? Or<br>> do you have large data sets for surface generation.<br>> <br>> Or which modules takes longs time in additon to the surface generation
<br>> modules,<br>> I mean minutes, hours or more.<br>> <br>> Tha! nk you for all<br>> <br>> Your respectfully<br>> <br>> Muzaffer Ayvaz<br>><br>> Yahoo! Music Unlimited - Access over 1 million songs. Try it free.
<br>Helena Mitasova<br>Dept. of Marine, Earth and Atm. Sciences<br>1125 Jordan Hall, NCSU Box 8208,<br>Raleigh NC 27695<br><a href="http://skagit.meas.ncsu.edu/~helena/">http://skagit.meas.ncsu.edu/~helena/</a><br><br>_______________________________________________
<br>grass5 mailing list<br><a href="mailto:grass5@grass.itc.it">grass5@grass.itc.it</a><br><a href="http://grass.itc.it/mailman/listinfo/grass5">http://grass.itc.it/mailman/listinfo/grass5</a><br></blockquote></div><br>