Filter löschen
Filter löschen

Parallelizing algorithms and finding the number of words each processor needs

1 Ansicht (letzte 30 Tage)
Assuming that m = n = p is divisible by 4, and that 4 processors are computing the matrix-matrix multiplication C = AB where A, B, C are n x n matrices.
Algorithm1:
function C = MatMult3(A, B)
[n, n] = size(A);
[n, n] = size(B);
C = zeros(n, n);
for j = 1 : n
C(:, j) = A * B(:, j);
end
a) How to parallelize this assuming m = n = p is divisible by 4?
Algorithm 2:
function C = MatMult4(A, B)
[n, n] = size(A);
[n, n] = size(B);
C = zeros(n, n);
for k = 1 : n
C = C + A(:, k) * B(k, :);
end
b) How to parallelize this assuming m = n = p is divisible by 4?
And how to parallelize in the case of a square block version?
c) Find the number of words that each processor needs to compute its part.
d) Find the number of flops that each processor computes in parallel.
  1 Kommentar
Steven Lord
Steven Lord am 19 Sep. 2020
This sounds like a homework assignment. If it is, show us the code you've written to try to solve the problem and ask a specific question about where you're having difficulty and we may be able to provide some guidance.
If you aren't sure where to start because you're not familiar with how to write MATLAB code, I suggest you start with the MATLAB Onramp tutorial (https://www.mathworks.com/support/learn-with-matlab-tutorials.html) to quickly learn the essentials of MATLAB.
If you aren't sure where to start because you're not familiar with the mathematics you'll need to solve the problem, I recommend asking your professor and/or teaching assistant for help.

Melden Sie sich an, um zu kommentieren.

Antworten (0)

Kategorien

Mehr zu Get Started with MATLAB finden Sie in Help Center und File Exchange

Community Treasure Hunt

Find the treasures in MATLAB Central and discover how the community can help you!

Start Hunting!

Translated by