wu :: forums (http://www.ocf.berkeley.edu/~wwu/cgi-bin/yabb/YaBB.cgi)
riddles >> cs >> Paralle programming
(Message started by: hoogle on Sep 26th, 2008, 8:47am)

Title: Paralle programming
Post by hoogle on Sep 26th, 2008, 8:47am
Suppose there are p processors, where each processor starts with p and its processor number pid in local variables, 0 ≤ pid ≤ p − 1. There is an integer array V [0 : p−1], and you are to find the smallest i such that V [i] = 1, or return the value p if there is no such i. The answer should be stored in the integer variable firstone.

Each processor is a standard microprocessor with a small amount of local memory (not enough to store large arrays), and there is as much global memory as is needed. V and firstone are stored in shared memory.
Make sure you identify which variables are local (every processor has its own copy of
the variable, such as pid), and which ones are global (there is a single instance of the variable, accessible to
all, such as firstone). If k processors try to read from the same memory location at the same time then they
all get the correct value, but if they try to write to the same memory location at the same time then the result
can be arbitrary. However, if they write to different locations simultaneously then all of the memory locations
receive the correct values. If one processor is writing to a memory location while another is reading from it
then the processor trying to do the read operation may receive an arbitrary value. In the statement x = y, for
global variables x and y, the y is being read and the x is being written.
To assist you, there is a command barrier. No processor will execute any statements after the barrier instruction
until all of them have reached it. For example, if the code is
statement 1
barrier
statement 2
then no processor starts statement 2 until all have finished statement 1. Barriers are often time-consuming,
so use them as infrequently as possible, but asymptotic time is most important. E.g., if algorithm A has no
barriers and takes time (n), while algorithm B has many barriers but takes time (√n), then B is better.
However, if algorithm C also takes (√n) time and has only a few barriers, then C is best.



Powered by YaBB 1 Gold - SP 1.4!
Forum software copyright © 2000-2004 Yet another Bulletin Board