## Design Automation for Field-coupled Nanotechnologies

Marcel Walter • Robert Wille • Frank Sill Torres Rolf Drechsler

# Design Automation for Field-coupled Nanotechnologies



Marcel Walter University of Bremen Bremen, Germany

Frank Sill Torres German Aerospace Center (DLR) Bremerhaven, Germany Robert Wille Johannes Kepler University Linz, Austria

Rolf Drechsler University of Bremen and DFKI GmbH Bremen, Germany

ISBN 978-3-030-89951-6 ISBN 978-3-030-89952-3 (eBook) https://doi.org/10.1007/978-3-030-89952-3

@ The Editor(s) (if applicable) and The Author(s), under exclusive license to Springer Nature Switzerland AG 2022

This work is subject to copyright. All rights are solely and exclusively licensed by the Publisher, whether the whole or part of the material is concerned, specifically the rights of translation, reprinting, reuse of illustrations, recitation, broadcasting, reproduction on microfilms or in any other physical way, and transmission or information storage and retrieval, electronic adaptation, computer software, or by similar or dissimilar methodology now known or hereafter developed.

The use of general descriptive names, registered names, trademarks, service marks, etc. in this publication does not imply, even in the absence of a specific statement, that such names are exempt from the relevant protective laws and regulations and therefore free for general use.

The publisher, the authors, and the editors are safe to assume that the advice and information in this book are believed to be true and accurate at the date of publication. Neither the publisher nor the authors or the editors give a warranty, expressed or implied, with respect to the material contained herein or for any errors or omissions that may have been made. The publisher remains neutral with regard to jurisdictional claims in published maps and institutional affiliations.

This Springer imprint is published by the registered company Springer Nature Switzerland AG The registered company address is: Gewerbestrasse 11, 6330 Cham, Switzerland

Dedicated to the loving memory of Barbara Walter (1932–2019)

Thank you, Grandma. Yours, Marcel.

#### **Preface**

Since the invention of integrated digital circuits, which heralded the beginning of the information age, their fabrication capabilities underwent rapid progress. Considering their transistor density doubled every few years since the 1960s, the physical limits of miniaturization will soon be reached. Consequently, novel paradigms are needed to enable computation-intensive future-oriented technologies such as artificial intelligence, autonomous driving, and immersive virtual reality.

Field-coupled nanocomputing (FCN) is a class of post-CMOS emerging integrated circuit technologies that includes contestants with enhancements in terms of energy dissipation and feature size. Certain implementations indicate the possibility to realize molecular-sized elementary devices with ultra-low energy dissipation or clock frequencies in the terahertz range.

Despite their promising characteristics, sophisticated automatic design methods are yet to be established. Due to the peculiarity and specificity of the FCN technologies' design constraints, conventional physical design algorithms cannot be applied. In other words, design automation for an entire class of highly promising nanotechnologies that could potentially enable a future of powerful and green computational devices is still in its infancy.

This book considers the main tasks in the area of design automation for FCN technologies that must be proficiently understood to enable large-scale composition of elementary building blocks to obtain correct systems from given function specifications. To this end, a holistic design flow is presented that covers

- Exact and scalable placement and routing
- One-pass logic synthesis
- Novel clocking mechanisms for data synchronization
- Formal verification for obtained circuit layouts

Additionally, theoretical groundwork is presented that lays the foundation for any algorithmic consideration in the future. Furthermore, an open-source and publicly available FCN design framework called *fiction*, which contains implementations of all discussed techniques, is presented.

viii Preface

The presented approaches address obstacles that have existed since the conceptualization of the FCN paradigm and could not be resolved since then. Thereby, this book substantially advances the state of the art in design automation for FCN technologies.

Bremen, Germany Marcel Walter

Linz, Austria Robert Wille

Bremerhaven, Germany Frank Sill Torres

Bremen, Germany Rolf Drechsler June 2021

#### Acknowledgments

Neither this book nor the included research work would have been possible without the support of exceptional people and institutions. We would like to seize the opportunity to express our gratitude towards them.

We are exceptionally grateful for the wonderful colleagues we have been fortunate to work with in the Research Group for Computer Architecture (AGRA) at the University of Bremen, and to the University of Bremen itself.

Special thanks to authors of all the chapters that provided a sturdy foundation to the work and research portrayed in this book.

Furthermore, our gratitude extends to all the researchers currently utilizing the *fiction* framework in their work. It is an honor to assist in the extension of the domain of field-coupled nanotechnologies.

