Codebase list cppad / debian/2017.00.00.8-1 doc / det_by_lu.cpp.xml
debian/2017.00.00.8-1

Tree @debian/2017.00.00.8-1 (Download .tar.gz)

det_by_lu.cpp.xml @debian/2017.00.00.8-1raw · history · blame

<?xml version='1.0'?>
<html xmlns='http://www.w3.org/1999/xhtml'
      xmlns:math='http://www.w3.org/1998/Math/MathML'
>
<head>
<title>Determinant Using Lu Factorization: Example and Test</title>
<meta http-equiv='Content-Type' content='text/html' charset='utf-8'/>
<meta name="description" id="description" content="Determinant Using Lu Factorization: Example and Test"/>
<meta name="keywords" id="keywords" content=" determinant using lu factorization: example test minors "/>
<style type='text/css'>
body { color : black }
body { background-color : white }
A:link { color : blue }
A:visited { color : purple }
A:active { color : purple }
</style>
<script type='text/javascript' language='JavaScript' src='_det_by_lu.cpp_xml.js'>
</script>
</head>
<body>
<table><tr>
<td>
<a href="http://www.coin-or.org/CppAD/" target="_top"><img border="0" src="_image.gif"/></a>
</td>
<td><a href="det_by_lu.xml" target="_top">Prev</a>
</td><td><a href="det_by_lu.hpp.xml" target="_top">Next</a>
</td><td>
<select onchange='choose_across0(this)'>
<option>Index-&gt;</option>
<option>contents</option>
<option>reference</option>
<option>index</option>
<option>search</option>
<option>external</option>
</select>
</td>
<td>
<select onchange='choose_up0(this)'>
<option>Up-&gt;</option>
<option>CppAD</option>
<option>speed</option>
<option>speed_utility</option>
<option>det_by_lu</option>
<option>det_by_lu.cpp</option>
</select>
</td>
<td>
<select onchange='choose_down3(this)'>
<option>speed-&gt;</option>
<option>speed_main</option>
<option>speed_utility</option>
<option>speed_double</option>
<option>speed_adolc</option>
<option>speed_cppad</option>
<option>speed_fadbad</option>
<option>speed_sacado</option>
</select>
</td>
<td>
<select onchange='choose_down2(this)'>
<option>speed_utility-&gt;</option>
<option>det_by_lu</option>
<option>det_of_minor</option>
<option>det_by_minor</option>
<option>det_33</option>
<option>det_grad_33</option>
<option>mat_sum_sq</option>
<option>ode_evaluate</option>
<option>sparse_jac_fun</option>
<option>sparse_hes_fun</option>
<option>uniform_01</option>
</select>
</td>
<td>
<select onchange='choose_down1(this)'>
<option>det_by_lu-&gt;</option>
<option>det_by_lu.cpp</option>
<option>det_by_lu.hpp</option>
</select>
</td>
<td>det_by_lu.cpp</td>
<td>Headings</td>
</tr></table><br/>



<center><b><big><big>Determinant Using Lu Factorization: Example and Test</big></big></b></center>
<code><font color="blue"><pre><tt>
<span style="font-weight: bold"><span style="color: #000080"># include</span></span> <span style="color: #FF0000">&lt;cppad/cppad.hpp&gt;</span>
<span style="font-weight: bold"><span style="color: #000080"># include</span></span> <span style="color: #FF0000">&lt;cppad/speed/det_by_lu.hpp&gt;</span>

