skip to main content
research-article

Python to accelerate embedded SoC design: A case study for systems biology

Published: 10 March 2014 Publication History

Abstract

We present SysPy (System Python) a tool which exploits the strengths of the popular Python scripting language to boost design productivity of embedded System on Chips for FPGAs. SysPy acts as a “glue” software between mature HDLs, ready-to-use VHDL components and programmable processor soft IP cores. SysPy can be used to: (i) automatically translate hardware components described in Python into synthesizable VHDL, (ii) capture top-level structural descriptions of processor-centric SoCs in Python, (iii) implement all the steps necessary to compile the user's C code for an instruction set processor core and generate processor specific Tcl scripts that import to the design project all the necessary HDL files of the processor's description and instantiate/connect the core to other blocks in a synthesizable top-level Python description. Moreover, we have developed a Hardware Abstraction Layer (HAL) in Python which allows user applications running in a host PC to utilize effortlessly the SoC's resources in the FPGA. SysPy's design capabilities, when complemented with the developed HAL software API, provide all the necessary tools for hw/sw partitioning and iterative design for efficient SoC's performance tuning. We demonstrate how SysPy's design flow and functionalities can be used by building a processor-centric embedded SoC for computational systems biology. The designed SoC, implemented using a Xilinx Virtex-5 FPGA, combines the flexibility of a programmable soft processor core (Leon3) with the high performance of an application specific core to simulate flexibly and efficiently the stochastic behavior of large size biomolecular reaction networks. Such networks are essential for studying the dynamics of complex biological systems consisting of multiple interacting pathways.

References

