data:image/s3,"s3://crabby-images/5e0bf/5e0bf548fc4cc6700e748ba1528d71b7560b7720" alt=""
data:image/s3,"s3://crabby-images/46ba1/46ba185631f2d8c41c879bb7fefe06748b8e099f" alt=""
@vgupta22. To clarify in PA1, prog 1, there was no SIMD execution involved. In the example here, there is a work queue for distributing tasks (work) to worker threads. The only inter-thread communication is the synchronization on the shared work queue.
data:image/s3,"s3://crabby-images/a204a/a204a87f9ed658f0e0dca5f2655fa9f83fd02706" alt=""
On PA 1 me and my partner were confused on why increasing beyond the 8 hardware threads kept giving us more and more speedup. If I understand it correctly I believe this slide answers that question. Having more than 8 tasks prevented threads from becoming idle by distributing the workload more evenly.
data:image/s3,"s3://crabby-images/6a982/6a982205befe1237e0317f187ef389b73e565b91" alt=""
I was wondering how using random numbers for dynamic assignment will impact performance. I will try that on PA2 with my partner
data:image/s3,"s3://crabby-images/f84f4/f84f43293c33b84bf315d71a359b75cc2a0c46b7" alt=""
@ckk My partner and I are trying that too. I think there are a lot of domains where the tasks have predictably increasing or decreasing compute time, which could make assigning them to threads in a naive order potentially pathological. One can imagine the Mandelbrot computation inducing this.
data:image/s3,"s3://crabby-images/058cb/058cbe142a2c52936102b9d662372d26fa6e9228" alt=""
Is there any case where static assignment is more efficient? It seems to me that we only use static assignment because of its ease of implementation.
data:image/s3,"s3://crabby-images/874de/874deba703232a22ac50943502df4f9e4d042a50" alt=""
@ia374765 When the overload resulting from a complex dynamic assignment implementation is too much perhaps?
Please log in to leave a comment.
Why do we need to use inter-task communication in this case whereas in prog1 and prog3 we just split up tasks and had them run using SIMD and no communication?