In addition, we want to especially acknowledge Gregor Kuhn, who beautifully implemented the SVG layout export. Many thanks also go to Mario Kneidinger, Till Schlechtweg, and Fabrizio Riente for code contributions. Also, we would like to thank Mathias Soeken for allowing the use of parts of his code in *fiction*. Adjacently, we give our thanks to Nikolaj Bjørner for implementing particular feature requests into the Z3 SMT solver, and Alan Mishchenko for his guidance and for sharing his knowledge about incremental satisfiability solving. Furthermore, we would like to thank José Augusto M. Nacif for providing the logic networks that he used as benchmarks in his works, which enabled the performance of comparative experimental evaluations.

Moreover, we would like to offer our gratitude to those outside of our specific working environment who provided unwavering support in the creation of this book and the work contained within it. Specifically, Bella Gardner, Stefan Hillmich, Rune Krauß, and Dan Sörgel as well as Antje and Richard Heinemann.

x Acknowledgments

For funding, we thank the Collaborative Research Center (Sonderforschungsbereich) 1320 *EASE – Everyday Activity Science and Engineering*. Finally, we thank Springer Nature and especially Charles "Chuck" Glaser for publishing this work.

Bremen, Germany Marcel Walter

Linz, Austria Robert Wille

Bremerhaven, Germany Frank Sill Torres

Bremen, Germany Rolf Drechsler
June 2021

### **Contents**

| 1 | Intr                        | on                          | 1                                             |          |  |  |
|---|-----------------------------|-----------------------------|-----------------------------------------------|----------|--|--|
| 2 | Preliminaries               |                             |                                               |          |  |  |
|   | 2.1                         | Logic Representations       |                                               |          |  |  |
|   |                             | 2.1.1                       | Boolean Functions                             | 7        |  |  |
|   |                             | 2.1.2                       | Truth Tables                                  | 9        |  |  |
|   |                             | 2.1.3                       | Logic Networks                                | 10       |  |  |
|   | 2.2                         | Satisfi                     | ability Solvers                               | 13       |  |  |
|   |                             | 2.2.1                       | Boolean Satisfiability (SAT)                  | 14       |  |  |
|   |                             | 2.2.2                       | Satisfiability Modulo Theories (SMT)          | 15       |  |  |
|   | 2.3                         | Field-                      | coupled Nanocomputing (FCN)                   | 19       |  |  |
|   |                             | 2.3.1                       | Cells                                         | 20       |  |  |
|   |                             | 2.3.2                       | Gates                                         | 21       |  |  |
|   |                             | 2.3.3                       | Clocking                                      | 25       |  |  |
|   |                             | 2.3.4                       | Circuit Layouts                               | 30       |  |  |
| 3 | Theoretical Groundwork      |                             |                                               |          |  |  |
|   | 3.1                         |                             |                                               |          |  |  |
|   | 3.2                         |                             | tability Proofs for FCN Placement and Routing | 38<br>39 |  |  |
|   | 3.3                         | Summary and Future Work     |                                               |          |  |  |
| 4 | Exact Placement and Routing |                             |                                               |          |  |  |
|   | 4.1                         | _                           |                                               |          |  |  |
|   |                             |                             | ılation as an SMT Problem                     | 49       |  |  |
|   |                             | 4.2.1                       | Global Synchronization                        | 54       |  |  |
|   |                             | 4.2.2                       | Predefined Clocking Schemes                   | 55       |  |  |
|   |                             | 4.2.3                       | Wire Crossings                                | 56       |  |  |
|   |                             | 4.2.4                       | Border I/O Pins                               | 58       |  |  |
|   |                             | 4.2.5                       | Secondary Optimization Criteria               | 59       |  |  |
|   | 4.3                         | nental and Parallel Solving | 61                                            |          |  |  |
|   |                             | 4.3.1                       | Incremental Solving                           | 61       |  |  |
|   |                             | 4.3.2                       | Parallel Solving                              | 66       |  |  |

xii Contents

