# FPGA TECHNOLOGY MAPPING FOR FRACTURABLE LOOK-UP TABLE MINIMIZATION

by

David Robert Dickin B.A.Sc., Simon Fraser University, 2008

#### THESIS SUBMITTED IN PARTIAL FULFILLMENT

#### OF THE REQUIREMENTS FOR THE DEGREE OF

### MASTER OF APPLIED SCIENCE

IN THE

SCHOOL

OF

ENGINEERING SCIENCE

© David Robert Dickin 2011 SIMON FRASER UNIVERSITY Summer 2011

All rights reserved. However, in accordance with the Copyright Act of Canada, this work may be reproduced, without authorization, under the conditions for Fair Dealing. Therefore, limited reproduction of this work for the purposes of private study, research, criticism, review, and news reporting is likely to be in accordance with the law, particularly if cited appropriately.

## **APPROVAL**

| Name:                | David Robert Dickin                                                              |
|----------------------|----------------------------------------------------------------------------------|
| Degree:              | Master of Applied Science                                                        |
| Title of Thesis:     | FPGA Technology Mapping for Fracturable Look-Up Table Minimization               |
| Examining Committee: | <b>Dr. Ash Parameswaran, P.Eng.</b><br>Professor of Engineering Science<br>Chair |

**Dr. Lesley Shannon, P.Eng.** Assistant Professor of Engineering Science Senior Supervisor

**Dr. Marek Syrzycki** Professor of Engineering Science Supervisor

**Dr. Glenn Chapman, P.Eng.** Professor of Engineering Science Internal Examiner

**Date Defended:** 

11 August 2011

# U SIMON FRASER UNIVERSITY

## Declaration of Partial Copyright Licence

The author, whose copyright is declared on the title page of this work, has granted to Simon Fraser University the right to lend this thesis, project or extended essay to users of the Simon Fraser University Library, and to make partial or single copies only for such users or in response to a request from the library of any other university, or other educational institution, on its own behalf or for one of its users.

The author has further granted permission to Simon Fraser University to keep or make a digital copy for use in its circulating collection (currently available to the public at the "Institutional Repository" link of the SFU Library website <www.lib.sfu.ca> at: <a href="http://ir.lib.sfu.ca/handle/1892/112>">http://ir.lib.sfu.ca/handle/1892/112></a>) and, without changing the content, to translate the thesis/project or extended essays, if technically possible, to any medium or format for the purpose of preservation of the digital work.

The author has further agreed that permission for multiple copying of this work for scholarly purposes may be granted by either the author or the Dean of Graduate Studies.

It is understood that copying or publication of this work for financial gain shall not be allowed without the author's written permission.

Permission for public performance, or limited permission for private scholarly use, of any multimedia materials forming part of this work, may have been granted by the author. This information may be found on the separately catalogued multimedia material and in the signed Partial Copyright Licence.

While licensing SFU to permit the above uses, the author retains copyright in the thesis, project or extended essays, including the right to change the work for subsequent purposes, including editing and publishing the work in whole or in part, and licensing other parties, as the author may desire.

The original Partial Copyright Licence attesting to these terms, and signed by this author, may be found in the original bound copy of this work, retained in the Simon Fraser University Archive.

Simon Fraser University Library Burnaby, BC, Canada

# Abstract

Modern commercial Field-Programmable Gate Array (FPGA) architectures contain lookup tables (LUTs) that can be "fractured" into two smaller LUTs. The potential to pack two LUTs into a space that could accommodate only one LUT in traditional architectures complicates FPGA technology mapping's resource minimization objective. Previous works introduced edge recovery techniques and the concept of LUT balancing, both of which produce mappings that pack into fewer fracturable LUTs. We combine these two ideas and evaluate their effectiveness for one commercial and four academic FPGA architectures, all of which contain fracturable LUTs. When combined, edge-recovery and LUT balancing yield a 9.0% to 16.1% reduction in fracturable LUT use, depending on the architecture. We also present a modified technology mapping algorithm called MO-Map that reduces fracturable LUT utilization by 9.7% to 17.2%.

# Acknowledgments

Thank you to my wonderful wife Diana. It is because of your unending love and support that I was able to finish my degree. To my parents, brother, and sister: thank you for believing that I would finish... eventually. Thanks to the many friends I have made throughout my graduate studies at Simon Fraser University for making the graduate school experience a friendly and fun one. Lastly, a big thank you to my supervisor, Dr. Lesley Shannon. You have been a wonderful person to work with and I am interminably indebted to you for the guidance and support you have given me.

I would also like to acknowledge the financial support and equipment that I have received from the following organizations that made my research possible: the Canadian Microelectronics Corporation, the Natural Sciences and Engineering Research Council, Xilinx, Altera, and Simon Fraser University.

# Contents

| Ар  | prova               | al                  | ii  |
|-----|---------------------|---------------------|-----|
| Ab  | strac               | t                   | iii |
| Ac  | know                | ledgments           | iv  |
| Co  | ontent              | S                   | v   |
| Lis | List of Tables ix   |                     | ix  |
| Lis | List of Figures xii |                     |     |
| Gl  | ossar               | y                   | XV  |
| 1   | Intro               | oduction            | 1   |
|     | 1.1                 | Motivation          | 2   |
|     | 1.2                 | Objective           | 3   |
|     | 1.3                 | Contributions       | 4   |
|     | 1.4                 | Thesis Organization | 5   |
| 2   | Back                | ground              | 6   |

### CONTENTS

|   | 2.1  | Field-Programmable Gate Array Architecture         | 6  |
|---|------|----------------------------------------------------|----|
|   |      | 2.1.1 Fracturable LUTs                             | 10 |
|   | 2.2  | FPGA CAD Tool Flow                                 | 12 |
|   | 2.3  | FPGA Technology Mapping                            | 14 |
|   |      | 2.3.1 Overview                                     | 15 |
|   |      | 2.3.2 FPGA Technology Mapping Objectives           | 17 |
|   |      | 2.3.3 General FPGA Technology Mapping Algorithm    | 18 |
|   |      | 2.3.4 Cut Enumeration                              | 18 |
|   |      | 2.3.5 Mapping for Minimum Depth                    | 20 |
|   |      | 2.3.6 Mapping for Minimum Area                     | 20 |
|   |      | 2.3.7 Deriving the Final Mapping                   | 22 |
|   | 2.4  | Complete Cut Enumeration Alternatives              | 23 |
|   | 2.5  | Technology Mapping for Fracturable LUTs            | 26 |
| 3 | Tech | nology Mapping for FLUT Minimization               | 28 |
|   | 3.1  | The Minimum Number of Fractruable LUTs             | 28 |
|   | 3.2  | Technology Mapping Techniques for Minimal          |    |
|   |      | Fracturable LUTs                                   | 31 |
|   | 3.3  | MO-Map: Multiple-Output Map                        | 33 |
| 4 | Exp  | erimental Methodology                              | 37 |
|   | 4.1  | Synthesis and Technology Mapping                   | 37 |
|   | 4.2  | Packing, Placement, and Routing Experimental Setup | 40 |
|   |      | 4.2.1 Academic Tool Flow                           | 40 |
|   |      | 4.2.2 Commercial Tool Flow                         | 44 |

#### CONTENTS

| 5  | Exp    | erimen  | tal Results                              | 46  |
|----|--------|---------|------------------------------------------|-----|
|    | 5.1    | Experi  | mental Results without LUT balancing     | 46  |
|    |        | 5.1.1   | Technology Mapping without LUT balancing | 47  |
|    |        | 5.1.2   | Packing without LUT balancing            | 50  |
|    | 5.2    | LUT E   | Salancing Experiments                    | 58  |
|    |        | 5.2.1   | Technology Mapping Results               | 58  |
|    |        | 5.2.2   | Packing Results                          | 67  |
|    | 5.3    | Placen  | nent and Routing Results                 | 75  |
|    |        | 5.3.1   | Maximum Operating Frequency              | 75  |
|    |        | 5.3.2   | Minimum Channel Width and Wirelength     | 77  |
|    | 5.4    | Estima  | ating the Impact on Silicon Area         | 85  |
| 6  | Con    | clusion | s and Future Work                        | 87  |
|    | 6.1    | Conclu  | usions                                   | 87  |
|    |        | 6.1.1   | Future Work                              | 90  |
| Bi | bliogi | raphy   |                                          | 92  |
| Aŗ | opend  | lix A F | 'LUT utilizations - no LUT balancing     | 99  |
| Aŗ | opend  | lix B L | UT distribution data                     | 107 |
| Aŗ | opend  | lix C F | 'LUT utilization - with LUT balancing    | 112 |
| Aţ | opend  | lix D V | PR Minimum Channel Width Geometric Means | 123 |
| Aŗ | opend  | lix E V | PR Wirelength Geometric Means            | 132 |

| Appendix F | Quartus II Fmax Geometric Means | 141 |
|------------|---------------------------------|-----|
|------------|---------------------------------|-----|

# **List of Tables**

| 4.1 | Benchmark suite circuits with baseline mapping statistics               | 41  |
|-----|-------------------------------------------------------------------------|-----|
| 5.1 | Runtime and LUT count of the mapped benchmark circuits                  | 48  |
| 5.2 | FLUT utilization for each tech-mapper/architecture combination          | 56  |
| 5.3 | LUT balancing Weight(6) and Weight(5) values that minimized average     |     |
|     | FLUT utilization for each tech-mapper/architecture combination          | 74  |
| 5.4 | Increase in minimum channel width for the benchmark suite packings that |     |
|     | have the greatest average FLUT minimization                             | 84  |
| 5.5 | Estimate of percent change in silicon area                              | 86  |
| A.1 | Benchmark circuit's FLUT utilization when mapped without LUT balanc-    |     |
|     | ing and packed for the M5 FPGA architecture                             | 99  |
| A.2 | Benchmark circuit's FLUT utilization when mapped without LUT balanc-    |     |
|     | ing and packed for the <i>M6</i> FPGA architecture                      | 101 |
| A.3 | Benchmark circuit's FLUT utilization when mapped without LUT balanc-    |     |
|     | ing and packed for the M7 FPGA architecture                             | 102 |
| A.4 | Benchmark circuit's FLUT utilization when mapped without LUT balanc-    |     |
|     | ing and packed for the M8 FPGA architecture                             | 103 |

| A.5         | Benchmark circuit's FLUT utilization when mapped without LUT balanc-          |
|-------------|-------------------------------------------------------------------------------|
|             | ing and packed for the Stratix II FPGA architecture                           |
| <b>B</b> .1 | ClassicMap LUT distribution data                                              |
| B.2         | WireMap LUT distribution data                                                 |
| B.3         | MO-Map LUT distribution data                                                  |
| <b>C</b> .1 | Benchmark suite's FLUT utilization geometric mean for mappings pro-           |
|             | duced with LUT balancing and packed for the M5 FPGA architecture 113          |
| C.2         | Benchmark suite's FLUT utilization geometric mean for mappings pro-           |
|             | duced with LUT balancing and packed for the M6 FPGA architecture 115          |
| C.3         | Benchmark suite's FLUT utilization geometric mean for mappings pro-           |
|             | duced with LUT balancing and packed for the M7 FPGA architecture 117          |
| C.4         | Benchmark suite's FLUT utilization geometric mean for mappings pro-           |
|             | duced with LUT balancing and packed for the M8 FPGA architecture 119          |
| C.5         | Benchmark suite's FLUT utilization geometric mean for mappings pro-           |
|             | duced with LUT balancing and packed for the Stratix II FPGA architecture. 121 |
| D.1         | Benchmark suite's minimum channel width (MCW) geometric mean for              |
|             | mappings produced with LUT balancing and packed for the M5 FPGA ar-           |
|             | chitecture                                                                    |
| D.2         | Benchmark suite's minimum channel width (MCW) geometric mean for              |
|             | mappings produced with LUT balancing and packed for the M6 FPGA               |
|             | architecture                                                                  |

| D.3 | Benchmark suite's minimum channel width (MCW) geometric mean for       |    |
|-----|------------------------------------------------------------------------|----|
|     | mappings produced with LUT balancing and packed for the M7 FPGA        |    |
|     | architecture                                                           | 28 |
| D.4 | Benchmark suite's minimum channel width (MCW) geometric mean for       |    |
|     | mappings produced with LUT balancing and packed for the M8 FPGA ar-    |    |
|     | chitecture                                                             | 30 |
| E.1 | Benchmark suite's wirelength geometric mean for mappings produced with |    |
|     | LUT balancing and packed for the <i>M5</i> FPGA architecture           | 33 |
| E.2 | Benchmark suite's wirelength geometric mean for mappings produced with |    |
|     | LUT balancing and packed for the <i>M6</i> FPGA architecture           | 35 |
| E.3 | Benchmark suite's wirelength geometric mean for mappings produced with |    |
|     | LUT balancing and packed for the M7 FPGA architecture                  | 37 |
| E.4 | Benchmark suite's wirelength geometric mean for mappings produced with |    |
|     | LUT balancing and packed for the <i>M</i> 8 FPGA architecture          | 39 |
| F.1 | Benchmark suite's maximum operating frequency geometric mean for       |    |
|     | mappings produced with LUT balancing and packed for the Stratix        |    |
|     | II FPGA architecture                                                   | 42 |

# **List of Figures**

| 2.1  | An example block diagram of an island-style FPGA.                        | 7  |
|------|--------------------------------------------------------------------------|----|
| 2.2  | A Basic Logic Element (BLE), which contains a single LUT and flip-flop   |    |
|      | pair                                                                     | 8  |
| 2.3  | A Complex Logic Block (CLB) that contains a cluster of BLEs              | 9  |
| 2.4  | An SRAM-based LUT with a <i>K</i> of 3                                   | 10 |
| 2.5  | Xilinx Virtex-5 fracturable LUT block diagram.                           | 11 |
| 2.6  | FLUT models for fractured mode and regular mode operation                | 12 |
| 2.7  | FPGA CAD Tool Flow.                                                      | 13 |
| 2.8  | An example Boolean logic function to be technology mapped for an FPGA.   | 16 |
| 2.9  | Top level pseudo-code describing a general cut-based FPGA technology     |    |
|      | mapping algorithm.                                                       | 19 |
| 2.10 | Exact Area computation pseudo-code.                                      | 22 |
| 2.11 | Final mapping derivation pseudo-code                                     | 23 |
| 2.12 | Top level pseudo-code for the priority cuts technology mapping algorithm | 25 |
| 3.1  | Potential LUT pairings to be implemented in a fractured mode FLUT with   |    |
|      | a <i>K</i> of 6 and a <i>M</i> of 5                                      | 30 |

| 3.2 | Top level pseudo-code for the priority cuts technology mapping algorithm  |    |
|-----|---------------------------------------------------------------------------|----|
|     | with MO-Map.                                                              | 34 |
| 3.3 | Pseudo-code for the MO-Map area recovery function.                        | 36 |
| 4.1 | A generic version of the CLB used in the four academic FPGA architec-     |    |
|     | tures targeted by VPR with AAPack.                                        | 42 |
| 5.1 | LUT distributions for ClassicMap, WireMap, and MO-Map without LUT         |    |
|     | balancing.                                                                | 49 |
| 5.2 | Percent reduction in FLUT usage relative to the baseline for each circuit |    |
|     | in the benchmark suite. Packed for the M5 FPGA architecture using VPR     |    |
|     | with AAPack.                                                              | 51 |
| 5.3 | Percent reduction in FLUT usage relative to the baseline for each circuit |    |
|     | in the benchmark suite. Packed for the M6 FPGA architecture using VPR     |    |
|     | with AAPack.                                                              | 52 |
| 5.4 | Percent reduction in FLUT usage relative to the baseline for each circuit |    |
|     | in the benchmark suite. Packed for the M7 FPGA architecture using VPR     |    |
|     | with AAPack.                                                              | 53 |
| 5.5 | Percent reduction in FLUT usage relative to the baseline for each circuit |    |
|     | in the benchmark suite. Packed for the M8 FPGA architecture using VPR     |    |
|     | with AAPack.                                                              | 54 |
| 5.6 | Percent reduction in ALM usage relative to the baseline for each circuit  |    |
|     | in the benchmark suite. Packed for the Stratix II FPGA architecture using |    |
|     | Quartus II                                                                | 55 |
| 5.7 | LUT distributions for ClassicMap with different <i>Weight(6)</i> values   | 59 |

| 5.8  | LUT distributions for WireMap with different <i>Weight(6)</i> values             | 60 |
|------|----------------------------------------------------------------------------------|----|
| 5.9  | LUT distributions for MO-Map with different <i>Weight(6)</i> values              | 61 |
| 5.10 | LUT distributions for ClassicMap with varying $Weight(5)$ and $Weight(6)$        | 64 |
| 5.11 | LUT distributions for WireMap with varying <i>Weight(5)</i> and <i>Weight(6)</i> | 65 |
| 5.12 | LUT distributions for MO-Map with varying <i>Weight(5)</i> and <i>Weight(6)</i>  | 66 |
| 5.13 | Academic architectures FLUT resource utilization for mappings with vary-         |    |
|      | ing <i>Weight</i> (6)                                                            | 68 |
| 5.14 | Stratix II ALM resource utilization for mappings with varying Weight(6).         | 69 |
| 5.15 | Academic architectures FLUT resource utilization for mappings with vary-         |    |
|      | ing Weight(5) and Weight(6)                                                      | 71 |
| 5.16 | Stratix II ALM resource utilization for mappings with varying Weight(5)          |    |
|      | and <i>Weight</i> (6)                                                            | 72 |
| 5.17 | Average maximum operating frequency reported by Quartus II                       | 76 |
| 5.18 | Academic architecture minimum channel widths for mappings with vary-             |    |
|      | ing <i>Weight</i> (6)                                                            | 79 |
| 5.19 | Academic architecture minimum channel widths for mappings with vary-             |    |
|      | ing Weight(5) and Weight(6)                                                      | 80 |
| 5.20 | Academic architecture wirelengths for mappings with varying <i>Weight(6)</i>     | 81 |
| 5.21 | Academic architecture wirelengths for mappings with varying Weight(5)            |    |
|      | and <i>Weight</i> (6)                                                            | 82 |

# Glossary

| AAPack | Architecture Aware Packer               |
|--------|-----------------------------------------|
| AF     | Area Flow                               |
| ALM    | Adaptive Logic Module                   |
| ASIC   | Application Specific Integrated Circuit |
| BLE    | Basic Logic Element                     |
| BLIF   | Berkeley Logic Interchange Format       |
| CAD    | Computer Aided Design                   |
| CLB    | Complex Logic Block                     |
| Fmax   | Maximum Operating Frequency             |
| FPGA   | Field-Programmable Gate Array           |
| HDL    | Hardware Description Language           |
| I/O    | Input and Output                        |
| IC     | Integrated Circuit                      |
| LAB    | Logic Array Block                       |
| MCNC   | Microelectronics Center North Carolina  |
|        |                                         |

MCW Minimum Channel Width

### GLOSSARY

| MO-Map | Multiple-Output Map                     |
|--------|-----------------------------------------|
| QUIP   | Quartus II University Interface Program |
| SRAM   | Static Random Access Memory             |
| VPR    | Versatile Place and Route               |
| VQM    | Verilog Quartus Mapping                 |

# Chapter 1

# Introduction

Field-Programmable Gate Arrays (FPGAs) are reconfigurable integrated circuits that have traditionally implemented Boolean logic using *look-up tables* (LUTs). A LUT can implement any function with up to *K* inputs (a K-LUT), where *K* is an architectural parameter. Technology mapping (tech-mapping) is the process of converting a technology-independent netlist into a netlist composed solely of primitive elements available for implementation on a target device. The resulting netlist is referred to as a *mapping*. Performing tech-mapping for a FPGA primarily entails mapping logic into LUTs (mapping for other FPGA elements, such as memories, multipliers, etc, also occurs).

One goal of FPGA tech-mapping is to minimize the number of LUTs in the mapping, i.e. the *area* of the mapping. Modern commercial FPGA architectures use *Fracturable LUTs* (FLUTs) instead of basic LUTs. A FLUT can operate as either a single normal LUT, or as two smaller LUTs with input-sharing constraints. This "fracturability" feature ensures that the number of FLUTs utilized will always be less than or equal to the number of LUTs in the mapping. Thus, the number of LUTs is not an accurate metric for evaluating the *area* of a mapping for FPGA architectures with FLUTs. Technology mapping techniques that

minimize the number of FLUTs, not LUTs, are desirable for modern FPGA architectures.

### **1.1** Motivation

Modern commercial FPGAs from Xilinx [1] and Altera [2] feature FLUTs instead of the traditional LUT. A FLUT is a structure that can operate as either a single K-LUT, or be "fractured" into two (K-1)-LUTs with input-sharing constraints. The two (K-1)-LUTs only have access to a fixed number of unique inputs, *M*, which necessitates the two (K-1)-LUTs either have inputs in common or unused input pins. The LUTs in a mapping are *packed* into FLUTs, either individually or in pairs, during later stages of the FPGA Computer Aided Design (CAD) tool flow.

The fact that two LUTs can potentially pack into a single FLUT ensures that the number of FLUTs utilized on an FPGA is always less than or equal to the number of LUTs in the mapping. Thus, the number of LUTs in the mapping is no longer a definitive measure of how many logic resources a design will occupy on an FPGA. Although the number of LUTs in a mapping is still important, the number of inputs each LUT in a mapping uses is also consequential. LUTs that use the majority of their *K* inputs will be harder to pack together into the two "fractured" (K-1)-LUTs of a FLUT. When technology mapping for a FLUT-based FPGA architecture, the *area* metric "number of LUTs" is flawed. It is the mapping that packs into smallest number of FLUTs that uses the least number of logic resources. Therefore, technology mapping algorithms that produce mappings that pack into fewer FLUTs are desirable.

## 1.2 Objective

Two previous works have been shown to produce mappings that pack into fewer FLUTs. Modifying the cost functions in the technology mapping algorithm to discourage the selection of LUTs that use all *K* of their inputs is called *LUT balancing* [3]. LUT balancing was found to provide benefit when mapping for Altera Stratix II FPGAs [4]. Another option is the WireMap technology mapper [5][6]. WireMap used edge-recovery heuristics to minimize the number of wires in a mapping and was shown to reduce FLUT utilization for Xilinx Virtex-5 FPGAs by virtue of generating mappings with reduced routing demands.

Using LUT balancing or WireMap during technology mapping causes the final mapping to contain more LUTs than usual. However, the LUTs in the mapping tend to pack into FLUTs more efficiently, resulting in lower logic resource usage if the target FPGA architecture has FLUTs. Although both techniques have the same advantage (a more "packable" mapping) and disadvantage (a greater number of LUTs in the mapping), they are implemented using different mechanisms in the technology mapping algorithm. The mechanisms are compatible, raising the question of whether or not LUT balancing and WireMap are complementary and can be used in combination to further reduce the FLUT count.

In the previous works, the effectiveness of WireMap was demonstrated using the Xilinx Virtex-5 while LUT balancing's effects were shown using the Altera Stratix II. One of the many differences between these two architectures is the number of unique inputs available to their FLUTs (The M parameter). Therefore, we are also interested in how the value of M affects the packability of our mappings.

The objective of this research is to identify technology mapping methods that minimize FLUT usage after packing. We adopt a three-pronged approach to achieving this goal:

• Study whether the edge-recovery techniques of WireMap can be combined with the

concept of LUT Balancing to enhance FLUT minimization.

- Evaluate the effects of different FLUT input-sharing constraints (i.e. *M* value) on a mapping's packability.
- Investigate improvements to technology mapping algorithms for FLUT minimization.

### **1.3** Contributions

This thesis can be divided into three main contributions:

- Combining WireMap with our LUT balancing schemes and analyzing the results to find the best parameters for FLUT minimization.
- Quantification of the interaction between the *M* parameter and a mappings packability.
- An enhancement to the tech-mapping algorithm, called Multiple-Output Map (MO-Map), that is combined with WireMap and LUT balancing to further reduce FLUT usage.

We explore the relative improvements gained by combining WireMap and our implementation of LUT balancing. The quality of a mapping is evaluated using the reduction in FLUT usage after packing the mapping. The mappings are packed for four FLUT-based FPGA architectures with different M values using a new version of the Versatile Place and Route (VPR) software that includes the Architecture Aware Packer (AAPack) [7][8]. Two of these academic architectures emulate the FLUTs found in commercial FPGAs. In addition, we use Quartus University Interface Program (QUIP) [9] to run the mappings through Altera's Quartus II software targeting a Stratix II [4] FPGA. When WireMap and LUT balancing are used, the average percent reduction in FLUT utilization, relative to mappings produced without WireMap or LUT balancing, ranged from 6.9% to 16.1% across the architectures. When MO-Map is used, the average percent reduction in FLUT usage is between 9.0% and 17.2% for the various architectures.

### **1.4 Thesis Organization**

The remainder of the thesis is structured as follows. Chapter 2 provides background on FPGA architecture and the CAD tool flow, particularly tech-mapping. Chapter 3 describes our LUT Balancing implementation and MO-Map. Chapter 4 explains our experimental methodology. Chapter 5 presents the experimental results. Chapter 6 concludes the thesis and outlines future work.

# Chapter 2

# Background

This chapter presents background material related to the contributions of this thesis. We begin by giving an overview of FPGA architecture and the FPGA CAD tool flow. We then outline common terminology and concepts used in FPGA technology mapping algorithms. Finally, prior work on FPGA technology mapping is discussed.

## 2.1 Field-Programmable Gate Array Architecture

FPGAs are integrated circuits that are manufactured to be reconfigurable. Reconfigurability is achieved by using static random access memory (SRAM) elements to specify the logic functions implemented by LUTs and routing connectivity. A SRAM-based FPGA can be configured to implement some desired circuit functionality, and reconfigured repeatedly as required by the designer. This reconfigurability is a notable advantage of a FPGA when compared to an Application Specific Integrated Circuit (ASIC). A design implemented on an ASIC should be able to operate faster, use less power, and occupy a smaller area than a FPGA implementation [10]. Although, the ASIC will be significantly more expensive to



Figure 2.1: An example block diagram of an island-style FPGA.

create and have a slower time to market.

This thesis focuses on the class of FPGA architectures known as *island-style* FPGAs, an example of which is depicted in Figure 2.1. An island-style FPGA consists of a grid of *Complex Logic Blocks* (CLBs) set in an interconnect framework. The CLBs contain LUTs and flip-flops to perform computation tasks while the interconnect framework consists of many programmable wires used to connect the CLBs together. Around the periphery of the CLB grid are Input/Output (I/O) blocks.



Figure 2.2: A Basic Logic Element (BLE), which contains a single LUT and flip-flop pair.

An island-style FPGA that has identical CLBs throughout is a *homogeneous* FPGA architecture. It is common in modern FPGA architectures to include specialized circuitry, referred to as *hard blocks*, in addition to the general purpose CLBs. Some examples of specialized circuits commonly found in commercial FPGAs are memories, multipliers, and multi-gigabit transceivers. An FPGA architecture that includes these additional circuits is a *heterogeneous* architecture.

Figure 2.2 shows a *Basic Logic Element* (BLE), which contains a single LUT and flipflop pair along with a 2-1 multiplexor that determines whether the registered or unregistered LUT output drives the output. A LUT can implement an arbitrary Boolean logic function with up to *K* inputs, where *K* is an architectural parameter (*K* is four in Figure 2.2). Flipflops provide the memory elements required for implementing sequential circuits. It is common for the CLBs of academic FPGA architectures to contain some number of BLEs.

Figure 2.3 illustrates a CLB that contains a *cluster* of BLEs. CLBs contain LUTs and flip-flops, usually in the form of BLEs, along with the routing elements required to connect to the FPGA's interconnect framework. A CLB may also contain other special purpose circuitry, such as carry-chain logic. The organization of LUTs and flip-flops within a CLB varies greatly between different FPGA architectures. A common arrangement is for the



Figure 2.3: A Complex Logic Block (CLB) that contains a cluster of BLEs.

CLB to contain a cluster of BLEs along with fast local interconnect connecting the BLEs in the cluster [11].

One example of a how a LUT is constructed is shown in Figure 2.4. Here we have an SRAM-based LUT with K equal to 3. The "SRAM Configuration Memory" is a bank of  $2^K$  SRAM bits that is programmed with the desired Boolean logic function's truth table when the FPGA is configured. The K select lines of the multiplexor tree are the LUT's inputs and choose which configuration SRAM bit value is propagated to the LUT's output.

The FPGA's interconnect framework is comprised of wire segments and switches. The switches are programmable and control which wire segments are connected together as well



Figure 2.4: An SRAM-based LUT with a *K* of 3.

as which wire segments connect to CLBs. The wire segments vary in length and run in both horizontal and vertical directions. Depending on the architecture, the wire segments may be uni-directional or bi-directional links. Modern FPGAs use uni-directional links because they have been found to be faster while occupying a similar area footprint [12].

#### 2.1.1 Fracturable LUTs

As of 2011, modern commercial FPGAs, such as the Xilinx Virtex-5 and the Altera Stratix II, have *fracturable look-up tables* (FLUTs). A FLUT is a LUT with the ability to be *fractured*, which means it can function as either a single large LUT (*regular mode*) or two smaller LUTs (*fractured mode*). A FLUT can be constructed using two LUTs and a 2-to-1 multiplexor. As an example, Figure 2.5 shows a block diagram of the FLUT found in the Xilinx Virtex-5 FPGA [13][14][15].

The Virtex-5 FLUT is a "dual-output 6-LUT". The FLUT has six inputs, two outputs, and encapsulates two 5-LUTs as well as a 2-to-1 multiplexor. When the FLUT is operated



Figure 2.5: Xilinx Virtex-5 fracturable LUT block diagram.

in regular mode it functions as a standard 6-LUT (K is six for the Virtex-5). To operate as a 6-LUT, one 5-LUT implements the logic function assuming In1 is high and the other 5-LUT implements the function assuming In1 is low. The In1 signal selects which 5-LUT drives Out1, the output of the 6-LUT, and the Out2 signal is unused. If the FLUT is operated in fractured mode, the In1 signal is programmed to always select the output of the top 5-LUT as the driver of Out1 and the bottom 5-LUT drives Out2. Thus, in fractured mode each FLUT output is driven by one of the 5-LUTs.

Since the Virtex-5 FLUT only has six inputs, and one of those inputs is dedicated to the multiplexor, the two 5-LUTs may only have five unique inputs between them. Clearly, this imposes a constraint upon which LUTs can be packed into a FLUT operating in fractured mode. Like the Virtex-5, the Altera Stratix II FLUT [16][3][4] has a *K* equal to six, meaning it operates as a 6-LUT in regular mode. However, the Stratix II FLUT has eight unique inputs that can be used by the two fractured mode 5-LUTs, instead of only five.

In this thesis, we use the parameter M to specify the number of unique inputs a FLUT



Figure 2.6: FLUT models for fractured mode and regular mode operation.

has when operating in fractured mode (M is five for the Virtex-5 FLUT and eight for the Stratix II.). We also assume that the two fractured mode LUTs have K minus one inputs. Figure 2.6 depicts the generic models we use for FLUTs operating in fractured and regular mode.

### 2.2 FPGA CAD Tool Flow

Circuits are typically specified in a Hardware Description Language (HDL) such as Verilog or VHDL. To convert an HDL circuit description into a configuration bitstream for an FPGA, the HDL is passed through a CAD tool flow. The steps that compose a typical FPGA CAD tool flow are shown in Figure 2.7. The academic software programs (i.e. programs for which the source code is available) - ODIN II [17], ABC [18], T-VPack [19], AAPack [7][8], and VPR [20] - that can perform each of these operations are included in brackets beneath each step in the figure.

The first step of the FPGA CAD flow is *HDL elaboration*, where the HDL is converted into a technology-independent netlist. Next *technology independent synthesis* is performed to optimize the netlist. Once optimizations are complete, *technology mapping* is performed,



Figure 2.7: FPGA CAD Tool Flow.

which maps the technology-independent netlist into a netlist of primitives available on the FPGA (i.e. LUTs, flip-flops, hard blocks, etc). This netlist of primitives is called a mapped netlist, or *mapping*. This thesis is primarily concerned with the technology mapping stage of the CAD flow.

After technology mapping is the *packing* or *clustering* stage. During packing, the primitives in the mapping (LUTs and flip-flops) are grouped into CLBs. If the FPGA architecture has FLUTs, then part of the packing process involves packing LUTs into FLUTs. After packing is *placement*, where the elements of the packed netlist (CLBs, hard blocks, I/Os) are assigned to specific locations on the FPGA. Finally, *routing* occurs to determine a configuration of the FPGA's interconnect framework that will to connect all the elements of the system together.

Packing is the stage of the CAD flow when LUTs are packed into FLUTs and is of particular interest to our work because FLUT utilization numbers are available after packing. The older academic clustering tool T-VPack is not capable of packing LUTs into FLUTs and is therefore not used in our experiments. However, the recently introduced AAPack tool is capable. AAPack has been incorporated into VPR as part of the Verilog-to-Routing project [21], and is the only academic FPGA CAD software we are aware of that supports FPGA architectures with FLUTs during packing.

In addition to the academic software tools mentioned previously, Altera and Xilinx provide a CAD tool suite for use with their products. It is possible to integrate portions of the academic tool flow with Altera's Quartus II software suite using the functionality provided by QUIP [9]. Methods also exist for interacting with the Xilinx CAD tools [22][23][24].

### 2.3 FPGA Technology Mapping

For LUT-based FPGAs, the technology mapping problem is to cover a Boolean network using K-LUTs to obtain a functionally equivalent K-LUT network. The conventional librarybased method of technology mapping used for ASICs is inappropriate for LUT-based FP-GAs due to the large number of functions a LUT can implement. In this section, we define terminology related to FPGA technology mapping, outline FPGA tech-mapping objectives, and provide a description of a general FPGA technology mapping algorithm based on previous works in the field.

#### 2.3.1 Overview

A Boolean network can be represented as a Directed Acyclic Graph (DAG). The vertices (nodes) of the DAG represent logic gates and the directed edges correspond to wires connecting the gates. The DAG also has *primary inputs* (PIs) and *primary outputs* (POs) representing the pins of the circuit. If the circuit is sequential, it will include registers. Each register is treated as an additional PI and PO in the DAG. The DAG is called the *subject graph*, and is the input to a technology mapping tool (*tech-mapper*).

The *AND-Inverter Graph* (AIG) format is a useful way of presenting a *subject graph* for synthesis and technology mapping [25]. Boolean logic in an AIG is implemented using only Inverters and 2-input AND gates. As an example, consider the Boolean logic in Equation 2.1. Figure 2.8(a) illustrates the Boolean network for the equation, Figure 2.8(b) shows the network converted to an AIG, and Figure 2.8(c) is the DAG representation.

$$Z = A + B + (C \cdot D) \tag{2.1}$$

FPGA technology mapping commonly employs the notion of *cuts*. A cut is a set of *leaf* nodes (*leaves*) in the subject graph associated with a particular *root* node. A set of leaf nodes constitutes a cut of a root node if all paths from the PIs to the root node pass through one or more leaf nodes. A cut is said to *cover* the root node and every node on the paths between the leaves and the root, but not the leaves themselves. Figure 2.8(d) identifies the three cuts of the DAG node  $n_3$  from Figure 2.8(b). Each quadrangle with a dotted line corresponds to a cut. All nodes covered by the cut are contained within the quadrangle. Each node that has a directed edge going into the quadrangle is a leaf of the cut. The node  $n_3$  is the root node of the three cuts. The three cuts are  $\{A, B, n_2\}$ ,  $\{C, D, n_1\}$ , and  $\{n_1, n_2\}$ .



Figure 2.8: An example Boolean logic function to be technology mapped for an FPGA.

 $n_2$ }.

If a cut has K or less leaf nodes, the cut is *K-feasible*. A K-feasible cut can be implemented using a K-LUT. A tech-mapper computes K-feasible cuts for all nodes in the subject graph, then selects a number of these cuts to form a mapped circuit (i.e. mapping) of the subject graph. A mapping is a network of K-feasible cuts (i.e. LUTs) that covers all of the nodes in the subject graph.

### 2.3.2 FPGA Technology Mapping Objectives

The primary optimization goal of LUT-based FPGA technology mapping is typically to minimize the mapped circuit's *delay*. The *unit delay* model, which assumes that each LUT on a path imposes a unit of delay, is common during technology mapping because no routing details are known at this early stage of the CAD tool flow. Under the unit-delay model, a mapping's delay is equal to its *depth*. The depth of a mapping is determined by the path from a PI to a PO that has the largest number of LUTs on it. The number of LUTs on that path is the depth. Thus, technology mapping for depth minimization under the unit-delay model is equivalent to mapping for minimum delay. FlowMap was the first algorithm to optimally solve the LUT-based FPGA technology mapping problem for depth minimization in polynomial time based using network flow computation [26].

Another common objective is to minimize the *area* of the mapped network. The area of a mapping is measured as the number of LUTs included in the mapping. LUT minimization has been shown to be a non-deterministic polynomial-time hard (NP-hard) problem [27]. This reason LUT count is used as an area metric, as opposed to silicon area, is that the FPGA is already fabricated and the size of each LUT is constant. The LUT count determines how many logic resources on the FPGA must be used to implement the mapping.

Technology mapping algorithms often combine these two objectives and map for minimum area under delay constraints. With this approach, the first priority is finding the minimum mapping depth (delay), and then minimizing the mapping's area while maintaining this depth. A downside to this approach is *area duplication*, where more LUTs are used than strictly necessary in order to minimize the depth of the circuit at the cost of additional area. Algorithms that can perform these tasks include CutMap [28], DAOmap [29], IMap [30], and the LUT-based FPGA technology mapping tools included in ABC [31][32].

Other technology mapping algorithms, such as PowerMap [33], PowerMinMap [34], Emap [35] and DVmap [36], aim to minimize power, which is also an NP-hard problem [37]. Routability is another objective tackled by RMap [38] and WireMap [5][6].

#### 2.3.3 General FPGA Technology Mapping Algorithm

This section reviews a general cut-based FPGA technology mapping algorithm based on previous works [26][29][31]. The top level pseudo-code for the algorithm is provided in Figure 2.9. The algorithm operates on a subject graph in AIG form, aig, and maps to LUTs with at most K inputs. The objective of the algorithm is to first minimize the depth of a circuit, and then map for minimal area (i.e. LUT count) while maintaining the depth.

