<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/xhtml;charset=UTF-8"/> <title>GNU Radio 3.3.0 C++ API: gr_fir_fcc_simd Class Reference</title> <link href="tabs.css" rel="stylesheet" type="text/css"/> <link href="doxygen.css" rel="stylesheet" type="text/css"/> </head> <body> <!-- Generated by Doxygen 1.6.3 --> <div class="contents"> <h1>gr_fir_fcc_simd Class Reference</h1><!-- doxytag: class="gr_fir_fcc_simd" --><!-- doxytag: inherits="gr_fir_fcc_generic" --> <p>common base class for SIMD versions of <a class="el" href="classgr__fir__fcc.html" title="Abstract class for FIR with float input, gr_complex output and gr_complex tapsThis...">gr_fir_fcc</a>This base class handles alignment issues common to SSE and 3DNOW subclasses. <a href="#_details">More...</a></p> <p><code>#include <<a class="el" href="gr__fir__fcc__simd_8h_source.html">gr_fir_fcc_simd.h</a>></code></p> <div class="dynheader"> Inheritance diagram for gr_fir_fcc_simd:</div> <div class="dynsection"> <div class="center"><img src="classgr__fir__fcc__simd__inherit__graph.png" border="0" usemap="#gr__fir__fcc__simd_inherit__map" alt="Inheritance graph"/></div> <map name="gr__fir__fcc__simd_inherit__map" id="gr__fir__fcc__simd_inherit__map"> <area shape="rect" id="node7" href="classgr__fir__fcc__3dnow.html" title="3DNow! version of gr_fir_fcc" alt="" coords="5,237,125,267"/><area shape="rect" id="node9" href="classgr__fir__fcc__sse.html" title="SSE version of gr_fir_fcc." alt="" coords="149,237,253,267"/><area shape="rect" id="node2" href="classgr__fir__fcc__generic.html" title="Concrete class for generic implementation of FIR with float input, gr_complex output..." alt="" coords="71,83,196,112"/><area shape="rect" id="node4" href="classgr__fir__fcc.html" title="Abstract class for FIR with float input, gr_complex output and gr_complex tapsThis..." alt="" coords="96,5,171,35"/></map> <center><span class="legend">[<a target="top" href="graph_legend.html">legend</a>]</span></center></div> <p><a href="classgr__fir__fcc__simd-members.html">List of all members.</a></p> <table border="0" cellpadding="0" cellspacing="0"> <tr><td colspan="2"><h2>Public Member Functions</h2></td></tr> <tr><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="classgr__fir__fcc__simd.html#af1b5f81c4f2fd407f2437ccf0e68e07b">gr_fir_fcc_simd</a> ()</td></tr> <tr><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="classgr__fir__fcc__simd.html#a98a04cf70768c2647d221fa9efa8ddf5">gr_fir_fcc_simd</a> (const <a class="el" href="classstd_1_1vector.html">std::vector</a>< <a class="el" href="gr__complex_8h.html#aec4bfe41433369afae9327f1b0bc9109">gr_complex</a> > &<a class="el" href="interpolator__taps_8h.html#a30bf032e13c2a9fc4a98e14e390cd65a">taps</a>)</td></tr> <tr><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="classgr__fir__fcc__simd.html#aaba4d235c2bd9c7d069f3b54ab17d6ba">~gr_fir_fcc_simd</a> ()</td></tr> <tr><td class="memItemLeft" align="right" valign="top">virtual void </td><td class="memItemRight" valign="bottom"><a class="el" href="classgr__fir__fcc__simd.html#addafd951a10d29910605186df87db899">set_taps</a> (const <a class="el" href="classstd_1_1vector.html">std::vector</a>< <a class="el" href="gr__complex_8h.html#aec4bfe41433369afae9327f1b0bc9109">gr_complex</a> > &<a class="el" href="interpolator__taps_8h.html#a30bf032e13c2a9fc4a98e14e390cd65a">taps</a>)</td></tr> <tr><td class="mdescLeft"> </td><td class="mdescRight">install <code>new_taps</code> as the current taps. <a href="#addafd951a10d29910605186df87db899"></a><br/></td></tr> <tr><td class="memItemLeft" align="right" valign="top">virtual <a class="el" href="gr__complex_8h.html#aec4bfe41433369afae9327f1b0bc9109">gr_complex</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="classgr__fir__fcc__simd.html#a868747af1b2acfc6fd376afd12fdcf29">filter</a> (const float input[])</td></tr> <tr><td class="mdescLeft"> </td><td class="mdescRight">compute a single output value. <a href="#a868747af1b2acfc6fd376afd12fdcf29"></a><br/></td></tr> <tr><td colspan="2"><h2>Protected Types</h2></td></tr> <tr><td class="memItemLeft" align="right" valign="top">typedef void(* </td><td class="memItemRight" valign="bottom"><a class="el" href="classgr__fir__fcc__simd.html#a14a79e1e8b9284727079c214a1ed68c7">fcomplex_dotprod_t</a> )(const float *input, const float *<a class="el" href="interpolator__taps_8h.html#a30bf032e13c2a9fc4a98e14e390cd65a">taps</a>, unsigned n_2_complex_blocks, float *result)</td></tr> <tr><td colspan="2"><h2>Protected Attributes</h2></td></tr> <tr><td class="memItemLeft" align="right" valign="top">float * </td><td class="memItemRight" valign="bottom"><a class="el" href="classgr__fir__fcc__simd.html#a906c60ba5291b279c76dcb9904a626ff">d_aligned_taps</a> [4]</td></tr> <tr><td class="memItemLeft" align="right" valign="top"><a class="el" href="classgr__fir__fcc__simd.html#a14a79e1e8b9284727079c214a1ed68c7">fcomplex_dotprod_t</a> </td><td class="memItemRight" valign="bottom"><a class="el" href="classgr__fir__fcc__simd.html#a2fc799422f5a0e280a248ca56704d71d">d_fcomplex_dotprod</a></td></tr> </table> <hr/><a name="_details"></a><h2>Detailed Description</h2> <p>common base class for SIMD versions of <a class="el" href="classgr__fir__fcc.html" title="Abstract class for FIR with float input, gr_complex output and gr_complex tapsThis...">gr_fir_fcc</a></p> <p>This base class handles alignment issues common to SSE and 3DNOW subclasses. </p> <hr/><h2>Member Typedef Documentation</h2> <a class="anchor" id="a14a79e1e8b9284727079c214a1ed68c7"></a><!-- doxytag: member="gr_fir_fcc_simd::fcomplex_dotprod_t" ref="a14a79e1e8b9284727079c214a1ed68c7" args=")(const float *input, const float *taps, unsigned n_2_complex_blocks, float *result)" --> <div class="memitem"> <div class="memproto"> <table class="memname"> <tr> <td class="memname">typedef void(* <a class="el" href="classgr__fir__fcc__simd.html#a14a79e1e8b9284727079c214a1ed68c7">gr_fir_fcc_simd::fcomplex_dotprod_t</a>)(const float *input, const float *<a class="el" href="interpolator__taps_8h.html#a30bf032e13c2a9fc4a98e14e390cd65a">taps</a>, unsigned n_2_complex_blocks, float *result)<code> [protected]</code></td> </tr> </table> </div> <div class="memdoc"> </div> </div> <hr/><h2>Constructor & Destructor Documentation</h2> <a class="anchor" id="af1b5f81c4f2fd407f2437ccf0e68e07b"></a><!-- doxytag: member="gr_fir_fcc_simd::gr_fir_fcc_simd" ref="af1b5f81c4f2fd407f2437ccf0e68e07b" args="()" --> <div class="memitem"> <div class="memproto"> <table class="memname"> <tr> <td class="memname">gr_fir_fcc_simd::gr_fir_fcc_simd </td> <td>(</td> <td class="paramname"></td> <td> ) </td> <td></td> </tr> </table> </div> <div class="memdoc"> </div> </div> <a class="anchor" id="a98a04cf70768c2647d221fa9efa8ddf5"></a><!-- doxytag: member="gr_fir_fcc_simd::gr_fir_fcc_simd" ref="a98a04cf70768c2647d221fa9efa8ddf5" args="(const std::vector< gr_complex > &taps)" --> <div class="memitem"> <div class="memproto"> <table class="memname"> <tr> <td class="memname">gr_fir_fcc_simd::gr_fir_fcc_simd </td> <td>(</td> <td class="paramtype">const <a class="el" href="classstd_1_1vector.html">std::vector</a>< <a class="el" href="gr__complex_8h.html#aec4bfe41433369afae9327f1b0bc9109">gr_complex</a> > & </td> <td class="paramname"> <em>taps</em></td> <td> ) </td> <td></td> </tr> </table> </div> <div class="memdoc"> </div> </div> <a class="anchor" id="aaba4d235c2bd9c7d069f3b54ab17d6ba"></a><!-- doxytag: member="gr_fir_fcc_simd::~gr_fir_fcc_simd" ref="aaba4d235c2bd9c7d069f3b54ab17d6ba" args="()" --> <div class="memitem"> <div class="memproto"> <table class="memname"> <tr> <td class="memname">gr_fir_fcc_simd::~gr_fir_fcc_simd </td> <td>(</td> <td class="paramname"></td> <td> ) </td> <td></td> </tr> </table> </div> <div class="memdoc"> </div> </div> <hr/><h2>Member Function Documentation</h2> <a class="anchor" id="a868747af1b2acfc6fd376afd12fdcf29"></a><!-- doxytag: member="gr_fir_fcc_simd::filter" ref="a868747af1b2acfc6fd376afd12fdcf29" args="(const float input[])" --> <div class="memitem"> <div class="memproto"> <table class="memname"> <tr> <td class="memname">virtual <a class="el" href="gr__complex_8h.html#aec4bfe41433369afae9327f1b0bc9109">gr_complex</a> gr_fir_fcc_simd::filter </td> <td>(</td> <td class="paramtype">const float </td> <td class="paramname"> <em>input</em>[]</td> <td> ) </td> <td><code> [virtual]</code></td> </tr> </table> </div> <div class="memdoc"> <p>compute a single output value. </p> <p><code>input</code> must have <a class="el" href="classgr__fir__fcc.html#a480be7ebc5d223ab61a8a375486acb41">ntaps()</a> valid entries. input[0] .. input[<a class="el" href="classgr__fir__fcc.html#a480be7ebc5d223ab61a8a375486acb41">ntaps()</a> - 1] are referenced to compute the output value.</p> <dl class="return"><dt><b>Returns:</b></dt><dd>the filtered input value. </dd></dl> <p>Reimplemented from <a class="el" href="classgr__fir__fcc__generic.html#ab72639ddf12ad3838e468235838ab38d">gr_fir_fcc_generic</a>.</p> </div> </div> <a class="anchor" id="addafd951a10d29910605186df87db899"></a><!-- doxytag: member="gr_fir_fcc_simd::set_taps" ref="addafd951a10d29910605186df87db899" args="(const std::vector< gr_complex > &taps)" --> <div class="memitem"> <div class="memproto"> <table class="memname"> <tr> <td class="memname">virtual void gr_fir_fcc_simd::set_taps </td> <td>(</td> <td class="paramtype">const <a class="el" href="classstd_1_1vector.html">std::vector</a>< <a class="el" href="gr__complex_8h.html#aec4bfe41433369afae9327f1b0bc9109">gr_complex</a> > & </td> <td class="paramname"> <em>taps</em></td> <td> ) </td> <td><code> [virtual]</code></td> </tr> </table> </div> <div class="memdoc"> <p>install <code>new_taps</code> as the current taps. </p> <p>Reimplemented from <a class="el" href="classgr__fir__fcc.html#a03a29e78ad8ea447e52f20156b2b2601">gr_fir_fcc</a>.</p> </div> </div> <hr/><h2>Member Data Documentation</h2> <a class="anchor" id="a906c60ba5291b279c76dcb9904a626ff"></a><!-- doxytag: member="gr_fir_fcc_simd::d_aligned_taps" ref="a906c60ba5291b279c76dcb9904a626ff" args="[4]" --> <div class="memitem"> <div class="memproto"> <table class="memname"> <tr> <td class="memname">float* <a class="el" href="classgr__fir__fcc__simd.html#a906c60ba5291b279c76dcb9904a626ff">gr_fir_fcc_simd::d_aligned_taps</a>[4]<code> [protected]</code></td> </tr> </table> </div> <div class="memdoc"> <p><code>aligned_taps</code> holds 4 copies of the coefficients preshifted by 0, 1, 2, or 3 float pairs to meet all possible input data alignments. This allows us to always fetch data and taps that are 128-bit aligned. </p> </div> </div> <a class="anchor" id="a2fc799422f5a0e280a248ca56704d71d"></a><!-- doxytag: member="gr_fir_fcc_simd::d_fcomplex_dotprod" ref="a2fc799422f5a0e280a248ca56704d71d" args="" --> <div class="memitem"> <div class="memproto"> <table class="memname"> <tr> <td class="memname"><a class="el" href="classgr__fir__fcc__simd.html#a14a79e1e8b9284727079c214a1ed68c7">fcomplex_dotprod_t</a> <a class="el" href="classgr__fir__fcc__simd.html#a2fc799422f5a0e280a248ca56704d71d">gr_fir_fcc_simd::d_fcomplex_dotprod</a><code> [protected]</code></td> </tr> </table> </div> <div class="memdoc"> </div> </div> <hr/>The documentation for this class was generated from the following file:<ul> <li><a class="el" href="gr__fir__fcc__simd_8h_source.html">gr_fir_fcc_simd.h</a></li> </ul> </div> <hr class="footer"/><address style="text-align: right;"><small>Generated on Wed Dec 29 19:52:43 2010 for GNU Radio 3.3.0 C++ API by <a href="http://www.doxygen.org/index.html"> <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.6.3 </small></address> </body> </html>