Results 1 to 2 of 2
Discuss Genius Needed Software Porgrammer + Cluster Help Needed at the General Chat within the DigitalWorldz - Satellite, Cable, Console Forums; Hello. I am currently doing my advanced project on a special method called FDTD (finite difference time domain) techniques method. One of the tasks i need to do is to look at parallel methods i.e ...
  1. #1
    VIP Member
    Join Date
    Jan 2007
    Posts
    997
    Downloads
    15
    Uploads
    0
    Mentioned
    0 Post(s)
    Tagged
    0 Thread(s)
    Quoted
    0 Post(s)

    Exclamation Genius Needed Software Porgrammer + Cluster Help Needed

    Hello.

    I am currently doing my advanced project on a special method called FDTD (finite difference time domain) techniques method. One of the tasks i need to do is to look at parallel methods i.e clusters to make the code run faster. Does anybody know where i canfind useful information from looking from the Internet it is a minefield. Need sto take into how the machines can process the threads of the code and concurrency issues. If anybody has any ebooks or links to any useful documents. Would be very much appreciated

    Thanks



  2. #2
    DW Honored Member
    Join Date
    Jun 2007
    Location
    Back in the Toon
    Posts
    752
    Downloads
    0
    Uploads
    0
    Mentioned
    0 Post(s)
    Tagged
    0 Thread(s)
    Quoted
    0 Post(s)

    Re: Genius Needed Software Porgrammer + Cluster Help Needed

    Well to start off, have a look at the wikipedia page here. There's a list of GPLed FTDT solvers on it (some of which are parallel), so you can see how others have done it. The most computationally demanding part of the calculation (and therefore the bit you want to 'parallelize' first) will most likely be some sort of matrix diagonalization. There are literally thousands of books, papers and sites about different algorithms for doing this sort of thing. The main things to consider are the type of matrix (dense, sparse, pseudo diagonal etc), amount of memory available to each machine (can you fit the whole matrix in memory on all machines, will you need to dump it to a temporary file, could use something like Global Arrays for distributed memory?) and network latency.

    I would expect you should learn a bit about MPI, which is generally the parallelization technique used on clusters. MPI-2 supports distributed memory natively, so that might be useful. The MIT books on mpi are pretty good. I bought them, but I'm sure you can 'obtain' them from the ether.

    I summary, I'd start off learning about MPI (plenty of tutorials and documentation on the web). After that, take a look at some of the packages listed on the wikipedia site to get an idea about what is possible.

    The golden rule in parallelizing a piece of software is to be as coarse as you can. Split the work into as big blocks as possible, so that each block/cpu/node can be left alone to do its work as long as possible. Doing it this way minimizes the interprocess communication and improves scalability. Of course there are exceptions and caveats, but if you start off thinking like that you'll do okay.

    Have fun



Similar Threads

  1. electrical genius needed
    By mentholflash01 in forum Wired and Wireless Networking
    Replies: 34
    Last Post: 12th April 2013, 00:58
  2. software needed
    By fes_786 in forum General Chat
    Replies: 4
    Last Post: 10th June 2008, 14:58
  3. software needed
    By avid in forum General Computer Topics
    Replies: 3
    Last Post: 16th October 2005, 12:33
  4. is n*l software needed???????????
    By rizla3066 in forum General Cable Discussion
    Replies: 3
    Last Post: 20th October 2004, 18:03

Visitors found this page by searching for:

algorithm genius needed

User Tag List

Tags for this Thread

Bookmarks

Posting Permissions

  • You may not post new threads
  • You may not post replies
  • You may not post attachments
  • You may not edit your posts
  •  
Copyright Digitalworldz 2013