#### 2.3.4 Cut Enumeration

The *cut-set* of a node, *n*, is the set of all enumerated K-feasible cuts that have *n* as the root node. The *EnumerateCuts* function of Figure 2.9 visits each node in the AIG in topological order and computes the cut-set of the node as per the methods presented in previous works [39][40][32]. The cut-set of a node is computed by considering all combinations of the node's *fanins* cut-sets along with the *trivial cut* of the node. The fanins of a node, *n*, are

```
TechnologyMap( aig, K )
{
    // compute K-feasible cuts for each node
    EnumerateCuts( aig, K );
    // select min-depth cut as the representative cut for each node
    MapMinDepth( aig, K );
    // select min-area cut as representative for non-critical nodes
    MapAreaRecover( aig, K );
    // determine set of cuts that will be LUTs in the mapping
    DeriveFinalMapping( aig, K );
}
```

Figure 2.9: Top level pseudo-code describing a general cut-based FPGA technology mapping algorithm.

the nodes in the graph that have a directed edge pointing to n (the *fanouts* are the nodes n has directed edges pointing to). The trivial cut of a node, n, is composed solely of the node itself.

To explain the cut computation procedure, let *A* and *B* be two cut-sets and  $\Diamond$  be the operator for creating a new set of *K*-feasible cuts from two cut-sets. The operation  $A \Diamond B$  is defined as:

$$A\Diamond B = \{u \cup v | u \in A, v \in B, |u \cup v| \le K\}$$
(2.2)

Now let the cut-set of a node, n, be denoted by  $\Phi(n)$  and let  $n_1$  and  $n_2$  be the famins of n.  $\Phi(n)$  is computed using Equation 2.3.

$$\Phi(n) = \left\{ \begin{array}{ll} \{\{n\}\} & \text{if } n \in \mathrm{PI} \\ \{\{n\}\} \cup \Phi(n_1) \Diamond \Phi(n_2) & \text{otherwise} \end{array} \right\}$$
(2.3)

Traversing the graph in topological order ensures that the cut-sets of the famins,  $\Phi(n_1)$
and  $\Phi(n_2)$ , have been computed prior to the cut computations for *n*.

### 2.3.5 Mapping for Minimum Depth

Once all the cuts have been computed and stored by the *EnumerateCuts* function of Figure 2.9, the *MapMinDepth* function is run to find the minimum depth of the mapping. Again the AIG graph is traversed in a topological order, at each node the cuts of the cut-set are compared against each other and the one with the minimum depth is selected as the *representative cut* of the node. The representative cut of a node is the "best" cut according to some optimization objective, in this case depth. Frequently, multiple cuts in the cut-set will have equivalent depth. In this case, additional cost functions are computed in order to break the tie and select a representative cut.

The depth of a cut under the unit delay model is equal to one plus the largest depth of its leaf's representative cuts. A PI node's depth is zero as its cut-set consists only of the trivial cut, and thus has no leaves. The PO node with the largest depth determines the depth of the mapping, which is what we are trying to minimize when performing depth optimal technology mapping. If all possible cuts are enumerated for all nodes in the graph and the representative cut of each node is the cut in the cut-set with the smallest depth, then the mapping's depth is guaranteed to be optimal [26].

#### 2.3.6 Mapping for Minimum Area

The *MapAreaRecover* function of Figure 2.9 is run once the minimum depth of the circuit has been determined. This is done to change the representative cuts of nodes with non-critical depth requirements to minimize the number of LUTs in the mapping. Unlike depth, the optimal area of the mapping is not determined due to the NP-hard nature of the problem.

Instead, heuristics are used to try and minimize area in a reasonable amount of time.

As in the *MapMinDepth* function, the graph is traversed in a topological order and the cuts in each cut-set are compared. This time a cost function that measures area is used instead of depth as the basis for comparison when determining the new representative cut. To ensure that the circuit depth does not degrade, the new representative cut's depth cannot exceed the node's maximum depth value, which was determined during the *MapMinDepth* function call. Multiple passes of the graph may be performed with different area cost functions.

The two cost functions used in ABC for evaluating the area of cuts are *Area Flow* and *Exact Area* [31][32]. Both functions include a *Weight()* function, which returns the base cost of a cut depending upon how many leaves the cut has. By default, *Weight()* returns 1.0 irregardless of the number of leaves.

The Area Flow (AF) [30] (*effective area* [39]) of a cut is used to give a global view of the area of a cut. The Area Flow of a cut, *c* is computed using Equation 2.4,

$$AF(c) = Weight(nLeaves(c)) + \sum_{i} \frac{AF(BestCut(Leaf_i(c)))}{nEstFanouts(Leaf_i(c))}$$
(2.4)

where  $BestCut(Leaf_i(c))$  is the representative cut of the *i*-th leaf of *c* and  $nEstFanouts(Leaf_i(c))$  is the estimated number of fanouts the *i*-th leaf of *c* will have in the mapping. If  $nEstFanouts(Leaf_i(c))$  is zero, then the denominator in Equation 2.4 is set to one to avoid division by zero.

The Exact Area of a cut provides a local view of the area of a cut. Exact Area is calculated by summing the *Weight()* of all cuts added to the mapping as a result of including *c*. This computation is recursive and requires keeping a *reference counter* for each node that counts how many times the node is used in the current mapping. Pseudo-code for the

```
float ComputeExactArea( cut c )
{
    // set the base area of the cut
    float Area = Weight(nLeaves(c));
    foreach leaf of c
    {
        // increment the leaf's reference counter
        RefCnt(leaf)++;
        // recurse if the leaf not yet part of the mapping
        if ( RefCnt(leaf) == 1 )
            Area += ComputeExactArea(BestCut(leaf));
    }
    // return the exact area of the cut c
    return Area;
}
```

Figure 2.10: Exact Area computation pseudo-code.

Exact Area calculation of a cut, *c*, is given in Figure 2.10. After the computation, another recursive function must be called to reset the reference counters to their previous values if the cut is not included in the mapping.

#### **2.3.7** Deriving the Final Mapping

The final step in our general FPGA technology mapping algorithm is the *DeriveFinalMapping* function. In this function, a set of representative cuts, which together cover all nodes in the DAG, is selected. This set of cuts forms the final mapping that is output by the techmapper (recall that a K-feasible cut can be implemented by a LUT). Pseudo code for the *DeriveFinalMapping* function is shown in Figure 2.11.

The *DeriveFinalMapping* function calls the *AddToMapping* function for each PO. The *AddToMapping* function adds the representative cut of the PO to the mapping as a LUT,

```
DeriveFinalMapping( aig, K )
{
      // loop for all PO's
      foreach PO in aig
           AddToMapping(PO);
}
// function to add the representative cut of a node to the mapping
AddToMapping( node n )
{
      // cut variable
      cut c = BestCut(n);
      // check if we should add this node
      if ( !( InMapping(n) ) && !( IsPI(n) ) )
      {
            // add the representative cut of this node to the mapping
            AddLutToMapping(c);
            // recurse for the leaves
            foreach leaf in c
                  AddToMapping(leaf);
      }
}
```

Figure 2.11: Final mapping derivation pseudo-code.

and then recursively calls itself for all leaves of the representative cut that are not already part of the mapping or a PI.

### 2.4 Complete Cut Enumeration Alternatives

For a circuit with m nodes, the number of K-feasible cuts for a node can be as large a  $O(m^K)$  [41]. Computing and storing all of the cuts for each node in a circuit can be time consuming and memory intensive. A number of techniques have been proposed to handle the large number of cuts that may be enumerated for larger circuits and high K values.

One approach is to perform cut ranking and pruning [39]. In this approach, cuts are

ranked according to the current cost function and the cuts that rank so poorly that they are unlikely to generate "good" cuts for other nodes are discarded (i.e. "pruned"). The maximum number of cuts that each node is allowed to store can also be capped, typically at some large number (e.g. 2000).

Another approach is the use of *factor cuts* [31]. The factor cuts of a node are a subset of the cut-set. Using factor cuts, it is possible to generate the other cuts in the cut-set when needed. Factor cuts were found to produce better delays and shorter run-times than conventional cut enumeration when the number of cuts each node is allowed to store is capped.

The notion of *priority cuts* [32] can be used to dramatically reduce the runtime and memory footprint of an FPGA tech-mapper. Priority cuts places a small cap (e.g. 8) on the number of cuts that can be stored for each node. To compensate for the small number of cuts generated, additional mapping passes are performed. The additional mapping passes use a variety of primary cost functions and tie-breaker cost functions when ranking the generated cuts. The benefit of priority cuts is reduced runtime because fewer cuts are generated and ranked, and a smaller memory footprint as fewer of the enumerated cuts are stored. A downside of this approach (and other approaches that do not perform complete cut enumeration) is that the algorithm cannot guarantee depth optimality. However, in practice the minimum depth found is often the same as that of a depth-optimal algorithm.

Figure 2.12 gives pseudo code for the priority cuts mapping algorithm. This pseudo code is a replacement for the general technology mapping pseudo code of Figure 2.9. In the general algorithm, cuts were enumerated only once using the *EnumerateCuts* function and then representative cuts were selected for each node using the *MapMinDepth* and *MapAreaRecover* functions. Unlike the general algorithm, the priority cuts tech-mapper

```
PriorityCutsMap( aig, K )
{
    // perform multiple mapping passes optimizing for Depth
    MappingPassDelay( MinNumInputs );
    MappingPassDelay( AreaFlow );
    // perform multiple mapping passes optimizing for Area Flow
    for ( i = 0 ; i < numAreaFlowPasses ; i++ ) {
        MappingPassArea( Area Flow );
    }
    // perform multiple mapping passes optimizing for Exact Area
    for ( i = 0 ; i < numExactAreaPasses ; i++ ) {
        MappingPassArea( ExactArea );
    }
    // determine set of cuts that will be LUTs in the mapping
    DeriveFinalMapping( aig, K );
}</pre>
```

```
Figure 2.12: Top level pseudo-code for the priority cuts technology mapping algorithm.
```

enumerates cuts during each of its multiple mapping passes. The functions *MappingPass-Delay* and *MappingPassArea* of Figure 2.12 perform a mapping passes that include cut enumeration and selecting representative cuts. During each pass, cut-sets that are no longer needed to generate other cut-sets further along in the graph are discarded on the fly to keep the memory footprint small.

The *MappingPassDelay* function goes through the AIG graph in topological order and enumerates and ranks cuts for each node. The highest ranked cuts are those that have the minimum depth, ties between nodes with equal depth are broken using the criteria specified in the argument to *MappingPassDelay* (*MinNumInputs* or *AreaFlow*). The highest ranking cuts are stored as the node's priority cuts. Once the minimum depth of the graph has been determined, *MappingPassArea* calls are made to map the graph while optimizing for area under depth constraints. Again cuts are enumerated and ranked for nodes in a topological order. This time, the ranking algorithm does not consider those cuts whose depth exceeds the required maximum depth determined for the node during *MappingPass-Delay*. The remaining cuts are ranked using the area cost function specified as an argument to *MappingPassArea*. After all mapping passes have been completed, the final mapping is derived in the same manner as the general technology mapping algorithm.

### 2.5 Technology Mapping for Fracturable LUTs

FPGA technology mapping traditionally produces a netlist of LUTs. These LUTs are later packed into FLUTs during the packing stage of the CAD tool flow. As a result, the majority of previous work does not explicitly consider FLUTs during technology mapping. This is compounded by the fact that until recently, the typical academic CAD tool flow could not model FPGAs with FLUTs at all. Those works that do take FLUTs into account during technology mapping are noted in this section.

One previous work presents a method of enumerating KL-cuts [42]. A KL-cut is a cut with a maximum of K inputs and L outputs. A KL-cut with L equal to two and K corresponding to the maximum LUT size could potentially map directly to FLUTs instead of LUTs. They present a covering algorithm that uses KL-cuts, but note that it is not intended to achieving state-of-the-art in mapping. It would be interesting if their covering algorithm could be modified to achieve state-of-the-art delay and area characteristics.

Another previous work describes the two-output RAM-based technology mapper called *Hydra* [43]. With Hydra, functions that have two outputs are considered early in the mapping process instead of during packing. Hydra focuses on area, and thus is not depth-optimal, and only works for combinatorial circuits.

The WireMap tech-mapper uses edge-recovery heuristics as part of its cut ranking cost function [5]. The edge-recovery heuristics were added to the complete cut enumeration tech-mapper of ABC and the mappings produced were found to occupy 6.3% fewer Virtex-5 FLUTs after packing [6]. In our work, we use a version of WireMap that has the edge-recovery techniques incorporated into the priority cuts tech-mapper of ABC. The edge-recovery heuristics are used as a tie-breaking cost function when ranking cuts. Their use favours cuts that add fewer edges (wires) to the mapping. A consequence of the edge-recovery heuristics noted in the previous work is an increase in the number of LUTs that use only 2, 3, or 4 of their 6 inputs, and a decrease in the number of LUTs that use 5 or 6 of their inputs. It is easier to pack LUTs that use fewer inputs into a fractured mode FLUT. Recall that FLUTs have a limited number of unique inputs, *M*, that are available to the two fractured mode LUTs. LUTs with fewer inputs have a smaller impact on this input-sharing constraint.

Employing *LUT balancing* during technology mapping to avoid the inclusion of LUTs that use all six of their inputs was found to be beneficial when mapping for the Altera Stratix II, a FPGA whose architecture contains FLUTs [3]. LUT balancing refers to modifying the cut ranking cost function in order to reduce the number of occurrences of LUTs that use a certain number of inputs in the mapping. A LUT that uses all six of its inputs (*K* is six for the Stratix II) cannot be packed into our FLUT model's fractured mode, and is therefore undesirable from a resource usage perspective. Modifying the cut ranking cost functions to prefer LUTs with a certain number of inputs was previously proposed for heterogeneous FPGA architectures that had two LUT structures with different numbers of inputs [39].

# **Chapter 3**

# **Technology Mapping for FLUT Minimization**

A FPGA mapping consists of LUTs, flip-flops, inputs/outputs, various types of hard blocks, and the connectivity of the elements. The traditional measurement of mapping area is equal to the number of LUTs in the mapping. When the FPGA has FLUT resources, this measure of mapping area is inaccurate because two LUTs can potentially be packed into a single FLUT resource. This chapter outlines the FLUT minimization problem and provides details about the MO-Map technology mapping algorithm.

## 3.1 The Minimum Number of Fractruable LUTs

The number of FLUTs that a mapping packs into is given by Equation 3.1.

$$nFLUT = \left\lceil \frac{nLutTotal + nLutRegMode}{2} \right\rceil$$
(3.1)

