Professional Documents
Culture Documents
Instruction Level Parallelism Vectorization, SSE Optimizing for the memory hierarchy
Announcements Partners?
Todays lecture Why multicore? Instruction Level Parallelism Vectorization, SSE Optimizing for the memory hierarchy
http://forums.vr-zone.com/
realworldtech.com
Pipelining
Assembly line processing - an auto plant
Dave Pattersons Laundry example: 4 people doing laundry wash (30 min) + dry (40 min) + fold (20 min) = 90 min
6 PM
9
Time
30 40 40 40 40 20 A B C D
Sequential execution takes 4 * 90min = 6 hours Pipelined execution takes 30+4*40+20 = 3.5 hours Bandwidth = loads/hour Pipelining helps bandwidth but not latency (90 min) Bandwidth limited by slowest pipeline stage Potential speedup = Number pipe stages
Multi-execution pipeline
MIPS R4000
integer unit
ex
x= y / z; a = b + c; s = q * r; i++;
m7
FP/int Multiply
IF ID
m1 m2 m3 m4 m5 m6
MEM WB
FP adder
a1 a2 a3 a4
FP/int divider
Div (latency = 25)
x = y / z; t = c q; a = x + c;
David Culler
Scott B. Baden / CSE 160 / Winter 2011
instructions complete Which instructions depend on the results When its safe to write a reg.
Scoreboard
FU
op fetch
op fetch
ex
ex
(Write after read) RAW (Read after write) WAW (Write after write)
Scott B. Baden / CSE 160 / Winter 2011
10
Vector computer: Cray-1 (1976) Intel and others support SIMD for multimedia and graphics
1 4 2 6
1 2 = 2 3
1 2 * 1 2
GPUs, Cell Broadband Engine Reduced performance on data dependent or irregular computations
forall i = 0 : n-1 if ( x[i] < 0) then y[i] = x[i] else y[i] = x[i] end if end forall
11
1/13/11
r[0:3] = a[0:3]*b[0:3]
4 floats 2 doubles
Jim Demmel
Scott B. Baden / CSE 160 / Winter 2011
13
Performance
Single precision:
With vectorization : 0.52 sec. Without vectorization : 1.9 sec. Double precision: With vectorization: 1.5 sec. Without vectorization : 3.0 sec.
14
15
16
Matrix Multiplication An important core operation in many numerical algorithms Given two conforming matrices A and B, form the matrix product A B A is m n B is n p Operation count: O(n3) multiply-adds for an n n square matrix Discussion follows from Demmel
www.cs.berkeley.edu/~demmel/cs267_Spr99/Lectures/Lect02.html
18
Unblocked Matrix Multiplication for i := 0 to n-1 for j := 0 to n-1 for k := 0 to n-1 C[i,j] += A[i,k] * B[k,j]
C[i,j]
A[i,:]
+=
B[:,j]
19
Analysis of performance
for i = 0 to n-1 // for each iteration i, load all of B into cache for j = 0 to n-1 // for each iteration (i,j), load A[i,:] into cache // for each iteration (i,j), load and store C[i,j] for k = 0 to n-1 C[i,j] += A[i,k] * B[k,j]
C[i,j]
A[i,:]
+=
B[:,j]
20
Analysis of performance
for i = 0 to n-1 // n n2 / L loads = n3/L, L=cache line size B[:,:] for j = 0 to n-1 // n2 / L loads = n2/L A[i,:] // n2 / L loads + n2 / L stores = 2n2 / L C[i,j] for k = 0 to n-1 C[i,j] += A[i,k] * B[k,j] Total:(n3 + 3n2) / L
C[i,j] A[i,:]
+=
B[:,j]
21
2 as n
!
22
C[i,j]
C[i,j]
A[i,k]
+
Scott B. Baden / CSE 160 / Winter 2011
B[k,j]
23
n2
Total:
// b = n/N = cache line size for k = 0 to N-1 // load each block A[i,k] and B[k,j] N3 times // = 2N3 (n/N)2 = 2Nn2 C[i,j] += A[i,k] * B[k,j] // do the matrix multiply // write each block C[i,j] once : n2
(2*N+2)*n2
A[i,k]
C[i,j]
C[i,j]
+
Scott B. Baden / CSE 160 / Winter 2011
B[k,j]
24
n/N = b as n
25
The results
26
http://www-suif.stanford.edu/papers/lam91.ps
27
Fin
Partitioning
Splits up the data over processors Different partitionings according to the processor geometry
For P processors geometries are of the form p0 p1, where P = p0 p1 For P=4: 3 possible geometries 14
0 1 2 3
41
0 1 2 3
2 2
0 1
31