<span style="color: #009900">bool</span> <span style="font-weight: bold"><span style="color: #000000">det_by_lu</span></span><span style="color: #990000">()</span>
<span style="color: #FF0000">{</span>     <span style="color: #009900">bool</span> ok <span style="color: #990000">=</span> <span style="font-weight: bold"><span style="color: #0000FF">true</span></span><span style="color: #990000">;</span>

     <span style="font-style: italic"><span style="color: #9A1900">// dimension of the matrix</span></span>
     <span style="color: #008080">size_t</span> n <span style="color: #990000">=</span> <span style="color: #993399">3</span><span style="color: #990000">;</span>

     <span style="font-style: italic"><span style="color: #9A1900">// construct the determinat object</span></span>
     CppAD<span style="color: #990000">::</span><span style="color: #008080">det_by_lu&lt;double&gt;</span> <span style="font-weight: bold"><span style="color: #000000">Det</span></span><span style="color: #990000">(</span>n<span style="color: #990000">);</span>

     <span style="color: #009900">double</span>  a<span style="color: #990000">[]</span> <span style="color: #990000">=</span> <span style="color: #FF0000">{</span>
          <span style="color: #993399">1</span><span style="color: #990000">.,</span> <span style="color: #993399">2</span><span style="color: #990000">.,</span> <span style="color: #993399">3</span><span style="color: #990000">.,</span>  <span style="font-style: italic"><span style="color: #9A1900">// a[0] a[1] a[2]</span></span>
          <span style="color: #993399">3</span><span style="color: #990000">.,</span> <span style="color: #993399">2</span><span style="color: #990000">.,</span> <span style="color: #993399">1</span><span style="color: #990000">.,</span>  <span style="font-style: italic"><span style="color: #9A1900">// a[3] a[4] a[5]</span></span>
          <span style="color: #993399">2</span><span style="color: #990000">.,</span> <span style="color: #993399">1</span><span style="color: #990000">.,</span> <span style="color: #993399">2</span><span style="color: #990000">.</span>   <span style="font-style: italic"><span style="color: #9A1900">// a[6] a[7] a[8]</span></span>
     <span style="color: #FF0000">}</span><span style="color: #990000">;</span>
     <span style="font-weight: bold"><span style="color: #000000">CPPAD_TESTVECTOR</span></span><span style="color: #990000">(</span><span style="color: #009900">double</span><span style="color: #990000">)</span> <span style="font-weight: bold"><span style="color: #000000">A</span></span><span style="color: #990000">(</span><span style="color: #993399">9</span><span style="color: #990000">);</span>
     <span style="color: #008080">size_t</span> i<span style="color: #990000">;</span>
     <span style="font-weight: bold"><span style="color: #0000FF">for</span></span><span style="color: #990000">(</span>i <span style="color: #990000">=</span> <span style="color: #993399">0</span><span style="color: #990000">;</span> i <span style="color: #990000">&lt;</span> <span style="color: #993399">9</span><span style="color: #990000">;</span> i<span style="color: #990000">++)</span>
          A<span style="color: #990000">[</span>i<span style="color: #990000">]</span> <span style="color: #990000">=</span> a<span style="color: #990000">[</span>i<span style="color: #990000">];</span>


     <span style="font-style: italic"><span style="color: #9A1900">// evaluate the determinant</span></span>
     <span style="color: #009900">double</span> det <span style="color: #990000">=</span> <span style="font-weight: bold"><span style="color: #000000">Det</span></span><span style="color: #990000">(</span>A<span style="color: #990000">);</span>

     <span style="color: #009900">double</span> check<span style="color: #990000">;</span>
     check <span style="color: #990000">=</span> a<span style="color: #990000">[</span><span style="color: #993399">0</span><span style="color: #990000">]*(</span>a<span style="color: #990000">[</span><span style="color: #993399">4</span><span style="color: #990000">]*</span>a<span style="color: #990000">[</span><span style="color: #993399">8</span><span style="color: #990000">]</span> <span style="color: #990000">-</span> a<span style="color: #990000">[</span><span style="color: #993399">5</span><span style="color: #990000">]*</span>a<span style="color: #990000">[</span><span style="color: #993399">7</span><span style="color: #990000">])</span>
           <span style="color: #990000">-</span> a<span style="color: #990000">[</span><span style="color: #993399">1</span><span style="color: #990000">]*(</span>a<span style="color: #990000">[</span><span style="color: #993399">3</span><span style="color: #990000">]*</span>a<span style="color: #990000">[</span><span style="color: #993399">8</span><span style="color: #990000">]</span> <span style="color: #990000">-</span> a<span style="color: #990000">[</span><span style="color: #993399">5</span><span style="color: #990000">]*</span>a<span style="color: #990000">[</span><span style="color: #993399">6</span><span style="color: #990000">])</span>
           <span style="color: #990000">+</span> a<span style="color: #990000">[</span><span style="color: #993399">2</span><span style="color: #990000">]*(</span>a<span style="color: #990000">[</span><span style="color: #993399">3</span><span style="color: #990000">]*</span>a<span style="color: #990000">[</span><span style="color: #993399">7</span><span style="color: #990000">]</span> <span style="color: #990000">-</span> a<span style="color: #990000">[</span><span style="color: #993399">4</span><span style="color: #990000">]*</span>a<span style="color: #990000">[</span><span style="color: #993399">6</span><span style="color: #990000">]);</span>

     ok <span style="color: #990000">=</span> CppAD<span style="color: #990000">::</span><span style="font-weight: bold"><span style="color: #000000">NearEqual</span></span><span style="color: #990000">(</span>det<span style="color: #990000">,</span> check<span style="color: #990000">,</span> <span style="color: #993399">1e-10</span><span style="color: #990000">,</span> <span style="color: #993399">1e-10</span><span style="color: #990000">);</span>

     <span style="font-weight: bold"><span style="color: #0000FF">return</span></span> ok<span style="color: #990000">;</span>
<span style="color: #FF0000">}</span>
</tt></pre>
</font></code>
<hr/>Input File: speed/example/det_by_lu.cpp

</body>
</html>