The term *nLutTotal* is the total number of LUTs in the mapping (i.e. the traditional measurement of a mapping's area). The term *nLutRegMode* is the number of LUTs that must be packed into a FLUT operating in regular mode (i.e. not fractured mode). *nLutRegMode* is always less than or equal to *nLutTotal*. Therefore, the number of FLUTs is always less than or equal to the number of LUTs in the mapping.

The value of *nLutTotal* is easily obtained during tech-mapping by counting the number of LUTs in the current mapping. Unfortunately, the total number of LUTs in *nLutRegMode* is not available until packing is performed. LUTs that use all *K* of their inputs must be packed into a FLUT operating in regular mode (they are too large for fractured mode). Therefore, LUTs using *K* inputs are included in the *nLutRegMode* count and can be counted during technology mapping. But for LUTs that used *K*-1 or fewer inputs, it is infeasible to discern whether or not a LUT should be included in the *nLutRegMode* count during a typical FPGA technology mapping process.

In order to pack a LUT with K-1 or fewer inputs into a fractured mode FLUT, a *pair LUT* must be identified. The pair LUT is packed into the FLUT along with the original LUT, and thus must also only use K-1 or fewer inputs. In addition, in order to be packed together into a FLUT, the two LUTs can only have M unique inputs between them (M is the number of inputs a FLUT operating in fractured mode has). This input-sharing constraint means that there is no guarantee that a LUT with K-1 or fewer inputs will be able to find a suitable pair LUT and could therefore potentially add to the *nLutRegMode* count.

Figure 3.1 illustrates some potential LUT pairings for a fractured mode FLUT with a K of 6 and a M of 5. The first pair can be packed together into a fractured mode FLUT because the LUTs have fewer than K inputs and the total number of unique inputs between them is less than or equal to M. The second pair of LUTs cannot be packed together into



Figure 3.1: Potential LUT pairings to be implemented in a fractured mode FLUT with a K of 6 and a M of 5.

a FLUT because they have six unique inputs between them, A,B,C,D,E,F, and thus fail to meet the input-sharing constraint. The last pair of LUTs have a common input, C, reducing the number of unique inputs to five for the pair, which meets the input-sharing constraint.

Finding suitable pairs of LUTs to pack together into a FLUT is usually performed during packing, not technology mapping. This is due to the fact that during tech-mapping, exactly which LUTs are included in the mapping is still being determined. Adding in the requirement to determine a pair LUT for each cut would increase mapping run-time by orders of magnitude due to the large number of cuts generated by cut enumeration. There are some previous works that tackle similar problems. KL-cut enumeration identifies pairs of K-feasible cuts during mapping [42], and a simultaneous mapping and clustering algorithm has been proposed [44]. But both methods have long run-times, and either don't guarantee depth-optimality in the case of the former, or don't consider FLUTs in the case of the latter.

The architectural parameter M has a strong influence on how many FLUTs end up operating in *nLutRegMode*. The second pair of LUTs in Figure 3.1 cannot fit in a fractured mode FLUT because they have six unique inputs between them and M is only 5. Had M been larger, there would be no issue packing the two LUTs together. Of course, a FLUT with a larger M will occupy more silicon area on the FPGA. Given that the two major FPGA vendors, Xilinx and Altera, have architectures with different values of M, it is unclear at this time what values of M are optimal.

# 3.2 Technology Mapping Techniques for Minimal Fracturable LUTs

Minimizing Equation 3.1 involves keeping the number of total LUTs small while maximizing the number of LUTs that can be packed into a fractured mode FLUT. Since the largest LUTs in the mapping, those with *K* inputs, are guaranteed to be unable to pack into a fractured mode FLUT, they should be avoided except when necessary to maintain the depth of a mapping. For LUTs with less than *K* inputs, it seems intuitive that those with the fewest inputs will be the easiest to pack into fractured mode FLUTs. This is because they put the least strain on the input-sharing restriction of a fractured mode FLUT. Unfortunately, LUTs with a small number of inputs tend to cover fewer nodes in the DAG, which requires more total LUTs be present in the mapping.

In this thesis, we combine two technology mapping techniques from previous works to technology map with the objective of minimizing FLUT utilization without degrading mapping depth. The first technique is the edge-recovery heuristics of the WireMap technology mapper [5][6]. And the second is the concept of LUT balancing [3]. Both techniques were introduced in Section 2.5, and both were found to produce mappings that packed into fewer FLUTs on commercial FPGA architectures.

We use a version of ABC that has the WireMap edge-recovery heuristics incorporated as an option in the priority cuts tech-mapper in our experiments. This version of ABC is not a release version, and was provided by Alan Mishchenko, an author of the WireMap papers [5][6]. The previous works presenting WireMap have the edge-recovery techniques incorporated into their traditional mapper, not the priority cuts mapper.

The exact modifications to the cut ranking cost functions used to implement LUT balancing in previous work were not disclosed as the software is proprietary. To implement LUT-Balancing for our experiments, we modified the value returned by the *Weight()* function for cuts with large numbers of inputs. The *Weight()* function is part of the Area Flow and Exact Area cost functions from Section 2.3.6, which are used to evaluate the area cost of cuts in ABC's tech-mappers. This modification was accomplished using the LUT library function of ABC, which allows the user to specify the area (i.e. *Weight()*) and delay (always set to unit delay) of a cut depending on how many inputs the cut has.

It is our goal to technology map such that FLUT resource usage is minimized without negatively affecting the mapping's depth (i.e. map for minimum area under depth constraints). To ensure that depth is not compromised during the initial mapping passes of

the priority cuts mapper, a *Weight()* of 1.0 is used for all cuts during the initial mapping passes. The area cost functions that use *Weight()* are used to break ties between cuts during the initial depth-determining mapping passes. Thus, modifying *Weight()* has an effect upon which cuts are selected as priority cuts for each node. In early experiments, we observed the depth of one particular benchmark increased by one if we did not take these precautions. No other modifications to ABC were necessary to implement our version of LUT balancing.

### **3.3 MO-Map: Multiple-Output Map**

In addition to combining the previous works, WireMap and LUT-Balancing, we sought to find new tech-mapping techniques for minimizing FLUT usage under delay constraints. The most successful of our exploratory techniques is presented here under the name Multiple-Output Map (MO-Map). MO-Map performs an extra area recovery step after each mapping pass in the ABC priority cuts mapper. Top level pseudo code for the priority cuts mapping algorithm with MO-Map is shown in Figure 3.2. The additions due to MO-Map are in bold.

After each mapping pass, the function *MoMapAreaRecovery* is called to expend extra effort towards minimizing the number of LUTs in the mapping. No cut enumeration occurs during *MoMapAreaRecovery*, instead the cuts from the previous mapping pass are stored. As discussed in Section 2.4, the priority cuts mapper is configured to discard a node's cutset as soon as possible during a mapping pass in order to keep the memory footprint small. Since *MoMapAreaRecovery* requires these cut-sets and isn't executed until the end of a mapping pass, the priority cuts mapper was modified to store the cut-sets of all nodes until

```
PriorityCutsMapWithMOMap( aig, K )
      // set flag to prevent priority cut discarding
      FlagDiscardCuts = 0;
      // perform multiple mapping passes optimizing for Depth
      MappingPassDelay( MinNumInputs );
      MoMapAreaRecovery();
      MappingPassDelay( AreaFlow );
      MoMapAreaRecovery();
      // perform multiple mapping passes optimizing for Area Flow
      for ( i = 0 ; i < numAreaFlowPasses ; i++ ) {</pre>
            MappingPassArea( Area Flow );
            MoMapAreaRecovery();
      }
      // perform multiple mapping passes optimizing for Exact Area
      for ( i = 0 ; i < numExactAreaPasses ; i++ ) {</pre>
            MappingPassArea( ExactArea );
            MoMapAreaRecovery();
      }
      // determine set of cuts that will be LUTs in the mapping
      DeriveFinalMapping( aig, K );
}
```

Figure 3.2: Top level pseudo-code for the priority cuts technology mapping algorithm with MO-Map.

after *MoMapAreaRecovery* has run. This is represented by setting *FlagDiscardCuts* to 0 in our pseudo code. Since we are not discarding cut-sets during a mapping pass, the memory footprint of MO-Map will be larger than the typical priority cuts mapper.

Pseudo code for the *MoMapAreaRecovery* function is given in Figure 3.3. In *MoMa-pAreaRecovery*, each node in the AIG is considered in topological order, as in a regular mapping pass. Each node that is included in the current mapping (i.e. the node is the root node of a cut that would become a LUT if this were the final mapping) has its representative cut reconsidered. The primary criteria used for ranking the cuts is always the Exact Area

cost function described in Section 2.3.6. Once the Exact Area of the representative cut is computed using *ComputeExactArea* and the representative cut is re-ranked, we consider the other priority cuts. The *ComputeExactArea* function is called for each priority cut, providing that the cut's depth is less than or equal to the required depth for the node, and then the cut is ranked and compared to the representative cut. If one of the node's priority cuts is found to rank higher than the representative cut, then it becomes the new representative cut. If a replacement occurs, then the required depth for all other AIG nodes in the graph must be recomputed.

Calling *MoMapAreaRecovery* after each mapping pass means that the Exact Area of cuts is being considered earlier in the mapping process and more frequently. The trade-off for this extra effort is an increase in run-time and memory footprint. The memory footprint increase is due to storing all priority cuts throughout the mapping pass instead of dynamically discarding the cut-sets once they are no longer needed to generate other cuts in the graph. The runtime increase we observed is covered in more detail in Section 5.1.1.

```
MoMapAreaRecovery( aig )
{
      // loop through aig
      foreach node, n, in topological order
      {
            // skip nodes that are not in the mapping
            if ( n is not in the mapping )
                  skip rest of loop iteration;
            //get representative cut of the node
            cut c = BestCut(n);
            // get Exact Area of the representative cut and re-rank it
            ComputeExactArea(c);
            Rank(c);
            // loop through priority cuts of n
            foreach priority cut, p, of n
            {
                  // ensure p meets depth constraints
                  if ( Depth(p) <= Required(n) )</pre>
                  {
                         // compare p to c
                         ComputeExactArea(p);
                         if (Rank(p) > Rank(c))
                         {
                               // Update mapping
                               Set BestCut(n) = p;
                               UpdateRequiredDepth( aig );
                         }
                  }
            }
      }
}
```

Figure 3.3: Pseudo-code for the MO-Map area recovery function.

# Chapter 4

# **Experimental Methodology**

In this section, we describe the setup and procedure of our experiments. We technology map a set of benchmark circuits and pack the resulting mappings for several FPGA architectures. We perform technology mapping with different algorithms and various LUT balancing parameters to find the best technology mapping parameters for reducing FLUT usage without affecting mapping depth. The number of FLUT resources used on the FP-GAs after packing is the metric we use to evaluate the area of a mapping.

### 4.1 Synthesis and Technology Mapping

The first step in each experimental run is to perform synthesis and technology mapping on the benchmark circuits using ABC [18]. The benchmark suite circuits are all initially in Berkeley Logic Interchange Format (BLIF) [45], and thus do not require HDL elaboration. Technology-independent synthesis is performed using ABC's *resyn2* script [25]. After synthesis, the ABC command *choice* is invoked to find structural choices [46][31]. Technology mapping proceeds using the priority cuts [32] mapper (command *if*) of ABC. All technology mapping is performed with K equal to six and the primary objective of depth minimization and the secondary objective of area minimization (i.e. mapping for minimal area under depth constraints). Mappings are checked for combinatorial equivalence with the input benchmark using the *cec* command of ABC. Because K is held constant throughout the remainder of this work, we adopt the notation "x-LUT" (e.g. 5-LUT, 6-LUT, etc) to denote a LUT that uses x of its K inputs instead of a LUT architecture with x inputs total.

The version of ABC we used, abc00406p, was obtained from one of WireMap's [5][6] authors. This version includes WireMap's edge-recovery heuristics in its priority cuts techmapper, whereas the previous work used the full cut enumeration technology mapper in ABC (command *fpga*). We added MO-Map's area recovery heuristic as an option to the priority cuts mapper, as described in Section 3.3. The use of both WireMap and MO-Map is selectable with command line flags when invoking the priority cuts command.

We use three different configurations of the priority cuts tech-mapper in our experiments; *ClassicMap*, *WireMap*, and *MO-Map*. ClassicMap is the base priority cuts techmapper. WireMap is the priority cuts tech-mapper with edge-recovery heuristics enabled. And MO-Map is the priority cuts tech-mapper with both edge-recovery heuristics and the extra area recovery heuristic introduced in Section 3.3 enabled. It is possible to use the extra area recovery heuristic introduced in this thesis without enabling the edge-recovery heuristics. However, early results were not promising, so we did not include that configuration in our experiments.

As discussed in Section 3.2, we implement LUT balancing by modifying the value returned by the *Weight()* function used in the Area Flow and Exact Area cost functions. We examine two LUT balancing schemes in our experiments. In the first scheme, we vary the weight of 6-LUTs (i.e. *Weight(6)*) from 1.0 to 2.5 in 0.1 increments while the weights

of the smaller LUTs are left at 1.0. When Weight(6) is greater than 1.0, the inclusion of 6-LUTs is unfavourable for the area recovery cost functions. Because we are targeting FPGA architectures with a *K* of six, a 6-LUT must be packed into a regular mode FLUT. Therefore, discouraging 6-LUTs, except when required to meet delay targets, is expected to reduce FLUT usage due to a reduced number of FLUTs operating in regular mode.

The second LUT balancing scheme varies both Weight(6) and Weight(5) to investigate whether further area gains are achievable. Unlike the 6-LUTs, a 5-LUT can potentially be packed into a fractured mode FLUT. We keep the value of smaller LUTs at 1.0, set Weight(6) to some value greater than 1.0, and then set Weight(5) to a value less than Weight(6) and greater than 1.0. The values of Weight(5) and Weight(6) were selected to coincide with interesting results from our first LUT balancing scheme experiments.

In our experiments, we perform technology mapping with three different configurations of the priority cuts tech-mapper (ClassicMap, WireMap, and MO-Map) and a wide variety of *Weight(6)* and *Weight(5)* values (our LUT balancing parameters). To provide a single point of reference for comparing these results we specify our *baseline mapping* to be the mappings produced by the ClassicMap mapper when no LUT balancing scheme is employed (i.e. *Weight(6)* and *Weight(5)* equal to 1.0). The baseline technology mapping configuration does not use the edge-recovery heuristics or LUT balancing area cost modifications.

Our benchmark suite consists of the twenty largest Microelectronics Center North Carolina (MCNC) benchmark suite circuits [47] and ten additional circuits from sources such as the Opencores organization [48]. All benchmark circuits are in the BLIF format, which can be read directly into ABC. Table 4.1 lists each benchmark circuit's name, the number of flip-flops in the circuit, the number of LUTs produced by our baseline mapping, the depth of the baseline mapping, and the source of the benchmark circuit.

### 4.2 Packing, Placement, and Routing Experimental Setup

After mapping, circuits are packed, placed, and routed using VPR [20] with AAPack [8] for four academic FPGA architectures. We also target a Stratix II architecture using the Quartus II software and QUIP, which performs the packing, placement, and routing for the commercial FPGA architecture.

#### 4.2.1 Academic Tool Flow

For the experiments, we created four academic FPGA architectures containing fracturable LUTs. The architectures are made for use with a version of VPR containing AAPack [8]. Unlike the older clustering tool T-VPack, AApack can pack for architectures containing fracturable LUTs and other complex structures. The value of M, the number of inputs a fractured mode FLUT can access, is varied for each architecture, while all other aspects of the architectures are the same. The four architectures have a K of 6 and M values of 5, 6, 7, and 8 (henceforth referred to as the M5, M6, M7, and M8 architectures).

The *M*5 architecture is included to mimic the dual-output 6-LUT of a Xilinx Virtex-5 [13][14][15]. The *M*8 FLUT has similar functionality to the FLUT found in the Adaptive Logic Module (ALM) of the Stratix II architecture [16][3][4]. However, our FLUT models are only meant to approximate, not replicate, these commercial structures.

A generic block diagram of the CLB used in our four academic FPGA architectures is shown in Figure 4.1. Each CLB contains one FLUT with a *K* of six and an *M* dependent on the architecture, and two registers. The CLBs each have eight inputs and four outputs. Eight

| Circuit Name | Flip-flops | LUIS | Depth | Origin    |  |
|--------------|------------|------|-------|-----------|--|
| s298         | 14         | 24   | 2     | MCNC      |  |
| glue2        | 40         | 316  | 12    | GroundHog |  |
| elliptic     | 194        | 318  | 6     | MCNC      |  |
| ex5p         | 0          | 369  | 4     | MCNC      |  |
| misex3       | 0          | 425  | 5     | MCNC      |  |
| alu4         | 0          | 519  | 5     | MCNC      |  |
| diffeq       | 305        | 560  | 7     | MCNC      |  |
| apex4        | 0          | 571  | 5     | MCNC      |  |
| bigkey       | 224        | 579  | 3     | MCNC      |  |
| tseng        | 385        | 640  | 7     | MCNC      |  |
| pajf         | 512        | 650  | 3     | UofT      |  |
| seq          | 0          | 657  | 5     | MCNC      |  |
| ex1010       | 0          | 660  | 5     | MCNC      |  |
| apex2        | 0          | 662  | 6     | MCNC      |  |
| des          | 0          | 812  | 5     | MCNC      |  |
| desa         | 64         | 865  | 6     | UofT      |  |
| iir1         | 204        | 870  | 18    | OpenCores |  |
| dsip         | 224        | 873  | 3     | MCNC      |  |
| rsd1         | 506        | 1102 | 10    | OpenCores |  |
| pdc          | 0          | 1379 | 7     | MCNC      |  |
| spla         | 0          | 1469 | 6     | MCNC      |  |
| frisc        | 886        | 1745 | 13    | MCNC      |  |
| s38584.1     | 1260       | 2387 | 6     | MCNC      |  |
| s38417       | 1462       | 2499 | 6     | MCNC      |  |
| rsd2         | 609        | 2531 | 15    | OpenCores |  |
| oc54         | 386        | 2537 | 38    | UofT      |  |
| clma         | 33         | 2988 | 9     | MCNC      |  |
| cfc18        | 2052       | 3410 | 8     | OpenCores |  |
| cfc          | 2052       | 3411 | 8     | OpenCores |  |
| cft8         | 2685       | 7081 | 10    | OpenCores |  |

 Table 4.1: Benchmark suite circuits with baseline mapping statistics.

 Circuit Name
 Flin-flops
 LUTs
 Depth
 Origin



Figure 4.1: A generic version of the CLB used in the four academic FPGA architectures targeted by VPR with AAPack.

inputs to allow the FLUT operating in regular mode as a 6-LUT and the two flip-flops to all have independent inputs when packed into the same CLB. Since this is a generic model of the CLB used in four slightly different architectures, the wiring to the FLUT bears some additional explanation. The number of wires going to the FLUT is the maximum of K and M, this is so that there are a sufficient number of inputs available, irregardless of the mode in which the FLUT is operating. For the M5 architecture, the FLUT has six inputs, equivalent to K, to provide enough inputs for the regular mode 6-LUT. The M6, M7, and M8 architectures have M inputs to ensure enough inputs are provided for their FLUT's fractured mode operation.

The flip-flops in our CLBs have a large number of input options compared to other FPGA architectures. Each flip-flop's input can be set to one of the eight CLB inputs or either of the two FLUT outputs. The flip-flops also have their own dedicated output pin. This was done to make packing flip-flops into CLBs with FLUTs trivial, thus discouraging flip-flops from being packed alone into a CLB. Our post-processing scripts count the number of CLBs in a packing and assume that the number of FLUTs equals the number of

CLBs. This assumption is true if no flip-flops are packed by themselves into a CLB. For the data presented in this thesis, we performed an additional check to verify our assumption.

Each FPGA architecture consists of a square grid of CLBs embedded in a sea of routing resources and surrounded by I/O pins. The size of the CLB grid is not fixed and grows as the packer requires more elements. Similarly, the channel width of the routing infrastructure, i.e. the number of wires in each routing channel, is allowed to grow to accommodate the routing demands of each individual design. These flexibilities are convenient when working with a variety of circuit sizes because no circuit will fail packing, placement, or routing due to insufficient resources.

The routing architecture of the academic FPGAs uses length-4, single driver, wire segments with  $F_s = 3$ ,  $F_c(in) = 0.15$  and  $F_c(out) = 0.125$ . These settings are identical to those of the default FPGA architecture provided in the VPR with AAPack distribution we used for our experiments [8]. The length refers to how many CLBs a segment spans, and single driver means that the wires are uni-directional. The parameter,  $F_s$ , refers to how many wires a segment can connect to at a switch block (where the horizontal and vertical routing channels meet).  $F_c(in)$  and  $F_c(out)$  give the fraction of routing tracks in an adjacent routing channel that a CLB's pin can connect to.

The version of VPR with AAPack we used in our experiments is area-driven. Timingdriven functionality had not been implemented when we were running our experiments. This means that our circuits are packed, placed, and routed without any regard for minimizing the critical path. As a result, the maximum operating frequency is not calculated or reported by our version of VPR with AAPack. This is acceptable given our focus on FLUT resource usage, but the recently released timing-driven functionality will be necessary for future work regarding the trade-off between area and speed for different technology mapping techniques.

#### 4.2.2 Commercial Tool Flow

The mapped benchmark circuits are also packed, placed, and routed using Altera's Quartus II software tool flow, via QUIP [9], targeting the Stratix II [4] device EP2S60F1020C3. The particular device was chosen due to its large number of I/O pins, which was required to fit some of the benchmarks.

To read the mapped circuits into Quartus, the mappings are converted from the BLIF format to the Verilog Quartus Mapping (VQM) format using a Perl script. The VQM format is a subset of Verilog. Valid VQM files contain only primitive elements available for implementation on an Altera FPGA. In our case, these elements are LUTs, Flip-Flops, and I/O pins. Quartus reads the VQM files into the synthesis portion of its tool flow. To prevent Quartus from doing any optimizations to our mappings, the What You See Is What You Get (WYSIWYG) flag is set. Even with the WYSIWYG flag set, Quartus will still do simple optimizations like discarding nets that do not connect to anything.

After synthesis, a "Standard Fit" is performed to pack, place, and route the design to the FPGA. Flags are set to tell Quartus to pack for density, pack registers for minimal area, and to turn off logic and register duplication during routing. These flags were set to encourage the tool to minimize the number of ALMs used. A timing analysis is done once packing, placement, and routing is complete to determine the maximum operating frequency of the circuit.

Our *M8* academic architecture's CLB was designed as a simplified version of the Stratix II ALM. However, there are a number of aspects of the Stratix II architecture that we did not include in our *M8* architecture. First, the Stratix II architecture organizes ALMs into

clusters of 10, called a *Logic Array Block* (LAB). The *M8* CLB has no clustering. Second, the FLUT of an ALM can implement two 6-LUTs in fractured mode, providing that the 6-LUTs implement functions with the same truth table. The *M8* does not have this feature. Third, ALMs contain carry-chain logic and extra multiplexors for implementing some 7-input functions. The *M8* does not have these features. Fourth, the ALM's flip-flops are not as richly connected as the *M8* architecture's flip-flops.

Because we are using the WYSIWYG flag in Quartus and our mapping solutions are restricted to 6-input functions, no ALM uses its 7-input functionality, and our mapping does not include any specialized logic from the ALMs such as carry chains. We did not find a way to prevent the Quartus II packing software from packing two 6-input functions with the same truth table into a single FLUT. As a result of the differences between the academic and commercial architectures and CAD tool software, it is not appropriate to do a direct comparison of our *M8* architecture results to the results of our experiments with the Stratix II.

The *M5* architecture's FLUT is intended to mimic that of the Xilinx Virtex-5 FPGA. However, the *M5* CLB is lacking many of the features of the Virtex-5's CLB (cluster size, carry chains, wide-input functions, etc) [14]. Thus, as with *M8* architecture, the results for we present for our academic architectures are not suitable for a direct comparison with the commercial architectures they are based upon.

# **Chapter 5**

# **Experimental Results**

In this chapter, we present the results of our experiments. The purpose of the experiments is to determine the extent to which the different technology mapping algorithms and LUT balancing schemes minimize FLUT usage after packing for a variety of FPGA architectures. We begin by comparing our technology mapping algorithm, MO-Map, to previous works without any LUT balancing involved. Next, we present the results of our experiments with LUT balancing enabled during technology mapping. To assess the impact of the various tech-mappers and LUT balancing schemes, we pack, place, and route the mapped designs for four different academic FPGA architectures and the Stratix II architecture.

### 5.1 Experimental Results without LUT balancing

In this section, we compare mappings produced with MO-Map to those created by the techmappers of previous works, ClassicMap and WireMap. To perform this comparison we have run the benchmark suite through our academic and commercial tool flows and ensured that technology mapping is performed without LUT balancing (i.e. all LUT weights are

#### 5.1.1 Technology Mapping without LUT balancing

Table 5.1 lists the depth, runtime, and LUT count of each circuit in the benchmark suite when mapped using each of the three tech-mapping algorithms and no LUT balancing. FLUT counts are not yet available as the circuits have only been mapped, not packed. The "Time" column lists the time taken by ABC to synthesize the circuit, create the choice network, and perform technology mapping. The "LUTs" columns show the number of LUTs present in each mapping. The "Depth" column gives the depth of the mappings. Only one "Depth" column is provided for each benchmark circuit as the depth did not degrade when using any of the tech-mappers. The geometric means of the LUT and Time columns are listed in the second to last row. The last row has the percent difference in runtime and LUT count with respect to ClassicMap, which is our baseline.

On average, MO-Map produces mappings with the smallest number of LUTs, followed by ClassicMap, and then WireMap. However, the differences are minimal. MO-Map reduces LUT count by only 0.4% with respect to ClassicMap, while WireMap increases then number of LUTs by 1.2%. Since the mappings have not yet been packed, we do not know how many FLUTs each mapping will utilize at this stage. The number of LUTs in a mapping presented is the traditional measure of a mapping's area.

MO-Map produces the least number LUTs, but it has the longest average tool runtime, 82.9% greater than ClassicMap's runtime. WireMap only had a slight increase in average runtime, 1.2% greater than ClassicMap. MO-Map's runtime scales poorly with the size of the benchmark circuit. This is likely due to the recalculation of required depth that MO-Map's additional area recovery step performs whenever it replaces a cut. The depth Table 5.1: Runtime and LUT count of the mapped benchmark circuits for each of the three tech-mappers. The geometric mean is calculated for each column and included in the second to last row. The last row has the percent difference with respect to ClassicMap.

|              |       | ClassicMap |       | WireMap  |       | MO-Map   |       |
|--------------|-------|------------|-------|----------|-------|----------|-------|
| Circuit      | Depth | Time (s)   | LUTs  | Time (s) | LUTs  | Time (s) | LUTs  |
| s298         | 2     | 0.09       | 24    | 0.09     | 24    | 0.09     | 24    |
| glue2        | 12    | 0.67       | 316   | 0.68     | 323   | 0.71     | 319   |
| elliptic     | 6     | 0.17       | 318   | 0.17     | 319   | 0.20     | 318   |
| ex5p         | 4     | 0.32       | 369   | 0.31     | 373   | 0.39     | 374   |
| misex3       | 5     | 0.37       | 425   | 0.38     | 429   | 0.47     | 415   |
| alu4         | 5     | 0.38       | 519   | 0.39     | 522   | 0.47     | 501   |
| diffeq       | 7     | 0.45       | 560   | 0.48     | 580   | 0.62     | 576   |
| apex4        | 5     | 0.47       | 571   | 0.48     | 581   | 0.66     | 569   |
| bigkey       | 3     | 0.54       | 579   | 0.55     | 579   | 0.65     | 579   |
| tseng        | 7     | 0.43       | 640   | 0.45     | 651   | 0.64     | 654   |
| pajf         | 3     | 0.35       | 650   | 0.35     | 653   | 0.43     | 652   |
| seq          | 5     | 0.57       | 657   | 0.57     | 672   | 0.89     | 662   |
| ex1010       | 5     | 0.51       | 660   | 0.50     | 663   | 0.68     | 648   |
| apex2        | 6     | 0.53       | 662   | 0.52     | 666   | 0.72     | 626   |
| des          | 5     | 0.77       | 812   | 0.82     | 829   | 1.31     | 797   |
| desa         | 6     | 1.06       | 865   | 1.11     | 858   | 1.43     | 827   |
| iir1         | 18    | 1.34       | 870   | 1.36     | 901   | 1.93     | 883   |
| dsip         | 3     | 0.43       | 873   | 0.45     | 873   | 0.59     | 873   |
| rsd1         | 10    | 1.57       | 1102  | 1.51     | 1113  | 2.34     | 1107  |
| pdc          | 7     | 1.46       | 1379  | 1.49     | 1392  | 3.00     | 1305  |
| spla         | 6     | 1.45       | 1469  | 1.46     | 1484  | 2.79     | 1425  |
| frisc        | 13    | 1.37       | 1745  | 1.44     | 1785  | 4.61     | 1769  |
| s38584.1     | 6     | 1.61       | 2387  | 1.64     | 2411  | 5.18     | 2398  |
| s38417       | 6     | 1.49       | 2499  | 1.46     | 2565  | 5.13     | 2547  |
| rsd2         | 15    | 3.68       | 2531  | 3.77     | 2586  | 7.90     | 2541  |
| oc54         | 38    | 4.00       | 2537  | 3.93     | 2597  | 7.76     | 2575  |
| clma         | 9     | 2.38       | 2988  | 2.34     | 3016  | 7.78     | 2880  |
| cfc18        | 8     | 3.11       | 3410  | 3.08     | 3430  | 17.45    | 3429  |
| cfc          | 8     | 2.99       | 3411  | 3.02     | 3428  | 14.20    | 3429  |
| cft8         | 10    | 8.59       | 7081  | 8.64     | 7151  | 61.23    | 7245  |
| geomean      | 6.66  | 0.87       | 921.1 | 0.88     | 932.5 | 1.60     | 917.1 |
| % difference | N/A   | N/A        | N/A   | 1.2%     | 1.2%  | 82.9%    | -0.4% |



Figure 5.1: LUT distributions for ClassicMap, WireMap, and MO-Map without LUT balancing.

requirement recalculation is performed for the entire graph, so larger circuits will not only make more numerous cut replacements, but the time required to do the replacement is proportional to the size of the circuit.

Figure 5.1 gives the LUT distributions of the three tech-mappers, ClassicMap, WireMap, and MO-Map. Each bar is the sum total number of LUTs using a particular number of inputs in the benchmark suite mappings. There are three bars in each x-axis category, one for each tech-mapper.

WireMap and MO-Map mappings have fewer 6-LUTs than the ClassicMap mappings

and more 2-LUTs, 3-LUTs, and 4-LUTs. This change in the distribution was noted in WireMap's previous work [5][6]. Since MO-Map is an addition to WireMap, it is unsurprising that MO-Map and WireMap have similar distributions. The biggest difference noted, is that MO-Map produces slightly fewer LUTs overall than WireMap.

### 5.1.2 Packing without LUT balancing

After synthesis and technology mapping with ABC, the mappings are packed for different FPGA architectures using both VPR with AAPack and Quartus II. After packing, we can see how many FLUTs each mapping required. The number of FLUTs utilized is a more accurate metric for comparing the area of mappings than LUTs when a FPGA architecture with fracturable LUTs is the implementation platform. However, this metric is not available until after packing is performed.

We compare the number of FLUTs used by WireMap and MO-Map mappings relative to our baseline (i.e. ClassicMap with no LUT balancing mappings). The packing results provides the definitive number of FLUTs used by each mapping. Figures 5.2, 5.3, 5.4, and 5.5 give the percent FLUT reduction of WireMap and MO-Map mappings relative to the baseline for the *M5*, *M6*, *M7*, and *M8* academic FPGA architectures respectively. Similarly, Figure 5.6 give the percent reduction of ALMs relative to the baseline when the mappings are packed for the Stratix II architecture using Quartus II.











Figure 5.4: Percent reduction in FLUT usage relative to the baseline for each circuit in the benchmark suite. Packed for the M7 FPGA architecture using VPR with AAPack. MO-Map averaged a 10.6% reduction, WireMap a 9.9% reduction.



Figure 5.5: Percent reduction in FLUT usage relative to the baseline for each circuit in the benchmark suite. Packed for the M8 FPGA architecture using VPR with AAPack. MO-Map averaged a 9.9% reduction, WireMap a 9.3% reduction.




Table 5.2 summarizes the results of Figures 5.2, 5.3, 5.4, and 5.5 by presenting the geometric mean of the benchmark suite's FLUT usage and the percent reduction of FLUTs compared to the ClassicMap results. For the Stratix II architecture row of Table 5.2, we are comparing ALM usage as opposed to FLUTs. Data for each individual benchmark circuit is included in Appendix A.

Table 5.2: FLUT utilization for each tech-mapper/architecture combination. The "Percent Reduction" columns are the percent reduction in FLUTs calculated with respect to the Baseline mapping of an architecture.

|              | ClassicMap<br>(Baseline) | Win    | reMap     | MC     | )-Map     |
|--------------|--------------------------|--------|-----------|--------|-----------|
| Architecture | FLUTs                    | FLUTs  | Percent   | FLUTs  | Percent   |
|              | (ALMs)                   | (ALMs) | Reduction | (ALMs) | Reduction |
| M5           | 756.87                   | 705.69 | 6.8%      | 695.41 | 8.1%      |
| M6           | 691.73                   | 627.44 | 9.3%      | 625.75 | 9.5%      |
| M7           | 662.04                   | 596.31 | 9.9%      | 591.72 | 10.6%     |
| M8           | 656.16                   | 595.30 | 9.3%      | 590.93 | 9.9%      |
| Stratix II   | 651.14                   | 602.26 | 7.5%      | 597.35 | 8.3%      |

On average, with respect to ClassicMap, WireMap reduces FLUT usage by 6.8% to 9.9%, depending on academic architecture, and reduces ALM utilization by 7.5% for the Stratix II. These FLUT reductions are comparable to the 6.3% reduction reported in previous work [6]. The differences between our experimental setup and that of the previous work (different FPGA architecture, different synthesis procedure, different benchmark suite circuits, and a priority cuts tech-mapper versus a complete cut enumeration tech-mapper) can be used to explain the differences between our results.

WireMap mappings pack into the same or fewer FLUTs than the equivalent ClassicMap mappings for every benchmark packed for an academic architecture. For the Stratix II architecture, WireMap only does worse than ClassicMap for the "elliptic" benchmark, where the WireMap mapping packs into 9 more ALMs than the ClassicMap mapping. To explain this discrepancy, we first note that "elliptic" has a large proportion of 6-LUTs in its mappings, 212 6-LUTs out of 319 total LUTs for WireMap and 225 6-LUTs out of 318 total LUTs for ClassicMap. We then examine the Quartus II packings and see that a great many of these 6-LUTs are packed together into ALMs, 65 dual 6-LUT ALMs for WireMap and 71 for ClassicMap. Recall that two 6-LUTs can be packed into a single Stratix II ALM providing that both 6-LUTs have identical truth tables and that our FLUTs in the academic FPGA architectures do not have this feature. It appears that for the "elliptic" benchmark, a great number of 6-LUTs that can take advantage of the extra features of a Stratix II ALM are included in the mapping. Therefore, WireMap's tendency to reduce the number of 6-LUTs is ineffective at reducing FLUT usage because many of the 6-LUTs can be packed into ALMs together.

MO-Map shows greater average FLUT and ALM reductions than WireMap, between 8.1% to 10.6% for the academic architectures and 8.3% for the Stratix II. However, for some benchmark circuits MO-Map produces a worse result than the baseline. Of particular note is the benchmark "dsip". MO-Map has very poor results for "dsip" when packing for the *M7*, *M8*, and Stratix II architectures, doing 28.5% to 32.6% worse than ClassicMap. We hypothesize that the repeated used of the Exact Area algorithm during MO-Maps extra area recovery step is the cause. The Exact Area algorithm optimizes area locally for a given node, it does not optimize for the global area problem. It seems likely that the superior solution found by ClassicMap and WireMap is never found by MO-Map due to MO-Map getting stuck in a local minima of the solution space due to repeated use of MO-Map's greedy area recovery step.

In summary, MO-Map reduces average FLUT usage with respect to the baseline by

0.2% to 1.3% (depending on architecture) more than WireMap when LUT balancing is disabled. Although there is a small average FLUT reduction, the greedy nature of MO-Map's extra area recovery step leads to poor results for specific benchmarks.

## 5.2 LUT Balancing Experiments

In this section, we present our experimental results when LUT balancing is used during the mapping process. We performed two sets of experiments with our LUT balancing scheme, which were described in Section 4.1. In the first set, the benchmark suite is mapped with varying values of Weight(6), ranging from 1.0 to 2.5 in 0.1 increments. In the second set we vary both Weight(6) and Weight(5). For brevity, we will refer to these two sets of experiments as the *W6 experiments* and the *W5&6 experiments* respectively.

### 5.2.1 Technology Mapping Results

We will begin by presenting the LUT distributions of the *W6 experiments* mappings. Figures 5.7, 5.8, and 5.9 present the LUT distributions for the ClassicMap, WireMap, and MO-Map tech-mappers respectively. The y-axes of the figures are the number of LUTs, normalized to the baseline mapping (ClassicMap without LUT Balancing). The x-axes has several categories for LUTs that use different numbers of their *K* inputs, and an additional category labelled "Total LUTs", which is the total number of LUTs. Each bar in an x-axis category represents the sum total number of LUTs found in all of the benchmark suite circuit's mappings, normalized to the baseline. Each bar colour corresponds to the *Weight(6)* value used to perform the tech-mapping. The data used to create these figures is presented in tabular form in Appendix B.













Analyzing Figures 5.7, 5.8, and 5.9 reveals several general trends. The most obvious trend is that as Weight(6) increases, the number of 6-LUTs in the mappings decrease. This is an expected result of raising Weight(6). Another expected trend observed, is that as Weight(6) rises, the number of LUTs that use five or fewer inputs increases to compensate for the missing 6-LUTs. Also, the total number of LUTs in the mapping, which is the traditional measurement of mapping *area*, increases with Weight(6). The data used to create these figures is presented in tabular form in Appendix B.

We note a large shift in the distribution when *Weight(6)* exceeds 2.0. At this point, the number of LUTs that use five of fewer inputs and the total number of LUTs increases drastically, while the number of 6-LUTs plummets. This effect occurs because we have weighted a 6-LUT such that it is more expensive than two LUTs that both use five or less inputs. As a result, it is typically favourable for the mapper to choose two smaller LUTs over a single 6-LUT.

When comparing the distributions, we see that WireMap and MO-Map produce similar results. When the WireMap and MO-Map distributions are compared to the ClassicMap distribution, it can be seen that the ClassicMap distribution has more 5-LUTs, while WireMap and MO-Map's distributions have more 2-LUTs and 3-LUTs. This effect is attributed to WireMap's edge-recovery heuristics, which modifies the LUT distribution such that LUTs with fewer inputs are favoured [6][5].

For all of our *W6 experiments* results, as *Weight(6)* increases, the number of 6-LUTs drops while the number of 5-LUTs increases. In our next set of experiments, the *W5&6 experiments*, we modify the *Weight(5)* value as well as *Weight(6)*. This is done to limit the increase of 5-LUTs noted in the *W6 experiments*. 5-LUTs are the largest LUTs that can be packed into a fractured mode FLUT, and are therefore the most likely to have packability

issues. Figures 5.10, 5.11, and 5.12 present the LUT distributions of our *W5&6 experiments* for ClassicMap, WireMap, and MO-Map respectively. These figures are presented in an identical manner to the previous LUT distribution figures.

Examining Figures 5.10, 5.11, and 5.12 relative to Figures 5.7, 5.8, and 5.9 shows that the average number of 5-LUTs included in the mappings of all tech-mappers has decreased now that Weight(5) is greater than 1.0 and that the average number of 6-LUTs remained relatively unchanged. The bars in the 5-LUT categories of Figures 5.10, 5.11, and 5.12 create a "sawtooth" pattern. Each "tooth" in the 5-LUT category is formed due by several bars side by side that have the same Weight(6) value and increasing Weight(5) values. The high point of each "tooth" occurs when Weight(5) is at its smallest value for a given Weight(6).

The average number of 2-LUTs, 3-LUTs, and 4-LUTs increased to compensate for the reduction of 5-LUTs. A less distinct version of the "sawtooth" pattern observed in the 5-LUT category is present in the 2-LUT, 3-LUT, and 4-LUT categories. The high point of a "tooth" in these smaller LUT categories tends to coincide with the highest values of *Weight(5)* for a given *Weight(6)*, a trend opposite to that seen in the 5-LUT category. This shows that more 2-LUTs, 3-LUTs, and 4-LUTs are being used to compensate for the reduced number of 5-LUTs when a high *Weight(5)* values is specified.

Previously, in the *W6 experiments*, the ClassicMap LUT distribution compensated for fewer 6-LUTs primarily with a large increase in 5-LUTs, whereas WireMap and MO-Map compensated by increasing the occurrence of all smaller LUT sizes. Increasing *Weight(5)* above 1.0 in the *W5&6 experiments* has forced the ClassicMap LUT distribution to become more similar to that of WireMap and MO-Map, where 3-LUTs and 4-LUTs occur more frequently to make up for the lack of 5-LUTs and 6-LUTs. Despite the similarity in 5-LUT and 6-LUT numbers, there are still notable differences between the different tech-mapper













LUT distributions. WireMap and MO-Map have higher numbers of the smaller 2-LUTs and 3-LUTs, while ClassicMap has more 4-LUTs and slightly fewer LUTs overall. This is a change from when LUT balancing was not used and MO-Map mappings had the fewest number of LUTs overall. MO-Map still has fewer total LUTs than WireMap.

#### 5.2.2 Packing Results

In this subsection, we present the FLUT usage data obtained from packing the mappings of our LUT balancing experiments. Figure 5.13 contains four sub-figures, one for each academic architecture, graphing the FLUT usage of the *W6 experiments*. Packing was performed with VPR's AAPack [7][8]. Due to space constraints, the FLUT usage for each individual circuit is not given. Instead, each data point is the benchmark suites geometric mean of FLUT usage when the suite is mapped with a given *Weight(6)* value. There are five lines in each of the subfigures. Three of the lines, *ClassicMap*, *WireMap*, and *MO-Map*, correspond with the left y-axis and give the average FLUT utilizations. The remaining two lines, (*ClassicMap - MO-Map*) and (*WireMap - MO-Map*), are measured against the right y-axis and give the difference in FLUT usage with respect to MO-Map. Figure 5.14 provides an equivalent graph detailing average ALM usage resulting from the Quartus II packings. Note that the left y-axes of the figures start at 500 to provide better resolution. The right y-axes of the figures all have a range of 200, but the endpoints of the range are varied to provide sufficient spacing between the lines on the graph for the purpose of clarity. The data used to create these graphs is included in tabular format in Appendix C.

Figures 5.13 and 5.14 include the packing results from Section 5.1.2, where no LUT balancing was performed, for reference. These are the Weight(6) 1.0 data points and the ClassicMap point is our baseline for comparison. As was noted in Section 5.1.2, WireMap



(c) M7 Architecture.



Figure 5.13: Academic architecture FLUT resource utilizations post-packing. Mapping is performed with the three tech-mappers and varyied values of Weight(6). Subfigures (a), (b), (c) and (d) correspond to one of the four academic FGPA architectures.



(a) Stratix II.

(b) M8 Architecture.

Figure 5.14: Stratix II ALM resource utilization after fitting. Mapping is performed with the three tech-mappers and varied values of *Weight(6)*. *M8* architecture results repeated for comparison purposes.

and MO-Map produce a significant reduction in FLUTs over the baseline when *Weight(6)* is 1.0. With the data of Figures 5.13 and 5.14 we can see that increasing *Weight(6)* to 1.1 produces a drastic reduction in average FLUT use for ClassicMap on all FPGA architectures. MO-Map and WireMap also see benefits, but not to the same extent as ClassicMap.

After the initial jump from 1.0 to 1.1, there are only small variations in the tech-mappers average FLUT usage until *Weight(6)* reaches 2.0. At that point, there is another significant jump up. This corresponds to the increase in total number of LUTs we observed in the LUT distributions of Section 5.2.1. For some of the architectures/tech-mapper combinations, increasing *Weight(6)* beyond 2.0 can produce worse results than the 1.0 scenario. So we can conclude that LUT balancing can be made too aggressive and negatively affect results.

For all architectures and *Weight(6)* values, MO-Map provides a greater average reduction in FLUT usage than either WireMap or ClassicMap. The average number of FLUTs in WireMap's results are less than ClassicMap's for the M5, M6, and M7 architectures, but are almost identical for the M8 architecture and the Stratix II. The gap between average FLUT usage for MO-Map and WireMap compared to ClassicMap gets smaller as M increases. This is an indication of the greater freedom large M values give to the packing tool, which allows for tighter mappings irregardless of LUT distribution. If M is large, then it becomes easier to pack two LUTs together into a fractured mode FLUT because the input sharing constraints are less stringent.

The difference in average FLUT count between ClassicMap and MO-Map varied from 5.1 to 70.3 FLUTs. The difference between WireMap and MO-Map varied from 1.7 to 12.3 FLUTs. We observe that the changing the *Weight(6)* value introduced significantly more variability between the results of ClassicMap and MO-Map than it did for WireMap and MO-Map.

Overall, the addition of LUT balancing provides benefits for all three tech-mappers. The Weight(6) value that minimizes average FLUT usage varies with tech-mapper and architecture, but is always between 1.1 and 2.0 in our results. MO-Map provides an incremental improvement over WireMap. ClassicMap becomes comparable with WireMap for a sufficiently large *M* value.

We will now consider the data from our W5&6 experiments. Figure 5.15 and Figure 5.16 are set up identically to Figure 5.13 and Figure 5.14, except that the x-axes list both the Weight(6) and Weight(5) values used during technology mapping. The Weight(5) values were selected after examining the data from our W6 experiments. The data used to create these graphs is included in Appendix C in tabular format.

Examining Figures 5.15 and 5.16 shows that the *W5&6 experiments* data has some similarities to the *W6 experiments* results. MO-Map shows small average FLUT reductions



(c) M7 Architecture.

(d) M8 Architecture.

Figure 5.15: Academic architecture FLUT resource utilizations post-packing. Mapping is performed with the three tech-mappers and varyied values of Weight(5) and Weight(6). Subfigures (a), (b), (c) and (d) correspond to one of the four academic FGPA architectures.



(a) Stratix II.

(b) M8 Architecture.

Figure 5.16: Stratix II ALM resource utilization after fitting. Mapping is performed with the three tech-mappers and varied values of *Weight(5)* and *Weight(6)*. *M8* architecture results repeated for comparison purposes.

over WireMap and ClassicMap in the majority of cases. Although, there are a few instances in the *M7*, *M8*, and Stratix II data where MO-Map performs equal to or slightly worse than ClassicMap or WireMap. WireMap reduces average FLUT usage over ClassicMap for *M5*, *M6*, and *M7*, but produces equivalent results for *M8* and the Stratix II architectures.

We note a "sawtooth" pattern in our results, each "tooth" of the saw corresponding to Weight(5) varying while Weight(6) remains constant. In the *M7*, *M8* and Stratix II architectures, for a given Weight(6), low values of Weight(5) produce smaller numbers of FLUTs. In contrast, for the *M5* architecture the opposite is true, values of Weight(5) close to that of Weight(6) produce the best results. For the *M6* architecture, the difference between different Weight(5) values is minimal.

Our results suggest that the appropriate Weight(5) value is related to the FLUT parameter *M*. For smaller *M* values, where a 5-LUT is more difficult to pack, the 5-LUT should

be weighted more heavily, closer to the weighting of a 6-LUT, as the LUT distribution produced can be packed more compactly into FLUTs. Conversely, large *M* values should weight 5-LUTs equal to or slightly more than a smaller LUT because 5-LUTs can be packed more easily in these architectures. There does not appear to be a benefit to replacing many 5-LUTs with smaller LUTs for architectures with large *M* values.

Comparing the *W6 experiments* data to the *W5&6 experiments* data, we find that a superior average FLUT reduction can be achieved for the *M5* and *M6* architecture when *Weight(5)* is adjusted. For *M7*, the results are almost equal. And for *M8* and Stratix II leaving *Weight(5)* at 1.0 produces the lowest average FLUT (ALM) utilization. The LUT balancing parameters that produced the fewest FLUTs (ALMs) are given in Table 5.3. An entry is provided for each architecture/tech-mapper combination. The tech-mapper that produced the greatest average FLUT reduction is highlighted in dark grey for each architecture. The tech-mapper that produced the smallest average FLUT reduction is highlighted in light grey. The baseline mapping is also included for each architecture and the percent reduction with respect to the baseline is provided.

In all cases, MO-Map provides the greatest percent reduction over the baseline mapping. However, MO-Map's percent reduction relative to the baseline is only 0.7% to 1.4% greater than that of the second best tech-mapper for an architecture. The tech-mapper with the second best percent reduction relative to the baseline varies with the architecture. WireMap reduces average FLUT usage more than ClassicMap for the *M5*, *M6*, and *M7* architectures, but does not produce a superior reduction for the *M8* architecture or the Stratix II.

Overall, once an appropriate LUT balancing scheme is included, there is little difference between the different tech-mappers in terms of FLUT minimization. Unfortunately, finding

| Architecture  | Mapper     | Weight(6) | Weight(5) | FLUTs  | <b>Percent Reduction</b> |
|---------------|------------|-----------|-----------|--------|--------------------------|
|               |            |           |           | (ALMs) |                          |
|               | Baseline   | 1.0       | 1.0       | 756.9  | N/A                      |
| M5            | ClassicMap | 1.6       | 1.4       | 705.0  | 6.9%                     |
| IVIJ          | WireMap    | 1.4       | 1.3       | 689.1  | 9.0%                     |
|               | MO-Map     | 1.4       | 1.3       | 683.8  | 9.7%                     |
|               | Baseline   | 1.0       | 1.0       | 691.7  | N/A                      |
| M6            | ClassicMap | 1.6       | 1.2       | 620.1  | 10.3%                    |
| IVIO          | WireMap    | 1.6       | 1.2       | 606.8  | 12.3%                    |
|               | MO-Map     | 2.4       | 1.6       | 599.7  | 13.3%                    |
|               | Baseline   | 1.0       | 1.0       | 662.0  | N/A                      |
| M7            | ClassicMap | 2.0       | 1.1       | 568.4  | 14.1%                    |
| 1 <b>v1</b> / | WireMap    | 1.8       | 1.0       | 557.4  | 15.8%                    |
|               | MO-Map     | 1.9       | 1.0       | 548.2  | 17.2%                    |
|               | Baseline   | 1.0       | 1.0       | 656.2  | N/A                      |
| MQ            | ClassicMap | 2.0       | 1.0       | 550.4  | 16.1%                    |
| IVIO          | WireMap    | 2.0       | 1.0       | 554.7  | 15.5%                    |
|               | MO-Map     | 1.9       | 1.0       | 544.5  | 17.0%                    |
|               | Baseline   | 1.0       | 1.0       | 651.1  | N/A                      |
| Strativ II    | ClassicMap | 2.0       | 1.0       | 570.6  | 12.4%                    |
| Sually II     | WireMap    | 1.6       | 1.0       | 571.0  | 12.3%                    |
|               | MO-Map     | 2.0       | 1.0       | 561.5  | 13.8%                    |

Table 5.3: LUT balancing *Weight(6)* and *Weight(5)* values that minimized average FLUT utilization for each tech-mapper/architecture combination.

the best LUT balancing weight values is achieved through trial and error with a given architecture/tech-mapper. The percent reduction of average FLUT usage relative to the baseline for all LUT balancing parameters, architectures, and tech-mappers is included in Appendix C.

## 5.3 Placement and Routing Results

In this section, we present the *maximum operating frequency* (Fmax) data from the Quartus II portion of our experiments targeting the Stratix II. In addition, we present the *minimum channel width* and *wirelength* results from VPR's placement and routing operations for the academic FPGA architectures. No maximum operating frequency is provided for the VPR results because the version of VPR with AAPack that we use in our experiments is not timing-driven.

### 5.3.1 Maximum Operating Frequency

Figure 5.17(a) and 5.17(b) show the maximum operating frequency reported by Quartus II for the *W6 experiments* and *W5&6 experiments* respectively. The number reported is the geometric mean of the benchmark suite circuit's maximum operating frequency. Only designs containing flip-flops reported a maximum operating frequency in the Quartus II timing analyzer log, so only those design's maximum operating frequencies are included in the calculation. In our benchmark suite, twenty out of the thirty benchmarks contained flip-flops. The y-axes of the figures list the maximum operating frequency in MHz. The x-axes show the weight parameters used for LUT balancing. There are three lines on each graph corresponding to the three tech-mappers. The data is presented in tabular format in Appendix F

Noting the very small range on the y-axis, we observe that the maximum operating frequency does not change significantly for any of our different mappings. The average maximum operating frequency remained between 190 and 196 MHz for all variants of our technology mapping parameters. At first, this data indicates that packing a design into



(a) Data for varying *Weight*(6) mappings.



(b) Data for varying *Weight*(6) and *Weight*(5).



fewer ALMs does not have a significant impact on circuit speed. However, we set several flags in the Quartus II software that instruct the CAD tools to optimize for area. Therefore, we expect that an increase in maximum operating frequency is possible with different tool settings. Further experimentation is necessary before concrete conclusions can be drawn.

Another caveat is that our benchmark suite is ill-suited for a maximum operating frequency analysis. Of the 30 benchmark circuits, only 20 have flip-flops and contribute towards our geometric mean. And of these 20, three circuits have such simplistic sequential components that their maximum operating frequency tops out at 500 MHz, the highest frequency that Quartus II optimizes for on the Stratix II without a specific maximum operating frequency target. Such circuits are too trivial for a meaningful critical path benchmark suite.

### **5.3.2** Minimum Channel Width and Wirelength

We are using an alpha version of the new VPR with AAPack software to place and route circuits on our academic FPGA architectures. This alpha software does not have a timingdriven mode, and thus does not provide a critical path estimate for a successfully routed circuit. We collected data from the placement and routing phases, including the minimum channel width and the total wirelength required to route a circuit, to provide some insight on the routing ramifications when packing designs into fewer FLUTs.

The minimum channel width is the minimum number of tracks in each routing channel on the FPGA that allowed for a successful routing of the circuit. VPR iteratively routes the design with different channel widths to search for this minimum. Wirelength is the total number of routing resources used to route a circuit and is expressed in units of "CLBs spanned". Wire segments can span more than one CLB. This unit keeps the wirelength metric independent from the physical length of wire segments in an FPGA architecture.

In our placement and routing runs, neither the size of the FPGA's CLB grid nor its routing channel width is fixed. This allows the FPGA to "grow" and provide enough resources to accommodate any circuit. A consequence of this "growth" circuits that packed into fewer FLUTs are placed onto a smaller FPGA Logic Block grid because fewer resources are required.

Figures 5.18 and 5.19 graph the geometric mean of the benchmark suite circuit's minimum channel width for the different architecture/tech-mapper combinations for the *W6 experiments* and *W5&6 experiments* data respectively. In a similar fashion, Figures 5.20 and 5.21 present the wirelength data for the *W6 experiments* and *W5&6 experiments* data. The minimum channel width data is available in tabular format in Appendix D, and the Wirelegnth data in Appendix E.

While performing routing for the smallest benchmark in our suite, "s298", VPR would sometimes quit with an error message. This error message would occur for some of the mappings produced by all three of the tech-mappers. We have been unable to resolve this error message, and so have excluded "s298" from all of the minimum channel width and wirelength averages.



(c) M7 Architecture.

(d) M8 Architecture.

Figure 5.18: Academic architecture minimum channel widths. Mapping is performed with the three tech-mappers and varyied values of *Weight(6)*. Subfigures (a), (b), (c) and (d) correspond to one of the four academic FGPA architectures.



(c) M7 Architecture.

(d) M8 Architecture.

Figure 5.19: Academic architecture minimum channel widths. Mapping is performed with the three tech-mappers and varyied values of *Weight(5)* and *Weight(6)*. Subfigures (a), (b), (c) and (d) correspond to one of the four academic FGPA architectures.



(c) M7 Architecture.

(d) M8 Architecture.

Figure 5.20: Academic architecture wirelengths. Mapping is performed with the three tech-mappers and varyied values of Weight(6). Subfigures (a), (b), (c) and (d) correspond to one of the four academic FGPA architectures.



(c) M7 Architecture.

(d) M8 Architecture.

Figure 5.21: Academic architecture wirelengths. Mapping is performed with the three tech-mappers and varyied values of *Weight(5)* and *Weight(6)*. Subfigures (a), (b), (c) and (d) correspond to one of the four academic FGPA architectures.

In Table 5.4, we revisit the mappings that produced the greatest percent decrease in average FLUT usage with respect to the baseline for each academic FPGA architecture. This data was previously presented in Table 5.3. We have added columns to the table stating the average minimum channel width (column "MCW") and wirelength for the benchmark suite routings. There are also columns showing the percent difference in minimum channel width and wirelength with respect to the baseline of the architecture. The tech-mapper that produced the greatest average FLUT reduction is highlighted in dark grey for each architecture. The tech-mapper that produced the smallest average FLUT reduction is highlighted in light grey.

Intuitively, packing the same amount of logic into a smaller FPGA CLB grid will lead to a higher density of routing resources, i.e. an increased minimum channel width. This trend is observed in our results; a decrease in FLUT usage is accompanied by an increase in minimum channel width ranging from 4.0% to 12.3% for our "best" mappings. We also observe that wirelength decreases with decreasing FLUT usage anywhere from 3.6% to 11.2%. This can be explained by noting that if the CLB grid is smaller, the wires connecting FLUTs together will not have to be as long to connect source to sink.

| Table 5.4: Incre<br>minimization. | ase in minimum | channe     | el widt | th for the | benchmark       | suite pach | kings that hav | ve the greatest | average FLUT          |
|-----------------------------------|----------------|------------|---------|------------|-----------------|------------|----------------|-----------------|-----------------------|
| Architecture                      | Tech-Mapper    | <i>W</i> 6 | W5      | FLUT       | FLUT<br>Percent | MCW        | MCW<br>Percent | Wirelength      | Wirelength<br>Percent |
|                                   |                |            |         |            | Reduction       |            | Difference     |                 | Difference            |
|                                   | Baseline       | 1.0        | 1.0     | 756.9      | N/A             | 26.7       | N/A            | 35514           | N/A                   |
| NIS                               | ClassicMap     | 1.6        | 1.4     | 705.0      | 6.9%            | 27.9       | 4.3%           | 32963           | -7.2%                 |
| CIVI                              | WireMap        | 1.4        | 1.3     | 689.1      | 9.0%            | 28.1       | 5.1%           | 32576           | -8.3%                 |
|                                   | MO-Map         | 1.4        | 1.3     | 683.8      | 9.7%            | 28.3       | 5.8%           | 31916           | -10.1%                |
|                                   | Baseline       | 1.0        | 1.0     | 691.7      | N/A             | 29.5       | N/A            | 34697           | N/A                   |
| YV                                | ClassicMap     | 1.6        | 1.2     | 620.1      | 10.3%           | 30.6       | 4.0%           | 32797           | -5.5%                 |
| INIO                              | WireMap        | 1.6        | 1.2     | 606.8      | 12.3%           | 31.7       | 7.7%           | 32232           | -7.1%                 |
|                                   | MO-Map         | 2.4        | 1.6     | 599.7      | 13.3%           | 33.1       | 12.3%          | 33421           | -3.7%                 |
|                                   | Baseline       | 1.0        | 1.0     | 662.0      | N/A             | 31.3       | N/A            | 34676           | N/A                   |
|                                   | ClassicMap     | 2.0        | 1.1     | 568.4      | 14.1%           | 33.7       | 7.6%           | 32268           | -6.9%                 |
| 111                               | WireMap        | 1.8        | 1.0     | 557.4      | 15.8%           | 33.8       | 8.2%           | 30806           | -11.2%                |
|                                   | MO-Map         | 1.9        | 1.0     | 548.2      | 17.2%           | 34.4       | 10.1%          | 31104           | -10.3%                |
|                                   | Baseline       | 1.0        | 1.0     | 656.2      | N/A             | 31.8       | N/A            | 33697           | N/A                   |
| MQ                                | ClassicMap     | 2.0        | 1.0     | 550.4      | 16.1%           | 35.4       | 11.4%          | 32498           | -3.6%                 |
| OTAT                              | WireMap        | 2.0        | 1.0     | 554.7      | 15.5%           | 34.7       | 9.3%           | 32412           | -3.8%                 |
|                                   | MO-Map         | 1.9        | 1.0     | 544.5      | 17.0%           | 34.8       | 9.5%           | 31763           | -5.7%                 |

## 5.4 Estimating the Impact on Silicon Area

It is interesting to consider whether or not the decrease in FLUTs resource requirements justifies the increase in minimum channel width. The programmable routing resources are known to take up the majority of an FPGAs silicon area, approximately 65-75% of the total die [11]. If we assume the remaining silicon area is used by logic resources, then we can calculate the net change in silicon area. We estimate the percent change in silicon area for our "best" mappings and present the data in Table 5.5.

To calculate the percent increase in silicon area due to the change in minimum channel width we multiplied the percent increase in channel width from Table 5.4 by 0.65 and 0.75. Similarly, the FLUT percent decrease column of Table 5.4 was multiplied by 0.25 and 0.35 to estimate the percent decrease in silicon area due to FLUTs. Depending on architecture and tech-mapper, we estimate that the percent increase in silicon area to be within -1.0% to 5.9%. However, given how rough our estimation method is, and how close to zero the percent increases are, it seems likely that these predicted changes to silicon area are within the margin of error.

|              |             |           | 4         | ,                       |                         |              |
|--------------|-------------|-----------|-----------|-------------------------|-------------------------|--------------|
| Architecture | Tech-Mapper | Weight(6) | Weight(5) | <b>Percent Increase</b> | <b>Percent Decrease</b> | Net Silicon  |
|              |             |           |           | In Silicon Area Due     | In Silicon Area         | Area Percent |
|              |             |           |           | To Routing              | Due to FLUTs            | Increase     |
|              | ClassicMap  | 1.6       | 1.4       | 2.8-3.2%                | 1.7-2.4%                | 0.4-1.5%     |
| M5           | WireMap     | 1.4       | 1.3       | 3.3 - 3.8%              | 2.2 -3.1%               | 0.2 -1.6%    |
|              | MO-Map      | 1.4       | 1.3       | 3.8 - 4.4%              | 2.4-3.4%                | 0.4-2.0%     |
|              | ClassicMap  | 1.6       | 1.2       | 2.6-3.0%                | 2.6-3.6%                | (-1.0)-0.4%  |
| M6           | WireMap     | 1.6       | 1.2       | 5.0-5.8%                | 3.1 - 4.3%              | 0.7-2.7%     |
|              | MO-Map      | 2.4       | 1.6       | 8.0-9.2%                | 3.3-4.7%                | 3.3-5.9%     |
|              | ClassicMap  | 2.0       | 1.1       | 5.0-5.7%                | 3.5-5.0%                | 0.0-2.2%     |
| M7           | WireMap     | 1.8       | 1.0       | 5.3-6.2%                | 4.0-5.5%                | (-0.2)-2.2%  |
|              | MO-Map      | 1.9       | 1.0       | 6.5-7.5%                | 4.3-6.0%                | 0.5 - 3.2%   |
|              | ClassicMap  | 2.0       | 1.0       | 7.4-8.5%                | 4.0-5.6%                | 1.8-4.5%     |
| M8           | WireMap     | 2.0       | 1.0       | 6.0-7.0%                | 3.9-5.4%                | 0.6-3.1%     |
|              | MO-Map      | 1.9       | 1.0       | 6.2-7.1%                | 4.3-6.0%                | 0.2-2.9%     |

Table 5.5: Estimate of percent change in silicon area.

## Chapter 6

# **Conclusions and Future Work**

The FPGAs of vendors Xilinx and Altera feature fracturable look-up tables as the primary component responsible for implementing Boolean logic. A FLUT has the ability to act as a single large LUT, or two smaller LUTs with input-sharing restrictions. In FPGA technol-ogy mapping, the *area* of a mapping is the number of LUTs included in the design. Such a metric is inaccurate for modern FPGAs because of the difference in logic implementation capabilities of a FLUT versus a LUT. Therefore, technology mapping techniques that minimize the number of FLUTs instead of LUTs are desirable.

## 6.1 Conclusions

In this thesis, we compared and evaluated three technology mapping algorithms, ClassicMap, WireMap, and MO-Map. The evaluation was based upon which algorithm's mappings packed into the smallest number of FLUTs, with the restriction that all mappings had to maintain a minimum mapping depth. In the absence of LUT balancing, WireMap mappings packed into an average of 6.8% to 9.9% fewer FLUTs than ClassicMap mappings for our academic FPGA architectures and 7.5% fewer ALMs for the commercial Stratix II architecture. MO-Map mappings, again in the absence of LUT balancing, packed into an average of 8.1% to 10.6% fewer FLUTs than ClassicMap for the academic FPGA architectures and 8.3% fewer ALMs for the Stratix II.

The effects of LUT balancing during technology mapping were also investigated. We implemented LUT balancing in ABC by modifying the weight of LUTs with a certain number of inputs in the area cost functions. The modified weights were only used during mapping iterations that were not determining the depth of a circuit. The benchmark suite was repeatedly mapped using many different LUT balancing parameters (Weight(6) and Weight(5)) in combination with the three technology mapping algorithms.

The LUT balancing parameters that produced the highest average reduction in FLUT usage for each technology mapper/architecture combination were previously summarized in Table 5.3. With respect to our baseline mapping (ClassicMap, Weight(6) = 1.0, Weight(5) = 1.0), ClassicMap with LUT balancing reduced average FLUT usage by 6.9% to 16.1%, depending on which academic FPGA architecture was targeted during packing. For the Stratix II, ClassicMap with LUT balancing produced a 12.4% average FLUT reduction. The equivalent results for WireMap with LUT balancing were a 9.0% to 15.8% reduction for the academic architectures and a 12.3% ALM reduction for the Stratix II. For MO-Map with LUT balancing, the academic architectures saw a 9.7% to 17.2% decrease in FLUTs and the Stratix II had a 12.8% ALM reduction.

Although MO-Map produced a higher average reduction in FLUTs than WireMap, we observed that MO-Map had poor results for specific benchmarks where it actually increased FLUT usage relative to ClassicMap. In addition, MO-Map has an average 82.9% increase in runtime compared to ClassicMap. WireMap FLUT reductions were less variable than

MO-Maps, and WireMap only showed a 1.2% increase in runtime relative to ClassicMap. We find it difficult to justify MO-Map's runtime increase and unreliability for the small decrease in average FLUTs relative to WireMap. Therefore, we conclude that in the absence of LUT balancing, WireMap is the most appropriate technology mapper for all of our FPGA architectures. We conclude that when LUT balancing is used, WireMap should be used for FPGA architectures with FLUTs that have low M values, such as the Xilinx Virtex-5, and either ClassicMap or WireMap are appropriate for the architectures with high M like the Altera Stratix II.

We did not find values for Weight(6) and Weight(5) that work optimally for all technology mapping algorithms and architectures. The average percent FLUT reductions listed in Table 5.3 are the greatest reductions out of all the LUT balancing parameters we tried for a given tech-mapper/architecture. We did not identify a set of weight values that produce optimal results for all architectures and tech-mappers. The best weight values varied, depending predominantly on M, and to a lesser extend upon which tech-mapper was used. However, we did note that increasing Weight(6) above 1.0 and keeping it less than 2.0 always decreased FLUT usage with respect to the mappings produced without LUT balancing.

From our VPR placement and routing results we observed that as a design is packed into fewer FLUTs, the average minimum channel width required to successfully route the circuit increases. This seems intuitive when you consider that the same amount of logic is being packed into a smaller grid of CLBs. The tighter packing requires an increased density of routing resources. Also, average wirelength decreases with decreasing FLUT usage. Again we hypothesize that packing into a smaller CLB grid means that wires do not have span as far to make connections. Our maximum operating frequency results with the Stratix II did not show significant variance when packing into fewer ALMs.

### 6.1.1 Future Work

The technology mapping techniques we considered in this thesis do not identify potential FLUTs during the mapping process. Instead, they attempt to reduce the frequency of occurrence of those LUTs that are *likely* to occupy a FLUT all by themselves once packed. The question of how to accurately predict FLUT resource usage during FPGA technology mapping is still open. Future effort to remedy this would involve incorporating KL-feasible cut enumeration [42] into ABC. A KL-feasible cut with a *L* of two can be implemented using a fractured mode FLUT. Thus, an accurate FLUT count would be available during technology mapping. Large modifications will need to be made in order to incorporate the KL-cut enumeration into ABC, make it depth-optimal, and adapt the cut area heuristics. Once a depth-optimal KL-cut algorithm is available it may also be possible to incorporate packing and technology-mapping together into a single step of the CAD tool flow. A previous work has already proposed a simultaneous mapping and clustering algorithm for FPGA architectures that do not contain FLUTs [44].

In the event that no new algorithms are explored, the LUT balancing technique produces good results for all our technology mapping algorithms. Unfortunately, our current method of identifying the "best" LUT weights is trial and error. A model that predicts good weight values for some the FPGA architectural values of *K* and *M* would be useful.

We did not draw any strong conclusions from our placement and routing results. Our experimental setup was not designed to accurately measure the effects of packing into fewer FLUTs on circuit speed and routing resources. To be able to draw meaningful conclusions, we would have to repeat our experiments with a timing-driven version of VPR with AA-

Pack that targeted academic FPGA architectures that have their CLB grid size and channel width fixed. For the Stratix II experiments, we would need to disable the area optimization flags from Quartus II. It is often possible to trade-off speed for area and we would like to repeat our experiments to ensure that we are not sacrificing too much speed for our FLUT reductions.

There is also room for improvement with our academic FPGA architectures and benchmark suite. Our academic architectures are simplistic. Creating FPGA architectures with a cluster size greater than one and with registers that have less abundant interconnect would create more realistic FPGAs. Including carry-chains and hard IP blocks would also help bring our academic architectures more in line with commercial ones. The benchmark suite does not include any circuits that have hard IP blocks. Some of our the benchmark circuits are also quite small. A more modern benchmark set would better reflect the size and type of circuits that are commonly targeted to FPGAs in industry.
### **Bibliography**

- [1] (2011) The Xilinx website. [Online]. Available: http://www.xilinx.com/
- [2] (2011) The Altera website. [Online]. Available: http://www.altera.com/
- [3] M. Hutton, J. Schleicher, D. Lewis, B. Pedersen, R. Yuan, S. Kaptanoglu, G. Baeckler,
   B. Ratchev, K. Padalia, M. Bourgeault, *et al.*, "Improving FPGA performance and area using an adaptive logic module," *Field Programmable Logic and Application*,
   pp. 135–144, 2004.
- [4] D. Lewis, E. Ahmed, G. Baeckler, V. Betz, M. Bourgeault, D. Cashman, D. Galloway, M. Hutton, C. Lane, A. Lee, *et al.*, "The Stratix II logic and routing architecture," in *Proceedings of the 2005 ACM/SIGDA 13th international symposium on Field-programmable gate arrays*. ACM, 2005, pp. 14–20.
- [5] S. Jang, B. Chan, K. Chung, and A. Mishchenko, "WireMap: FPGA technology mapping for improved routability," in *Proceedings of the 16th international ACM/SIGDA symposium on Field programmable gate arrays.* ACM, 2008, pp. 47–55.
- [6] —, "Wiremap: FPGA technology mapping for improved routability and enhanced LUT merging," ACM Transactions on Reconfigurable Technology and Systems (TRETS), vol. 2, no. 2, pp. 1–24, 2009.

- [7] J. Luu, "A Hierarchical Description Language and Packing Algorithm for Heterogenous FPGAs," Master's thesis, University of Toronto, 2010.
- [8] J. Luu, J. Anderson, and J. Rose, "Architecture description and packing for logic blocks with hierarchy, modes and complex interconnect," in *Proceedings of the 19th ACM/SIGDA international symposium on Field programmable gate arrays*. ACM, 2011, pp. 227–236.
- [9] S. Malhotra, T. Borer, D. Singh, and S. Brown, "The quartus university interface program: enabling advanced fpga research," in *Field-Programmable Technology*, 2004.
   *Proceedings. 2004 IEEE International Conference on*. IEEE, 2004, pp. 225–230.
- [10] I. Kuon and J. Rose, "Measuring the gap between FPGAs and ASICs," Computer-Aided Design of Integrated Circuits and Systems, IEEE Transactions on, vol. 26, no. 2, pp. 203–215, 2007.
- [11] E. Ahmed and J. Rose, "The effect of LUT and cluster size on deep-submicron FPGA performance and density," *Very Large Scale Integration (VLSI) Systems, IEEE Transactions on*, vol. 12, no. 3, pp. 288–298, 2004.
- [12] G. Lemieux, E. Lee, M. Tom, and A. Yu, "Directional and single-driver wires in fpga interconnect," in *Field-Programmable Technology*, 2004. Proceedings. 2004 IEEE International Conference on. IEEE, 2004, pp. 41–48.
- [13] A. Cosoroaba and F. Rivoallon, "Achieving higher system performance with the virtex-5 family of fpgas," *Xilinx WP245 V*, vol. 1.
- [14] Xilinx. (2010, May) Virtex-5 FPGA User Guide. ug190.pdf. [Online]. Available: http://www.xilinx.com/support/documentation/user\_guides/

- [15] T. Ahmed, P. Kundarewich, J. Anderson, B. Taylor, and R. Aggarwal, "Architecturespecific packing for Virtex-5 FPGAs," in *Proceedings of the 16th international* ACM/SIGDA symposium on Field programmable gate arrays. ACM, 2008, pp. 5–13.
- [16] Altera. Stratix II Device Handbook. stratix2\_handbook.pdf. [Online]. Available: http://www.altera.com/literature/hb/stx2/
- [17] P. Jamieson, K. Kent, F. Gharibian, and L. Shannon, "Odin ii-an open-source verilog hdl synthesis tool for cad research," in 2010 18th IEEE Annual International Symposium on Field-Programmable Custom Computing Machines. IEEE, 2010, pp. 149–156.
- [18] (2011) ABC: A System for Sequential Synthesis and Verification website. [Online]. Available: http://www.eecs.berkeley.edu/ alanmi/abc/
- [19] A. Marquardt, V. Betz, and J. Rose, "Using cluster-based logic blocks and timingdriven packing to improve FPGA speed and density," in *Proceedings of the 1999* ACM/SIGDA seventh international symposium on Field programmable gate arrays. ACM, 1999, pp. 37–46.
- [20] J. Luu, I. Kuon, P. Jamieson, T. Campbell, A. Ye, W. Fang, and J. Rose, "VPR 5.0: FPGA cad and architecture exploration tools with single-driver routing, heterogeneity and process scaling," in *Proceeding of the ACM/SIGDA international symposium on Field programmable gate arrays*. ACM, 2009, pp. 133–142.
- [21] (2011) The VTR website. [Online]. Available: http://www.eecg.utoronto.ca/vtr/

- [22] C. Lavin, M. Padilla, P. Lundrigan, B. Nelson, and B. Hutchings, "Rapid prototyping tools for fpga designs: Rapidsmith," in *Field-Programmable Technology (FPT 2010)*. *International Conference on*, 2010.
- [23] P. Bellows and B. Hutchings, "Jhdl-an hdl for reconfigurable systems," in FPGAs for Custom Computing Machines, 1998. Proceedings. IEEE Symposium on. IEEE, 1998, pp. 175–184.
- [24] S. Guccione, D. Levi, and P. Sundararajan, "Jbits: A java-based interface for reconfigurable computing," in 2nd Annual Military and Aerospace Applications of Programmable Devices and Technologies Conference (MAPLD). Citeseer, 1999, pp. 1–9.
- [25] A. Mishchenko, S. Chatterjee, and R. Brayton, "DAG-aware AIG rewriting: A fresh look at combinational logic synthesis," in *Design Automation Conference*, 2006 43rd ACM/IEEE. IEEE, 2006, pp. 532–535.
- [26] J. Cong and Y. Ding, "FlowMap: An optimal technology mapping algorithm for delay optimization in lookup-table based FPGA designs," *Computer-Aided Design of Integrated Circuits and Systems, IEEE Transactions on*, vol. 13, no. 1, pp. 1–12, 2002.
- [27] A. Farrahi and M. Sarrafzadeh, "Complexity of the lookup-table minimization problem for FPGA technology mapping," *Computer-Aided Design of Integrated Circuits and Systems, IEEE Transactions on*, vol. 13, no. 11, pp. 1319–1332, 2002.
- [28] J. Cong and Y. Hwang, "Simultaneous depth and area minimization in lut-based fpga mapping," in *Proceedings of the 1995 ACM third international symposium on Fieldprogrammable gate arrays.* ACM, 1995, pp. 68–74.

- [29] D. Chen and J. Cong, "DAOmap: a depth-optimal area optimization mapping algorithm for FPGA designs," in *Proceedings of the 2004 IEEE/ACM International conference on Computer-aided design*. IEEE Computer Society, 2004, pp. 752–759.
- [30] V. Manohararajah, S. Brown, and Z. Vranesic, "Heuristics for area minimization in LUT-based FPGA technology mapping," *Computer-Aided Design of Integrated Circuits and Systems, IEEE Transactions on*, vol. 25, no. 11, pp. 2331–2340, 2006.
- [31] A. Mishchenko, S. Chatterjee, and R. Brayton, "Improvements to technology mapping for LUT-based FPGAs," *Computer-Aided Design of Integrated Circuits and Systems, IEEE Transactions on*, vol. 26, no. 2, pp. 240–253, 2007.
- [32] A. Mishchenko, S. Cho, S. Chatterjee, and R. Brayton, "Combinational and sequential mapping with priority cuts," in *Computer-Aided Design*, 2007. ICCAD 2007. IEEE/ACM International Conference on. IEEE, 2007, pp. 354–361.
- [33] Z. Wang, E. Liu, J. Lai, and T. Wang, "Power minization in lut-based fpga technology mapping," in *Proceedings of the 2001 Asia and South Pacific Design Automation Conference*. ACM, 2001, pp. 635–640.
- [34] H. Li, W. Mak, and S. Katkoori, "Efficient lut-based fpga technology mapping for power minimization," in *Proceedings of the 2003 Asia and South Pacific Design Automation Conference*. ACM, 2003, pp. 353–358.
- [35] J. Lamoureux and S. Wilton, "On the interaction between power-aware fpga cad algorithms," in *Proceedings of the 2003 IEEE/ACM international conference on Computer-aided design*. IEEE Computer Society, 2003, p. 701.

- [36] D. Chen, J. Cong, F. Li, and L. He, "Low-power technology mapping for fpga architectures with dual supply voltages," in *Proceedings of the 2004 ACM/SIGDA 12th international symposium on Field programmable gate arrays*. ACM, 2004, pp. 109– 117.
- [37] A. Farrahi and M. Sarrafzadeh, "Fpga technology mapping for power minimization," *Field-Programmable Logic Architectures, Synthesis and Applications*, pp. 66– 77, 1994.
- [38] M. Schlag, J. Kong, and P. Chan, "Routability-driven technology mapping for lookup table-based fpga's," *Computer-Aided Design of Integrated Circuits and Systems, IEEE Transactions on*, vol. 13, no. 1, pp. 13–26, 1994.
- [39] J. Cong, C. Wu, and Y. Ding, "Cut ranking and pruning: enabling a general and efficient FPGA mapping solution," in *Proceedings of the 1999 ACM/SIGDA seventh international symposium on Field programmable gate arrays.* ACM, 1999, p. 35.
- [40] P. Pan and C. Lin, "A new retiming-based technology mapping algorithm for lutbased fpgas," in *Proceedings of the 1998 ACM/SIGDA sixth international symposium* on Field programmable gate arrays. ACM, 1998, pp. 35–42.
- [41] J. Cong and Y. Ding, "On area/depth trade-off in lut-based fpga technology mapping," Very Large Scale Integration (VLSI) Systems, IEEE Transactions on, vol. 2, no. 2, pp. 137–148, 1994.
- [42] O. Martinello Jr, F. Marques, R. Ribas, and A. Reis, "Kl-cuts: a new approach for logic synthesis targeting multiple output blocks," in *Proceedings of the Conference* on Design, Automation and Test in Europe, 2010, pp. 777–782.

- [43] D. Filo, J. Yang, F. Mailhot, and G. De Micheli, "Technology mapping for a twooutput ram-based field programmable gate array," in *Proceedings of the conference on European design automation*. IEEE Computer Society Press, 1991, pp. 534–538.
- [44] J. Lin, D. Chen, and J. Cong, "Optimal simultaneous mapping and clustering for fpga delay optimization," in *Proceedings of the 43rd annual Design Automation Conference.* ACM, 2006, pp. 472–477.
- [45] U. Berkeley, "Berkeley logic interchange format (blif)," Oct Tools Distribution, vol. 2.
- [46] S. Chatterjee, A. Mishchenko, R. Brayton, X. Wang, and T. Kam, "Reducing structural bias in technology mapping," *Computer-Aided Design of Integrated Circuits and Systems, IEEE Transactions on*, vol. 25, no. 12, pp. 2894–2903, 2006.
- [47] S. Yang, *Logic synthesis and optimization benchmarks user guide: version 3.0.* Citeseer, 1991.
- [48] (2011) OpenCores website. [Online]. Available: http://opencores.org/

## Appendix A

## **FLUT utilizations - no LUT balancing**

Table A.1: Benchmark circuit's FLUT utilization when mapped without LUT balancing and packed for the *M5* FPGA architecture. FLUT percent reduction is calculated with respect to the architecture's baseline mapping.

| M5 Architecture |            |       |           |            |             |  |  |  |
|-----------------|------------|-------|-----------|------------|-------------|--|--|--|
|                 | ClassicMap | Wi    | reMap     | MO-Map     |             |  |  |  |
|                 | (baseline) |       |           |            |             |  |  |  |
| Circuit         | FLUTs      | FLUTs | Percent   | FLUTs      | Percent     |  |  |  |
|                 |            |       | Reduction |            | Reduction   |  |  |  |
| s298            | 13         | 13    | 0.0%      | 13         | 0.0%        |  |  |  |
| elliptic        | 292        | 286   | 2.1%      | 285        | 2.4%        |  |  |  |
| ex5p            | 317        | 266   | 16.1%     | 265        | 16.4%       |  |  |  |
| misex3          | 350        | 324   | 7.4%      | 320        | 8.6%        |  |  |  |
| alu4            | 423        | 403   | 4.7%      | 392        | 7.3%        |  |  |  |
| diffeq          | 488        | 476   | 2.5%      | 479        | 1.8%        |  |  |  |
| bigkey          | 514        | 514   | 0.0%      | 514        | 0.0%        |  |  |  |
| apex4           | 516        | 471   | 8.7%      | 471        | 8.7%        |  |  |  |
| ex1010          | 634        | 594   | 6.3%      | 603        | 4.9%        |  |  |  |
| tseng           | 508        | 470   | 7.5%      | 466        | 8.3%        |  |  |  |
| seq             | 552        | 522   | 5.4%      | 513        | 7.1%        |  |  |  |
| apex2           | 548        | 507   | 7.5%      | 488        | 10.9%       |  |  |  |
|                 |            |       | Co        | ontinued o | n next page |  |  |  |

| M5 Architecture |            |         |           |        |           |  |  |  |  |
|-----------------|------------|---------|-----------|--------|-----------|--|--|--|--|
|                 | ClassicMap | WireMap |           | MC     | D-Map     |  |  |  |  |
|                 | (baseline) |         |           |        |           |  |  |  |  |
| Circuit         | FLUTs      | FLUTs   | Percent   | FLUTs  | Percent   |  |  |  |  |
|                 |            |         | Reduction |        | Reduction |  |  |  |  |
| des             | 663        | 635     | 4.2%      | 636    | 4.1%      |  |  |  |  |
| dsip            | 568        | 568     | 0.0%      | 569    | -0.2%     |  |  |  |  |
| spla            | 1243       | 1095    | 11.9%     | 1068   | 14.1%     |  |  |  |  |
| pdc             | 1173       | 1062    | 9.5%      | 1036   | 11.7%     |  |  |  |  |
| frisc           | 1615       | 1532    | 5.1%      | 1527   | 5.4%      |  |  |  |  |
| s38584.1        | 1719       | 1653    | 3.8%      | 1628   | 5.3%      |  |  |  |  |
| s38417          | 1861       | 1733    | 6.9%      | 1702   | 8.5%      |  |  |  |  |
| clma            | 2694       | 2396    | 11.1%     | 2300   | 14.6%     |  |  |  |  |
| cfc18           | 3055       | 2902    | 5.0%      | 2709   | 11.3%     |  |  |  |  |
| cfc             | 3049       | 2902    | 4.8%      | 2682   | 12.0%     |  |  |  |  |
| iir1            | 743        | 669     | 10.0%     | 655    | 11.8%     |  |  |  |  |
| oc54            | 2089       | 1944    | 6.9%      | 1936   | 7.3%      |  |  |  |  |
| rsd1            | 908        | 848     | 6.6%      | 840    | 7.5%      |  |  |  |  |
| rsd2            | 2127       | 1963    | 7.7%      | 1921   | 9.7%      |  |  |  |  |
| cft8            | 5958       | 5735    | 3.7%      | 5667   | 4.9%      |  |  |  |  |
| desa            | 674        | 671     | 0.4%      | 666    | 1.2%      |  |  |  |  |
| glue2           | 228        | 207     | 9.2%      | 208    | 8.8%      |  |  |  |  |
| pajf            | 535        | 408     | 23.7%     | 405    | 24.3%     |  |  |  |  |
| geomean         | 756.87     | 705.69  | 6.8%      | 695.41 | 8.1%      |  |  |  |  |

 Table A.1 – continued from previous page

Table A.2: Benchmark circuit's FLUT utilization when mapped without LUT balancing and packed for the *M6* FPGA architecture. FLUT percent reduction is calculated with respect to the architecture's baseline mapping.

| M6 Architecture        |            |       |           |        |           |  |  |
|------------------------|------------|-------|-----------|--------|-----------|--|--|
|                        | ClassicMap | Wi    | reMap     | MO-Map |           |  |  |
|                        | (baseline) |       |           |        |           |  |  |
| Circuit                | FLUTs      | FLUTs | Percent   | FLUTs  | Percent   |  |  |
|                        |            |       | Reduction |        | Reduction |  |  |
| s298                   | 12         | 11    | 8.3%      | 11     | 8.3%      |  |  |
| elliptic               | 285        | 277   | 2.8%      | 278    | 2.5%      |  |  |
| ex5p                   | 312        | 249   | 20.2%     | 246    | 21.2%     |  |  |
| misex3                 | 342        | 300   | 12.3%     | 296    | 13.5%     |  |  |
| alu4                   | 414        | 382   | 7.7%      | 366    | 11.6%     |  |  |
| diffeq                 | 440        | 412   | 6.4%      | 409    | 7.0%      |  |  |
| bigkey                 | 514        | 514   | 0.0%      | 514    | 0.0%      |  |  |
| apex4                  | 503        | 429   | 14.7%     | 428    | 14.9%     |  |  |
| ex1010                 | 602        | 512   | 15.0%     | 528    | 12.3%     |  |  |
| tseng                  | 432        | 369   | 14.6%     | 363    | 16.0%     |  |  |
| seq                    | 543        | 470   | 13.4%     | 465    | 14.4%     |  |  |
| apex2                  | 534        | 468   | 12.4%     | 438    | 18.0%     |  |  |
| des                    | 615        | 571   | 7.2%      | 574    | 6.7%      |  |  |
| dsip                   | 568        | 568   | 0.0%      | 568    | 0.0%      |  |  |
| spla                   | 1231       | 1018  | 17.3%     | 999    | 18.8%     |  |  |
| pdc                    | 1164       | 971   | 16.6%     | 928    | 20.3%     |  |  |
| frisc                  | 1468       | 1223  | 16.7%     | 1253   | 14.6%     |  |  |
| s38584.1               | 1554       | 1479  | 4.8%      | 1437   | 7.5%      |  |  |
| s38417                 | 1582       | 1541  | 2.6%      | 1526   | 3.5%      |  |  |
| clma                   | 2600       | 2111  | 18.8%     | 2071   | 20.3%     |  |  |
| cfc18                  | 2157       | 2017  | 6.5%      | 2268   | -5.1%     |  |  |
| cfc                    | 2158       | 2009  | 6.9%      | 2249   | -4.2%     |  |  |
| iir1                   | 669        | 613   | 8.4%      | 599    | 10.5%     |  |  |
| oc54                   | 1970       | 1826  | 7.3%      | 1812   | 8.0%      |  |  |
| rsd1                   | 807        | 753   | 6.7%      | 757    | 6.2%      |  |  |
| rsd2                   | 1932       | 1781  | 7.8%      | 1751   | 9.4%      |  |  |
| cft8                   | 5058       | 4737  | 6.3%      | 4739   | 6.3%      |  |  |
| desa                   | 665        | 657   | 1.2%      | 642    | 3.5%      |  |  |
| glue2                  | 216        | 196   | 9.3%      | 196    | 9.3%      |  |  |
| Continued on next page |            |       |           |        |           |  |  |

| M6 Architecture |            |         |           |        |           |  |  |  |  |
|-----------------|------------|---------|-----------|--------|-----------|--|--|--|--|
|                 | ClassicMap | WireMap |           | MO     | D-Map     |  |  |  |  |
|                 | (baseline) |         |           |        |           |  |  |  |  |
| Circuit         | FLUTs      | FLUTs   | Percent   | FLUTs  | Percent   |  |  |  |  |
|                 |            |         | Reduction |        | Reduction |  |  |  |  |
| pajf            | 373        | 368     | 1.3%      | 362    | 2.9%      |  |  |  |  |
| geomean         | 691.73     | 627.44  | 9.3%      | 625.75 | 9.5%      |  |  |  |  |

Table A.2 – continued from previous page

Table A.3: Benchmark circuit's FLUT utilization when mapped without LUT balancing and packed for the *M7* FPGA architecture. FLUT percent reduction is calculated with respect to the architecture's baseline mapping.

| M7 Architecture |            |       |           |            |             |  |  |  |
|-----------------|------------|-------|-----------|------------|-------------|--|--|--|
|                 | ClassicMap | Wi    | reMap     | MC         | D-Map       |  |  |  |
|                 | (baseline) |       |           |            |             |  |  |  |
| Circuit         | FLUTs      | FLUTs | Percent   | FLUTs      | Percent     |  |  |  |
|                 |            |       | Reduction |            | Reduction   |  |  |  |
| s298            | 12         | 11    | 8.3%      | 11         | 8.3%        |  |  |  |
| elliptic        | 281        | 272   | 3.2%      | 267        | 5.0%        |  |  |  |
| ex5p            | 305        | 243   | 20.3%     | 239        | 21.6%       |  |  |  |
| misex3          | 339        | 298   | 12.1%     | 288        | 15.0%       |  |  |  |
| alu4            | 411        | 378   | 8.0%      | 360        | 12.4%       |  |  |  |
| diffeq          | 406        | 364   | 10.3%     | 347        | 14.5%       |  |  |  |
| bigkey          | 514        | 514   | 0.0%      | 514        | 0.0%        |  |  |  |
| apex4           | 491        | 402   | 18.1%     | 388        | 21.0%       |  |  |  |
| ex1010          | 562        | 478   | 14.9%     | 462        | 17.8%       |  |  |  |
| tseng           | 414        | 366   | 11.6%     | 361        | 12.8%       |  |  |  |
| seq             | 533        | 462   | 13.3%     | 446        | 16.3%       |  |  |  |
| apex2           | 525        | 458   | 12.8%     | 423        | 19.4%       |  |  |  |
| des             | 605        | 563   | 6.9%      | 542        | 10.4%       |  |  |  |
| dsip            | 344        | 344   | 0.0%      | 456        | -32.6%      |  |  |  |
| spla            | 1213       | 981   | 19.1%     | 945        | 22.1%       |  |  |  |
| pdc             | 1147       | 924   | 19.4%     | 866        | 24.5%       |  |  |  |
|                 |            |       | Co        | ontinued o | n next page |  |  |  |

| M7 Architecture |            |        |           |        |           |  |  |  |  |
|-----------------|------------|--------|-----------|--------|-----------|--|--|--|--|
|                 | ClassicMap | Wi     | reMap     | MC     | D-Map     |  |  |  |  |
|                 | (baseline) |        |           |        |           |  |  |  |  |
| Circuit         | FLUTs      | FLUTs  | Percent   | FLUTs  | Percent   |  |  |  |  |
|                 |            |        | Reduction |        | Reduction |  |  |  |  |
| frisc           | 1304       | 1096   | 16.0%     | 1100   | 15.6%     |  |  |  |  |
| s38584.1        | 1452       | 1395   | 3.9%      | 1360   | 6.3%      |  |  |  |  |
| s38417          | 1569       | 1541   | 1.8%      | 1526   | 2.7%      |  |  |  |  |
| clma            | 2551       | 2049   | 19.7%     | 1991   | 22.0%     |  |  |  |  |
| cfc18           | 2146       | 2010   | 6.3%      | 2147   | 0.0%      |  |  |  |  |
| cfc             | 2148       | 2002   | 6.8%      | 2154   | -0.3%     |  |  |  |  |
| iir1            | 660        | 587    | 11.1%     | 572    | 13.3%     |  |  |  |  |
| oc54            | 1856       | 1706   | 8.1%      | 1702   | 8.3%      |  |  |  |  |
| rsd1            | 758        | 721    | 4.9%      | 722    | 4.7%      |  |  |  |  |
| rsd2            | 1860       | 1723   | 7.4%      | 1687   | 9.3%      |  |  |  |  |
| cft8            | 4975       | 4619   | 7.2%      | 4604   | 7.5%      |  |  |  |  |
| desa            | 658        | 650    | 1.2%      | 622    | 5.5%      |  |  |  |  |
| glue2           | 215        | 194    | 9.8%      | 193    | 10.2%     |  |  |  |  |
| pajf            | 360        | 326    | 9.4%      | 330    | 8.3%      |  |  |  |  |
| geomean         | 662.04     | 596.31 | 9.9%      | 591.72 | 10.6%     |  |  |  |  |

 Table A.3 – continued from previous page

Table A.4: Benchmark circuit's FLUT utilization when mapped without LUT balancing and packed for the *M8* FPGA architecture. FLUT percent reduction is calculated with respect to the architecture's baseline mapping.

| M8 Architecture        |            |         |           |        |           |  |  |  |  |
|------------------------|------------|---------|-----------|--------|-----------|--|--|--|--|
|                        | ClassicMap | WireMap |           | MO-Map |           |  |  |  |  |
|                        | (baseline) |         |           |        |           |  |  |  |  |
| Circuit                | FLUTs      | FLUTs   | Percent   | FLUTs  | Percent   |  |  |  |  |
|                        |            |         | Reduction |        | Reduction |  |  |  |  |
| s298                   | 12         | 11      | 8.3%      | 11     | 8.3%      |  |  |  |  |
| elliptic               | 272        | 266     | 2.2%      | 267    | 1.8%      |  |  |  |  |
| ex5p                   | 300        | 243     | 19.0%     | 239    | 20.3%     |  |  |  |  |
| Continued on next page |            |         |           |        |           |  |  |  |  |

| M8 Architecture |            |        |           |        |           |  |  |  |
|-----------------|------------|--------|-----------|--------|-----------|--|--|--|
|                 | ClassicMap | Wi     | reMap     | MO-Map |           |  |  |  |
|                 | (baseline) |        |           |        |           |  |  |  |
| Circuit         | FLUTs      | FLUTs  | Percent   | FLUTs  | Percent   |  |  |  |
|                 |            |        | Reduction |        | Reduction |  |  |  |
| misex3          | 339        | 298    | 12.1%     | 288    | 15.0%     |  |  |  |
| alu4            | 411        | 378    | 8.0%      | 360    | 12.4%     |  |  |  |
| diffeq          | 406        | 364    | 10.3%     | 347    | 14.5%     |  |  |  |
| bigkey          | 514        | 514    | 0.0%      | 514    | 0.0%      |  |  |  |
| apex4           | 483        | 402    | 16.8%     | 388    | 19.7%     |  |  |  |
| ex1010          | 538        | 478    | 11.2%     | 458    | 14.9%     |  |  |  |
| tseng           | 414        | 366    | 11.6%     | 361    | 12.8%     |  |  |  |
| seq             | 533        | 462    | 13.3%     | 446    | 16.3%     |  |  |  |
| apex2           | 525        | 458    | 12.8%     | 423    | 19.4%     |  |  |  |
| des             | 605        | 563    | 6.9%      | 542    | 10.4%     |  |  |  |
| dsip            | 344        | 344    | 0.0%      | 456    | -32.6%    |  |  |  |
| spla            | 1193       | 981    | 17.8%     | 945    | 20.8%     |  |  |  |
| pdc             | 1132       | 924    | 18.4%     | 866    | 23.5%     |  |  |  |
| frisc           | 1255       | 1082   | 13.8%     | 1069   | 14.8%     |  |  |  |
| s38584.1        | 1452       | 1395   | 3.9%      | 1360   | 6.3%      |  |  |  |
| s38417          | 1569       | 1541   | 1.8%      | 1526   | 2.7%      |  |  |  |
| clma            | 2551       | 2049   | 19.7%     | 1991   | 22.0%     |  |  |  |
| cfc18           | 2146       | 2010   | 6.3%      | 2147   | 0.0%      |  |  |  |
| cfc             | 2148       | 2002   | 6.8%      | 2148   | 0.0%      |  |  |  |
| iir1            | 657        | 587    | 10.7%     | 572    | 12.9%     |  |  |  |
| oc54            | 1856       | 1706   | 8.1%      | 1702   | 8.3%      |  |  |  |
| rsd1            | 758        | 721    | 4.9%      | 722    | 4.7%      |  |  |  |
| rsd2            | 1840       | 1723   | 6.4%      | 1687   | 8.3%      |  |  |  |
| cft8            | 4975       | 4619   | 7.2%      | 4604   | 7.5%      |  |  |  |
| desa            | 658        | 650    | 1.2%      | 622    | 5.5%      |  |  |  |
| glue2           | 215        | 194    | 9.8%      | 193    | 10.2%     |  |  |  |
| pajf            | 334        | 321    | 3.9%      | 330    | 1.2%      |  |  |  |
| geomean         | 656.16     | 595.30 | 9.3%      | 590.93 | 9.9%      |  |  |  |

 Table A.4 – continued from previous page

| Table A.5: Benchmark circuit's FLUT utilization      | when mapped  | without LUT    | balancing  |
|------------------------------------------------------|--------------|----------------|------------|
| and packed for the Stratix II FPGA architecture.     | FLUT percent | t reduction is | calculated |
| with respect to the architecture's baseline mapping. |              |                |            |

| Stratix II Architecture |            |       |           |            |             |  |  |
|-------------------------|------------|-------|-----------|------------|-------------|--|--|
|                         | ClassicMap | Wi    | reMap     | MO-Map     |             |  |  |
|                         | (baseline) |       |           |            |             |  |  |
| Circuit                 | FLUTs      | FLUTs | Percent   | FLUTs      | Percent     |  |  |
|                         |            |       | Reduction |            | Reduction   |  |  |
| s298                    | 13         | 11    | 15.4%     | 11         | 15.4%       |  |  |
| elliptic                | 205        | 214   | -4.4%     | 209        | -2.0%       |  |  |
| ex5p                    | 303        | 240   | 20.8%     | 241        | 20.5%       |  |  |
| misex3                  | 336        | 306   | 8.9%      | 288        | 14.3%       |  |  |
| alu4                    | 403        | 376   | 6.7%      | 362        | 10.2%       |  |  |
| diffeq                  | 389        | 372   | 4.4%      | 354        | 9.0%        |  |  |
| bigkey                  | 539        | 539   | 0.0%      | 539        | 0.0%        |  |  |
| apex4                   | 472        | 391   | 17.2%     | 376        | 20.3%       |  |  |
| ex1010                  | 496        | 447   | 9.9%      | 433        | 12.7%       |  |  |
| tseng                   | 381        | 371   | 2.6%      | 367        | 3.7%        |  |  |
| seq                     | 540        | 462   | 14.4%     | 450        | 16.7%       |  |  |
| apex2                   | 508        | 451   | 11.2%     | 422        | 16.9%       |  |  |
| des                     | 623        | 601   | 3.5%      | 578        | 7.2%        |  |  |
| dsip                    | 439        | 439   | 0.0%      | 564        | -28.5%      |  |  |
| spla                    | 1180       | 989   | 16.2%     | 970        | 17.8%       |  |  |
| pdc                     | 1124       | 941   | 16.3%     | 902        | 19.8%       |  |  |
| frisc                   | 1182       | 1109  | 6.2%      | 1075       | 9.1%        |  |  |
| s38584.1                | 1432       | 1429  | 0.2%      | 1382       | 3.5%        |  |  |
| s38417                  | 1474       | 1463  | 0.7%      | 1482       | -0.5%       |  |  |
| clma                    | 2261       | 2014  | 10.9%     | 1904       | 15.8%       |  |  |
| cfc18                   | 2102       | 2025  | 3.7%      | 2112       | -0.5%       |  |  |
| cfc                     | 2099       | 2030  | 3.3%      | 2100       | 0.0%        |  |  |
| iir1                    | 703        | 625   | 11.1%     | 606        | 13.8%       |  |  |
| oc54                    | 1906       | 1743  | 8.6%      | 1741       | 8.7%        |  |  |
| rsd1                    | 743        | 727   | 2.2%      | 762        | -2.6%       |  |  |
| rsd2                    | 1822       | 1736  | 4.7%      | 1691       | 7.2%        |  |  |
| cft8                    | 5210       | 4792  | 8.0%      | 4877       | 6.4%        |  |  |
| desa                    | 671        | 658   | 1.9%      | 636        | 5.2%        |  |  |
| glue2                   | 229        | 208   | 9.2%      | 212        | 7.4%        |  |  |
|                         |            |       | Co        | ontinued o | n next page |  |  |

| Stratix II Architecture |            |         |           |        |           |  |  |  |  |  |
|-------------------------|------------|---------|-----------|--------|-----------|--|--|--|--|--|
|                         | ClassicMap | WireMap |           | MO     | D-Map     |  |  |  |  |  |
|                         | (baseline) |         |           |        |           |  |  |  |  |  |
| Circuit                 | FLUTs      | FLUTs   | Percent   | FLUTs  | Percent   |  |  |  |  |  |
|                         |            |         | Reduction |        | Reduction |  |  |  |  |  |
| pajf                    | 351        | 333     | 5.1%      | 331    | 5.7%      |  |  |  |  |  |
| geomean                 | 651.22     | 602.40  | 7.5%      | 597.62 | 8.2%      |  |  |  |  |  |

 Table A.5 – continued from previous page

## **Appendix B**

## LUT distribution data

Table B.1: ClassicMap LUT distribution data. The LUT counts presented are the geometric means of the benchmark suite's mappings. Each row corresponds to the set of mappings created using the specified *Weight(6)* and *Weight(5)* values.

| ClassicMap |           |      |      |       |         |           |          |  |
|------------|-----------|------|------|-------|---------|-----------|----------|--|
|            |           |      |      | LU    | T Size  |           |          |  |
| Weight(6)  | Weight(5) | 2    | 3    | 4     | 5       | 6         | All      |  |
| 1.0        | 1.0       | 2454 | 2643 | 8360  | 9444    | 18915     | 41816    |  |
| 1.1        | 1.0       | 2632 | 3961 | 9498  | 15261   | 10909     | 42261    |  |
| 1.2        | 1.0       | 2569 | 4183 | 9606  | 15599   | 10488     | 42445    |  |
| 1.3        | 1.0       | 2677 | 4349 | 9587  | 15898   | 10150     | 42661    |  |
| 1.4        | 1.0       | 2594 | 4351 | 9910  | 16775   | 9311      | 42941    |  |
| 1.5        | 1.0       | 2593 | 4206 | 10159 | 17183   | 8941      | 43082    |  |
| 1.6        | 1.0       | 2605 | 4256 | 10114 | 17517   | 8677      | 43169    |  |
| 1.7        | 1.0       | 2611 | 4323 | 10136 | 17610   | 8572      | 43252    |  |
| 1.8        | 1.0       | 2602 | 4311 | 10195 | 17709   | 8472      | 43289    |  |
| 1.9        | 1.0       | 2588 | 4375 | 10230 | 18031   | 8253      | 43477    |  |
| 2.0        | 1.0       | 3321 | 4288 | 12067 | 21542   | 5066      | 46284    |  |
| 2.1        | 1.0       | 3868 | 4394 | 13215 | 22354   | 3972      | 47803    |  |
| 2.2        | 1.0       | 3898 | 4378 | 13147 | 22417   | 3956      | 47796    |  |
| 2.3        | 1.0       | 3893 | 4376 | 13151 | 22484   | 3947      | 47851    |  |
|            |           |      |      |       | Continu | ied on ne | ext page |  |

|           |           | (                         | ClassicN | Лар                     |                                |                      |       |
|-----------|-----------|---------------------------|----------|-------------------------|--------------------------------|----------------------|-------|
|           |           |                           |          | LU                      | T Size                         |                      |       |
| Weight(6) | Weight(5) | 2                         | 3        | 4                       | 5                              | 6                    | All   |
| 2.4       | 1.0       | 3891                      | 4369     | 13188                   | 22484                          | 3940                 | 47872 |
| 2.5       | 1.0       | 3920                      | 4318     | 13187                   | 22494                          | 3946                 | 47865 |
| 1.2       | 1.1       | 2800                      | 4958     | 14316                   | 9259                           | 11205                | 42538 |
| 1.4       | 1.1       | 2942                      | 5008     | 14623                   | 10103                          | 10273                | 42949 |
| 1.4       | 1.2       | 2940                      | 5222     | 15108                   | 8729                           | 10945                | 42944 |
| 1.4       | 1.3       | 2971                      | 5247     | 15932                   | 7314                           | 11601                | 43065 |
| 1.6       | 1.1       | 2873                      | 5245     | 15362                   | 10954                          | 9084                 | 43518 |
| 1.6       | 1.2       | 2963                      | 5453     | 15335                   | 10228                          | 9517                 | 43496 |
| 1.6       | 1.3       | 3032                      | 5389     | 15553                   | 9060                           | 10313                | 43347 |
| 1.6       | 1.4       | 3027                      | 5628     | 16257                   | 7223                           | 11254                | 43389 |
| 1.8       | 1.1       | 2843                      | 5334     | 15442<br>15718<br>16800 | 11534<br>10906<br>9369<br>6993 | 8594<br>8831<br>9284 | 43747 |
| 1.8       | 1.2       | 2927                      | 5468     |                         |                                |                      | 43850 |
| 1.8       | 1.4       | 2935                      | 5665     |                         |                                |                      | 44053 |
| 1.8       | 1.6       | 2860                      | 5910     | 17361                   |                                | 10828                | 43952 |
| 2.0       | 1.1       | 2827                      | 5650     | 17142                   | 11761                          | 7394                 | 44774 |
| 2.0       | 1.2       | 2891                      | 5771     | 17479                   | 11146                          | 7621                 | 44908 |
| 2.0       | 1.6       | 2912                      | 6863     | 19647                   | 7770                           | 8449                 | 45641 |
| 2.4       | 1.1       | 3379                      | 7002     | 20977                   | 12857                          | 4131                 | 48346 |
| 2.4       | 1.2       | 3535 7409                 |          | 21192                   | 12265                          | 4230                 | 48631 |
| 2.4       | 1.6       | 2995 7420 22877 8504 6085 |          |                         |                                |                      | 47881 |
| 2.4       | 2.0       | 3318                      | 8642     | 26122                   | 5271                           | 6498                 | 49851 |

 Table B.1 – continued from previous page

|           |           |                                                                                                                                                                                                   | WireM                                                                                                                                                                                                | ар    |                           |           |          |  |
|-----------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|---------------------------|-----------|----------|--|
|           |           |                                                                                                                                                                                                   |                                                                                                                                                                                                      | LUT   | Size                      |           |          |  |
| Weight(6) | Weight(5) | 2                                                                                                                                                                                                 | 3                                                                                                                                                                                                    | 4     | 5                         | 6         | All      |  |
| 1.0       | 1.0       | 4410                                                                                                                                                                                              | 5572                                                                                                                                                                                                 | 9334  | 10244                     | 12801     | 42361    |  |
| 1.1       | 1.0       | 4077                                                                                                                                                                                              | 5879                                                                                                                                                                                                 | 10060 | 11464                     | 11041     | 42521    |  |
| 1.2       | 1.0       | 4152                                                                                                                                                                                              | 4077         5879         10060         11464         110           4152         6121         10181         11675         106           4367         6339         10235         11887         101    |       | 10619                     | 42748     |          |  |
| 1.3       | 1.0       | 4367                                                                                                                                                                                              | 6339                                                                                                                                                                                                 | 10235 | 11887                     | 10190     | 43018    |  |
| 1.4       | 1.0       | 4307         0339         10233         11887         101           4288         6398         10661         12330         958           4319         6304         10821         12663         920 |                                                                                                                                                                                                      |       |                           |           | 43264    |  |
| 1.5       | 1.0       | 4319                                                                                                                                                                                              | 4319         6304         10821         12663         9268           4319         6238         10957         13253         8799           4300         6300         10006         13260         9688 |       |                           |           |          |  |
| 1.6       | 1.0       | 4319                                                                                                                                                                                              | 6238                                                                                                                                                                                                 | 10957 | 13253                     | 8799      | 43566    |  |
| 1.7       | 1.0       | 4309                                                                                                                                                                                              | 6309                                                                                                                                                                                                 | 10996 | 13360                     | 8688      | 43662    |  |
| 1.8       | 1.0       | 4287                                                                                                                                                                                              | 6301                                                                                                                                                                                                 | 11029 | 13473                     | 8603      | 43693    |  |
| 1.9       | 1.0       | 4269                                                                                                                                                                                              | 6421                                                                                                                                                                                                 | 11135 | 13707                     | 8360      | 43892    |  |
| 2.0       | 1.0       | 4265                                                                                                                                                                                              | 6478                                                                                                                                                                                                 | 11213 | 13880                     | 8211      | 44047    |  |
| 2.1       | 1.0       | 6677                                                                                                                                                                                              | 7690                                                                                                                                                                                                 | 13290 | 16364                     | 4249      | 48270    |  |
| 2.2       | 1.0       | 6660                                                                                                                                                                                              | 7709                                                                                                                                                                                                 | 13245 | 16408                     | 4234      | 48256    |  |
| 2.3       | 1.0       | 6682                                                                                                                                                                                              | 7718                                                                                                                                                                                                 | 13255 | 16436                     | 4211      | 48302    |  |
| 2.4       | 1.0       | 6686                                                                                                                                                                                              | 7707                                                                                                                                                                                                 | 13285 | 16436                     | 4206      | 48320    |  |
| 2.5       | 1.0       | 6672                                                                                                                                                                                              | 7653                                                                                                                                                                                                 | 13281 | 16492                     | 4200      | 48298    |  |
| 1.2       | 1.1       | 4320                                                                                                                                                                                              | 6072                                                                                                                                                                                                 | 11856 | 9118                      | 11310     | 42676    |  |
| 1.4       | 1.1       | 4541                                                                                                                                                                                              | 4541 6367 11846                                                                                                                                                                                      |       | 10014 10338<br>8630 11043 |           | 43106    |  |
| 1.4       | 1.2       | 4638                                                                                                                                                                                              | 6515                                                                                                                                                                                                 | 12293 | 8630                      | 11043     | 43119    |  |
| 1.4       | 1.3       | 4756                                                                                                                                                                                              | 6737                                                                                                                                                                                                 | 12814 | 7177                      | 11746     | 43230    |  |
| 1.6       | 1.1       | 4508                                                                                                                                                                                              | 6447                                                                                                                                                                                                 | 12608 | 10815                     | 9265      | 43643    |  |
| 1.6       | 1.2       | 4656                                                                                                                                                                                              | 6596                                                                                                                                                                                                 | 12653 | 9986                      | 9713      | 43604    |  |
| 1.6       | 1.3       | 4829                                                                                                                                                                                              | 4656         6596         12653         9           4829         6838         12590         8                                                                                                        |       | 8860                      | 10426     | 43543    |  |
| 1.6       | 1.4       | 4827                                                                                                                                                                                              | 7034                                                                                                                                                                                                 | 13137 | 7196                      | 11373     | 43567    |  |
| 1.8       | 1.1       | 4514                                                                                                                                                                                              | 6502                                                                                                                                                                                                 | 12642 | 11414                     | 8797      | 43869    |  |
| 1.8       | 1.2       | 4637                                                                                                                                                                                              | 6765                                                                                                                                                                                                 | 13108 | 10272                     | 9213      | 43995    |  |
| 1.8       | 1.4       | 4770                                                                                                                                                                                              | 7206                                                                                                                                                                                                 | 13889 | 8617                      | 9725      | 44207    |  |
| 1.8       | 1.6       | 4777                                                                                                                                                                                              | 7537                                                                                                                                                                                                 | 14127 | 6818                      | 10897     | 44156    |  |
| 2.0       | 1.1       | 4424                                                                                                                                                                                              | 6608                                                                                                                                                                                                 | 13113 | 11706                     | 8372      | 44223    |  |
| 2.0       | 1.2       | 4541                                                                                                                                                                                              | 6868                                                                                                                                                                                                 | 13364 | 10996                     | 8564      | 44333    |  |
| 2.0       | 1.6       | 4802                                                                                                                                                                                              | 7775                                                                                                                                                                                                 | 14537 | 7552                      | 9937      | 44603    |  |
|           |           |                                                                                                                                                                                                   |                                                                                                                                                                                                      |       | Continu                   | ued on ne | ext page |  |

Table B.2: WireMap LUT distribution data. The LUT counts presented are the geometric means of the benchmark suite's mappings. Each row corresponds to the set of mappings created using the specified Weight(6) and Weight(5) values.

|           |           |           | WireMa    | ар    |        |      |       |  |
|-----------|-----------|-----------|-----------|-------|--------|------|-------|--|
|           |           |           |           | LUI   | [ Size |      |       |  |
| Weight(6) | Weight(5) | 2         | 3         | 4     | 5      | 6    | All   |  |
| 2.4       | 1.1       | 5444      | 8909      | 16923 | 12901  | 4336 | 48513 |  |
| 2.4       | 1.2       | 5638 9133 |           | 17289 | 12149  | 4484 | 48693 |  |
| 2.4       | 1.6       | 4782      | 4782 9895 |       | 8190   | 6297 | 48015 |  |
| 2.4       | 2.0       | 4749      | 10624     | 19682 | 6882   | 6600 | 48537 |  |

 Table B.2 – continued from previous page

Table B.3: MO-Map LUT distribution data. The LUT counts presented are the geometric means of the benchmark suite's mappings. Each row corresponds to the set of mappings created using the specified Weight(6) and Weight(5) values.

|           |           |                       | MO-Ma | ap          |         |           |          |
|-----------|-----------|-----------------------|-------|-------------|---------|-----------|----------|
|           |           |                       |       | LUT         | Size    |           |          |
| Weight(6) | Weight(5) | 2                     | 3     | 4           | 5       | 6         | All      |
| 1.0       | 1.0       | 4239                  | 5926  | 9248        | 9257    | 13184     | 41854    |
| 1.1       | 1.0       | 3991                  | 5562  | 9899        | 11811   | 10737     | 42000    |
| 1.2       | 1.0       | 4090                  | 5629  | 10084       | 11891   | 10432     | 42126    |
| 1.3       | 1.0       | 4331                  | 5682  | 10053       | 12231   | 10033     | 42330    |
| 1.4       | 1.0       | 4280                  | 5759  | 10370       | 12839   | 9359      | 42607    |
| 1.5       | 1.0       | 4365                  | 5821  | 10505       | 12972   | 9150      | 42813    |
| 1.6       | 1.0       | 4340                  | 5874  | 10850       | 13537   | 8510      | 43111    |
| 1.7       | 1.0       | 4345                  | 5914  | 10901       | 13632   | 8391      | 43183    |
| 1.8       | 1.0       | 4300 5945 10859 13757 |       |             | 8341    | 43202     |          |
| 1.9       | 1.0       | 4293 5971             |       | 10993       | 13894   | 8147      | 43298    |
| 2.0       | 1.0       | 4272                  | 6116  | 10957 14063 |         | 8027      | 43435    |
| 2.1       | 1.0       | 5434                  | 8427  | 14309       | 15313   | 4167      | 47650    |
| 2.2       | 1.0       | 5307                  | 8392  | 14262       | 15469   | 4137      | 47567    |
| 2.3       | 1.0       | 5310                  | 8399  | 14245       | 15489   | 4142      | 47585    |
| 2.4       | 1.0       | 5354                  | 8413  | 14265       | 15448   | 4143      | 47623    |
| 2.5       | 1.0       | 5363                  | 8418  | 14275       | 15430   | 4148      | 47634    |
| 1.2       | 1.1       | 4244                  | 5750  | 11899       | 8914    | 11309     | 42116    |
|           |           |                       |       |             | Continu | ued on ne | ext page |

|           |           |                       | MO-Ma | ар    |             |       |       |
|-----------|-----------|-----------------------|-------|-------|-------------|-------|-------|
|           |           |                       |       | LUI   | [ Size      |       |       |
| Weight(6) | Weight(5) | 2                     | 3     | 4     | 5           | 6     | All   |
| 1.4       | 1.1       | 4506                  | 5997  | 11602 | 10354       | 10116 | 42575 |
| 1.4       | 1.2       | 4581                  | 6148  | 12252 | 8472        | 11102 | 42555 |
| 1.4       | 1.3       | 4650                  | 6468  | 12623 | 7348        | 11605 | 42694 |
| 1.6       | 1.1       | 4481                  | 6112  | 12295 | 11303       | 8950  | 43141 |
| 1.6       | 1.2       | 4692                  | 6255  | 12368 | 10496       | 9357  | 43168 |
| 1.6       | 1.3       | 4884                  | 6601  | 12556 | 8666        | 10441 | 43148 |
| 1.6       | 1.4       | 4829                  | 6742  | 12880 | 7486        | 11141 | 43078 |
| 1.8       | 1.1       | 4489                  | 6129  | 12460 | 11708       | 8595  | 43381 |
| 1.8       | 1.2       | 4640 6376 12774 11018 |       |       |             | 8722  | 43530 |
| 1.8       | 1.4       | 4906 6907 13969       |       | 8449  | 9626        | 43857 |       |
| 1.8       | 1.6       | 4760                  | 7168  | 13977 | 6903        | 10766 | 43574 |
| 2.0       | 1.1       | 4410                  | 6205  | 13021 | 11813       | 8176  | 43625 |
| 2.0       | 1.2       | 4527 6464 13224 1125  |       |       |             | 8275  | 43744 |
| 2.0       | 1.6       | 4833                  | 7337  | 14540 | 7576        | 9803  | 44089 |
| 2.4       | 1.1       | 5020                  | 8455  | 17085 | 12910       | 4262  | 47732 |
| 2.4       | 1.2       | 5262 8746             |       | 17295 | 17295 12283 |       | 47928 |
| 2.4       | 1.6       | 4654                  | 9596  | 18858 | 8253        | 6092  | 47453 |
| 2.4       | 2.0       | 4650                  | 10385 | 19724 | 6942        | 6299  | 48000 |

 Table B.3 – continued from previous page

## **Appendix C**

# **FLUT utilization - with LUT balancing**

| appings produced with LUT balancing and packed    | f mappings created using the listed Weight(6) and | o the architecture's baseline mapping.            |
|---------------------------------------------------|---------------------------------------------------|---------------------------------------------------|
| Table C.1: Benchmark suite's FLUT utilization get | for the M5 FPGA architecture Each row corres      | Weight(5) values. FLUT percent reduction is calcu |

|     |           | 5     | <i>M5</i> Archi   | tecture |                  |            |                  |
|-----|-----------|-------|-------------------|---------|------------------|------------|------------------|
|     | Weight(5) | FLUTs | sicMap<br>Percent | FLUTs   | remap<br>Percent | FLUTs      | J-Map<br>Percent |
|     | )         |       | Reduction         |         | Reduction        |            | Reduction        |
|     | 1.0       | 756.9 | 0.0%              | 705.7   | 6.8%             | 695.4      | 8.1%             |
| . – | 1.0       | 729.1 | 3.7%              | 704.0   | 7.0%             | 695.7      | 8.1%             |
|     | 1.0       | 726.8 | 4.0%              | 701.4   | 7.3%             | 693.8      | 8.3%             |
| . – | 1.0       | 726.3 | 4.0%              | 700.8   | 7.4%             | 691.7      | 8.6%             |
|     | 1.0       | 729.9 | 3.6%              | 704.0   | 7.0%             | 695.4      | 8.1%             |
| . – | 1.0       | 731.9 | 3.3%              | 704.3   | 7.0%             | 696.0      | 8.0%             |
|     | 1.0       | 733.1 | 3.1%              | 706.7   | 6.6%             | 700.6      | 7.4%             |
| . — | 1.0       | 734.0 | 3.0%              | 707.1   | 6.6%             | 701.5      | 7.3%             |
| . – | 1.0       | 734.9 | 2.9%              | 708.8   | 6.3%             | 701.7      | 7.3%             |
|     | 1.0       | 739.3 | 2.3%              | 712.2   | 5.9%             | 703.0      | 7.1%             |
| . – | 1.0       | 762.7 | -0.8%             | 715.5   | 5.5%             | 704.3      | 6.9%             |
|     | 1.0       | 769.8 | -1.7%             | 728.8   | 3.7%             | 718.0      | 5.1%             |
|     | 1.0       | 769.2 | -1.6%             | 728.7   | 3.7%             | 716.9      | 5.3%             |
|     | 1.0       | 770.5 | -1.8%             | 728.8   | 3.7%             | 717.0      | 5.3%             |
|     | 1.0       | 769.9 | -1.7%             | 728.6   | 3.7%             | 717.5      | 5.2%             |
|     | 1.0       | 770.0 | -1.7%             | 728.4   | 3.8%             | 717.8      | 5.2%             |
|     | 1.1       | 712.1 | 5.9%              | 697.4   | 7.9%             | 690.0      | 8.8%             |
|     | 1.1       | 713.1 | 5.8%              | 698.7   | 7.7%             | 689.5      | 8.9%             |
|     | 1.2       | 712.1 | 5.9%              | 695.5   | 8.1%             | 687.3      | 9.2%             |
|     | 1.3       | 706.4 | 6.7%              | 689.1   | 9.0%             | 683.8      | 9.7%             |
|     |           |       |                   |         | Ŭ                | ontinued o | n next page      |

|                  |          | MO-Map | S Percent | Reduction | 2 8.1% | 7 8.5% | 9.0%  | 3 9.3% | 4 7.9% | 4 8.0% | 3 8.8% | 5 9.3% | ) 7.7% | 4 7.7% | 4 8.9% | 7 5.6% | ) 5.5% | 3 6.1% | ) 6.1% |
|------------------|----------|--------|-----------|-----------|--------|--------|-------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
|                  |          |        | FLUT      |           | 695.2  | 692.7  | 688.7 | 686.3  | 697.4  | 696.2  | 690.3  | 686.6  | 698.9  | 698.4  | 689.4  | 714.7  | 715.0  | 710.8  | 710.9  |
| vious page       |          | reMap  | Percent   | Reduction | 7.2%   | 7.5%   | 8.2%  | 9.0%   | 6.9%   | 7.6%   | 7.9%   | 8.6%   | 6.0%   | 6.1%   | 8.2%   | 4.0%   | 4.0%   | 5.1%   | 4.8%   |
| from pre         | itecture | Wi     | FLUTS     |           | 702.7  | 700.4  | 694.7 | 689.1  | 704.7  | 699.2  | 697.0  | 691.7  | 711.8  | 710.8  | 694.6  | 726.4  | 726.4  | 718.5  | 720.7  |
| – continued      | M5Arch   | sicMap | Percent   | Reduction | 4.8%   | 4.9%   | 6.1%  | 6.9%   | 4.4%   | 4.4%   | 4.8%   | 6.1%   | 3.5%   | 3.5%   | 5.2%   | 1.1%   | 0.8%   | 1.2%   | -0.2%  |
| <b>Fable C.1</b> |          | Clas   | FLUTs     |           | 720.6  | 719.4  | 710.8 | 705.0  | 723.2  | 723.5  | 720.4  | 710.7  | 730.7  | 730.5  | 717.4  | 748.7  | 750.8  | 747.9  | 758.6  |
| Γ,               |          |        | Weight(5) |           | 1.1    | 1.2    | 1.3   | 1.4    | 1.1    | 1.2    | 1.4    | 1.6    | 1.1    | 1.2    | 1.6    | 1.1    | 1.2    | 1.6    | 2.0    |
|                  |          |        | Weight(6) |           | 1.6    | 1.6    | 1.6   | 1.6    | 1.8    | 1.8    | 1.8    | 1.8    | 2.0    | 2.0    | 2.0    | 2.4    | 2.4    | 2.4    | 2.4    |

| 08   |
|------|
| us J |
| vio  |
| pre  |
| m    |
| fro  |
| ed   |
| inu  |
| nti  |
| - C0 |
| 1-   |
| U.   |

|           |           |       | M6Archi   | tecture |           |            |             |
|-----------|-----------|-------|-----------|---------|-----------|------------|-------------|
|           |           | Clas  | sicMap    | Wir     | eMap      | MC         | )-Map       |
| Weight(6) | Weight(5) | FLUTs | Percent   | FLUTs   | Percent   | FLUTs      | Percent     |
|           |           |       | Reduction |         | Reduction |            | Reduction   |
| 1.0       | 1.0       | 691.7 | 0.0%      | 627.4   | 9.3%      | 625.8      | 9.5%        |
| 1.1       | 1.0       | 640.8 | 7.4%      | 618.2   | 10.6%     | 615.4      | 11.0%       |
| 1.2       | 1.0       | 639.5 | 7.6%      | 615.0   | 11.1%     | 612.3      | 11.5%       |
| 1.3       | 1.0       | 638.6 | 7.7%      | 613.5   | 11.3%     | 610.1      | 11.8%       |
| 1.4       | 1.0       | 636.4 | 8.0%      | 610.4   | 11.8%     | 607.3      | 12.2%       |
| 1.5       | 1.0       | 637.0 | 7.9%      | 606.6   | 11.8%     | 607.3      | 12.2%       |
| 1.6       | 1.0       | 637.4 | 7.8%      | 610.0   | 11.8%     | 607.6      | 12.2%       |
| 1.7       | 1.0       | 637.2 | 7.9%      | 6.909   | 11.8%     | 607.5      | 12.2%       |
| 1.8       | 1.0       | 637.7 | 7.8%      | 609.8   | 11.8%     | 607.9      | 12.1%       |
| 1.9       | 1.0       | 640.4 | 7.4%      | 611.6   | 11.6%     | 607.6      | 12.2%       |
| 2.0       | 1.0       | 649.1 | 6.2%      | 612.1   | 11.5%     | 609.7      | 11.9%       |
| 2.1       | 1.0       | 657.6 | 4.9%      | 613.6   | 11.3%     | 608.5      | 12.0%       |
| 2.2       | 1.0       | 657.6 | 4.9%      | 613.6   | 11.3%     | 607.9      | 12.1%       |
| 2.3       | 1.0       | 658.5 | 4.8%      | 614.0   | 11.2%     | 608.2      | 12.1%       |
| 2.4       | 1.0       | 657.8 | 4.9%      | 613.4   | 11.3%     | 608.4      | 12.0%       |
| 2.5       | 1.0       | 657.9 | 4.9%      | 613.3   | 11.3%     | 608.2      | 12.1%       |
| 1.2       | 1.1       | 625.4 | 9.6%      | 614.3   | 11.2%     | 609.7      | 11.9%       |
| 1.4       | 1.1       | 623.4 | 9.9%      | 612.1   | 11.5%     | 608.0      | 12.1%       |
| 1.4       | 1.3       | 622.0 | 10.1%     | 610.8   | 11.7%     | 606.3      | 12.3%       |
| 1.4       | 1.4       | 621.0 | 10.2%     | 609.0   | 12.0%     | 608.8      | 12.0%       |
|           |           |       |           |         | Cc        | ontinued o | n next page |

