Giter Site home page Giter Site logo

eecysu / graflex Goto Github PK

View Code? Open in Web Editor NEW
3.0 1.0 0.0 109.25 MB

[FPGA 2024] GraFlex: Flexible Graph Processing on FPGAs through Customized Scalable Interconnection Network

License: Apache License 2.0

Pascal 0.02% Tcl 3.87% JavaScript 2.26% Shell 1.28% Batchfile 0.06% Verilog 33.57% SystemVerilog 0.82% VHDL 41.37% Stata 0.09% Forth 0.03% Python 0.17% C 0.12% PureBasic 0.01% C++ 3.63% Ada 12.47% LLVM 0.22% Makefile 0.02%

graflex's Introduction

GraFlex

GraFlex: Flexible Graph Processing on FPGAs through Customized Scalable Interconnection Network


Code Structure

  • applications -> Example implementations of graph applications
  • automation -> Python scripts to generate Tcl scripts for GraFlex automation flow
  • UTIL_IP -> Infrastructure IP library packaged with Vivado 2020.2

Prerequisites

Software

  • Python >= 3.7
  • Vivado & Vitis & Vitis HLS 2020.2
  • XRT Version: xrt_202110.2.11.634 or xrt_202020.2.8.743 (newer ones not verified)

Hardware

  • AMD Xilinx Alveo U280 Acceleration Board

Quick Start (Check the GraFlex_AutoDemo.mp4 video for example)

Try GraFlex with the BFS example (Bellman-Ford, 2 PEs)

Step 1: Generate Tcl Scripts for Automation

cd <path_to>/GraFlex/applications/bfs_bf/PE_2
export PYTHONPATH=<path_to>/GraFlex/automation
python auto_backend.py

Step 2: Invoke Tcl Scripts from Vivado

vivado -source autoTcl/auto_backend.tcl

Step 3: Wait for Vivado to Finish Synthesis and Generate Compilable Object (.xo)

Step 4: Compile the Object with Vitis v++

Check applications/bfs_bf/PE_2/xo2xclbin for example

Artifact Evaluation

Current release is not fully stable. To access the graph datasets and directly reproduce the results, please visit the following Zenodo link: DOI

Cite this work

If you use this work in your paper, please cite our work here.

@inproceedings{su2024graflex,
  title={GraFlex: Flexible Graph Processing on FPGAs through Customized Scalable Interconnection Network},
  author={Su, Chunyou and Du, Linfeng and Liang, Tingyuan and Lin, Zhe and Wang, Maolin and Sinha, Sharad and Zhang, Wei},
  booktitle={Proceedings of the 2024 ACM/SIGDA International Symposium on Field Programmable Gate Arrays},
  pages={143--153},
  year={2024}
}

graflex's People

Contributors

eecysu avatar

Stargazers

齐豪 avatar  avatar Linfeng DU avatar

Watchers

 avatar

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. 📊📈🎉

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google ❤️ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.