Movatterモバイル変換


[0]ホーム

URL:


Skip to content

Navigation Menu

Sign in
Appearance settings

Search code, repositories, users, issues, pull requests...

Provide feedback

We read every piece of feedback, and take your input very seriously.

Saved searches

Use saved searches to filter your results more quickly

Sign up
Appearance settings

🕹 OpenPARF: An Open-Source Placement and Routing Framework for Large-Scale Heterogeneous FPGAs with Deep Learning Toolkit

License

NotificationsYou must be signed in to change notification settings

PKU-IDEA/OpenPARF

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

40 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

🚀 A High-Performance FPGA Placement and Routing Framework Powered byPyTorch

State-of-the-Art  | GPU-Accelerated  | Production-Ready

Table of Contents

Overview

OpenPARF is a cutting-edge FPGA placement and routing framework that delivers superior performance through innovative algorithms and GPU acceleration. Our framework achieves up to 12.7% improvement in routed wirelength and 2X+ speedup in placement compared to state-of-the-art solutions.

Key Features

  • 🔋Advanced Placement Technology

    • Multi-Electrostatic-based placement engine
    • Multi-die FPGA support with SLL count optimization
    • Comprehensive unit support (LUT, FF, DSP, BRAM, IO, etc.)
  • High Performance

    • GPU acceleration via CUDA
    • 0.4-12.7% better routed wirelength
    • 2X+ faster placement speed
  • 🛠Production Ready

    • Industry-standard architecture support
    • Extensive benchmarking suite
    • Well-documented API and examples

Latest Updates

🎉OpenPARF 2.0 Release (2024/02/02)

  • Multi-die FPGA placement support
  • Flexshelf architecture format
  • Performance improvements and bug fixes
  • Release Notes

Visual Demo

Experience the power of our electrostatic field-based placement through these visualizations from benchmarkISPD2016/FPGA06:

LUTFFDSPBRAM
LUTffdspBRAM

Getting Started

Prerequisites

  • Python 3.7+
  • C++14 compatible compiler
  • PyTorch 1.7.1
  • CUDA 11.0 (for GPU acceleration)
  • Gurobi 9.5 (optional)

Installation

# Create conda environmentmamba create --name openparf python=3.7mamba activate openparf# Install dependenciesmamba install cmake boost bisonmamba install pytorch==1.7.1 torchvision==0.8.2 cudatoolkit=11.0 -c pytorchpip install hummingbird-ml pyyaml networkx tqdm# Build OpenPARFgit clone --recursive https://github.com/PKU-IDEA/OpenPARF.gitmkdir build&&cd buildcmake .. -DCMAKE_PREFIX_PATH=$CONDA_PREFIX -DPYTHON_EXECUTABLE=$(which python) -DCMAKE_INSTALL_PREFIX=../install -DPython3_EXECUTABLE=$(which python)make -j8&& make install

For detailed installation instructions, seeINSTALL.md.

Running Benchmarks

Download the benchmarks according toBENCHMARKS.md, then run the following command:

cd ../installpython openparf.py --config unittest/regression/ispd2016/FPGA01.json

For more benchmark information, seeBENCHMARKS.md.

Documentation

Resources

Team & Contributors

OpenPARF is developed and maintained byPKU-IDEA Lab at Peking University, under the supervision ofProf. Yibo Lin.

Core Contributors:

Publications

For academic papers and citations, please see ourpublications list.

License

OpenPARF is released under the BSD 3-Clause License. SeeLICENSE for details.

About

🕹 OpenPARF: An Open-Source Placement and Routing Framework for Large-Scale Heterogeneous FPGAs with Deep Learning Toolkit

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Contributors2

  •  
  •  

[8]ページ先頭

©2009-2025 Movatter.jp