

| Simulate Design                        | - Validate The C function                                           |
|----------------------------------------|---------------------------------------------------------------------|
| Synthesize Design                      | - Baseline design                                                   |
| 1: Initial Optimizations               | - Define interfaces (and data packing)<br>- Define loop trip counts |
| 2: Pipeline for Performance            | - Pipeline and dataflow                                             |
| 3: Optimize Structures for Performance | - Partition memories and ports<br>- Remove false dependencies       |
| 4: Reduce Latency                      | - Optionally specify latency requirements                           |
| 5: Improve Area                        | - Optionally recover resources through sharing                      |

X15638-110617

The figure above details all the steps in the methodology and the subsequent sections in this chapter explain the optimizations in detail.



**IMPORTANT!:** Designs will reach the optimum performance after step 3.

Step 4 is used to minimize, or specifically control, the latency through the design and is only required for applications where this is of concern. Step 5 explains how to reduce the resources required for hardware implementation and is typically only applied when larger hardware functions fail to implement in the available resources. The FPGA has a fixed number of resources, and there is typically no benefit in creating a smaller implementation if the performance goals have been met.