|             |           | -Map   | Percent   | Reduction | 12.4% | 12.8% | 12.4% | 12.3% | 12.2% | 12.6% | 12.6% | 12.5% | 12.2% | 12.5% | 12.4% | 12.5% | 12.8%  | 13.3% | 13.0% |
|-------------|-----------|--------|-----------|-----------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|--------|-------|-------|
|             |           | MO     | FLUTs     |           | 605.7 | 603.5 | 606.0 | 606.6 | 607.0 | 604.8 | 604.9 | 605.0 | 607.6 | 605.1 | 606.3 | 605.1 | 602.9  | 599.7 | 601.7 |
| vious page  |           | eMap   | Percent   | Reduction | 11.9% | 12.3% | 11.7% | 11.9% | 11.9% | 12.1% | 11.6% | 11.9% | 11.4% | 11.7% | 12.0% | 11.7% | 11.8%  | 12.1% | 11.4% |
| from pre    | tecture   | Wir    | FLUTS     |           | 609.5 | 606.8 | 611.1 | 609.5 | 609.7 | 608.3 | 611.5 | 609.1 | 613.2 | 611.1 | 608.9 | 610.8 | 6.00.9 | 608.1 | 613.2 |
| - continued | M6Archite | sicMap | Percent   | Reduction | 10.0% | 10.3% | 9.6%  | 10.3% | 9.6%  | 10.1% | 9.7%  | 10.1% | 9.8%  | 10.0% | 10.3% | 9.2%  | 9.1%   | 9.3%  | 8.2%  |
| lable C.2 - |           | Class  | FLUTs     |           | 622.2 | 620.1 | 623.0 | 620.5 | 623.3 | 622.2 | 624.5 | 622.2 | 624.1 | 622.5 | 620.7 | 627.9 | 628.7  | 627.2 | 634.8 |
|             |           |        | Weight(5) |           | 1.1   | 1.2   | 1.3   | 1.4   | 1.1   | 1.2   | 1.4   | 1.6   | 1.1   | 1.2   | 1.6   | 1.1   | 1.2    | 1.6   | 2.0   |
|             |           |        | Weight(6) |           | 1.6   | 1.6   | 1.6   | 1.6   | 1.8   | 1.8   | 1.8   | 1.8   | 2.0   | 2.0   | 2.0   | 2.4   | 2.4    | 2.4   | 2.4   |

| þε  |
|-----|
| ns  |
| vio |
| ore |
| n I |
| roi |
| łf  |
| lec |
| nu  |
| tij |
| n   |
| ວ   |
| 1   |
| 2   |
| -   |