|   | 4.4  | Experimental Results                                         | 69 |
|---|------|--------------------------------------------------------------|----|
|   |      | 4.4.1 Implementation and Setup                               | 69 |
|   |      | 4.4.2 Quality Comparison Against State-of-the-Art Algorithms | 70 |
|   |      | 4.4.3 Design Space Exploration                               | 73 |
|   |      | 4.4.4 Benefit of Incremental Solving                         | 74 |
|   | 4.5  | Summary and Future Work                                      | 77 |
| 5 | Scal | ble Placement and Routing                                    | 79 |
|   | 5.1  | The Impact of Logic Network Preprocessing                    | 80 |
|   | 5.2  | Relation to Orthogonal Graph Drawing                         | 83 |
|   | 5.3  | Addressing FCN Design Constraints                            | 85 |
|   | 5.4  | Resulting Algorithm                                          | 88 |
|   | 5.5  | Experimental Results                                         | 92 |
|   |      | 5.5.1 Implementation and Setup                               | 92 |
|   |      | 5.5.2 Scalability Comparison Against State-of-the-Art        |    |
|   |      | Algorithms                                                   | 92 |
|   | 5.6  | Summary and Future Work                                      | 96 |
| 6 | One  | Pass Synthesis                                               | 99 |
|   | 6.1  | ·                                                            | 00 |
|   | 6.2  | General Idea1                                                | 02 |
|   | 6.3  | Formulation as a SAT Problem                                 | 03 |
|   | 6.4  | Experimental Results                                         | 07 |
|   |      | 6.4.1 Implementation and Setup                               | 07 |
|   |      |                                                              | 08 |
|   |      | 6.4.3 Generating a Design Library                            | 10 |
|   |      | 6.4.4 Further Benefits of the One-pass Scheme                | 12 |
|   | 6.5  | Summary and Future Work                                      | 13 |
| 7 | Exp  | oiting Clocks for Synchronization 1                          | 15 |
|   | 7.1  | Global Synchronization Revisited                             | 16 |
|   |      | 7.1.1 Combinational Circuits                                 | 16 |
|   |      | 7.1.2 Sequential Circuits                                    | 19 |
|   | 7.2  | Synchronization Elements                                     | 21 |
|   |      | 7.2.1 Basic Latch                                            | 21 |
|   |      | 7.2.2 D Latch                                                | 24 |
|   | 7.3  | Experimental Results                                         | 26 |
|   |      | 7.3.1 Implementation and Setup                               | 27 |
|   |      |                                                              | 29 |
|   |      | 7.3.3 Adapting Conventional Methods to FCN                   | 31 |
|   | 7.4  | Summary and Future Work                                      | 33 |
| 8 | For  | nal Verification                                             | 35 |
|   | 8.1  |                                                              | 36 |
|   | 8.2  | Verification Approach                                        | 38 |
|   |      | ==                                                           | 38 |
|   |      | 8.2.2 Enforcing Proper Synchronization                       | 39 |

Contents xiii

|     |       | 8.2.3   | Resulting Equivalence Checking Process   | 143 |
|-----|-------|---------|------------------------------------------|-----|
|     | 8.3   | Exper   | imental Results                          | 145 |
|     |       | 8.3.1   | Implementation and Setup                 | 145 |
|     |       | 8.3.2   | Validation of Physical Design Algorithms | 145 |
|     | 8.4   | Summ    | nary and Future Work                     | 148 |
| 9   | ficti | on: A H | Iolistic Open-Source Framework           | 151 |
|     | 9.1   | Relate  | ed Work on FCN Design Tools              | 152 |
|     |       | 9.1.1   | QCADesigner                              | 152 |
|     |       | 9.1.2   | ToPoliNano and MagCAD                    | 152 |
|     |       | 9.1.3   | NMLSim                                   | 153 |
|     |       | 9.1.4   | Ropper                                   | 154 |
|     |       | 9.1.5   | SiQAD                                    | 154 |
|     | 9.2   | The U   | ser's Perspective                        | 155 |
|     |       | 9.2.1   | The Command-Line Interface               | 155 |
|     |       | 9.2.2   | Specifications to Be Realized            | 157 |
|     |       | 9.2.3   | Physical Design                          | 158 |
|     |       | 9.2.4   | Validation and Verification              | 160 |
|     |       | 9.2.5   | Scripting for Experimental Evaluations   | 162 |
|     |       | 9.2.6   | Full User Documentation                  | 163 |
|     | 9.3   | The D   | eveloper's Perspective                   | 173 |
|     |       | 9.3.1   | Third-Party Libraries                    | 174 |
|     |       | 9.3.2   | Architecture and Data Types              | 177 |
|     |       | 9.3.3   | Implementing a Naive Placer              | 180 |
|     | 9.4   | Summ    | nary and Future Work                     | 182 |
| 10  | Sun   | ımary a | and Conclusions                          | 185 |
| Ref | erenc | es      |                                          | 187 |