# Flynn's Taxonomy

Prof. Mike Flynn's famous taxonomy of parallel computers

#### Computer Instruction Cycle





# **Control Unit ALU** 2. Decode Instruction 3. Get Data Registers **FETCH CYCLE EXECUTION CYCLE** 1. Fetch Instruction 4. Execute Instruction Main Memory

# Flynn's Taxonomy

Proposed by Prof. Mike Flynn in 1966

how many <u>instructions</u>
vs
how much data

can be processed simultaneously

# **SISD Instruction Pool** Single Instruction Single Data

# Von-Neumann Architecture



#### SIMD

#### **Instruction Pool**



Single Instruction **MULTIPLE** Data

Same processing instruction runs on all processors

Data level parallelism NOT Concurrency

#### Applications:

- \* Image editing
- \* Multimedia processing

#### arm CORTEX®-A9



Arm NEON
technology is an
advanced SIMD
(single instruction
multiple data)
architecture
extension for the
Arm Cortex-A series

## **MISD Instruction Pool** Pipelining!!! No real example in real life Applications: \* convolution \* matrix operations \* data sorting Data Pool **DIFFERENT** processing **MULTIPLE** Instruction instructions run on **SINGLE** Data SAME data

### **MIMD Instruction Pool MULTIPLE** Instruction **MULTIPLE** Data **DIFFERENT** processing Data Pool instructions can run on **DIFFERENT** data **Processing:** asynch, independent Memory: shared or distributed **Applications:** \* Simulation \* Emulation (VM) \* CAD/CAM \* Modeling

#### Intel® Xeon Phi™ Coprocessor Block Diagram



#### More MIMD

#### **SPMD**

- Same program multiple data
- Program executed at independent execution points
- Most common style of parallel programming

#### **MPMD**

- Multiple program multiple data
- At least 2 programs
- One program is master/controller
- Others 'nodes' receive program from master

### SPMD







# Playstation 3 – Cell Processor (MPMD)



# Pop Quiz! What architecture is this???

#### AMD GPU Hardware Architecture



- AMD 5870 Cypress
- 20 SIMD engines
- 16 SIMD units per core
- 5 multiply-adds per functional unit (VLIW processing)
- 2.72 Teraflops Single Precision
- 544 Gigaflops Double Precision

**Source**: Introductory OpenCL SAAHPC2010, Benedict R. Gaster

# Flynn's Taxonomy

- quite difficult to fit parallel architectures
  - Ancient 1966!!!
  - Where do these fit??? <<< <u>UNCLEAR</u>
    - instruction level parallel
    - fine-grain speculative multithreading
- Most important distinction is between SIMD and MIMD