<!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>linbox: algorithms</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.7.4 --> <script type="text/javascript"> function hasClass(ele,cls) { return ele.className.match(new RegExp('(\\s|^)'+cls+'(\\s|$)')); } function addClass(ele,cls) { if (!this.hasClass(ele,cls)) ele.className += " "+cls; } function removeClass(ele,cls) { if (hasClass(ele,cls)) { var reg = new RegExp('(\\s|^)'+cls+'(\\s|$)'); ele.className=ele.className.replace(reg,' '); } } function toggleVisibility(linkObj) { var base = linkObj.getAttribute('id'); var summary = document.getElementById(base + '-summary'); var content = document.getElementById(base + '-content'); var trigger = document.getElementById(base + '-trigger'); if ( hasClass(linkObj,'closed') ) { summary.style.display = 'none'; content.style.display = 'block'; trigger.src = 'open.png'; removeClass(linkObj,'closed'); addClass(linkObj,'opened'); } else if ( hasClass(linkObj,'opened') ) { summary.style.display = 'block'; content.style.display = 'none'; trigger.src = 'closed.png'; removeClass(linkObj,'opened'); addClass(linkObj,'closed'); } return false; } </script> <div id="top"> <div id="titlearea"> <table cellspacing="0" cellpadding="0"> <tbody> <tr style="height: 56px;"> <td style="padding-left: 0.5em;"> <div id="projectname">linbox</div> </td> </tr> </tbody> </table> </div> <div id="navrow1" class="tabs"> <ul class="tablist"> <li><a href="index.html"><span>Main Page</span></a></li> <li><a href="pages.html"><span>Related Pages</span></a></li> <li><a href="modules.html"><span>Modules</span></a></li> <li><a href="namespaces.html"><span>Namespaces</span></a></li> <li><a href="annotated.html"><span>Data Structures</span></a></li> <li><a href="files.html"><span>Files</span></a></li> <li><a href="dirs.html"><span>Directories</span></a></li> <li><a href="examples.html"><span>Examples</span></a></li> </ul> </div> </div> <div class="header"> <div class="summary"> <a href="#nested-classes">Data Structures</a> | <a href="#groups">Modules</a> | <a href="#files">Files</a> | <a href="#func-members">Functions</a> </div> <div class="headertitle"> <div class="title">algorithms</div> </div> </div> <div class="contents"> <p>The core linear algebra algorithms of <a class="el" href="namespace_lin_box.html" title="Namespace in which all linbox code resides.">LinBox</a>. <a href="#details">More...</a></p> <table class="memberdecls"> <tr><td colspan="2"><h2><a name="nested-classes"></a> Data Structures</h2></td></tr> <tr><td class="memItemLeft" align="right" valign="top">class  </td><td class="memItemRight" valign="bottom"><a class="el" href="class_lin_box_1_1_blackbox_container_symmetrize.html">BlackboxContainerSymmetrize< Field, _Blackbox, RandIter ></a></td></tr> <tr><td class="mdescLeft"> </td><td class="mdescRight">Symmetrizing iterator (for rank computations). <a href="class_lin_box_1_1_blackbox_container_symmetrize.html#details">More...</a><br/></td></tr> <tr><td colspan="2"><h2><a name="groups"></a> Modules</h2></td></tr> <tr><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="group___c_r_a.html">Chinese Remaindering Algorithm</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p>Chinese Remaindering (<code>cra</code>) in <a class="el" href="namespace_lin_box.html" title="Namespace in which all linbox code resides.">LinBox</a>. </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="group__diophant.html">Diophantine solvers</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p>NO DOC YET. </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="group__elim.html">Elimination</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p>NO DOC YET. </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="group__lanczos.html">Lanczos</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p>NO DOC YET. </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="group__padic.html">p-adic lifting for linear system solutions.</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p>interface for solving linear system by p-adic lifting technique over the quotient field of a ring. </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="group__sigmabase.html">Sigma-basis</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p>NO DOC YET. </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="group__wiedemann.html">Wiedemann</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p>NO DOC YET. </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top"> </td><td class="memItemRight" valign="bottom"><a class="el" href="group___solvers.html">Solvers</a></td></tr> <tr><td colspan="2"><h2><a name="files"></a> Files</h2></td></tr> <tr><td class="memItemLeft" align="right" valign="top">file  </td><td class="memItemRight" valign="bottom"><a class="el" href="bbcharpoly_8h.html">bbcharpoly.h</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p>no doc. </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top">file  </td><td class="memItemRight" valign="bottom"><a class="el" href="blackbox-block-container-base_8h.html">blackbox-block-container-base.h</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p>NO DOC. </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top">file  </td><td class="memItemRight" valign="bottom"><a class="el" href="blackbox-block-container_8h.html">blackbox-block-container.h</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p>no doc. </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top">file  </td><td class="memItemRight" valign="bottom"><a class="el" href="blas-domain_8h.html">blas-domain.h</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p>NO DOC. </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top">file  </td><td class="memItemRight" valign="bottom"><a class="el" href="cra-domain_8h.html">cra-domain.h</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p>Wrapper around OMP/SEQ version of ChineseRemainder. </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top">file  </td><td class="memItemRight" valign="bottom"><a class="el" href="cra-early-multip_8h.html">cra-early-multip.h</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p>NO DOC. </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top">file  </td><td class="memItemRight" valign="bottom"><a class="el" href="cra-early-single_8h.html">cra-early-single.h</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p>NO DOC. </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top">file  </td><td class="memItemRight" valign="bottom"><a class="el" href="cra-full-multip-fixed_8h.html">cra-full-multip-fixed.h</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p>CRA for multi-residues. </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top">file  </td><td class="memItemRight" valign="bottom"><a class="el" href="cra-full-multip_8h.html">cra-full-multip.h</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p>NO DOC. </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top">file  </td><td class="memItemRight" valign="bottom"><a class="el" href="cra-givrnsfixed_8h.html">cra-givrnsfixed.h</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p>NO DOC. </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top">file  </td><td class="memItemRight" valign="bottom"><a class="el" href="cra-kaapi_8h.html">cra-kaapi.h</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p>NO DOC. </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top">file  </td><td class="memItemRight" valign="bottom"><a class="el" href="lifting-container_8h.html">lifting-container.h</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p>Lifting from <code>mod p^n</code> to rationals NO DOC. </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top">file  </td><td class="memItemRight" valign="bottom"><a class="el" href="matrix-hom_8h.html">matrix-hom.h</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p>Matrix Homomorphism A map function converts a matrix on a field/ring to its natural image in another field/ring. </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top">file  </td><td class="memItemRight" valign="bottom"><a class="el" href="rational-reconstruction_8h.html">rational-reconstruction.h</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p>NO DOC. </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top">file  </td><td class="memItemRight" valign="bottom"><a class="el" href="rational-solver_8h.html">rational-solver.h</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p>Rational solving (Dixon, Wiedemann,...) </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top">file  </td><td class="memItemRight" valign="bottom"><a class="el" href="rns_8h.html">rns.h</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p><b>R</b>esidue <b>N</b>umber <b>S</b>ystem tools. </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top">file  </td><td class="memItemRight" valign="bottom"><a class="el" href="rns_8inl.html">rns.inl</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p><b>R</b>esidue <b>N</b>umber <b>S</b>ystem implementation. </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top">file  </td><td class="memItemRight" valign="bottom"><a class="el" href="smith-form-adaptive_8h.html">smith-form-adaptive.h</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p>Implement the adaptive algorithm for Smith form computation. </p> <br/></td></tr> </p> <tr><td class="memItemLeft" align="right" valign="top">file  </td><td class="memItemRight" valign="bottom"><a class="el" href="wiedemann_8h.html">wiedemann.h</a></td></tr> <p><tr><td class="mdescLeft"> </td><td class="mdescRight"><p>minpoly computation and Wiedeman solvers. </p> <br/></td></tr> </p> <tr><td colspan="2"><h2><a name="func-members"></a> Functions</h2></td></tr> <tr><td class="memTemplParams" colspan="2">template<class Polynomial , class Blackbox > </td></tr> <tr><td class="memTemplItemLeft" align="right" valign="top">Polynomial & </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="group__algorithms.html#ga1ef0e9d69b30d9e2db5e3c52a6bf0839">cia</a> (Polynomial &P, const Blackbox &A, const Method::BlasElimination &M)</td></tr> <tr><td class="mdescLeft"> </td><td class="mdescRight">Algorithm computing the integer characteristic polynomial of a dense matrix. <a href="#ga1ef0e9d69b30d9e2db5e3c52a6bf0839"></a><br/></td></tr> </table> <hr/><a name="details" id="details"></a><h2>Detailed Description</h2> <p>The core linear algebra algorithms of <a class="el" href="namespace_lin_box.html" title="Namespace in which all linbox code resides.">LinBox</a>. </p> <p>The codes here implement algorithms for linear algebra problems. The names often reflect the authorship of the central algorithm (Lanczos, Wiedemann, ...). In contrast, the "drivers" in the <a class="el" href="group__solutions.html">solutions</a> directory are named for the problem solved (rank, det, ...). Those are generally wrappers of algorithms from this directory. Their purpose is to give a simple and direct user interface and sometimes to provide a solution strategy which is a hybrid of algorithms from this directory.</p> <p>Algorithm classes and functions generally have the field class as a template parameter. Blackbox algorithms may have a BlackboxMatrix parameter or allow a Blackbox class as template parameter. Elimination codes work over DenseMatrix or SparseMatrix types with varying degrees of substitution among the types possible. </p> <hr/><h2>Function Documentation</h2> <a class="anchor" id="ga1ef0e9d69b30d9e2db5e3c52a6bf0839"></a><!-- doxytag: member="LinBox::cia" ref="ga1ef0e9d69b30d9e2db5e3c52a6bf0839" args="(Polynomial &P, const Blackbox &A, const Method::BlasElimination &M)" --> <div class="memitem"> <div class="memproto"> <table class="memname"> <tr> <td class="memname">Polynomial& LinBox::cia </td> <td>(</td> <td class="paramtype">Polynomial & </td> <td class="paramname"><em>P</em>, </td> </tr> <tr> <td class="paramkey"></td> <td></td> <td class="paramtype">const Blackbox & </td> <td class="paramname"><em>A</em>, </td> </tr> <tr> <td class="paramkey"></td> <td></td> <td class="paramtype">const Method::BlasElimination & </td> <td class="paramname"><em>M</em> </td> </tr> <tr> <td></td> <td>)</td> <td></td><td></td> </tr> </table> </div> <div class="memdoc"> <p>Algorithm computing the integer characteristic polynomial of a dense matrix. </p> <dl class="bib"><dt><b><a class="el" href="bib.html#_bib000003">Bibliography:</a></b></dt><dd>[Dumas-Pernet-Wan ISSAC05]</dd></dl> </div> </div> </div> <hr class="footer"/><address class="footer"><small>Generated on Tue Aug 30 2011 for linbox by  <a href="http://www.doxygen.org/index.html"> <img class="footer" src="doxygen.png" alt="doxygen"/></a> 1.7.4 </small></address> </body> </html>