[1]
Aeroflex Gaisler GRMON. 2012. Debug monitor for Leon. http://www.gaisler.com.
[2]
Aeroflex Gaisler Leon3. 2012. LEON3 Multiprocessing CPU Core. http://www.gaisler.com.
[3]
B. J. Bornstein, S. M. Keating, A. Jouraku, and M. Hucka. 2008. LibSBML: An API library for SBML. Bioinformatics 24, 6, 880--881.
[4]
B. Chapman and J. Chang. 2000. Biopython: Python tools for computational biology. SIGBIO Newsl. 20, 2, 15--19.
[5]
P. Chen, D. Kirkpatrick, and K. Keutzer. 2001. Scripting for EDA tools: a case study. In Proceedings of the International Symposium on Quality Electronic Design. 87--93.
[6]
Ciranova. 2012. PyCell Studio. http://www.ciranova.com.
[7]
Copasi. 2012. Biochemical network simulator. http://www.copasi.org/.
[8]
J. Decaluwe. 2004. MyHDL: A Python-based hardware description language. Linux J, 127, 5--9.
[9]
European Bioinformatics Institute. 2012. Biomodels database - a database of annotated published models. http://www.ebi.ac.uk/biomodels-main/.
[10]
G. Ewing. 2007. Plex: A Lexical Analysis Module for Python. http://www.cosc.canterbury.ac.nz/greg.ewing/python/Plex.
[11]
H. Fangohr. 2004. A comparison of C, MATLAB, and Python as teaching languages in engineering. In Proceedings of the International Conference on Computational Science (ICCS'04). M. Bubak, G. van Albada, P. Sloot, and J. Dongarra, Eds., Lecture Notes in Computer Science, vol. 3039, Springer, 1210--1217.
[12]
M. A. Gibson and J. Bruck. 2000. Efficient exact stochastic simulation of chemical systems with many species and many channels. J. Phys. Chem. A 104, 9, 1876--1889.
[13]
D. T. Gillespie. 1976. A general method for numerically simulating the stochastic time evolution of coupled chemical reactions. J. Comput. Phys. 22, 1--40.
[14]
D. T. Gillespie. 2007. Stochastic simulation of chemical kinetics. Ann. Rev. Phys. Chem. 58, 35--55.
[15]
P. Haglund, O. Mencer, W. Luk, and B. Tai. 2003. PyHDL: Hardware scripting with Python. In Proceedings of the International Conference on Field Programmable Logic. 1040--1043.
[16]
O. G. Hazapis and E. S. Manolakos. 2011. Scalable FRM-SSA SoC design for the simulation of networks with thousands of biochemical reactions in real time. In Proceedings of the International Conference on Field Programmable Logic and Applications. 459--463.
[17]
M. Hucka, A. Finney, H. M. Sauro, H. Bolouri, J. C. Doyle, and H. Kitano. 2003. The Systems Biology Markup Language (SBML): a medium for representation and exchange of biochemical network models. Bioinformatics 19, 4, 524--531.
[18]
B. Hutchings, B. Nelson, S. West, and R. Curtis. 2009. Comparing fine-grained performance on the Ambric MPPA against an FPGA. In Proceedings of the International Conference on Field Programmable Logic and Applications (FPL'09). 174--179.
[19]
H. Li, Y. Cao, L. R. Petzold, and D. T. Gillespie. 2008. Algorithms and software for stochastic simulation of biochemical reacting systems. Biotechnol. Progr. 24, 1, 56--61.
[20]
E. Logaras and E. S. Manolakos. 2010. SysPy: Using Python for processor-centric SoC design. In Proceedings of the IEEE International Conference on Electronics, Circuits and Systems. 762--765.
[21]
A. Mashtizadeh. 2007. PHDL: A Python hardware design framework. M.S. thesis, Department of Electrical Engineering and Computer Science, Massachusetts Institute of technology.
[22]
O. Mencer, M. Morf, and M. J. Flynn. 1998. PAM-Blox: High performance FPGA design for adaptive computing. In Proceedings of the IEEE Symposium on FPGAs for Custom Computing Machines. 167--174.
[23]
K. J. Millman and M. Aivazis. 2011. Python for Scientists and Engineers. Comput. Sci. Eng. 13, 2, 9--12.
[24]
C. J. Myers. 2009. Engineering Genetic Circuits. Chapman and Hall/CRC Mathematical & Computational Biology Series, CRC Press.
[25]
C. J. Myers, N. Barker, K. Jones, H. Kuwahara, C. Madsen, and N.-P. D. Nguyen. 2009. iBioSim. Bioinformatics 25, 21, 2848--2849.
[26]
OpenCores AVR. 2009. Atmel Mega128 processor core. http://opencores.org/project,avrcore.
[27]
OpenCores MinSoC. 2012. Minimal OpenRISC system on chip. http://opencores.org/project,minsoc.
[28]
J. Ou and V. K. Prasanna. 2004. PyGen: A Matlab/Simulink based tool for synthesizing parameterized and energy efficient designs using FPGAs. In Proceedings of the International Symposium on Field-Programmable Custom Computing Machines. 47--56.
[29]
E. Ouzounoglou, K. Vekrellis, and E. S. Manolakos. 2011. In silico modeling of alpha-synuclein oligomerization effects on neuronal homeostasis. In Proceedings of the International Conference on Systems Biology.
[30]
M. Pineda-Krch. 2008. GillespieSSA: Implementing the Gillespie Stochastic Simulation Algorithm in R. J. Stat. Software 25, 12, 1--18.
[31]
M. Rathinam, L. R. Petzold, Y. Cao, and D. T. Gillespie. 2003. Stiffness in stochastic chemically reacting systems: The implicit tau-leaping method. J. Chem. Phys. 119, 24, 12784--12794.
[32]
M. Schoeberl, S. Korsholm, T. Kalibera, and A. P. Ravn. 2011. A Hardware Abstraction Layer in Java. ACM Trans. Embed. Comput. Syst. 10, 4, 1--40.
[33]
StochPy. 2012. Stochastic modelling in Python. http://stompy.sourceforge.net/.
[34]
Synopsys Synphony. 2012. High Level Synthesis with Synphony C compiler. http://www.synopsys.com.
[35]
SysPy. 2012. System Python. http://cgi.di.uoa.gr/∼evlog/syspy.html.
[36]
SysPy Gillespie SoC. 2012. http://cgi.di.uoa.gr/∼evlog/Gillespie_SoC.html.
[37]
Xilinx System Generator. 2009. System Generator for DSP, UG640. http://www.xilinx.com.
[38]
Xilinx XST. 2009. Xilinx Synthesis Technology User Guide, UG627. http://www.xilinx.com.
[39]
M. Yoshimi, Y. Iwaoka, Y. Nishikawa, et al. 2007. FPGA implementation of a data-driven stochastic biochemical simulator with the Next Reaction Method. In Proceedings of the International Conference on Field Programmable Logic and Applications (FPL'07). 254--259.
[40]
M. Yoshimi, Y. Osana, Y. Iwaoka, et al. 2006. An FPGA implementation of high throughput stochastic simulator for large-scale biochemical systems. In Proceedings of the International Conference on Field Programmable Logic and Applications (FPL'06). 1--6.
[41]
M. Zhang, S. Tu, and Z. Chai. 2008. PDSDL: A dynamic System Description Language. In Proceedings of the International SoC Design Conference. Vol. 1. IEEE, 204--209.

Cited By

View all
  • (2023)ZyPy: Intercepting NumPy operations for acceleration on FPGAsProceedings of the 13th International Symposium on Highly Efficient Accelerators and Reconfigurable Technologies10.1145/3597031.3597033(100-106)Online publication date: 14-Jun-2023
  • (2020)Enabling transparent hardware acceleration on Zynq SoC for scientific computingACM SIGBED Review10.1145/3412821.341282617:1(30-35)Online publication date: 27-Jul-2020
  • (2018)Hot & Spicy: Improving Productivity with Python and HLS for FPGAs2018 IEEE 26th Annual International Symposium on Field-Programmable Custom Computing Machines (FCCM)10.1109/FCCM.2018.00022(85-92)Online publication date: Apr-2018
  • Show More Cited By

Recommendations

Comments

Information & Contributors

Information

Published In

cover image ACM Transactions on Embedded Computing Systems
ACM Transactions on Embedded Computing Systems  Volume 13, Issue 4
Regular Papers
November 2014
647 pages
ISSN:1539-9087
EISSN:1558-3465
DOI:10.1145/2592905
Issue’s Table of Contents
Permission to make digital or hard copies of all or part of this work for personal or classroom use is granted without fee provided that copies are not made or distributed for profit or commercial advantage and that copies bear this notice and the full citation on the first page. Copyrights for components of this work owned by others than ACM must be honored. Abstracting with credit is permitted. To copy otherwise, or republish, to post on servers or to redistribute to lists, requires prior specific permission and/or a fee. Request permissions from [email protected]

Publisher

Association for Computing Machinery

New York, NY, United States

Journal Family

Publication History

Published: 10 March 2014
Accepted: 01 August 2013
Revised: 01 May 2013
Received: 01 October 2012
Published in TECS Volume 13, Issue 4

Permissions

Request permissions for this article.

Check for updates

Author Tags

  1. Biomolecular reaction networks
  2. FPGA
  3. Gillespie's Stochastic Simulation Algorithm
  4. Python
  5. SoC
  6. SysPy
  7. Systems Biology
  8. VHDL
  9. hw/sw co-design
  10. scripting languages

Qualifiers

  • Research-article
  • Research
  • Refereed

Funding Sources

Contributors

Other Metrics

Bibliometrics & Citations

Bibliometrics

Article Metrics

  • Downloads (Last 12 months)13
  • Downloads (Last 6 weeks)1
Reflects downloads up to 18 Jan 2025

Other Metrics

Citations

Cited By

View all
  • (2023)ZyPy: Intercepting NumPy operations for acceleration on FPGAsProceedings of the 13th International Symposium on Highly Efficient Accelerators and Reconfigurable Technologies10.1145/3597031.3597033(100-106)Online publication date: 14-Jun-2023
  • (2020)Enabling transparent hardware acceleration on Zynq SoC for scientific computingACM SIGBED Review10.1145/3412821.341282617:1(30-35)Online publication date: 27-Jul-2020
  • (2018)Hot & Spicy: Improving Productivity with Python and HLS for FPGAs2018 IEEE 26th Annual International Symposium on Field-Programmable Custom Computing Machines (FCCM)10.1109/FCCM.2018.00022(85-92)Online publication date: Apr-2018
  • (2016)Python facilitates the rapid prototyping and hw/sw verification of processor centric SoCs for FPGAs2016 IEEE International Symposium on Circuits and Systems (ISCAS)10.1109/ISCAS.2016.7527465(1214-1217)Online publication date: May-2016
  • (2015)Many-core CPUs can deliver scalable performance to stochastic simulations of large-scale biochemical reaction networks2015 International Conference on High Performance Computing & Simulation (HPCS)10.1109/HPCSim.2015.7237084(517-524)Online publication date: Jul-2015

View Options

Login options

Full Access

View options

PDF

View or Download as a PDF file.

PDF

eReader

View online with eReader.

eReader

Media

Figures

Other

Tables

Share

Share

Share this Publication link

Share on social media