| acked     | ) and          |           |
|-----------|----------------|-----------|
| g and pe  | leight(6       |           |
| ulancing  | isted <b>W</b> | pping.    |
| LUT ba    | g the l        | ine ma    |
| d with    | ed usin        | 's basel  |
| roduce    | s creat        | tecture   |
| pings p   | napping        | ne archi  |
| or map    | et of n        | ect to th |
| mean f    | to the s       | ith resp  |
| ometric   | ponds 1        | lated w   |
| tion ge   | corres         | s calcu   |
| utiliza   | ich row        | uction i  |
| S FLUT    | re Ea          | ent red   |
| k suite's | chitectu       | JT perc   |
| chmarl    | GA are         | es. FLI   |
| .3: Ber   | M7 FP          | 5) valu   |
| Table C   | for the        | Weight(   |

|             |         | -Map   | Percent   | Reduction | 15.5% | 15.0% | 13.2% | 12.4% | 15.8% | 15.3% | 13.5% | 12.6% | 16.0% | 15.7% | 13.0% | 15.5% | 15.1% | 13.6% | 12.6% |
|-------------|---------|--------|-----------|-----------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
|             |         | MO     | FLUTs     |           | 559.2 | 563.0 | 574.8 | 579.7 | 557.7 | 560.8 | 573.0 | 578.8 | 556.1 | 558.2 | 576.2 | 559.4 | 562.1 | 571.9 | 578.6 |
| vious page  |         | eMap   | Percent   | Reduction | 14.4% | 13.7% | 12.6% | 10.8% | 14.5% | 14.0% | 12.8% | 10.9% | 14.5% | 14.2% | 11.5% | 14.0% | 13.6% | 11.9% | 10.5% |
| from pre    | tecture | Wir    | FLUTs     |           | 566.8 | 571.2 | 578.8 | 590.4 | 566.0 | 569.1 | 577.1 | 590.1 | 565.9 | 568.2 | 586.2 | 569.2 | 572.0 | 583.1 | 592.3 |
| - continued | M7Archi | sicMap | Percent   | Reduction | 13.9% | 13.4% | 12.5% | 10.9% | 14.0% | 13.5% | 12.7% | 10.8% | 14.1% | 13.8% | 11.7% | 13.3% | 12.8% | 11.6% | 8.8%  |
| Table C.3 - |         | Class  | FLUTs     |           | 570.1 | 573.2 | 579.1 | 589.7 | 569.0 | 572.5 | 578.0 | 590.8 | 568.4 | 570.5 | 584.8 | 573.8 | 577.1 | 584.9 | 603.5 |
| L           |         |        | Weight(5) |           | 1.1   | 1.2   | 1.3   | 1.4   | 1.1   | 1.2   | 1.4   | 1.6   | 1.1   | 1.2   | 1.6   | 1.1   | 1.2   | 1.6   | 2.0   |
|             |         |        | Weight(6) |           | 1.6   | 1.6   | 1.6   | 1.6   | 1.8   | 1.8   | 1.8   | 1.8   | 2.0   | 2.0   | 2.0   | 2.4   | 2.4   | 2.4   | 2.4   |

| ğ           |
|-------------|
| previous    |
| from        |
| - continued |
| C.3 -       |

| an for mappings produced with LUT balancing and packed  | he set of mappings created using the listed Weight(6) and | respect to the architecture's baseline mapping.             |
|---------------------------------------------------------|-----------------------------------------------------------|-------------------------------------------------------------|
| Table C.4: Benchmark suite's FLUT utilization geometric | for the M8 FPGA architecture Each row corresponds to      | Weight(5) values. FLUT percent reduction is calculated with |

|          | 1ap MO-Map | Percent FLUTs Percent | eduction Reduction | 9.3% 590.9 9.9% | 12.4% 564.1 14.0% | 13.0% 561.4 14.4% | 13.4% 559.3 14.8% | 14.3% 550.9 16.0% | 14.5% 550.2 16.1% | 15.3% 546.3 16.7% | 15.3% 545.8 16.8% | 15.4% 545.8 16.8% | 15.4% 544.5 17.0% | 15.5% 544.6 17.0% | 14.0% 553.4 15.7% | 14.0% 552.6 15.8% | 13.9% 552.9 15.7% | 13.9% 553.1 15.7% | 13.9% 553.3 15.7% | 12.1% 573.7 12.6% | 13.0% 561.4 14.4% | 12.0% 573.8 12.6% | 10.1% 581.2 11.4% |
|----------|------------|-----------------------|--------------------|-----------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|
| itecture | WireM      | FLUTs F               | R                  | 595.3           | 575.0             | 570.9             | 568.3             | 562.3             | 560.8             | 556.1             | 555.5             | 555.1             | 554.9             | 554.7             | 564.2             | 564.4             | 564.8             | 565.0             | 565.1             | 577.0             | 571.0             | 577.4             | 589.7             |
| M8Arch   | sicMap     | Percent               | Reduction          | 0.0%            | 12.8%             | 13.3%             | 13.7%             | 15.2%             | 15.4%             | 15.7%             | 15.7%             | 15.8%             | 15.8%             | 16.1%             | 14.4%             | 14.5%             | 14.3%             | 14.4%             | 14.4%             | 12.5%             | 13.4%             | 12.4%             | 10.6%             |
|          | Clas       | FLUTS                 |                    | 656.2           | 572.3             | 568.7             | 566.4             | 556.6             | 555.3             | 553.2             | 553.1             | 552.7             | 552.6             | 550.4             | 561.4             | 561.0             | 562.0             | 561.8             | 561.8             | 574.3             | 568.2             | 574.8             | 586.4             |
|          |            | Weight(5)             |                    | 1.0             | 1.0               | 1.0               | 1.0               | 1.0               | 1.0               | 1.0               | 1.0               | 1.0               | 1.0               | 1.0               | 1.0               | 1.0               | 1.0               | 1.0               | 1.0               | 1.1               | 1.1               | 1.2               | 1.3               |
|          |            | Weight(6)             | I                  | 1.0             | 1.1               | 1.2               | 1.3               | 1.4               | 1.5               | 1.6               | 1.7               | 1.8               | 1.9               | 2.0               | 2.1               | 2.2               | 2.3               | 2.4               | 2.5               | 1.2               | 1.4               | 1.4               | 1.4               |

|             |         | -Map   | Percent   | Reduction | 16.0% | 15.3% | 12.7% | 11.8% | 16.2% | 15.7% | 13.2% | 11.9% | 16.5% | 16.1% | 12.3% | 15.2% | 14.7% | 12.9% | 11.9% |
|-------------|---------|--------|-----------|-----------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
|             |         | MO     | FLUTs     |           | 551.2 | 555.5 | 573.0 | 578.7 | 549.6 | 552.8 | 569.3 | 578.1 | 548.0 | 550.6 | 575.2 | 556.6 | 559.4 | 571.4 | 578.0 |
| vious page  |         | eMap   | Percent   | Reduction | 14.3% | 13.6% | 11.9% | 10.1% | 14.9% | 13.6% | 12.2% | 10.2% | 15.0% | 14.5% | 10.8% | 13.6% | 13.1% | 11.2% | 9.8%  |
| from pre    | tecture | Wir    | FLUTs     |           | 562.4 | 567.0 | 577.8 | 589.9 | 558.5 | 567.2 | 576.4 | 589.5 | 557.9 | 561.3 | 585.6 | 566.6 | 569.9 | 582.8 | 592.0 |
| – continued | M8Archi | sicMap | Percent   | Reduction | 14.9% | 14.1% | 12.4% | 10.6% | 15.5% | 14.8% | 13.5% | 10.5% | 15.7% | 15.1% | 11.6% | 14.3% | 13.6% | 11.7% | 8.4%  |
| Table C.4   |         | Class  | FLUTs     |           | 558.5 | 563.8 | 574.7 | 586.3 | 554.5 | 559.3 | 567.3 | 587.2 | 552.8 | 557.1 | 580.3 | 562.2 | 566.7 | 579.3 | 601.3 |
| L           |         |        | Weight(5) |           | 1.1   | 1.2   | 1.3   | 1.4   | 1.1   | 1.2   | 1.4   | 1.6   | 1.1   | 1.2   | 1.6   | 1.1   | 1.2   | 1.6   | 2.0   |
|             |         |        | Weight(6) |           | 1.6   | 1.6   | 1.6   | 1.6   | 1.8   | 1.8   | 1.8   | 1.8   | 2.0   | 2.0   | 2.0   | 2.4   | 2.4   | 2.4   | 2.4   |

| β        |
|----------|
| ns       |
| io       |
| ev       |
| Id       |
| m        |
| fro      |
| þ        |
| Je       |
| n        |
| Iti      |
| O        |
| ်<br>၂   |
| <u>_</u> |
| 4        |
|          |

| ed with LUT balancing and packed                                            | eated using the listed Weight(6) and                                           | re's baseline mapping.                                                             |
|-----------------------------------------------------------------------------|--------------------------------------------------------------------------------|------------------------------------------------------------------------------------|
| able C.5: Benchmark suite's FLUT utilization geometric mean for mappings pr | or the Stratix II FPGA architecture Each row corresponds to the set of mapping | Veight(5) values. FLUT percent reduction is calculated with respect to the archite |

| Stratix IIArchitecture | lassicMap WireMap MO-Map | S Percent FLUTs Percent FLUTs Percent | Reduction Reduction Reduction | 1 0.0% 602.3 7.5% 597.3 8.3% | 3 9.5% 589.5 9.5% 577.6 11.3% | 4         10.3%         586.2         10.0%         576.3         11.5% | 4         10.3%         583.9         10.3%         576.0         11.5% | <b>)</b> 11.7% <b>578.0</b> 11.2% <b>566.8</b> 13.0% | <u>3 11.9% 577.6 11.3% 567.8 12.8%</u> | <b>)</b> 12.3% <b>571.0</b> 12.3% <b>564.7</b> 13.3% | <u>8 11.9% 575.0 11.7% 562.9 13.5%</u> | <u>8 11.6%</u> 573.7 11.9% 563.9 13.4% | 3 11.6% 571.5 12.2% 564.4 13.3% | 5 12.4% 572.6 12.1% 561.5 13.8% | <b>4</b> 9.8% 582.0 10.6% 576.7 11.4% | 5 9.9% 581.8 10.7% 575.1 11.7% | 7 9.9% 582.0 10.6% 574.7 11.7% | <u>) 10.0%</u> 582.2 10.6% 575.8 11.6% | <u>5 9.9% 581.9 10.6% 575.4 11.6%</u> | <u>3 9.6% 591.8 9.1% 586.4 9.9%</u> | )         10.2%         585.8         10.0%         577.3         11.3% | 4 9.5% 589.7 9.4% 586.5 9.9% | <b>)</b> 7.9% 600.8 7.7% 595.5 8.5% | - |
|------------------------|--------------------------|---------------------------------------|-------------------------------|------------------------------|-------------------------------|-------------------------------------------------------------------------|-------------------------------------------------------------------------|------------------------------------------------------|----------------------------------------|------------------------------------------------------|----------------------------------------|----------------------------------------|---------------------------------|---------------------------------|---------------------------------------|--------------------------------|--------------------------------|----------------------------------------|---------------------------------------|-------------------------------------|-------------------------------------------------------------------------|------------------------------|-------------------------------------|---|
| Stratix IIArchitectur  | ClassicMap W             | UTs Percent FLUTs                     | Reduction                     | 1.1 0.0% 602.3               | 9.3 9.5% 589.5                | 4.4 10.3% 586.2                                                         | 4.4 10.3% 583.9                                                         | 5.0 11.7% 578.0                                      | 3.8 11.9% 577.6                        | 1.0 12.3% 571.0                                      | 3.8 11.9% 575.0                        | 5.8 11.6% 573.7                        | 5.3 11.6% 571.5                 | 0.6 12.4% 572.6                 | 7.4 9.8% 582.0                        | 6.6 9.9% 581.8                 | 6.7 9.9% 582.0                 | 6.0 10.0% 582.2                        | 6.5 9.9% 581.9                        | 8.8 9.6% 591.8                      | 4.9 10.2% 585.8                                                         | 9.4 9.5% 589.7               | 0.0 7.9% 600.8                      | - |
|                        |                          | Weight(5) FL                          |                               | 1.0 65                       | 1.0 58                        | 1.0 58                                                                  | 1.0 58                                                                  | 1.0 57                                               | 1.0 57                                 | 1.0 57                                               | 1.0 57                                 | 1.0 57                                 | 1.0 57                          | 1.0 57                          | 1.0 58                                | 1.0 58                         | 1.0 58                         | 1.0 58                                 | 1.0 58                                | 1.1 58                              | 1.1 58                                                                  | 1.2 58                       | 1.3 60                              | - |
|                        |                          | Weight(6)                             |                               | 1.0                          | 1.1                           | 1.2                                                                     | 1.3                                                                     | 1.4                                                  | 1.5                                    | 1.6                                                  | 1.7                                    | 1.8                                    | 1.9                             | 2.0                             | 2.1                                   | 2.2                            | 2.3                            | 2.4                                    | 2.5                                   | 1.2                                 | 1.4                                                                     | 1.4                          | 1.4                                 |   |

121

|             |              | )-Map  | Percent   | Reduction | 12.9% | 12.6% | 9.7%  | 8.9%  | 13.1% | 12.6% | 10.1% | 9.1%  | 12.8% | 12.6% | 9.2%  | 11.4% | 11.1% | 9.8%  | 8.3%  |
|-------------|--------------|--------|-----------|-----------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
|             |              | MC     | FLUTs     |           | 567.4 | 569.2 | 587.9 | 593.3 | 566.0 | 569.0 | 585.0 | 592.1 | 567.5 | 569.3 | 591.0 | 576.7 | 579.0 | 587.4 | 597.1 |
| vious page  |              | eMap   | Percent   | Reduction | 10.6% | 10.1% | 9.0%  | 7.9%  | 11.6% | 10.0% | 9.0%  | 8.1%  | 11.5% | 11.1% | 8.0%  | 10.0% | 9.5%  | 7.8%  | 6.6%  |
| from pre    | chitecture   | Wir    | FLUTs     |           | 582.3 | 585.2 | 592.8 | 599.9 | 575.9 | 586.3 | 592.2 | 598.6 | 576.2 | 578.8 | 598.8 | 586.1 | 589.1 | 600.6 | 608.3 |
| – continued | Stratix IIAr | sicMap | Percent   | Reduction | 11.2% | 10.5% | 8.7%  | 7.5%  | 12.1% | 11.6% | 10.2% | 7.6%  | 11.9% | 11.2% | 8.6%  | 10.7% | 10.1% | 8.5%  | 5.1%  |
| Table C.5   |              | Clas   | FLUTs     |           | 578.5 | 582.8 | 594.7 | 602.4 | 572.6 | 575.5 | 584.7 | 601.9 | 574.0 | 578.3 | 594.9 | 581.2 | 585.4 | 595.9 | 618.1 |
| L           |              |        | Weight(5) |           | 1.1   | 1.2   | 1.3   | 1.4   | 1.1   | 1.2   | 1.4   | 1.6   | 1.1   | 1.2   | 1.6   | 1.1   | 1.2   | 1.6   | 2.0   |
|             |              |        | Weight(6) |           | 1.6   | 1.6   | 1.6   | 1.6   | 1.8   | 1.8   | 1.8   | 1.8   | 2.0   | 2.0   | 2.0   | 2.4   | 2.4   | 2.4   | 2.4   |

| D2       |  |
|----------|--|
| previous |  |
| from     |  |
| inued    |  |
| cont     |  |
| C.5 –    |  |

\_\_\_\_

\_\_\_\_\_

\_\_\_\_ \_\_\_\_

т

## **Appendix D**

# **VPR Minimum Channel Width**

## **Geometric Means**

Weight(6) and Weight(5) values. Minimum channel width percent difference is calculated with respect to the architecture's balancing and packed for the M5 FPGA architecture.. Each row corresponds to the set of mappings created using the listed Table D.1: Benchmark suite's minimum minimum channel width geometric mean for mappings produced with LUT baseline mapping.

|             |         |        |           |            | -    | -    |      | -    |      | -    | -    | -    | -    |       | -    |      | -     | -     |      |      |
|-------------|---------|--------|-----------|------------|------|------|------|------|------|------|------|------|------|-------|------|------|-------|-------|------|------|
|             |         | D-Map  | Percent   | Difference | 5.8% | 4.6% | 5.2% | 5.7% | 5.7% | 4.0% | 4.0% | 4.9% | 5.2% | 3.1%  | 4.0% | 5.7% | 3.2%  | 5.0%  | 4.5% | 5.7% |
|             |         | M      | MCW       |            | 28.3 | 27.9 | 28.1 | 28.3 | 28.2 | 27.8 | 27.8 | 28.0 | 28.1 | 27.5  | 27.8 | 28.2 | 27.6  | 28.1  | 27.9 | 28.3 |
| evious page |         | reMap  | Percent   | Difference | 5.1% | 3.0% | 3.4% | 5.6% | 6.8% | 3.1% | 4.0% | 4.5% | 5.5% | 2.7%  | 2.8% | 4.2% | 2.4%  | 3.8%  | 5.2% | 5.0% |
| from pr     | tecture | .W     | MCW       |            | 28.1 | 27.5 | 27.6 | 28.2 | 28.5 | 27.5 | 27.8 | 27.9 | 28.2 | 27.4  | 27.5 | 27.8 | 27.4  | 27.7  | 28.1 | 28.1 |
| – continued | M5Archi | sicMap | Percent   | Difference | 3.8% | 1.3% | 1.9% | 3.7% | 4.3% | 0.3% | 2.8% | 1.3% | 3.0% | -0.6% | 0.6% | 4.4% | -0.3% | -0.2% | 2.0% | 0.8% |
| able D.1    |         | Clas   | MCW       |            | 27.7 | 27.1 | 27.2 | 27.7 | 27.9 | 26.8 | 27.5 | 27.1 | 27.5 | 26.6  | 26.9 | 27.9 | 26.6  | 26.7  | 27.3 | 26.9 |
| Ĩ           |         |        | Weight(5) |            | 1.3  | 1.1  | 1.2  | 1.3  | 1.4  | 1.1  | 1.2  | 1.4  | 1.6  | 1.1   | 1.2  | 1.6  | 1.1   | 1.2   | 1.6  | 2.0  |
|             |         |        | Weight(6) |            | 1.4  | 1.6  | 1.6  | 1.6  | 1.6  | 1.8  | 1.8  | 1.8  | 1.8  | 2.0   | 2.0  | 2.0  | 2.4   | 2.4   | 2.4  | 2.4  |
|             |         |        | -         |            |      | -    |      |      |      |      |      |      | -    |       | -    |      |       | -     |      |      |

| ã     |
|-------|
| vious |
| n pre |
| from  |
| nued  |
| ontir |
| J     |
| -     |
|       |

and Weight(5) values. Minimum channel width percent difference is calculated with respect to the architecture's baseline Table D.2: Benchmark suite's minimum channel width geometric mean for mappings produced with LUT balancing and packed for the M6 FPGA architecture.. Each row corresponds to the set of mappings created using the listed Weight(6) mapping.

|           |           |      | M6Archit   | tecture |            |           |             |
|-----------|-----------|------|------------|---------|------------|-----------|-------------|
|           |           | Clas | ssicMap    | .W      | ireMap     | W         | D-Map       |
| Weight(6) | Weight(5) | MCW  | Percent    | MCW     | Percent    | MCW       | Percent     |
|           |           |      | Difference |         | Difference |           | Difference  |
| 1.0       | 1.0       | 29.5 | 0.0%       | 30.8    | 4.5%       | 31.0      | 5.3%        |
| 1.1       | 1.0       | 30.1 | 2.3%       | 31.3    | 6.3%       | 31.4      | 6.4%        |
| 1.2       | 1.0       | 29.9 | 1.6%       | 31.4    | 6.6%       | 31.4      | 6.7%        |
| 1.3       | 1.0       | 30.2 | 2.3%       | 31.4    | 6.6%       | 31.8      | 7.8%        |
| 1.4       | 1.0       | 30.2 | 2.3%       | 31.6    | 7.3%       | 31.6      | 7.1%        |
| 1.5       | 1.0       | 29.9 | 1.6%       | 31.6    | 7.1%       | 31.8      | 8.0%        |
| 1.6       | 1.0       | 29.9 | 1.4%       | 31.4    | 6.5%       | 31.7      | 7.6%        |
| 1.7       | 1.0       | 30.1 | 2.3%       | 31.7    | 7.6%       | 31.6      | 7.4%        |
| 1.8       | 1.0       | 30.1 | 2.1%       | 31.4    | 6.4%       | 31.6      | 7.2%        |
| 1.9       | 1.0       | 29.7 | 0.8%       | 31.0    | 5.2%       | 31.5      | 7.0%        |
| 2.0       | 1.0       | 29.7 | 0.9%       | 31.2    | 5.9%       | 31.7      | 7.4%        |
| 2.1       | 1.0       | 30.3 | 2.7%       | 32.5    | 10.4%      | 33.1      | 12.4%       |
| 2.2       | 1.0       | 29.9 | 1.5%       | 32.3    | 9.6%       | 33.0      | 12.0%       |
| 2.3       | 1.0       | 29.7 | 0.9%       | 32.2    | 9.4%       | 33.0      | 11.9%       |
| 2.4       | 1.0       | 29.9 | 1.6%       | 32.5    | 10.3%      | 32.8      | 11.2%       |
| 2.5       | 1.0       | 29.8 | 1.2%       | 32.9    | 11.6%      | 32.8      | 11.2%       |
| 1.2       | 1.1       | 30.8 | 4.6%       | 31.1    | 5.5%       | 31.7      | 7.6%        |
| 1.4       | 1.1       | 31.4 | 6.5%       | 31.8    | 7.8%       | 32.1      | 9.1%        |
| 1.4       | 1.3       | 31.1 | 5.6%       | 31.6    | 7.2%       | 31.9      | 8.1%        |
|           |           |      |            |         | Co         | ntinued o | n next page |

|                               |         | 0-Map   | Percent   | Difference | 8.4% | 9.0% | 9.3% | 10.9% | 9.5% | 10.0% | 8.3% | 9.6% | 8.7% | 8.2% | 9.2% | 10.0% | 13.1% | 13.6% | 12.3% | 12.8% |
|-------------------------------|---------|---------|-----------|------------|------|------|------|-------|------|-------|------|------|------|------|------|-------|-------|-------|-------|-------|
|                               |         | M       | MCW       |            | 32.0 | 32.1 | 32.2 | 32.7  | 32.3 | 32.4  | 31.9 | 32.3 | 32.0 | 31.9 | 32.2 | 32.4  | 33.3  | 33.5  | 33.1  | 33.3  |
| evious page                   |         | reMap   | Percent   | Difference | 8.7% | 6.1% | 7.7% | 8.8%  | 7.7% | 8.1%  | 7.0% | 8.6% | 9.8% | 6.9% | 8.5% | 8.6%  | 10.3% | 11.7% | 12.2% | 12.6% |
| from pro                      | tecture | !M      | MCW       |            | 32.0 | 31.3 | 31.7 | 32.1  | 31.7 | 31.9  | 31.5 | 32.0 | 32.4 | 31.5 | 32.0 | 32.0  | 32.5  | 32.9  | 33.1  | 33.2  |
| <ul> <li>continued</li> </ul> | M6Archi | ssicMap | Percent   | Difference | 5.9% | 4.7% | 4.0% | 5.7%  | 6.4% | 5.6%  | 5.3% | 6.2% | 8.4% | 5.1% | 6.6% | 6.5%  | 7.9%  | 8.7%  | 9.1%  | 9.1%  |
| able D.2                      |         | Clas    | MCW       |            | 31.2 | 30.9 | 30.6 | 31.1  | 31.3 | 31.1  | 31.0 | 31.3 | 32.0 | 31.0 | 31.4 | 31.4  | 31.8  | 32.0  | 32.2  | 32.1  |
| Ľ                             |         |         | Weight(5) |            | 1.4  | 1.1  | 1.2  | 1.3   | 1.4  | 1.1   | 1.2  | 1.4  | 1.6  | 1.1  | 1.2  | 1.6   | 1.1   | 1.2   | 1.6   | 2.0   |
|                               |         |         | Weight(6) |            | 1.4  | 1.6  | 1.6  | 1.6   | 1.6  | 1.8   | 1.8  | 1.8  | 1.8  | 2.0  | 2.0  | 2.0   | 2.4   | 2.4   | 2.4   | 2.4   |
|                               |         |         |           |            |      |      |      |       |      |       |      |      |      |      |      |       |       |       |       |       |

| b          |
|------------|
| previous   |
| from       |
| continued  |
|            |
| <b>D</b> . |
and Weight(5) values. Minimum channel width percent difference is calculated with respect to the architecture's baseline Table D.3: Benchmark suite's minimum channel width geometric mean for mappings produced with LUT balancing and packed for the M7 FPGA architecture. Each row corresponds to the set of mappings created using the listed Weight(6) mapping.

|           |           |      | M7Archit   | tecture |            |           |             |
|-----------|-----------|------|------------|---------|------------|-----------|-------------|
|           |           | Cla  | ssicMap    | Ŵ       | ireMap     | M         | D-Map       |
| Weight(6) | Weight(5) | MCW  | Percent    | MCW     | Percent    | MCW       | Percent     |
|           |           |      | Difference |         | Difference |           | Difference  |
| 1.0       | 1.0       | 31.3 | 0.0%       | 31.9    | 2.1%       | 33.1      | 6.0%        |
| 1.1       | 1.0       | 32.6 | 4.1%       | 33.2    | 6.1%       | 33.6      | 7.4%        |
| 1.2       | 1.0       | 33.0 | 5.7%       | 33.3    | 6.6%       | 34.0      | 8.7%        |
| 1.3       | 1.0       | 33.1 | 5.7%       | 33.3    | 6.4%       | 34.3      | 9.6%        |
| 1.4       | 1.0       | 33.5 | 7.2%       | 33.8    | 8.0%       | 34.1      | 9.2%        |
| 1.5       | 1.0       | 33.4 | 6.8%       | 33.9    | 8.3%       | 34.2      | 9.4%        |
| 1.6       | 1.0       | 33.5 | 7.0%       | 34.0    | 8.6%       | 34.6      | 10.6%       |
| 1.7       | 1.0       | 33.6 | 7.4%       | 33.9    | 8.3%       | 34.6      | 10.5%       |
| 1.8       | 1.0       | 33.5 | 7.0%       | 33.8    | 8.2%       | 34.5      | 10.2%       |
| 1.9       | 1.0       | 33.6 | 7.3%       | 33.6    | 7.6%       | 34.4      | 10.1%       |
| 2.0       | 1.0       | 33.2 | 6.2%       | 34.2    | 9.4%       | 35.0      | 11.8%       |
| 2.1       | 1.0       | 33.5 | 7.3%       | 34.9    | 11.6%      | 35.9      | 14.8%       |
| 2.2       | 1.0       | 33.7 | 7.8%       | 34.9    | 11.6%      | 35.9      | 14.7%       |
| 2.3       | 1.0       | 33.7 | 7.6%       | 34.9    | 11.5%      | 35.7      | 14.1%       |
| 2.4       | 1.0       | 33.6 | 7.4%       | 34.9    | 11.4%      | 36.1      | 15.5%       |
| 2.5       | 1.0       | 33.7 | 7.6%       | 34.8    | 11.2%      | 36.1      | 15.5%       |
| 1.2       | 1.1       | 33.0 | 5.5%       | 33.2    | 6.1%       | 33.6      | 7.4%        |
| 1.4       | 1.1       | 33.4 | 6.8%       | 34.5    | 10.2%      | 33.4      | 6.8%        |
| 1.4       | 1.2       | 33.1 | 5.8%       | 33.9    | 8.4%       | 32.9      | 5.3%        |
|           |           |      |            |         | Co         | ntinued o | n next page |

|             |         |         |           |            |      |       |      |      |      |      |       |      |      |       |       |      |       |       |       | _     |
|-------------|---------|---------|-----------|------------|------|-------|------|------|------|------|-------|------|------|-------|-------|------|-------|-------|-------|-------|
|             |         | D-Map   | Percent   | Difference | 5.8% | 10.1% | 9.5% | 7.8% | 8.4% | 9.3% | 11.4% | 9.5% | 8.8% | 10.7% | 10.5% | 9.0% | 14.3% | 13.3% | 11.1% | 10.3% |
|             |         | M       | MCW       |            | 33.1 | 34.4  | 34.3 | 33.7 | 33.9 | 34.2 | 34.8  | 34.2 | 34.0 | 34.6  | 34.6  | 34.1 | 35.7  | 35.4  | 34.7  | 34.5  |
| evious page |         | ireMap  | Percent   | Difference | 7.7% | 6.4%  | 7.3% | 6.1% | 3.8% | 6.9% | 8.2%  | 7.1% | 6.0% | 7.3%  | 7.7%  | 6.2% | 11.1% | 12.8% | 9.0%  | 8.8%  |
| from pro    | tecture | !M      | MCW       |            | 33.7 | 33.3  | 33.5 | 33.2 | 32.5 | 33.4 | 33.8  | 33.5 | 33.1 | 33.6  | 33.7  | 33.2 | 34.8  | 35.3  | 34.1  | 34.0  |
| - continued | M7Archi | ssicMap | Percent   | Difference | 5.5% | 5.8%  | 6.1% | 6.8% | 5.8% | 7.9% | 8.5%  | 7.7% | 6.4% | 7.6%  | 7.2%  | 7.8% | 10.9% | 12.0% | 10.6% | 10.9% |
| able D.3    |         | Clas    | MCW       |            | 33.0 | 33.1  | 33.2 | 33.4 | 33.1 | 33.8 | 33.9  | 33.7 | 33.3 | 33.7  | 33.5  | 33.7 | 34.7  | 35.0  | 34.6  | 34.7  |
| Ĩ           |         |         | Weight(5) |            | 1.3  | 1.1   | 1.2  | 1.3  | 1.4  | 1.1  | 1.2   | 1.4  | 1.6  | 1.1   | 1.2   | 1.6  | 1.1   | 1.2   | 1.6   | 2.0   |
|             |         |         | Weight(6) |            | 1.4  | 1.6   | 1.6  | 1.6  | 1.6  | 1.8  | 1.8   | 1.8  | 1.8  | 2.0   | 2.0   | 2.0  | 2.4   | 2.4   | 2.4   | 2.4   |
|             |         | -       |           |            |      |       |      | -    |      |      |       |      | -    |       | -     |      |       | -     |       | -     |

| b           |
|-------------|
| previous    |
| from        |
| continued   |
| I           |
| <b>D.</b> 3 |

and Weight(5) values. Minimum channel width percent difference is calculated with respect to the architecture's baseline Table D.4: Benchmark suite's minimum channel width geometric mean for mappings produced with LUT balancing and packed for the M8 FPGA architecture.. Each row corresponds to the set of mappings created using the listed Weight(6) mapping.

|           |           |      | M8Archit   | tecture |            |           |             |
|-----------|-----------|------|------------|---------|------------|-----------|-------------|
|           |           | Clat | ssicMap    | Ŵ       | ireMap     | M         | D-Map       |
| Weight(6) | Weight(5) | MCW  | Percent    | MCW     | Percent    | MCW       | Percent     |
|           |           |      | Difference |         | Difference |           | Difference  |
| 1.0       | 1.0       | 31.8 | 0.0%       | 32.8    | 3.3%       | 33.7      | 6.0%        |
| 1.1       | 1.0       | 33.9 | 6.8%       | 33.5    | 5.5%       | 34.2      | 7.7%        |
| 1.2       | 1.0       | 34.6 | 9.0%       | 33.4    | 5.1%       | 34.0      | 6.9%        |
| 1.3       | 1.0       | 34.5 | 8.6%       | 34.0    | 7.0%       | 34.1      | 7.2%        |
| 1.4       | 1.0       | 35.0 | 10.3%      | 34.3    | 7.9%       | 34.7      | 9.3%        |
| 1.5       | 1.0       | 34.9 | 9.9%       | 34.0    | 7.0%       | 34.8      | 9.7%        |
| 1.6       | 1.0       | 35.0 | 10.1%      | 34.1    | 7.3%       | 34.5      | 8.7%        |
| 1.7       | 1.0       | 35.0 | 10.1%      | 34.5    | 8.5%       | 34.9      | 9.9%        |
| 1.8       | 1.0       | 35.1 | 10.6%      | 34.7    | 9.2%       | 35.0      | 10.1%       |
| 1.9       | 1.0       | 35.1 | 10.6%      | 34.4    | 8.2%       | 34.8      | 9.5%        |
| 2.0       | 1.0       | 35.4 | 11.4%      | 34.7    | 9.3%       | 35.1      | 10.5%       |
| 2.1       | 1.0       | 35.9 | 13.0%      | 35.6    | 12.1%      | 36.3      | 14.3%       |
| 2.2       | 1.0       | 36.4 | 14.5%      | 35.6    | 12.0%      | 36.3      | 14.2%       |
| 2.3       | 1.0       | 36.1 | 13.6%      | 35.4    | 11.5%      | 36.7      | 15.5%       |
| 2.4       | 1.0       | 36.0 | 13.3%      | 35.6    | 12.1%      | 36.6      | 15.3%       |
| 2.5       | 1.0       | 36.2 | 13.9%      | 35.7    | 12.5%      | 36.7      | 15.6%       |
| 1.2       | 1.1       | 33.7 | 6.0%       | 33.4    | 5.2%       | 33.9      | 6.6%        |
| 1.4       | 1.1       | 34.3 | 8.1%       | 33.9    | 6.7%       | 34.3      | 7.9%        |
| 1.4       | 1.2       | 33.8 | 6.5%       | 33.5    | 5.3%       | 34.3      | 8.0%        |
|           |           |      |            |         | Co         | ntinued o | n next page |

|          |                |                                                        |                                                                                        |                                                                                                                      | r –                                                                                                                                                                         |                                                                                                                                                                                                                     | 1                                                       |                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                                        | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------|----------------|--------------------------------------------------------|----------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | D-Map          | Percent                                                | Difference                                                                             | 6.7%                                                                                                                 | 8.9%                                                                                                                                                                        | 9.5%                                                                                                                                                                                                                | 7.3%                                                    | 6.9%                                                                                                                                                                                                                                                                                                                                                                                     | 10.6%                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 8.8%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 9.5%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 7.4%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 8.9%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 9.3%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 8.8%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 14.5%                                                  | 14.7%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 12.1%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 9.1%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|          | M              | MCW                                                    |                                                                                        | 33.9                                                                                                                 | 34.6                                                                                                                                                                        | 34.8                                                                                                                                                                                                                | 34.1                                                    | 33.9                                                                                                                                                                                                                                                                                                                                                                                     | 35.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 34.6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 34.8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 34.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 34.6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 34.7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 34.5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 36.4                                                   | 36.4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 35.6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 34.6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|          | reMap          | Percent                                                | Difference                                                                             | 5.3%                                                                                                                 | 7.3%                                                                                                                                                                        | 7.8%                                                                                                                                                                                                                | 6.0%                                                    | 3.3%                                                                                                                                                                                                                                                                                                                                                                                     | 8.5%                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 8.1%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 6.1%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 4.5%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 8.4%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 7.6%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 7.1%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 12.6%                                                  | 13.3%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 11.3%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 10.3%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| tecture  | Wi             | MCW                                                    |                                                                                        | 33.4                                                                                                                 | 34.1                                                                                                                                                                        | 34.3                                                                                                                                                                                                                | 33.7                                                    | 32.8                                                                                                                                                                                                                                                                                                                                                                                     | 34.5                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 34.3                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 33.7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 33.2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 34.4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 34.2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 34.0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 35.8                                                   | 36.0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 35.4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 35.0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| M8Archit | ssicMap        | Percent                                                | Difference                                                                             | 5.9%                                                                                                                 | 9.1%                                                                                                                                                                        | 8.5%                                                                                                                                                                                                                | 7.8%                                                    | 6.1%                                                                                                                                                                                                                                                                                                                                                                                     | 10.5%                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 9.6%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 9.2%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 7.2%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 10.9%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 9.6%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 10.8%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 14.7%                                                  | 14.1%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 13.6%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 10.8%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|          | Clas           | MCW                                                    |                                                                                        | 33.6                                                                                                                 | 34.7                                                                                                                                                                        | 34.5                                                                                                                                                                                                                | 34.3                                                    | 33.7                                                                                                                                                                                                                                                                                                                                                                                     | 35.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 34.8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 34.7                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 34.0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 35.2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 34.8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 35.2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 36.4                                                   | 36.2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 36.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 35.2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|          |                | Weight(5)                                              |                                                                                        | 1.3                                                                                                                  | 1.1                                                                                                                                                                         | 1.2                                                                                                                                                                                                                 | 1.3                                                     | 1.4                                                                                                                                                                                                                                                                                                                                                                                      | 1.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1.2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 1.4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1.6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1.1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 1.2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1.6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 1.1                                                    | 1.2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1.6                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 2.0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|          |                | Weight(6)                                              |                                                                                        | 1.4                                                                                                                  | 1.6                                                                                                                                                                         | 1.6                                                                                                                                                                                                                 | 1.6                                                     | 1.6                                                                                                                                                                                                                                                                                                                                                                                      | 1.8                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 1.8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 1.8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1.8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 2.0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 2.0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 2.0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 2.4                                                    | 2.4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 2.4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 2.4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|          | M8Architecture | M8Architecture       ClassicMap     WireMap     MO-Map | M8ArchitectureM8ArchitectureClassicMapWireMapWeight(6)Weight(5)MCWPercentMCWPercentMCW | M8ArchitectureM8ArchitectureClassicMapWireMapWeight(5)WCWPercentWeight(5)MCWPercentMCWPercentMCWDifferenceDifference | M8ArchitectureM8ArchitectureWeight(5)ClassicMapWireMapWeight(5)MCWPercentMO-MapWeight(5)WCWPercentMCW1.41.333.6 $5.9%$ $33.4$ $5.3%$ 1.41.333.6 $5.9%$ $33.4$ $5.3%$ $33.9$ | M8ArchitectureM8ArchitectureWeight(6)Weight(5)MCWPercentMO-MapWeight(6)Weight(5)MCWPercentMCWNoteMCWPercentMCWPercent1.41.333.6 $5.9%$ $33.4$ $5.3%$ $33.9$ $6.7%$ 1.61.1 $34.7$ $9.1%$ $34.1$ $7.3%$ $34.6$ $8.9%$ | $ \begin{array}{c c c c c c c c c c c c c c c c c c c $ | M8ArchitectureWeight(6)Weight(5)ClassicMapWireMapMO-MapWeight(6)Weight(5)MCWPercentMCWPercent1.41.333.6 $5.9%$ $33.4$ $5.3%$ $33.9$ $6.7%$ 1.61.1 $34.7$ $9.1%$ $34.1$ $7.3%$ $34.6$ $8.9%$ 1.61.2 $34.5$ $8.5%$ $34.3$ $7.8%$ $34.8$ $9.5%$ 1.61.3 $34.3$ $7.8%$ $34.1$ $7.3%$ $34.8$ $9.5%$ 1.61.3 $34.3$ $7.8%$ $34.1$ $7.3%$ $34.8$ $9.5%$ 1.61.3 $34.3$ $7.8%$ $34.1$ $7.3%$ $9.5%$ | M8ArchitectureWeight(6)Ueight(5)ClassicMapWireMapMO-MapWeight(6)Weight(5)MCWPercentMCWPercentWeight(6)Weight(5)MCWPercentMCWPercent1.41.333.6 $5.9%$ $33.4$ $5.3%$ $33.9$ $6.7%$ 1.61.1 $34.7$ $9.1%$ $34.1$ $7.3%$ $34.6$ $8.9%$ 1.61.2 $34.5$ $8.5%$ $34.3$ $7.8%$ $34.6$ $8.9%$ 1.61.3 $34.3$ $7.8%$ $33.7$ $6.0%$ $34.1$ $7.3%$ 1.61.433.7 $6.1%$ $33.7$ $6.0%$ $34.1$ $7.3%$ 1.61.4 $33.7$ $6.1%$ $33.7$ $6.0%$ $34.1$ $7.3%$ 1.61.4 $33.7$ $6.1%$ $32.8$ $3.3%$ $6.9%$ | M8ArchitectureWeight(6)Weight(5)MCWPercentWireMapMO-MapWeight(6)Weight(5)MCWPercentMCWPercent1.41.333.6 $5.9%$ $33.4$ $5.3%$ $33.9$ $6.7%$ 1.61.1 $34.7$ $9.1%$ $34.1$ $7.3%$ $34.6$ $8.9%$ 1.61.1 $34.7$ $9.1%$ $34.3$ $7.8%$ $34.6$ $8.9%$ 1.61.2 $34.5$ $8.5%$ $34.3$ $7.8%$ $34.6$ $8.9%$ 1.61.3 $34.3$ $7.8%$ $34.6$ $8.9%$ 1.61.3 $34.5$ $8.5%$ $34.3$ $7.8%$ $9.5%$ 1.61.3 $34.3$ $7.8%$ $34.1$ $7.3%$ 1.61.3 $34.3$ $7.8%$ $34.1$ $7.3%$ 1.61.4 $33.7$ $6.1%$ $34.1$ $7.3%$ 1.81.1 $35.1$ $10.5%$ $34.5$ $8.5%$ $37.1$ | <i>M8</i> ArchitectureWeight(6)Weight(5)MCWPercentWireMapM0-MapWeight(6)Weight(5)MCWPercentMCWPercent1.41.3 $33.6$ $5.9\%$ $33.4$ $5.3\%$ $33.9$ $6.7\%$ 1.61.1 $34.7$ $9.1\%$ $34.1$ $7.3\%$ $34.6$ $8.9\%$ 1.61.1 $34.7$ $9.1\%$ $34.1$ $7.3\%$ $34.6$ $8.9\%$ 1.61.2 $34.5$ $8.5\%$ $34.3$ $7.8\%$ $34.6$ $8.9\%$ 1.61.3 $34.3$ $7.8\%$ $34.3$ $7.8\%$ $34.6$ $8.9\%$ 1.61.3 $34.3$ $7.8\%$ $34.3$ $7.8\%$ $9.5\%$ 1.61.3 $34.3$ $7.8\%$ $33.7$ $6.0\%$ $34.1$ $7.3\%$ 1.61.4 $33.7$ $6.1\%$ $32.8$ $3.3.9$ $6.9\%$ 1.81.1 $35.1$ $10.5\%$ $34.5$ $8.5\%$ $34.6$ $8.8\%$ 1.81.2 $34.8$ $9.6\%$ $34.3$ $8.1\%$ $8.6\%$ | <i>M</i> SArchitecture <i>Meight(5)C</i> lassicMap <i>W</i> ireMapMO-Map <i>Weight(5)C</i> LassicMap <i>W</i> ireMap <i>MO-MapWeight(5)MCWPercentMCWPercentWeight(5)MCWPercentMCWPercentWeight(5)MCWPercentMCWPercentWeight(5)MCWPercentMCWPercentWeight(5)MCWPercentMCWPercentUtel</i> 11.333.6 $5.9\%$ $33.4$ $5.3\%$ $33.9$ $6.7\%$ <i>1.6</i> 1.1 $34.7$ $9.1\%$ $34.1$ $7.3\%$ $34.6$ $8.9\%$ <i>1.6</i> 1.2 $34.5$ $8.5\%$ $34.3$ $7.8\%$ $34.3$ $7.8\%$ <i>1.6</i> 1.3 $34.3$ $7.8\%$ $34.3$ $7.8\%$ $34.6$ $8.9\%$ <i>1.6</i> 1.4 $33.7$ $6.1\%$ $34.6$ $8.9\%$ <i>1.8</i> 1.1 $35.1$ $10.5\%$ $34.3$ $8.1\%$ $9.5\%$ <i>1.8</i> 1.4 $34.7$ $9.2\%$ $33.7$ $6.1\%$ $34.8$ $9.5\%$ | M8ArchitectureWeight(6)Weight(5)M8ArchitectureWeight(6)Weight(5)MCWPercentM0-MapWeight(6)Weight(5)MCWPercentMCW1.41.333.6 $5.9\%$ $33.4$ $5.3\%$ $33.9$ $6.7\%$ 1.61.1 $34.7$ $9.1\%$ $34.1$ $7.3\%$ $34.6$ $8.9\%$ 1.61.1 $34.3$ $7.8\%$ $34.3$ $7.8\%$ $34.1$ $7.3\%$ 1.61.2 $34.3$ $7.8\%$ $34.3$ $7.8\%$ $9.5\%$ 1.61.3 $34.3$ $7.8\%$ $34.1$ $7.3\%$ $9.5\%$ 1.61.3 $34.3$ $7.8\%$ $34.1$ $7.3\%$ $9.5\%$ 1.61.4 $33.7$ $6.1\%$ $32.8$ $3.3.9$ $6.9\%$ 1.81.1 $35.1$ $10.5\%$ $34.5$ $8.5\%$ $34.6$ $8.8\%$ 1.81.4 $34.7$ $9.2\%$ $34.3$ $8.1\%$ $9.5\%$ 1.81.4 $34.7$ $9.2\%$ $33.7$ $6.1\%$ $34.8$ $9.5\%$ 1.81.4 $34.7$ $9.2\%$ $34.1$ $7.4\%$ $34.8$ $9.5\%$ 1.81.6 $34.0$ $7.2\%$ $33.2$ $4.5\%$ $9.5\%$ 1.81.6 $34.0$ $7.2\%$ $33.2$ $4.5\%$ $9.5\%$ | M8ArchitectureWeight(6)ClassicMapWireMapM0-MapWeight(5)MCWPercentMCWPercentWeight(6)Weight(7)MCWPercentMCW1.41.3 $33.6$ $5.9\%$ $33.4$ $5.3\%$ $33.9$ 6.7\%1.61.1 $34.7$ $9.1\%$ $34.1$ $7.3\%$ $34.6$ $8.9\%$ 1.61.1 $34.7$ $9.1\%$ $34.1$ $7.3\%$ $34.6$ $8.9\%$ 1.61.2 $34.5$ $8.5\%$ $34.3$ $7.8\%$ $34.6$ $8.9\%$ 1.61.3 $34.3$ $7.8\%$ $34.3$ $7.8\%$ $34.6$ $8.9\%$ 1.61.3 $34.3$ $7.8\%$ $34.3$ $7.8\%$ $9.5\%$ 1.61.4 $33.7$ $6.0\%$ $34.1$ $7.3\%$ 1.81.1 $35.1$ $10.5\%$ $34.5$ $8.5\%$ $33.9$ $6.9\%$ 1.81.1 $35.1$ $10.5\%$ $34.3$ $8.1\%$ $9.5\%$ 1.81.4 $34.7$ $9.2\%$ $33.7$ $6.1\%$ $34.6$ $8.8\%$ 1.81.6 $34.0$ $7.2\%$ $33.2$ $4.5\%$ $34.1$ $7.4\%$ 2.01.1 $35.2$ $10.9\%$ $34.4$ $8.4\%$ $9.5\%$ | M8ArchitectureWeight(6)ClassicMapWireMapM0-MapWeight(5)MCWPercentMCWPercentWeight(5)MCWPercentMCWPercent1.41.333.6 $5.9\%$ $33.4$ $5.3\%$ $33.9$ $6.7\%$ 1.61.1 $34.7$ $9.1\%$ $34.1$ $7.3\%$ $34.6$ $8.9\%$ 1.61.1 $34.7$ $9.1\%$ $34.1$ $7.3\%$ $34.6$ $8.9\%$ 1.61.2 $34.3$ $7.8\%$ $34.1$ $7.3\%$ $34.6$ $8.9\%$ 1.61.2 $34.3$ $7.8\%$ $34.3$ $7.8\%$ $34.1$ $7.3\%$ 1.61.2 $34.3$ $7.8\%$ $34.3$ $7.8\%$ $34.1$ $7.3\%$ 1.61.2 $34.3$ $7.8\%$ $34.3$ $7.8\%$ $34.1$ $7.3\%$ 1.61.1 $35.1$ $10.5\%$ $34.3$ $34.6$ $8.9\%$ 1.81.1 $35.1$ $10.5\%$ $34.3$ $8.1\%$ $9.5\%$ 1.81.4 $34.7$ $9.2\%$ $34.4$ $8.4\%$ $9.5\%$ 1.81.6 $34.0$ $7.2\%$ $34.4$ $8.4\%$ $9.5\%$ 2.01.1 $35.2$ $10.9\%$ $34.1$ $7.4\%$ 2.01.1 $35.2$ $10.9\%$ $34.1$ $7.4\%$ 2.01.1 $35.2$ $10.9\%$ $34.1$ $7.4\%$ | $\begin{array}{ c c c c c c c c c c c c c c c c c c c$ | M8ArchitectureWeight(6)Weight(5)MCWPercentM0-MapWeight(5)MCWPercentDifferenceDifference11.411.333.6 $5.9\%$ $33.4$ $5.3\%$ $33.9$ $6.7\%$ 11.611.1 $34.7$ $9.1\%$ $34.1$ $7.3\%$ $34.6$ $8.9\%$ 11.611.1 $34.7$ $9.1\%$ $34.1$ $7.3\%$ $34.6$ $8.9\%$ 11.611.2 $34.3$ $7.8\%$ $34.6$ $8.9\%$ 11.611.3 $34.3$ $7.8\%$ $34.1$ $7.3\%$ 11.611.2 $34.3$ $7.8\%$ $34.1$ $7.3\%$ 11.611.3 $34.3$ $7.8\%$ $34.1$ $7.3\%$ 11.611.4 $33.7$ $6.1\%$ $34.1$ $7.3\%$ 11.811.1 $35.1$ $10.5\%$ $34.3$ $8.1\%$ $9.5\%$ 11.811.1 $35.1$ $10.5\%$ $34.3$ $8.1\%$ $9.5\%$ 11.811.1 $35.1$ $10.5\%$ $34.3$ $8.1\%$ $9.5\%$ 11.811.1 $35.2$ $10.9\%$ $34.4$ $8.4\%$ $9.5\%$ 12.011.1 $35.2$ $10.9\%$ $34.4$ $8.9\%$ $9.5\%$ 2.011.1 $35.2$ $10.9\%$ $34.4$ $8.9\%$ $9.5\%$ 2.011.1 $35.2$ $10.9\%$ $34.1$ $7.4\%$ $9.5\%$ 2.011.1 $35.2$ $10.9\%$ $34.1$ $7.4\%$ $9.5\%$ 2.011.1 $35.2$ $10.9\%$ $34.0$ | M8ArchitectureWeight(6)Weight(5)MCWPercentMO-MapWeight(6)Weight(5)MCWPercentMCWNercentMCWPercentMCW11.41.3 $33.6$ $5.9\%$ $33.4$ $5.3\%$ 11.61.1 $34.7$ $9.1\%$ $34.1$ $7.3\%$ $34.6$ 11.61.1 $34.7$ $9.1\%$ $34.1$ $7.3\%$ $34.6$ 11.61.2 $34.5$ $8.5\%$ $34.3$ $7.8\%$ $34.6$ 11.61.3 $34.5$ $8.5\%$ $34.3$ $7.8\%$ $34.6$ 11.61.3 $34.7$ $9.1\%$ $34.6$ $8.9\%$ 11.61.4 $33.7$ $6.1\%$ $34.6$ $8.8\%$ 11.61.4 $33.7$ $6.1\%$ $34.6$ $8.8\%$ 11.61.1 $35.1$ $10.5\%$ $34.5$ $8.5\%$ $34.1$ $7.3\%$ 11.81.1 $35.1$ $10.5\%$ $34.5$ $8.5\%$ $34.6$ $8.8\%$ 11.81.1 $35.2$ $10.5\%$ $34.5$ $8.1\%$ $9.5\%$ 11.81.1 $35.2$ $10.9\%$ $34.6$ $8.9\%$ $34.6$ $8.9\%$ 12.011.81.1 $35.2$ $10.9\%$ $34.6$ $8.9\%$ 12.011.1 $35.2$ $10.9\%$ $34.6$ $8.9\%$ $34.6$ 2.011.1 $35.2$ $10.9\%$ $34.6$ $8.9\%$ 2.011.1 $35.2$ $10.9\%$ $34.7$ $9.5\%$ 2.11.1 $36.4$ $1$ | M8ArchitectureWeight(6)Weight(5)MCWPercentMO-MapWeight(6)Weight(5)MCWPercentMCWNCWPercentDifferenceDifference1.41.3 $33.6$ $5.9\%$ $33.4$ $5.3\%$ $39.9$ $6.7\%$ $31.1$ $7.3\%$ $33.9$ $6.7\%$ $1.6$ 1.1 $34.7$ $9.1\%$ $34.1$ $7.3\%$ $34.6$ $8.9\%$ $1.6$ 1.1 $34.7$ $9.1\%$ $34.1$ $7.3\%$ $34.6$ $8.9\%$ $1.6$ 1.2 $34.5$ $8.5\%$ $34.1$ $7.3\%$ $39.6$ $1.6$ 1.2 $34.5$ $8.5\%$ $34.1$ $7.3\%$ $1.6$ 1.2 $34.5$ $8.5\%$ $34.1$ $7.3\%$ $1.6$ 1.1 $35.1$ $10.5\%$ $34.5$ $8.5\%$ $34.6$ $8.9\%$ $1.8$ 1.1 $35.1$ $10.5\%$ $34.5$ $8.5\%$ $34.6$ $8.9\%$ $1.8$ 1.1 $35.1$ $10.5\%$ $34.5$ $8.1\%$ $34.6$ $8.9\%$ $1.8$ 1.1 $35.1$ $10.5\%$ $34.4$ $8.4\%$ $9.5\%$ $2.0$ 1.1 $35.2$ $10.9\%$ $34.4$ $8.4\%$ $9.5\%$ $2.0$ 1.1 $35.2$ $10.8\%$ $34.6$ $8.9\%$ $2.0$ 1.1 $35.4$ $14.7\%$ $34.6$ $8.4\%$ $2.0$ 1.1 $36.4$ $14.7\%$ $2.4$ $34.1$ $14.7\%$ $2.4$ 1.1 $36.1$ $13.6\%$ $35.4$ $14.7\%$ <tr< th=""></tr<> |

| pa          |
|-------------|
| previous    |
| from        |
| tinued      |
| – con       |
| <b>D.</b> 4 |

**Appendix E** 

# **VPR Wirelength Geometric Means**

| nappings produced with LUT balancing and packed for the | mappings created using the listed Weight(6) and Weight(5) | st to the architecture's baseline mapping.              |
|---------------------------------------------------------|-----------------------------------------------------------|---------------------------------------------------------|
| Benchmark suite's wirelength geometric mean for m       | architecture Each row corresponds to the set of n         | irelength percent difference is calculated with respect |
| Table E.1.                                              | M5 FPG <sup>A</sup>                                       | values. W                                               |

|           |           |            | M5Arc      | hitecture  |            |             |              |
|-----------|-----------|------------|------------|------------|------------|-------------|--------------|
|           |           | Classic    | cMap       | Wire       | Map        | -OM         | Map          |
| Veight(6) | Weight(5) | Wirelength | Percent    | Wirelength | Percent    | Wirelength  | Percent      |
|           |           |            | Difference |            | Difference |             | Difference   |
| 1.0       | 1.0       | 26.7       | 0.0%       | 28.1       | 5.1%       | 27.7        | 3.6%         |
| 1.1       | 1.0       | 27.4       | 2.4%       | 27.8       | 3.9%       | 27.5        | 2.9%         |
| 1.2       | 1.0       | 27.3       | 2.2%       | 27.6       | 3.2%       | 27.6        | 3.3%         |
| 1.3       | 1.0       | 27.2       | 1.9%       | 27.3       | 2.3%       | 27.7        | 3.7%         |
| 1.4       | 1.0       | 26.8       | 0.4%       | 27.5       | 2.8%       | 27.8        | 4.1%         |
| 1.5       | 1.0       | 27.0       | 1.1%       | 27.3       | 2.0%       | 27.7        | 3.6%         |
| 1.6       | 1.0       | 26.7       | 0.0%       | 27.2       | 1.7%       | 27.4        | 2.4%         |
| 1.7       | 1.0       | 27.2       | 1.7%       | 27.9       | 4.4%       | 27.9        | 4.5%         |
| 1.8       | 1.0       | 27.2       | 1.7%       | 27.6       | 3.3%       | 28.1        | 5.1%         |
| 1.9       | 1.0       | 26.9       | 0.7%       | 27.3       | 2.1%       | 27.9        | 4.5%         |
| 2.0       | 1.0       | 26.3       | -1.4%      | 27.3       | 2.2%       | 27.7        | 3.8%         |
| 2.1       | 1.0       | 26.4       | -1.1%      | 27.2       | 1.9%       | 27.7        | 3.8%         |
| 2.2       | 1.0       | 26.3       | -1.6%      | 26.9       | 0.8%       | 27.7        | 3.7%         |
| 2.3       | 1.0       | 26.3       | -1.6%      | 27.3       | 2.1%       | 27.7        | 3.6%         |
| 2.4       | 1.0       | 26.3       | -1.4%      | 27.1       | 1.3%       | 27.8        | 4.2%         |
| 2.5       | 1.0       | 26.3       | -1.6%      | 27.5       | 2.8%       | 27.8        | 3.9%         |
| 1.2       | 1.1       | 27.6       | 3.1%       | 27.5       | 3.0%       | 27.5        | 3.0%         |
| 1.4       | 1.1       | 27.2       | 1.9%       | 27.7       | 3.7%       | 27.9        | 4.5%         |
| 1.4       | 1.2       | 27.4       | 2.5%       | 27.9       | 4.6%       | 28.0        | 4.7%         |
| 1.4       | 1.3       | 27.7       | 3.8%       | 28.1       | 5.1%       | 28.3        | 5.8%         |
|           |           |            |            |            |            | Continued o | in next page |

### APPENDIX E. VPR WIRELENGTH GEOMETRIC MEANS

|               |           | Map     | Percent    | Difference | 4.6% | 5.2% | 5.7% | 5.7% | 4.0% | 4.0% | 4.9% | 5.2% | 3.1%  | 4.0% | 5.7% | 3.2%  | 5.0%  | 4.5% | 5.7% |
|---------------|-----------|---------|------------|------------|------|------|------|------|------|------|------|------|-------|------|------|-------|-------|------|------|
|               |           | NO-I    | Wirelength |            | 27.9 | 28.1 | 28.3 | 28.2 | 27.8 | 27.8 | 28.0 | 28.1 | 27.5  | 27.8 | 28.2 | 27.6  | 28.1  | 27.9 | 28.3 |
| ous page      |           | Map     | Percent    | Difference | 3.0% | 3.4% | 5.6% | 6.8% | 3.1% | 4.0% | 4.5% | 5.5% | 2.7%  | 2.8% | 4.2% | 2.4%  | 3.8%  | 5.2% | 5.0% |
| d from previ  | hitecture | Wire    | Wirelength |            | 27.5 | 27.6 | 28.2 | 28.5 | 27.5 | 27.8 | 27.9 | 28.2 | 27.4  | 27.5 | 27.8 | 27.4  | 27.7  | 28.1 | 28.1 |
| .1 – continue | M5Arc]    | cMap    | Percent    | Difference | 1.3% | 1.9% | 3.7% | 4.3% | 0.3% | 2.8% | 1.3% | 3.0% | -0.6% | 0.6% | 4.4% | -0.3% | -0.2% | 2.0% | 0.8% |
| Table E       |           | Classic | Wirelength |            | 27.1 | 27.2 | 27.7 | 27.9 | 26.8 | 27.5 | 27.1 | 27.5 | 26.6  | 26.9 | 27.9 | 26.6  | 26.7  | 27.3 | 26.9 |
|               |           |         | Weight(5)  |            | 1.1  | 1.2  | 1.3  | 1.4  | 1.1  | 1.2  | 1.4  | 1.6  | 1.1   | 1.2  | 1.6  | 1.1   | 1.2   | 1.6  | 2.0  |
|               |           |         | Weight(6)  |            | 1.6  | 1.6  | 1.6  | 1.6  | 1.8  | 1.8  | 1.8  | 1.8  | 2.0   | 2.0  | 2.0  | 2.4   | 2.4   | 2.4  | 2.4  |

| width geometric mean for mappings produced with LUT balancing and packed | ow corresponds to the set of mappings created using the listed Weight(6) and | erence is calculated with respect to the architecture's baseline mapping. |
|--------------------------------------------------------------------------|------------------------------------------------------------------------------|---------------------------------------------------------------------------|
| elength width geometric n                                                | Each row corresponds to                                                      | cent difference is calculate                                              |
| e E.2: Benchmark suite's wirel                                           | he M6 FPGA architecture E                                                    | tht(5) values. Wirelength percer                                          |
| Tablé                                                                    | for the                                                                      | Weig                                                                      |

|           | č          | M6Arc                   | hitecture  |                       |             |                       |
|-----------|------------|-------------------------|------------|-----------------------|-------------|-----------------------|
|           | Classic    | cMap                    | Wire       | Map                   | MO-]        | Map                   |
| Veight(5) | Wirelength | Different<br>Difference | Wirelength | Percent<br>Difference | Wirelength  | Percent<br>Difference |
| 1 0       | 205        |                         | 30.8       | 4 50%                 | 31.0        | 5 30%                 |
| 1.0       | 30.1       | 2.3%                    | 31.3       | 6.3%                  | 31.4        | 6.4%                  |
| 1.0       | 29.9       | 1.6%                    | 31.4       | 6.6%                  | 31.4        | 6.7%                  |
| 1.0       | 30.2       | 2.3%                    | 31.4       | 6.6%                  | 31.8        | 7.8%                  |
| 1.0       | 30.2       | 2.3%                    | 31.6       | 7.3%                  | 31.6        | 7.1%                  |
| 1.0       | 29.9       | 1.6%                    | 31.6       | 7.1%                  | 31.8        | 8.0%                  |
| 1.0       | 29.9       | 1.4%                    | 31.4       | 6.5%                  | 31.7        | 7.6%                  |
| 1.0       | 30.1       | 2.3%                    | 31.7       | 7.6%                  | 31.6        | 7.4%                  |
| 1.0       | 30.1       | 2.1%                    | 31.4       | 6.4%                  | 31.6        | 7.2%                  |
| 1.0       | 29.7       | 0.8%                    | 31.0       | 5.2%                  | 31.5        | 7.0%                  |
| 1.0       | 29.7       | 0.9%                    | 31.2       | 5.9%                  | 31.7        | 7.4%                  |
| 1.0       | 30.3       | 2.7%                    | 32.5       | 10.4%                 | 33.1        | 12.4%                 |
| 1.0       | 29.9       | 1.5%                    | 32.3       | 9.6%                  | 33.0        | 12.0%                 |
| 1.0       | 29.7       | 0.9%                    | 32.2       | 9.4%                  | 33.0        | 11.9%                 |
| 1.0       | 29.9       | 1.6%                    | 32.5       | 10.3%                 | 32.8        | 11.2%                 |
| 1.0       | 29.8       | 1.2%                    | 32.9       | 11.6%                 | 32.8        | 11.2%                 |
| 1.1       | 30.8       | 4.6%                    | 31.1       | 5.5%                  | 31.7        | 7.6%                  |
| 1.1       | 31.4       | 6.5%                    | 31.8       | 7.8%                  | 32.1        | 9.1%                  |
| 1.3       | 31.1       | 5.6%                    | 31.6       | 7.2%                  | 31.9        | 8.1%                  |
| 1.4       | 31.2       | 5.9%                    | 32.0       | 8.7%                  | 32.0        | 8.4%                  |
|           |            |                         |            |                       | Continued o | on next page          |

|        |           | Table E.   | 2 – continue | ed from previ  | ous page   |            |            |
|--------|-----------|------------|--------------|----------------|------------|------------|------------|
|        |           | Classic    | Map          | Mirel<br>Wirel | Man        | MO-N       | Man        |
| ght(6) | Weight(5) | Wirelength | Percent      | Wirelength     | Percent    | Wirelength | Percent    |
|        |           |            | Difference   | )              | Difference | 1          | Difference |
| 9.1    | 1.1       | 30.9       | 4.7%         | 31.3           | 6.1%       | 32.1       | 9.0%       |
| 9.1    | 1.2       | 30.6       | 4.0%         | 31.7           | 7.7%       | 32.2       | 9.3%       |
| 1.6    | 1.3       | 31.1       | 5.7%         | 32.1           | 8.8%       | 32.7       | 10.9%      |
| 1.6    | 1.4       | 31.3       | 6.4%         | 31.7           | 7.7%       | 32.3       | 9.5%       |
| 1.8    | 1.1       | 31.1       | 5.6%         | 31.9           | 8.1%       | 32.4       | 10.0%      |
| 8.1    | 1.2       | 31.0       | 5.3%         | 31.5           | 7.0%       | 31.9       | 8.3%       |
| 1.8    | 1.4       | 31.3       | 6.2%         | 32.0           | 8.6%       | 32.3       | 9.6%       |
| 8.1    | 1.6       | 32.0       | 8.4%         | 32.4           | 9.8%       | 32.0       | 8.7%       |
| 2.0    | 1.1       | 31.0       | 5.1%         | 31.5           | 6.9%       | 31.9       | 8.2%       |
| 2.0    | 1.2       | 31.4       | 6.6%         | 32.0           | 8.5%       | 32.2       | 9.2%       |
| 2.0    | 1.6       | 31.4       | 6.5%         | 32.0           | 8.6%       | 32.4       | 10.0%      |
| 2.4    | 1.1       | 31.8       | 7.9%         | 32.5           | 10.3%      | 33.3       | 13.1%      |
| 2.4    | 1.2       | 32.0       | 8.7%         | 32.9           | 11.7%      | 33.5       | 13.6%      |
| 2.4    | 1.6       | 32.2       | 9.1%         | 33.1           | 12.2%      | 33.1       | 12.3%      |
| 2.4    | 2.0       | 32.1       | 9.1%         | 33.2           | 12.6%      | 33.3       | 12.8%      |

| ba       |   |
|----------|---|
| previous |   |
| from     |   |
|          | ŀ |
| a        | ŀ |
| ă        |   |
| Ē        | ŀ |
| •Ξ       | ١ |
| Ξ        | Ľ |
| 5        |   |
| చ        |   |
| Ĩ        |   |
| $\sim$   |   |

| enchmark suite's wirelength geometric mean<br>rchitecture Each row corresponds to the sel<br>length percent difference is calculated with re |
|----------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                                              |

| ClassicMap $iight(5)$ WirelengthPercentWirel $iight(5)$ WirelengthPercentWirel $1.0$ $31.3$ $0.0\%$ $31$ $1.0$ $32.6$ $4.1\%$ $32$ $1.0$ $33.0$ $5.7\%$ $32$ $1.0$ $33.1$ $5.7\%$ $32$ $1.0$ $33.5$ $7.2\%$ $32$ $1.0$ $33.5$ $7.0\%$ $32$ $1.0$ $33.5$ $7.0\%$ $32$ $1.0$ $33.5$ $7.0\%$ $32$ $1.0$ $33.5$ $7.0\%$ $32$ $1.0$ $33.5$ $7.3\%$ $32$ $1.0$ $33.5$ $7.3\%$ $32$ $1.0$ $33.5$ $7.3\%$ $32$ $1.0$ $33.5$ $7.3\%$ $32$ $1.0$ $33.5$ $7.3\%$ $32$                                                                                                                                 | WireMap           length         Percen           Differen         Differen           1.9         2.1%           3.2         6.1%           3.3         6.4%           3.9         8.3%           3.9         8.6%           3.9         8.6%           3.9         8.6%           3.9         8.2%           3.6         7.6% | t Wirelength<br>ce 33.1<br>33.6<br>34.0<br>34.0<br>34.3<br>34.3<br>34.3<br>34.3<br>34.3<br>34.3         | Map<br>Percent<br>Difference<br>6.0%<br>7.4%<br>8.7%<br>9.6%<br>9.2%<br>9.4%<br>10.6%                 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|
| ight(5)WirelengthPercentWirel $ight(5)$ Difference $0.0%$ $31$ $1.0$ $31.3$ $0.0%$ $31$ $1.0$ $32.6$ $4.1%$ $32$ $1.0$ $32.6$ $4.1%$ $32$ $1.0$ $33.0$ $5.7%$ $32$ $1.0$ $33.1$ $5.7%$ $32$ $1.0$ $33.5$ $7.2%$ $32$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.5$ $7.3%$ $32$ $1.0$ $33.5$ $7.3%$ $32$ $1.0$ $33.5$ $7.3%$ $32$ $1.0$ $33.5$ $7.3%$ $32$                                                                                                                                                               | length Percen<br>Differen<br>1.9 2.1%<br>3.2 6.1%<br>3.3 6.6%<br>3.3 6.4%<br>3.9 8.0%<br>3.9 8.3%<br>4.0 8.6%<br>3.9 8.3%<br>3.6 7.6%                                                                                                                                                                                          | t Wirelength<br>ce 33.1<br>33.6<br>33.6<br>34.0<br>34.0<br>34.3<br>34.3<br>34.3<br>34.3<br>34.6<br>34.6 | Percent<br>Difference<br>6.0%<br>7.4%<br>8.7%<br>9.6%<br>9.2%<br>9.4%<br>10.6%                        |
| Difference       1.0     31.3     0.0%     31       1.0     32.6     4.1%     32       1.0     33.0     5.7%     32       1.0     33.1     5.7%     32       1.0     33.5     7.2%     32       1.0     33.5     7.2%     32       1.0     33.5     7.0%     32       1.0     33.5     7.0%     32       1.0     33.5     7.0%     32       1.0     33.5     7.0%     32       1.0     33.5     7.0%     32       1.0     33.5     7.0%     32       1.0     33.5     7.0%     32       1.0     33.5     7.0%     32       1.0     33.5     7.3%     32       1.0     33.5     7.3%     32 | Differen           1.9         2.1%           3.2         6.1%           3.3         6.4%           3.8         8.0%           3.9         8.3%           3.9         8.6%           3.9         8.6%           3.9         8.6%           3.9         8.2%           3.6         8.2%                                         | ce 33.1<br>33.1<br>33.6<br>34.0<br>34.3<br>34.1<br>34.2<br>34.6<br>34.6<br>34.6<br>34.6                 | Difference<br>6.0%<br>7.4%<br>8.7%<br>9.6%<br>9.2%<br>9.4%<br>10.6%                                   |
| 1.0 $31.3$ $0.0%$ $31$ $1.0$ $32.6$ $4.1%$ $32$ $1.0$ $32.0$ $5.7%$ $32$ $1.0$ $33.1$ $5.7%$ $32$ $1.0$ $33.5$ $7.2%$ $32$ $1.0$ $33.5$ $7.2%$ $32$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.5$ $7.3%$ $32$ $1.0$ $33.5$ $7.3%$ $32$ $1.0$ $33.5$ $7.3%$ $32$ $1.0$ $33.5$ $7.3%$ $32$                                                                                                                                                                                                                                | 1.9     2.1%       3.2     6.1%       3.3     6.6%       3.3     6.4%       3.8     8.0%       3.9     8.3%       3.9     8.6%       3.9     8.6%       3.9     8.3%       3.9     8.2%       3.6     7.6%                                                                                                                     | 33.1<br>33.6<br>33.6<br>34.0<br>34.3<br>34.3<br>34.1<br>34.2<br>34.6<br>34.6                            | $\begin{array}{c} 6.0\% \\ 7.4\% \\ 8.7\% \\ 9.6\% \\ 9.2\% \\ 9.4\% \\ 10.6\% \\ 10.5\% \end{array}$ |
| 1.0 $32.6$ $4.1%$ $32$ $1.0$ $33.0$ $5.7%$ $33$ $1.0$ $33.1$ $5.7%$ $32$ $1.0$ $33.5$ $7.2%$ $32$ $1.0$ $33.5$ $7.2%$ $32$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.5$ $7.3%$ $32$ $1.0$ $33.5$ $7.3%$ $32$ $1.0$ $33.5$ $7.3%$ $32$                                                                                                                                                                                                                                                         | 3.2     6.1%       3.3     6.6%       3.3     6.4%       3.3     6.4%       3.9     8.0%       3.9     8.3%       3.9     8.6%       3.9     8.3%       3.9     8.3%       3.9     8.2%       3.6     7.6%                                                                                                                     | 33.6<br>34.0<br>34.3<br>34.1<br>34.1<br>34.6<br>34.6                                                    | 7.4%<br>8.7%<br>9.6%<br>9.2%<br>9.4%<br>10.6%                                                         |
| 1.0 $33.0$ $5.7%$ $33$ $1.0$ $33.1$ $5.7%$ $33$ $1.0$ $33.5$ $7.2%$ $33$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.5$ $7.3%$ $32$ $1.0$ $33.5$ $7.3%$ $32$ $1.0$ $33.5$ $7.3%$ $32$                                                                                                                                                                                                                                                                                  | 3.3     6.6%       3.3     6.4%       3.8     8.0%       3.9     8.3%       4.0     8.6%       3.9     8.3%       3.9     8.3%       3.9     8.3%       3.6     8.2%       3.6     7.6%                                                                                                                                        | 34.0<br>34.3<br>34.1<br>34.1<br>34.2<br>34.6<br>34.6                                                    | $\begin{array}{c} 8.7\% \\ 9.6\% \\ 9.2\% \\ 9.4\% \\ 10.6\% \\ 10.5\% \end{array}$                   |
| 1.0 $33.1$ $5.7%$ $33$ $1.0$ $33.5$ $7.2%$ $33$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.5$ $7.3%$ $32$ $1.0$ $33.5$ $7.3%$ $32$ $1.0$ $33.5$ $7.3%$ $32$                                                                                                                                                                                                                                                                                                                                    | 3.3     6.4%       3.8     8.0%       3.9     8.3%       3.9     8.6%       3.9     8.3%       3.9     8.3%       3.6     8.2%       3.6     7.6%                                                                                                                                                                              | 34.3<br>34.1<br>34.2<br>34.6<br>34.6                                                                    | $\begin{array}{c} 9.6\% \\ 9.2\% \\ 9.4\% \\ 10.6\% \\ 10.5\% \end{array}$                            |
| 1.0 $33.5$ $7.2%$ $33$ $1.0$ $33.4$ $6.8%$ $33$ $1.0$ $33.5$ $7.0%$ $32$ $1.0$ $33.6$ $7.4%$ $33$ $1.0$ $33.5$ $7.0%$ $33$ $1.0$ $33.5$ $7.0%$ $33$ $1.0$ $33.5$ $7.3%$ $32$ $1.0$ $33.5$ $7.3%$ $32$ $1.0$ $33.5$ $7.3%$ $32$                                                                                                                                                                                                                                                                                                                                                             | 3.8     8.0%       3.9     8.3%       4.0     8.6%       3.9     8.3%       3.8     8.2%       3.6     7.6%                                                                                                                                                                                                                    | 34.1<br>34.2<br>34.6<br>34.6                                                                            | $\begin{array}{c} 9.2\% \\ 9.4\% \\ 10.6\% \\ 10.5\% \end{array}$                                     |
| 1.0 $33.4$ $6.8%$ $33$ $1.0$ $33.5$ $7.0%$ $34$ $1.0$ $33.6$ $7.4%$ $35$ $1.0$ $33.5$ $7.0%$ $35$ $1.0$ $33.6$ $7.3%$ $35$ $1.0$ $33.2$ $6.2%$ $34$ $1.0$ $33.5$ $7.3%$ $32$ $1.0$ $33.5$ $7.3%$ $34$                                                                                                                                                                                                                                                                                                                                                                                      | 3.9     8.3%       4.0     8.6%       3.9     8.3%       3.8     8.2%       3.6     7.6%                                                                                                                                                                                                                                       | 34.2<br>34.6<br>34.6                                                                                    | 9.4%<br>10.6%<br>10.5%                                                                                |
| 1.0         33.5         7.0%         34           1.0         33.6         7.4%         35           1.0         33.5         7.0%         35           1.0         33.5         7.0%         35           1.0         33.5         7.3%         35           1.0         33.5         7.3%         35           1.0         33.5         7.3%         35           1.0         33.5         7.3%         35           1.0         33.5         7.3%         32                                                                                                                           | 4.0     8.6%       3.9     8.3%       3.8     8.2%       3.6     7.6%                                                                                                                                                                                                                                                          | 34.6<br>34.6                                                                                            | 10.6%<br>10.5%                                                                                        |
| 1.0 $33.6$ $7.4%$ $33.3$ $1.0$ $33.5$ $7.0%$ $35.5$ $1.0$ $33.6$ $7.3%$ $35.5$ $1.0$ $33.6$ $7.3%$ $35.5$ $1.0$ $33.5$ $7.3%$ $32.5$ $1.0$ $33.5$ $7.3%$ $32.5$                                                                                                                                                                                                                                                                                                                                                                                                                            | 3.9 8.3%<br>3.8 8.2%<br>3.6 7.6%                                                                                                                                                                                                                                                                                               | 34.6                                                                                                    | 10.5%                                                                                                 |
| 1.0         33.5         7.0%         33           1.0         33.6         7.3%         35           1.0         33.2         6.2%         32           1.0         33.5         7.3%         32                                                                                                                                                                                                                                                                                                                                                                                          | 3.8 8.2%<br>3.6 7.6%                                                                                                                                                                                                                                                                                                           | 1                                                                                                       |                                                                                                       |
| $1.0$ $33.6$ $7.3\%$ $32$ $1.0$ $33.2$ $6.2\%$ $3^2$ $1.0$ $33.5$ $7.3\%$ $3^2$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 3.6 7.6%                                                                                                                                                                                                                                                                                                                       | 34.5                                                                                                    | 10.2%                                                                                                 |
| 1.0         33.2         6.2%         3.2           1.0         33.5         7.3%         3.2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                | 34.4                                                                                                    | 10.1%                                                                                                 |
| 1.0 33.5 7.3% 34                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 4.2 9.4%                                                                                                                                                                                                                                                                                                                       | 35.0                                                                                                    | 11.8%                                                                                                 |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 11.6%                                                                                                                                                                                                                                                                                                                          | 35.9                                                                                                    | 14.8%                                                                                                 |
| 1.0 33.7 7.8% 34                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 11.6%                                                                                                                                                                                                                                                                                                                          | 35.9                                                                                                    | 14.7%                                                                                                 |
| 1.0 33.7 7.6% 34                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | <u>11.5%</u>                                                                                                                                                                                                                                                                                                                   | 35.7                                                                                                    | 14.1%                                                                                                 |
| 1.0 33.6 7.4% 3 <sup>-</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 11.4%                                                                                                                                                                                                                                                                                                                          | 36.1                                                                                                    | 15.5%                                                                                                 |
| 1.0 33.7 7.6% 34                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 11.2%                                                                                                                                                                                                                                                                                                                          | 36.1                                                                                                    | 15.5%                                                                                                 |
| 1.1 33.0 5.5% 35                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 3.2 6.1%                                                                                                                                                                                                                                                                                                                       | 33.6                                                                                                    | 7.4%                                                                                                  |
| 1.1 33.4 6.8% 3 <sup>-</sup>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 4.5 10.2%                                                                                                                                                                                                                                                                                                                      | 33.4                                                                                                    | 6.8%                                                                                                  |
| 1.2 33.1 5.8% 35                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 3.9 8.4%                                                                                                                                                                                                                                                                                                                       | 32.9                                                                                                    | 5.3%                                                                                                  |
| 1.3 33.0 5.5% 35                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 3.7 7.7%                                                                                                                                                                                                                                                                                                                       | 33.1                                                                                                    | 5.8%                                                                                                  |

### APPENDIX E. VPR WIRELENGTH GEOMETRIC MEANS

|                |           | Map    | Percent    | Difference | 10.1% | 9.5% | 7.8% | 8.4% | 9.3% | 11.4% | 9.5% | 8.8% | 10.7% | 10.5% | 9.0% | 14.3% | 13.3% | 11.1% | 10.3% |
|----------------|-----------|--------|------------|------------|-------|------|------|------|------|-------|------|------|-------|-------|------|-------|-------|-------|-------|
|                |           | -OM    | Wirelength |            | 34.4  | 34.3 | 33.7 | 33.9 | 34.2 | 34.8  | 34.2 | 34.0 | 34.6  | 34.6  | 34.1 | 35.7  | 35.4  | 34.7  | 34.5  |
| ous page       |           | Map    | Percent    | Difference | 6.4%  | 7.3% | 6.1% | 3.8% | 6.9% | 8.2%  | 7.1% | 6.0% | 7.3%  | 7.7%  | 6.2% | 11.1% | 12.8% | 9.0%  | 8.8%  |
| an mount brevi | hitecture | Wire   | Wirelength |            | 33.3  | 33.5 | 33.2 | 32.5 | 33.4 | 33.8  | 33.5 | 33.1 | 33.6  | 33.7  | 33.2 | 34.8  | 35.3  | 34.1  | 34.0  |
|                | M7Arc     | cMap   | Percent    | Difference | 5.8%  | 6.1% | 6.8% | 5.8% | 7.9% | 8.5%  | 7.7% | 6.4% | 7.6%  | 7.2%  | 7.8% | 10.9% | 12.0% | 10.6% | 10.9% |
| T ANIC T       |           | Classi | Wirelength |            | 33.1  | 33.2 | 33.4 | 33.1 | 33.8 | 33.9  | 33.7 | 33.3 | 33.7  | 33.5  | 33.7 | 34.7  | 35.0  | 34.6  | 34.7  |
|                |           |        | Weight(5)  |            | 1.1   | 1.2  | 1.3  | 1.4  | 1.1  | 1.2   | 1.4  | 1.6  | 1.1   | 1.2   | 1.6  | 1.1   | 1.2   | 1.6   | 2.0   |
|                |           |        | Weight(6)  |            | 1.6   | 1.6  | 1.6  | 1.6  | 1.8  | 1.8   | 1.8  | 1.8  | 2.0   | 2.0   | 2.0  | 2.4   | 2.4   | 2.4   | 2.4   |

continued from previous page Table E.3 -

| pings produced with LUT balancing and packed for the                  | pings created using the listed Weight(6) and Weight(5)              | the architecture's baseline mapping.                                       |
|-----------------------------------------------------------------------|---------------------------------------------------------------------|----------------------------------------------------------------------------|
| 3.4: Benchmark suite's wirelength geometric mean for mappings produce | GA architecture Each row corresponds to the set of mappings created | Wirelength percent difference is calculated with respect to the architectu |
| Table E                                                               | M8 FP                                                               | values.                                                                    |

|           |        |            |            |      |      |      |      | -     | -    | -     |       |       |       |       | -     |       | -     |       |       |      | -    | -    | -    | —           |
|-----------|--------|------------|------------|------|------|------|------|-------|------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|------|------|------|------|-------------|
|           | Map    | Percent    | Difference | 6.0% | 7.7% | 6.9% | 7.2% | 9.3%  | 9.7% | 8.7%  | 9.9%  | 10.1% | 9.5%  | 10.5% | 14.3% | 14.2% | 15.5% | 15.3% | 15.6% | 6.6% | 7.9% | 8.0% | 6.7% | n next page |
|           | -OM    | Wirelength |            | 33.7 | 34.2 | 34.0 | 34.1 | 34.7  | 34.8 | 34.5  | 34.9  | 35.0  | 34.8  | 35.1  | 36.3  | 36.3  | 36.7  | 36.6  | 36.7  | 33.9 | 34.3 | 34.3 | 33.9 | Continued o |
|           | Map    | Percent    | Difference | 3.3% | 5.5% | 5.1% | 7.0% | 7.9%  | 7.0% | 7.3%  | 8.5%  | 9.2%  | 8.2%  | 9.3%  | 12.1% | 12.0% | 11.5% | 12.1% | 12.5% | 5.2% | 6.7% | 5.3% | 5.3% |             |
| hitecture | Wire   | Wirelength |            | 32.8 | 33.5 | 33.4 | 34.0 | 34.3  | 34.0 | 34.1  | 34.5  | 34.7  | 34.4  | 34.7  | 35.6  | 35.6  | 35.4  | 35.6  | 35.7  | 33.4 | 33.9 | 33.5 | 33.4 |             |
| M8Arcl    | cMap   | Percent    | Difference | 0.0% | 6.8% | 9.0% | 8.6% | 10.3% | 9.9% | 10.1% | 10.1% | 10.6% | 10.6% | 11.4% | 13.0% | 14.5% | 13.6% | 13.3% | 13.9% | 6.0% | 8.1% | 6.5% | 5.9% |             |
|           | Classi | Wirelength |            | 31.8 | 33.9 | 34.6 | 34.5 | 35.0  | 34.9 | 35.0  | 35.0  | 35.1  | 35.1  | 35.4  | 35.9  | 36.4  | 36.1  | 36.0  | 36.2  | 33.7 | 34.3 | 33.8 | 33.6 |             |
|           |        | Weight(5)  |            | 1.0  | 1.0  | 1.0  | 1.0  | 1.0   | 1.0  | 1.0   | 1.0   | 1.0   | 1.0   | 1.0   | 1.0   | 1.0   | 1.0   | 1.0   | 1.0   | 1.1  | 1.1  | 1.2  | 1.3  |             |
|           |        | Weight(6)  |            | 1.0  | 1.1  | 1.2  | 1.3  | 1.4   | 1.5  | 1.6   | 1.7   | 1.8   | 1.9   | 2.0   | 2.1   | 2.2   | 2.3   | 2.4   | 2.5   | 1.2  | 1.4  | 1.4  | 1.4  |             |

### APPENDIX E. VPR WIRELENGTH GEOMETRIC MEANS

|           |           | Table E.   | .4 – continue | ed from previ | ous page   |            |            |
|-----------|-----------|------------|---------------|---------------|------------|------------|------------|
|           |           |            | M8Arc         | hitecture     |            |            |            |
|           |           | Classic    | cMap          | Wirel         | Map        | NO-N       | Map        |
| Weight(6) | Weight(5) | Wirelength | Percent       | Wirelength    | Percent    | Wirelength | Percent    |
|           |           |            | Difference    |               | Difference |            | Difference |
| 1.6       | 1.1       | 34.7       | 9.1%          | 34.1          | 7.3%       | 34.6       | 8.9%       |
| 1.6       | 1.2       | 34.5       | 8.5%          | 34.3          | 7.8%       | 34.8       | 9.5%       |
| 1.6       | 1.3       | 34.3       | 7.8%          | 33.7          | 6.0%       | 34.1       | 7.3%       |
| 1.6       | 1.4       | 33.7       | 6.1%          | 32.8          | 3.3%       | 33.9       | 6.9%       |
| 1.8       | 1.1       | 35.1       | 10.5%         | 34.5          | 8.5%       | 35.1       | 10.6%      |
| 1.8       | 1.2       | 34.8       | 9.6%          | 34.3          | 8.1%       | 34.6       | 8.8%       |
| 1.8       | 1.4       | 34.7       | 9.2%          | 33.7          | 6.1%       | 34.8       | 9.5%       |
| 1.8       | 1.6       | 34.0       | 7.2%          | 33.2          | 4.5%       | 34.1       | 7.4%       |
| 2.0       | 1.1       | 35.2       | 10.9%         | 34.4          | 8.4%       | 34.6       | 8.9%       |
| 2.0       | 1.2       | 34.8       | 9.6%          | 34.2          | 7.6%       | 34.7       | 9.3%       |
| 2.0       | 1.6       | 35.2       | 10.8%         | 34.0          | 7.1%       | 34.5       | 8.8%       |
| 2.4       | 1.1       | 36.4       | 14.7%         | 35.8          | 12.6%      | 36.4       | 14.5%      |
| 2.4       | 1.2       | 36.2       | 14.1%         | 36.0          | 13.3%      | 36.4       | 14.7%      |
| 2.4       | 1.6       | 36.1       | 13.6%         | 35.4          | 11.3%      | 35.6       | 12.1%      |
| 2.4       | 2.0       | 35.2       | 10.8%         | 35.0          | 10.3%      | 34.6       | 9.1%       |

| - 14     |  |
|----------|--|
| previous |  |
| from     |  |
| inued    |  |
| conti    |  |
| 4 -      |  |

Appendix F

## **Quartus II Fmax Geometric Means**

balancing and packed for the Stratix II FPGA architecture.. Each row corresponds to the set of mappings created using the listed Weight(6) and Weight(5) values. Maximum operating frequency percent difference is calculated with respect to Table F.1: Benchmark suite's maximum operating frequency (Fmax) geometric mean for mappings produced with LUT the architecture's baseline mapping.

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |           | Claceto    | Stratix II | Architecture | uey        | N-OM       | hel        |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|-----------|------------|------------|--------------|------------|------------|------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |         |           | Classic    | Map        | WireN        | 1ap        | M-UM       | Aap        |
| Image: DifferenceDifferenceDifferenceDifference1.01.0193.9 $0.0\%$ 193.1 $0.4\%$ 193.7 $0.1\%$ 1.11.0192.8 $0.0\%$ 193.4 $0.3\%$ 193.9 $0.0\%$ 1.21.0192.2 $0.0\%$ 193.4 $0.3\%$ 193.9 $0.0\%$ 1.31.0192.2 $0.0\%$ 193.5 $0.0\%$ 193.6 $0.0\%$ 1.41.0192.6 $0.7\%$ 193.6 $0.2\%$ 193.6 $0.2\%$ 1.51.0192.8 $0.5\%$ 193.6 $0.2\%$ 193.6 $0.2\%$ 1.61.0193.7 $0.1\%$ 193.6 $0.2\%$ 193.6 $0.4\%$ 1.71.0193.7 $0.1\%$ 193.6 $0.2\%$ 194.8 $0.4\%$ 1.71.0193.7 $0.1\%$ 193.7 $0.1\%$ $0.4\%$ 1.81.0193.7 $0.1\%$ 193.6 $0.4\%$ $0.4\%$ 2.01.0192.7 $0.1\%$ 192.9 $0.4\%$ 2.11.0192.7 $0.1\%$ 192.9 $0.4\%$ 2.21.0192.6 $0.7\%$ 193.4 $0.4\%$ 2.31.0192.4 $0.2\%$ 193.4 $0.4\%$ 2.41.0192.4 $0.2\%$ 192.9 $0.6\%$ 2.51.0192.4 $0.2\%$ 192.4 $0.4\%$ 2.61.0192.6 $0.7\%$ 192.3 $0.4\%$ 2.11.0192.4 $0.2\%$ 192.4 $0.4\%$ 2.21.0192.6 <td< td=""><td>ight(6)</td><td>Weight(5)</td><td>Fmax (MHz)</td><td>Percent</td><td>Fmax (MHz)</td><td>Percent</td><td>Fmax (MHz)</td><td>Percent</td></td<>                                                                          | ight(6) | Weight(5) | Fmax (MHz) | Percent    | Fmax (MHz)   | Percent    | Fmax (MHz) | Percent    |
| 1.01.0193.9 $0.0\%$ 193.1 $-0.4\%$ 193.7 $-0.1\%$ 1.11.0192.8 $-0.6\%$ 193.4 $-0.3\%$ 195.9 $1.0\%$ 1.21.0192.2 $-0.9\%$ 193.2 $-0.3\%$ 193.9 $0.0\%$ 1.31.0192.2 $-0.9\%$ 193.5 $-0.2\%$ 193.6 $-0.2\%$ 1.41.0192.6 $-0.7\%$ 193.6 $-0.2\%$ 193.6 $-0.2\%$ 1.51.0192.8 $-0.5\%$ 193.6 $-0.2\%$ 192.4 $-0.8\%$ 1.61.0193.0 $-0.5\%$ 194.2 $0.1\%$ $192.4$ $-0.8\%$ 1.71.0193.0 $-0.5\%$ 194.2 $0.1\%$ $192.4$ $-0.8\%$ 1.71.0193.7 $-0.1\%$ 192.6 $-0.2\%$ $195.4$ $-0.8\%$ 1.81.0193.7 $-0.1\%$ 194.2 $0.1\%$ $192.4$ $-0.8\%$ 1.91.0192.7 $-0.6\%$ 193.7 $-0.1\%$ $192.9$ $-0.6\%$ 2.01.0192.0 $-1.0\%$ 193.7 $-0.1\%$ $192.9$ $-0.5\%$ 2.11.0192.4 $-0.8\%$ 194.4 $0.2\%$ $194.8$ $0.4\%$ 2.11.0192.6 $-0.7\%$ 192.6 $-0.7\%$ $197.4$ $-0.3\%$ 2.11.0192.4 $-0.8\%$ 192.4 $-0.3\%$ $-0.5\%$ $197.4$ $-0.3\%$ 2.11.0192.6 $-0.7\%$ 192.6 $-0.7\%$ $197.4$ $-0.3\%$ 2.11.0192.4 <td></td> <td></td> <td></td> <td>Difference</td> <td></td> <td>Difference</td> <td></td> <td>Difference</td>                                                                       |         |           |            | Difference |              | Difference |            | Difference |
| 1.1 $1.0$ $192.8$ $-0.6%$ $193.4$ $-0.3%$ $195.9$ $1.0%$ $1.2$ $1.0$ $192.2$ $-0.9%$ $193.2$ $-0.3%$ $193.9$ $0.0%$ $1.3$ $1.0$ $192.2$ $-0.9%$ $193.5$ $-0.2%$ $193.6$ $-0.2%$ $1.4$ $1.0$ $192.6$ $-0.7%$ $193.6$ $-0.2%$ $192.4$ $-0.8%$ $1.5$ $1.0$ $192.8$ $-0.5%$ $193.6$ $-0.2%$ $192.4$ $-0.8%$ $1.6$ $1.0$ $193.0$ $-0.5%$ $194.2$ $0.1%$ $192.6$ $-0.2%$ $1.7$ $1.0$ $193.7$ $-0.1%$ $194.2$ $0.1%$ $192.9$ $-0.5%$ $1.7$ $1.0$ $192.7$ $-0.6%$ $193.7$ $-0.1%$ $192.9$ $-0.5%$ $1.7$ $1.0$ $192.7$ $-0.1%$ $192.6$ $-0.7%$ $192.9$ $-0.5%$ $1.9$ $1.0$ $192.7$ $-0.1%$ $192.6$ $-0.7%$ $192.9$ $-0.5%$ $2.0$ $1.0$ $192.6$ $-0.1%$ $192.4$ $-0.3%$ $192.4$ $-0.3%$ $2.1$ $1.0$ $192.4$ $-0.8%$ $192.4$ $-0.2%$ $199.3$ $-0.3%$ $2.1$ $1.0$ $192.4$ $-0.2%$ $192.6$ $-0.7%$ $199.3$ $-0.3%$ $2.1$ $1.0$ $192.4$ $-0.8%$ $192.4$ $-0.3%$ $-0.2%$ $2.1$ $1.0$ $192.4$ $-0.2%$ $192.6$ $-0.7%$ $190.3$ $-1.9%$ $2.1$ $1.0$ $192.4$ $-0.2%$ <td>1.0</td> <td>1.0</td> <td>193.9</td> <td>0.0%</td> <td>193.1</td> <td>-0.4%</td> <td>193.7</td> <td>-0.1%</td> | 1.0     | 1.0       | 193.9      | 0.0%       | 193.1        | -0.4%      | 193.7      | -0.1%      |
| 1.21.0192.2 $-0.9\%$ 193.2 $-0.3\%$ 193.9 $0.0\%$ 1.31.0192.2 $-0.9\%$ 192.3 $-0.8\%$ 192.4 $-0.8\%$ 1.41.0192.6 $-0.7\%$ 193.6 $-0.2\%$ 192.4 $-0.8\%$ 1.51.0192.8 $0.5\%$ 193.6 $-0.2\%$ 192.4 $-0.8\%$ 1.61.0193.0 $-0.5\%$ 194.2 $0.1\%$ 192.4 $-0.8\%$ 1.71.0193.7 $-0.1\%$ 192.4 $-0.8\%$ 1.71.0193.7 $-0.1\%$ 192.4 $-0.8\%$ 1.81.0193.7 $-0.1\%$ 192.4 $-0.8\%$ 1.91.0192.7 $-0.1\%$ 194.2 $0.4\%$ 1.9192.0 $-1.0\%$ 193.7 $-0.1\%$ $192.9$ $-0.5\%$ 2.01.0192.6 $-0.7\%$ 192.9 $-0.5\%$ 2.11.0191.8 $-1.1\%$ 194.4 $0.2\%$ $194.8$ $0.4\%$ 2.11.0192.6 $-0.7\%$ 193.1 $-0.4\%$ 2.11.0192.4 $-0.8\%$ $194.4$ $0.2\%$ $194.8$ $-0.4\%$ 2.31.0192.4 $-0.8\%$ 194.4 $0.2\%$ $197.7$ $-0.6\%$ 2.41.0192.6 $-0.7\%$ 192.1 $-0.4\%$ 2.51.0192.6 $-0.7\%$ 192.7 $-0.6\%$ 2.41.0192.6 $-0.7\%$ 192.7 $-0.6\%$ 2.51.0192.6 $-0.7\%$ 192.7 $-0.6\%$ 2.                                                                                                                                                                                                                 | 1.1     | 1.0       | 192.8      | -0.6%      | 193.4        | -0.3%      | 195.9      | 1.0%       |
| 1.31.0192.2 $-0.9\%$ 192.3 $-0.8\%$ 192.4 $-0.8\%$ 1.41.0192.6 $-0.7\%$ 193.6 $-0.2\%$ 193.6 $-0.2\%$ 1.51.0192.8 $-0.5\%$ 193.6 $-0.2\%$ 193.6 $-0.2\%$ 1.61.0192.3 $-0.5\%$ 194.2 $0.1\%$ $192.4$ $-0.8\%$ 1.71.0193.7 $-0.1\%$ 194.2 $0.1\%$ $192.9$ $-0.5\%$ 1.81.0192.7 $-0.1\%$ 195.6 $0.9\%$ $192.9$ $-0.5\%$ 1.91.0192.7 $-0.1\%$ 195.6 $0.9\%$ $192.9$ $-0.5\%$ 1.91.0192.0 $-1.0\%$ 193.7 $-0.1\%$ $194.8$ $0.4\%$ 2.01.0191.8 $-1.1\%$ $194.8$ $0.5\%$ $193.4$ $-0.3\%$ 2.11.0192.4 $-0.2\%$ 192.6 $-0.7\%$ $190.3$ $-1.9\%$ 2.11.0192.4 $-0.2\%$ $192.6$ $-0.7\%$ $192.7$ $-0.6\%$ 2.11.0191.4 $-1.3\%$ $192.6$ $-0.7\%$ $192.7$ $-0.6\%$ 2.31.0191.4 $-1.1\%$ $192.6$ $-0.7\%$ $192.7$ $-0.6\%$ 2.41.0191.4 $-1.1\%$ $192.6$ $-0.7\%$ $192.7$ $-0.6\%$ 2.51.0191.9 $-1.0\%$ $192.6$ $-0.7\%$ $192.7$ $-0.6\%$ 2.41.0191.4 $-1.1\%$ $192.6$ $-0.7\%$ $192.7$ $-0.6\%$ 2.51.01.0                                                                                                                                                                          | 1.2     | 1.0       | 192.2      | -0.9%      | 193.2        | -0.3%      | 193.9      | 0.0%       |
| 1.4 $1.0$ $192.6$ $-0.7%$ $193.6$ $-0.2%$ $193.6$ $-0.2%$ $1.5$ $1.0$ $192.8$ $-0.5%$ $193.6$ $-0.2%$ $192.4$ $-0.8%$ $1.6$ $1.0$ $193.0$ $-0.5%$ $194.2$ $0.1%$ $192.9$ $-0.5%$ $1.7$ $1.0$ $193.7$ $-0.1%$ $195.6$ $0.9%$ $192.9$ $-0.5%$ $1.8$ $1.0$ $192.7$ $-0.1%$ $195.6$ $0.9%$ $192.9$ $-0.5%$ $1.9$ $1.0$ $192.7$ $-0.1%$ $193.7$ $-0.1%$ $192.9$ $-0.5%$ $2.0$ $1.0$ $192.0$ $-1.0%$ $193.7$ $-0.1%$ $192.9$ $-0.5%$ $2.0$ $1.0$ $192.0$ $-1.0%$ $193.2$ $-0.4%$ $194.8$ $0.4%$ $2.1$ $1.0$ $191.8$ $-1.1%$ $194.8$ $0.5%$ $194.8$ $0.4%$ $2.1$ $1.0$ $191.8$ $-1.1%$ $192.6$ $-0.7%$ $190.3$ $-1.9%$ $2.1$ $1.0$ $191.4$ $-1.3%$ $192.6$ $-0.7%$ $190.3$ $-1.9%$ $2.4$ $1.0$ $191.4$ $-1.3%$ $192.6$ $-0.7%$ $192.7$ $-0.6%$ $2.5$ $1.0$ $191.9$ $-1.0%$ $192.6$ $-0.7%$ $192.1$ $-0.1%$ $2.5$ $1.0$ $192.6$ $-0.7%$ $192.1$ $-1.1%$ $2.5$ $1.0$ $192.6$ $-0.7%$ $192.1$ $-1.0%$ $2.5$ $1.0$ $192.6$ $-0.7%$ $191.8$ $-1.1%$ $2.$                                                                                                                         | 1.3     | 1.0       | 192.2      | -0.9%      | 192.3        | -0.8%      | 192.4      | -0.8%      |
| 1.51.0192.8 $-0.5\%$ 193.6 $-0.2\%$ 192.4 $-0.8\%$ 1.61.0193.0 $-0.5\%$ 194.2 $0.1\%$ 192.8 $-0.6\%$ 1.71.0193.7 $-0.1\%$ 195.6 $0.9\%$ 192.9 $-0.5\%$ 1.81.0192.7 $-0.6\%$ 193.7 $-0.1\%$ $192.9$ $-0.5\%$ 1.91.0192.0 $-1.0\%$ 193.7 $-0.1\%$ $192.9$ $-0.5\%$ 2.01.0192.0 $-1.0\%$ 193.2 $-0.4\%$ $194.8$ $0.4\%$ 2.11.0191.8 $-1.1\%$ 194.8 $0.5\%$ $190.3$ $-1.9\%$ 2.11.0192.4 $-0.2\%$ 194.4 $0.2\%$ $190.3$ $-1.9\%$ 2.21.0191.4 $-1.3\%$ 192.6 $-0.7\%$ $190.3$ $-1.9\%$ 2.41.0191.4 $-1.3\%$ 192.6 $-0.7\%$ $192.7$ $-0.6\%$ 2.51.0191.9 $-1.0\%$ 192.6 $-0.7\%$ $192.0$ $-1.0\%$ 2.51.0191.9 $-1.0\%$ $192.6$ $-0.7\%$ $192.0$ $-1.0\%$ 2.51.0191.9 $-1.0\%$ $192.6$ $-0.7\%$ $192.0$ $-1.0\%$ 2.51.0191.9 $-1.0\%$ $192.6$ $-0.7\%$ $191.8$ $-1.1\%$ 2.51.1193.2 $-0.3\%$ $192.9$ $-0.5\%$ $194.4$ $0.2\%$ 1.41.1 $193.4$ $-0.3\%$ $192.9$ $-0.5\%$ $194.4$ $0.2\%$ 1.41.2 $194.2$                                                                                                                                                                       | 1.4     | 1.0       | 192.6      | -0.7%      | 193.6        | -0.2%      | 193.6      | -0.2%      |
| 1.61.0193.0 $-0.5\%$ 194.2 $0.1\%$ 192.8 $-0.6\%$ 1.71.0193.7 $-0.1\%$ 195.6 $0.9\%$ 192.9 $-0.5\%$ 1.81.0192.7 $-0.1\%$ 195.1 $0.6\%$ 1.91.0192.0 $-1.0\%$ 193.7 $-0.1\%$ $195.1$ $0.6\%$ 2.01.0192.0 $-1.0\%$ 193.2 $-0.1\%$ $194.8$ $0.5\%$ $194.8$ $0.4\%$ 2.01.0191.8 $-1.1\%$ 194.8 $0.5\%$ $193.4$ $-0.3\%$ 2.11.0192.4 $-0.8\%$ 192.6 $-0.7\%$ $190.3$ $-1.9\%$ 2.21.0191.4 $-1.3\%$ $192.6$ $-0.7\%$ $192.1$ $-0.4\%$ 2.31.0191.4 $-1.3\%$ $192.6$ $-0.7\%$ $192.7$ $-0.6\%$ 2.41.0191.7 $-1.1\%$ $192.6$ $-0.7\%$ $192.7$ $-0.6\%$ 2.51.0191.9 $-1.0\%$ $192.6$ $-0.7\%$ $192.7$ $-0.6\%$ 2.51.0191.9 $-1.0\%$ $192.6$ $-0.7\%$ $192.7$ $-0.6\%$ 1.41.1193.2 $-0.3\%$ $192.9$ $-0.7\%$ $194.4$ $0.2\%$ 1.41.2193.4 $-0.3\%$ $192.9$ $-0.7\%$ $194.4$ $0.2\%$                                                                                                                                                                                                                                                                                               | 1.5     | 1.0       | 192.8      | -0.5%      | 193.6        | -0.2%      | 192.4      | -0.8%      |
| 1.7 $1.0$ $193.7$ $-0.1%$ $195.6$ $0.9%$ $192.9$ $-0.5%$ $1.8$ $1.0$ $192.7$ $-0.6%$ $193.7$ $-0.1%$ $195.1$ $0.6%$ $1.9$ $1.0$ $192.0$ $-1.0%$ $193.2$ $-0.4%$ $194.8$ $0.5%$ $2.0$ $1.0$ $191.8$ $-1.1%$ $194.8$ $0.5%$ $193.4$ $-0.3%$ $2.1$ $1.0$ $191.8$ $-1.1%$ $194.8$ $0.5%$ $193.4$ $-0.3%$ $2.1$ $1.0$ $193.6$ $-0.2%$ $192.6$ $-0.7%$ $190.3$ $-1.9%$ $2.2$ $1.0$ $192.4$ $-0.8%$ $194.4$ $0.2%$ $193.1$ $-0.4%$ $2.3$ $1.0$ $191.4$ $-1.3%$ $192.2$ $-0.9%$ $192.7$ $-0.6%$ $2.4$ $1.0$ $191.7$ $-1.1%$ $192.6$ $-0.7%$ $192.7$ $-0.6%$ $2.4$ $1.0$ $191.9$ $-1.0%$ $192.6$ $-0.7%$ $192.7$ $-0.6%$ $2.4$ $1.0$ $191.9$ $-1.0%$ $192.6$ $-0.7%$ $192.7$ $-0.6%$ $2.5$ $1.0$ $191.9$ $-1.0%$ $192.6$ $-0.7%$ $192.0$ $-1.0%$ $2.5$ $1.1$ $195.0$ $0.6%$ $194.2$ $0.1%$ $192.8$ $-0.1%$ $1.4$ $1.1$ $193.4$ $-0.3%$ $192.9$ $-0.1%$ $194.4$ $0.2%$ $1.4$ $1.1$ $193.4$ $-0.3%$ $192.9$ $-0.9%$ $0.1%$ $0.1%$ $1.4$ $1.1$ $193.4$                                                                                                                           | 1.6     | 1.0       | 193.0      | -0.5%      | 194.2        | 0.1%       | 192.8      | -0.6%      |
| 1.81.0192.7 $-0.6\%$ 193.7 $-0.1\%$ 195.1 $0.6\%$ 1.91.0192.0 $-1.0\%$ 193.2 $-0.4\%$ 194.8 $0.4\%$ 2.01.0191.8 $-1.1\%$ 194.8 $0.5\%$ 193.4 $-0.3\%$ 2.11.0191.8 $-1.1\%$ 192.6 $-0.7\%$ 190.3 $-1.9\%$ 2.11.0192.4 $-0.2\%$ 192.6 $-0.7\%$ 190.3 $-1.9\%$ 2.21.0191.4 $-1.3\%$ 192.6 $-0.7\%$ 192.1 $-0.4\%$ 2.31.0191.4 $-1.3\%$ 192.6 $-0.7\%$ 192.7 $-0.6\%$ 2.41.0191.9 $-1.0\%$ 192.6 $-0.7\%$ 192.0 $-1.0\%$ 2.51.0191.9 $-1.0\%$ 192.6 $-0.7\%$ 192.0 $-1.0\%$ 2.51.0191.9 $-1.0\%$ 192.6 $-0.7\%$ 192.0 $-1.0\%$ 2.61.1195.0 $0.6\%$ 194.2 $0.1\%$ $192.0$ $-1.1\%$ 1.41.2193.4 $-0.3\%$ 192.9 $-0.5\%$ 194.4 $0.2\%$                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1.7     | 1.0       | 193.7      | -0.1%      | 195.6        | 0.9%       | 192.9      | -0.5%      |
| 1.9 $1.0$ $192.0$ $-1.0%$ $193.2$ $-0.4%$ $194.8$ $0.4%$ $2.0$ $1.0$ $191.8$ $-1.1%$ $194.8$ $0.5%$ $193.4$ $-0.3%$ $2.1$ $1.0$ $193.6$ $-0.2%$ $192.6$ $-0.7%$ $190.3$ $-1.9%$ $2.2$ $1.0$ $192.4$ $-0.8%$ $194.4$ $0.2%$ $192.1$ $-0.4%$ $2.3$ $1.0$ $191.4$ $-1.3%$ $192.2$ $-0.9%$ $192.1$ $-0.4%$ $2.4$ $1.0$ $191.4$ $-1.3%$ $192.2$ $-0.9%$ $192.7$ $-0.6%$ $2.4$ $1.0$ $191.7$ $-1.1%$ $192.6$ $-0.7%$ $192.0$ $-1.0%$ $2.5$ $1.0$ $191.9$ $-1.0%$ $192.6$ $-0.7%$ $192.0$ $-1.0%$ $2.5$ $1.0$ $191.9$ $-1.0%$ $192.6$ $-0.7%$ $191.8$ $-1.1%$ $2.5$ $1.0$ $191.9$ $-1.0%$ $192.6$ $-0.7%$ $191.8$ $-1.1%$ $1.4$ $1.1$ $195.0$ $0.6%$ $194.2$ $0.1%$ $193.8$ $-0.1%$ $1.4$ $1.2$ $193.4$ $-0.3%$ $192.9$ $-0.2%$ $194.4$ $0.2%$                                                                                                                                                                                                                                                                                                                              | 1.8     | 1.0       | 192.7      | -0.6%      | 193.7        | -0.1%      | 195.1      | 0.6%       |
| 2.0 $1.0$ $191.8$ $-1.1%$ $194.8$ $0.5%$ $193.4$ $-0.3%$ $2.1$ $1.0$ $193.6$ $-0.2%$ $192.6$ $-0.7%$ $190.3$ $-1.9%$ $2.2$ $1.0$ $192.4$ $-0.8%$ $194.4$ $0.2%$ $193.1$ $-0.4%$ $2.3$ $1.0$ $191.4$ $-1.3%$ $192.2$ $-0.9%$ $192.7$ $-0.6%$ $2.4$ $1.0$ $191.7$ $-1.1%$ $192.6$ $-0.7%$ $192.7$ $-0.6%$ $2.5$ $1.0$ $191.9$ $-1.0%$ $192.6$ $-0.7%$ $192.0$ $-1.0%$ $2.5$ $1.0$ $191.9$ $-1.0%$ $192.6$ $-0.7%$ $191.8$ $-1.1%$ $2.5$ $1.0$ $191.9$ $-1.0%$ $192.6$ $-0.7%$ $191.8$ $-1.1%$ $1.4$ $1.1$ $195.0$ $0.6%$ $194.2$ $0.1%$ $193.8$ $-0.1%$ $1.4$ $1.2$ $193.4$ $-0.3%$ $192.9$ $-0.5%$ $194.4$ $0.2%$                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 1.9     | 1.0       | 192.0      | -1.0%      | 193.2        | -0.4%      | 194.8      | 0.4%       |
| 2.1 $1.0$ $193.6$ $-0.2%$ $192.6$ $-0.7%$ $190.3$ $-1.9%$ $2.2$ $1.0$ $192.4$ $-0.8%$ $194.4$ $0.2%$ $193.1$ $-0.4%$ $2.3$ $1.0$ $191.4$ $-1.3%$ $192.2$ $-0.9%$ $192.7$ $-0.6%$ $2.4$ $1.0$ $191.7$ $-1.1%$ $192.6$ $-0.7%$ $192.0$ $-1.0%$ $2.5$ $1.0$ $191.7$ $-1.1%$ $192.6$ $-0.7%$ $192.0$ $-1.0%$ $2.5$ $1.0$ $191.9$ $-1.0%$ $192.6$ $-0.7%$ $191.8$ $-1.1%$ $1.2$ $1.1$ $195.0$ $0.6%$ $194.2$ $0.1%$ $191.8$ $-1.1%$ $1.4$ $1.1$ $193.2$ $-0.3%$ $192.9$ $-0.5%$ $194.4$ $0.2%$ $1.4$ $1.2$ $193.4$ $-0.3%$ $192.2$ $-0.9%$ $194.3$ $0.2%$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 2.0     | 1.0       | 191.8      | -1.1%      | 194.8        | 0.5%       | 193.4      | -0.3%      |
| 2.2 $1.0$ $192.4$ $-0.8%$ $194.4$ $0.2%$ $193.1$ $-0.4%$ $2.3$ $1.0$ $191.4$ $-1.3%$ $192.2$ $-0.9%$ $192.7$ $-0.6%$ $2.4$ $1.0$ $191.7$ $-1.1%$ $192.6$ $-0.7%$ $192.0$ $-1.0%$ $2.5$ $1.0$ $191.9$ $-1.0%$ $192.6$ $-0.7%$ $191.8$ $-1.1%$ $2.5$ $1.0$ $191.9$ $-1.0%$ $192.6$ $-0.7%$ $191.8$ $-1.1%$ $1.2$ $1.1$ $195.0$ $0.6%$ $194.2$ $0.1%$ $193.8$ $-0.1%$ $1.4$ $1.1$ $193.2$ $-0.3%$ $192.9$ $-0.5%$ $194.4$ $0.2%$ $1.4$ $1.2$ $193.4$ $-0.3%$ $192.2$ $-0.9%$ $194.3$ $0.2%$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | 2.1     | 1.0       | 193.6      | -0.2%      | 192.6        | -0.7%      | 190.3      | -1.9%      |
| 2.3 $1.0$ $191.4$ $-1.3%$ $192.2$ $-0.9%$ $192.7$ $-0.6%$ $2.4$ $1.0$ $191.7$ $-1.1%$ $192.6$ $-0.7%$ $192.0$ $-1.0%$ $2.5$ $1.0$ $191.9$ $-1.0%$ $192.6$ $-0.7%$ $192.0$ $-1.0%$ $2.5$ $1.0$ $191.9$ $-1.0%$ $192.6$ $-0.7%$ $191.8$ $-1.1%$ $1.2$ $1.1$ $195.0$ $0.6%$ $194.2$ $0.1%$ $193.8$ $-0.1%$ $1.4$ $1.1$ $193.2$ $-0.3%$ $192.9$ $-0.5%$ $194.4$ $0.2%$ $1.4$ $1.2$ $193.4$ $-0.3%$ $192.2$ $-0.9%$ $194.3$ $0.2%$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 2.2     | 1.0       | 192.4      | -0.8%      | 194.4        | 0.2%       | 193.1      | -0.4%      |
| 2.4 $1.0$ $191.7$ $-1.1%$ $192.6$ $-0.7%$ $192.0$ $-1.0%$ $2.5$ $1.0$ $191.9$ $-1.0%$ $192.6$ $-0.7%$ $191.8$ $-1.1%$ $1.2$ $1.1$ $195.0$ $0.6%$ $194.2$ $0.1%$ $193.8$ $-0.1%$ $1.4$ $1.1$ $193.2$ $-0.3%$ $192.9$ $-0.5%$ $194.4$ $0.2%$ $1.4$ $1.2$ $193.4$ $-0.3%$ $192.2$ $-0.9%$ $194.3$ $0.2%$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 2.3     | 1.0       | 191.4      | -1.3%      | 192.2        | -0.9%      | 192.7      | -0.6%      |
| 2.5 $1.0$ $191.9$ $-1.0%$ $192.6$ $-0.7%$ $191.8$ $-1.1%$ $1.2$ $1.1$ $195.0$ $0.6%$ $194.2$ $0.1%$ $193.8$ $-0.1%$ $1.4$ $1.1$ $193.2$ $-0.3%$ $192.9$ $-0.5%$ $194.4$ $0.2%$ $1.4$ $1.2$ $193.4$ $-0.3%$ $192.2$ $-0.9%$ $194.3$ $0.2%$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 2.4     | 1.0       | 191.7      | -1.1%      | 192.6        | -0.7%      | 192.0      | -1.0%      |
| 1.2 $1.1$ $195.0$ $0.6%$ $194.2$ $0.1%$ $193.8$ $-0.1%$ $1.4$ $1.1$ $193.2$ $-0.3%$ $192.9$ $-0.5%$ $194.4$ $0.2%$ $1.4$ $1.2$ $193.4$ $-0.3%$ $192.2$ $-0.9%$ $194.3$ $0.2%$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 2.5     | 1.0       | 191.9      | -1.0%      | 192.6        | -0.7%      | 191.8      | -1.1%      |
| 1.4 $1.1$ $193.2$ $-0.3%$ $192.9$ $-0.5%$ $194.4$ $0.2%$ $1.4$ $1.2$ $193.4$ $-0.3%$ $192.2$ $-0.9%$ $194.3$ $0.2%$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1.2     | 1.1       | 195.0      | 0.6%       | 194.2        | 0.1%       | 193.8      | -0.1%      |
| 1.4         1.2         193.4         -0.3%         192.2         -0.9%         194.3         0.2%                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1.4     | 1.1       | 193.2      | -0.3%      | 192.9        | -0.5%      | 194.4      | 0.2%       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1.4     | 1.2       | 193.4      | -0.3%      | 192.2        | -0.9%      | 194.3      | 0.2%       |

### APPENDIX F. QUARTUS II FMAX GEOMETRIC MEANS

|                |              | Aap      | Percent    | Difference | -0.5% | -0.5% | 0.4%  | 0.2%  | -0.4% | -0.2% | -0.3% | -0.4% | 0.1%  | -0.4% | -0.2% | -0.3% | -0.2% | -0.2% | 0.8%  | -0.7% |
|----------------|--------------|----------|------------|------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
|                |              | MO-M     | Fmax (MHz) |            | 193.0 | 192.9 | 194.7 | 194.2 | 193.1 | 193.4 | 193.3 | 193.0 | 194.1 | 193.2 | 193.6 | 193.3 | 193.6 | 193.4 | 195.4 | 192.5 |
| us page        |              | 1ap      | Percent    | Difference | 0.5%  | 0.2%  | -0.7% | -0.9% | 0.3%  | -0.8% | 0.0%  | -0.1% | 0.4%  | -0.6% | -0.1% | 0.1%  | -0.2% | -0.2% | 0.1%  | -0.5% |
| ed from previo | Architecture | WireN    | Fmax (MHz) |            | 194.9 | 194.3 | 192.6 | 192.2 | 194.6 | 192.4 | 194.0 | 193.8 | 194.7 | 192.7 | 193.6 | 194.1 | 193.5 | 193.6 | 194.1 | 192.9 |
| F.1 – continu  | Stratix IL   | Map      | Percent    | Difference | -0.2% | 0.5%  | -0.4% | 0.1%  | -0.4% | -0.1% | 0.2%  | 0.1%  | 0.2%  | -0.4% | 1.0%  | -0.2% | -0.7% | -0.2% | -1.2% | -0.8% |
| Table I        |              | ClassicM | Fmax (MHz) |            | 193.5 | 194.9 | 193.1 | 194.0 | 193.2 | 193.7 | 194.3 | 194.1 | 194.3 | 193.0 | 195.9 | 193.6 | 192.5 | 193.4 | 191.7 | 192.4 |
|                |              |          | Weight(5)  |            | 1.3   | 1.1   | 1.2   | 1.3   | 1.4   | 1.1   | 1.2   | 1.4   | 1.6   | 1.1   | 1.2   | 1.6   | 1.1   | 1.2   | 1.6   | 2.0   |
|                |              |          | Weight(6)  |            | 1.4   | 1.6   | 1.6   | 1.6   | 1.6   | 1.8   | 1.8   | 1.8   | 1.8   | 2.0   | 2.0   | 2.0   | 2.4   | 2.4   | 2.4   | 2.4   |

| 2        |   |
|----------|---|
| previous |   |
| from     | • |
| inued    |   |
| ont      | • |
| с<br>Г   | ζ |
|          |   |