8414

Automatic Generation Of Application-Specific Accelerators for FPGAs from Python Loop Nests

David Sheffield, Michael Anderson, Kurt Keutzer
Electrical Engineering and Computer Sciences, University of California at Berkeley
University of California at Berkeley, Technical Report No. UCB/EECS-2012-203, 2012

@techreport{Sheffield:EECS-2012-203,

   Author={Sheffield, David and Anderson, Michael and Keutzer, Kurt},

   Title={Automatic Generation Of Application-Specific Accelerators for FPGAs from Python Loop Nests},

   Institution={EECS Department, University of California, Berkeley},

   year={2012},

   Month={oct},

   URL={http://www.eecs.berkeley.edu/Pubs/TechRpts/2012/EECS-2012-203.html},

   Number={UCB/EECS-2012-203}

}

Download Download (PDF)   View View   Source Source   Source codes Source codes

1850

views

We present Three Fingered Jack, a highly productive approach to mapping vectorizable applications to the FPGA. Our system applies traditional dependence analysis and reordering transformations to a restricted set of Python loop nests. It does this to uncover parallelism and divide computation between multiple parallel processing elements (PEs) that are automatically generated through high-level synthesis of the optimized loop body. Design space exploration on the FPGA proceeds by varying the number of PEs in the system. Over four benchmark kernels, our system achieves 3x to 6x relative to soft-core C performance.
No votes yet.
Please wait...

* * *

* * *

HGPU group © 2010-2024 hgpu.org

All rights belong to the respective authors

Contact us: