C-Based Design Methodology for FPGA Implementation of ClustalW MSA
Systolisation of the pairwise distance computation algorithm and mapping into field programmable gate arrays (FPGA) have proven to give superior performance at a lower cost, compared to the same algorithm running on a cluster of workstations. The primary design methodology for this approach is based on the hardware description languages such as VHDL and Verilog HDL. An alternative design methodology, however, is the use of a high level language such as C to describe the algorithms and generate equivalent hardware descriptions for implementation in FPGA so as to reduce time to market. This paper describes the design and implementation of the ClustalW first stage multiple sequence alignment based on the Smith-Waterman algorithm on a low cost FPGA development platform using a C language development tool suite. Performance evaluation results show that comparable performance could be achieved to that of Pentium 4 systems and other HDL-based solutions using even the smallest commercially available FPGA device with this design methodology.
Keywordsmultiple sequence alignment ClustalW FPGA sequence analysis
Unable to display preview. Download preview PDF.
- 4.Yamaguchi, Y., Maruyama, T., Konagaya, A.: High Speed Homology Search with FPGAs. In: Pacific Symposium on Biocomputing, pp. 271–282 (2002)Google Scholar
- 5.Sullivan, C., Wilson, A., Chappell, S.: Using C based Logic Synthesis to Bridge the Productivity Gap. In: Proc. of the 2004 Conference on Asia South Pacific Design Automation, pp. 349–354 (2004)Google Scholar
- 7.Liu, W., Schmidt, B., Voss, G., Muller-Wittig, W.: Streaming Algorithms for Biological Sequence Alignment on GPUs. IEEE Trans. Parallel Distrib. Syst. (to be published)Google Scholar
- 8.Xilinx: Virtex-4 Family Overview. ds112.pdf (2007)Google Scholar
- 10.Yu, C.W., Kwong, K.H., Lee, K.H., Leong, P.H.W.: A Smith-Waterman Systolic Cell. In: Proc. of 13th Int. Workshop Field Programmable Logic and Applications, pp. 375–384 (2003)Google Scholar