Sophie

Sophie

distrib > Fedora > 16 > i386 > by-pkgid > 4bc66056a634db26a1f4d0845dc41ca6 > files > 4726

mrpt-doc-0.9.5-0.1.20110925svn2670.fc16.i686.rpm

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head><meta http-equiv="Content-Type" content="text/html;charset=iso-8859-1">
<title>mrpt::random::CRandomGenerator Class Reference</title>
<link href="doxygen.css" rel="stylesheet" type="text/css">
<link href="tabs.css" rel="stylesheet" type="text/css">
</head><body>
<div align="left"><a href="http://www.mrpt.org/">Main MRPT website</a> &gt; <b>C++ reference</b> </div>
<div align="right">
<a href="index.html"><img border="0" src="mrpt_logo.png" alt="MRPT logo"></a>
</div>
<!-- Generated by Doxygen 1.7.5 -->
<script type="text/javascript">
var searchBox = new SearchBox("searchBox", "search",false,'Search');
</script>
  <div id="navrow1" class="tabs">
    <ul class="tablist">
      <li><a href="index.html"><span>Main&#160;Page</span></a></li>
      <li><a href="pages.html"><span>Related&#160;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 class="current"><a href="annotated.html"><span>Classes</span></a></li>
      <li><a href="files.html"><span>Files</span></a></li>
      <li>
        <div id="MSearchBox" class="MSearchBoxInactive">
          <div class="left">
            <form id="FSearchBox" action="search.php" method="get">
              <img id="MSearchSelect" src="search/mag.png" alt=""/>
              <input type="text" id="MSearchField" name="query" value="Search" size="20" accesskey="S" 
                     onfocus="searchBox.OnSearchFieldFocus(true)" 
                     onblur="searchBox.OnSearchFieldFocus(false)"/>
            </form>
          </div><div class="right"></div>
        </div>
      </li>
    </ul>
  </div>
  <div id="navrow2" class="tabs2">
    <ul class="tablist">
      <li><a href="annotated.html"><span>Class&#160;List</span></a></li>
      <li><a href="classes.html"><span>Class&#160;Index</span></a></li>
      <li><a href="inherits.html"><span>Class&#160;Hierarchy</span></a></li>
      <li><a href="functions.html"><span>Class&#160;Members</span></a></li>
    </ul>
  </div>
  <div id="nav-path" class="navpath">
    <ul>
      <li class="navelem"><a class="el" href="namespacemrpt.html">mrpt</a>      </li>
      <li class="navelem"><a class="el" href="namespacemrpt_1_1random.html">random</a>      </li>
      <li class="navelem"><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html">CRandomGenerator</a>      </li>
    </ul>
  </div>
</div>
<div class="header">
  <div class="summary">
<a href="#nested-classes">Classes</a> &#124;
<a href="#pro-methods">Protected Member Functions</a> &#124;
<a href="#pro-attribs">Protected Attributes</a>  </div>
  <div class="headertitle">
<div class="title">mrpt::random::CRandomGenerator Class Reference<div class="ingroups"><a class="el" href="group__mrpt__base__grp.html">[mrpt-base]</a></div></div>  </div>
</div>
<div class="contents">
<!-- doxytag: class="mrpt::random::CRandomGenerator" --><hr/><a name="details" id="details"></a><h2>Detailed Description</h2>
<div class="textblock"><p>A thred-safe pseudo random number generator, based on an internal MT19937 randomness generator. </p>
<p>The base algorithm for randomness is platform-independent. See <a href="http://en.wikipedia.org/wiki/Mersenne_twister">http://en.wikipedia.org/wiki/Mersenne_twister</a></p>
<p>For real thread-safety, each thread must create and use its own instance of this class.</p>
<p>Single-thread programs can use the static object <a class="el" href="namespacemrpt_1_1random.html#a4743bfa8fcb282b6f5d66395ccabaa73" title="A static instance of a CRandomGenerator class, for use in single-thread applications.">mrpt::random::randomGenerator</a> </p>
</div>
<p><code>#include &lt;<a class="el" href="_random_generators_8h_source.html">mrpt/random/RandomGenerators.h</a>&gt;</code></p>

<p><a href="classmrpt_1_1random_1_1_c_random_generator-members.html">List of all members.</a></p>
<table class="memberdecls">
<tr><td colspan="2"><h2><a name="nested-classes"></a>
Classes</h2></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">struct &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="structmrpt_1_1random_1_1_c_random_generator_1_1_t_m_t19937__data.html">TMT19937_data</a></td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Data used internally by the MT19937 PRNG algorithm.  <a href="structmrpt_1_1random_1_1_c_random_generator_1_1_t_m_t19937__data.html#details">More...</a><br/></td></tr>
<tr><td colspan="2"><h2><a name="pub-methods"></a>
Public Member Functions</h2></td></tr>
<tr><td colspan="2"><div class="groupHeader">Initialization</div></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#a9dd3aa1b262e296450419370123866d1">CRandomGenerator</a> ()</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Default constructor: initialize random seed based on current time.  <a href="#a9dd3aa1b262e296450419370123866d1"></a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#a5134b7ac823d79b9f0f555ffdba7bd86">CRandomGenerator</a> (const uint32_t seed)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Constructor for providing a custom random seed to initialize the PRNG.  <a href="#a5134b7ac823d79b9f0f555ffdba7bd86"></a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#a231ef5bd9387714debad4914e5da6985">randomize</a> (const uint32_t seed)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Initialize the PRNG from the given random seed.  <a href="#a231ef5bd9387714debad4914e5da6985"></a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#add506d08802a5a6e1b1aa46a76048cd1">randomize</a> ()</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Randomize the generators, based on current time.  <a href="#add506d08802a5a6e1b1aa46a76048cd1"></a><br/></td></tr>
<tr><td colspan="2"><div class="groupHeader">Uniform pdf</div></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">uint32_t&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#aede40e77053b8b4350fd786f1683e260">drawUniform32bit</a> ()</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Generate a uniformly distributed pseudo-random number using the MT19937 algorithm, in the whole range of 32-bit integers.  <a href="#aede40e77053b8b4350fd786f1683e260"></a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">double&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#a7a4bbaa961f106cd88a872986737a2fb">drawUniform</a> (const double Min, const double Max)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Generate a uniformly distributed pseudo-random number using the MT19937 algorithm, scaled to the selected range.  <a href="#a7a4bbaa961f106cd88a872986737a2fb"></a><br/></td></tr>
<tr><td class="memTemplParams" colspan="2">template&lt;class MAT &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top">void&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#a2378ba5fdabf270b2c48726dbcb627cc">drawUniformMatrix</a> (MAT &amp;matrix, const double unif_min=0, const double unif_max=1)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Fills the given matrix with independent, uniformly distributed samples.  <a href="#a2378ba5fdabf270b2c48726dbcb627cc"></a><br/></td></tr>
<tr><td class="memTemplParams" colspan="2">template&lt;class VEC &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top">void&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#a4ef658fc363148b999c6654c07e8c504">drawUniformVector</a> (VEC &amp;v, const double unif_min=0, const double unif_max=1)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Fills the given vector with independent, uniformly distributed samples.  <a href="#a4ef658fc363148b999c6654c07e8c504"></a><br/></td></tr>
<tr><td colspan="2"><div class="groupHeader">Normal/Gaussian pdf</div></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">double&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#a174c76f98b4213166fb87b577fdf2aaa">drawGaussian1D_normalized</a> (double *likelihood=NULL)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Generate a normalized (mean=0, std=1) normally distributed sample.  <a href="#a174c76f98b4213166fb87b577fdf2aaa"></a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">double&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#a3eab704e20a481c7ebf9884b06726cec">drawGaussian1D</a> (const double mean, const double std)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Generate a normally distributed pseudo-random number.  <a href="#a3eab704e20a481c7ebf9884b06726cec"></a><br/></td></tr>
<tr><td class="memTemplParams" colspan="2">template&lt;class MAT &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top">void&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#a63ed9d57fc7fe778bd50842f49077dda">drawGaussian1DMatrix</a> (MAT &amp;matrix, const double mean=0, const double std=1)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Fills the given matrix with independent, 1D-normally distributed samples.  <a href="#a63ed9d57fc7fe778bd50842f49077dda"></a><br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="el" href="namespacemrpt_1_1math.html#a3814c2b868f059d6a7ab0d8ecd2311d6">CMatrixDouble</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#aff719f0ca610030fc41a75e2b2373822">drawDefinitePositiveMatrix</a> (const size_t dim, const double std_scale=1.0, const double diagonal_epsilon=1e-8)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Generates a random definite-positive matrix of the given size, using the formula C = v*v^t + epsilon*I, with "v" being a vector of gaussian random samples.  <a href="#aff719f0ca610030fc41a75e2b2373822"></a><br/></td></tr>
<tr><td class="memTemplParams" colspan="2">template&lt;class VEC &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top">void&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#acbe63466320842a1ceb738bae1a062e4">drawGaussian1DVector</a> (VEC &amp;v, const double mean=0, const double std=1)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Fills the given vector with independent, 1D-normally distributed samples.  <a href="#acbe63466320842a1ceb738bae1a062e4"></a><br/></td></tr>
<tr><td class="memTemplParams" colspan="2">template&lt;typename T &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top">void&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#a7e74a5bba69f5a49b40ed38f32499c9d">drawGaussianMultivariate</a> (<a class="el" href="classstd_1_1vector.html">std::vector</a>&lt; T &gt; &amp;out_result, const <a class="el" href="classmrpt_1_1math_1_1_c_matrix_template_numeric.html">CMatrixTemplateNumeric</a>&lt; T &gt; &amp;cov, const <a class="el" href="classstd_1_1vector.html">std::vector</a>&lt; T &gt; *mean=NULL)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Generate multidimensional random samples according to a given covariance matrix.  <a href="#a7e74a5bba69f5a49b40ed38f32499c9d"></a><br/></td></tr>
<tr><td class="memTemplParams" colspan="2">template&lt;class VECTORLIKE , class COVMATRIX &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top">void&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#ae8d65bbc56b2f33acfcfaae4343b79b9">drawGaussianMultivariate</a> (VECTORLIKE &amp;out_result, const COVMATRIX &amp;cov, const VECTORLIKE *mean=NULL)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Generate multidimensional random samples according to a given covariance matrix.  <a href="#ae8d65bbc56b2f33acfcfaae4343b79b9"></a><br/></td></tr>
<tr><td class="memTemplParams" colspan="2">template&lt;typename VECTOR_OF_VECTORS , typename COVMATRIX &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top">void&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#a02ebde6aa19bc11b17960e88e2a9e58b">drawGaussianMultivariateMany</a> (VECTOR_OF_VECTORS &amp;ret, size_t desiredSamples, const COVMATRIX &amp;cov, const typename <a class="el" href="eigen__plugins_8h.html#afd07186978da46f9908364e389f8a403">VECTOR_OF_VECTORS::value_type</a> *mean=NULL)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Generate a given number of multidimensional random samples according to a given covariance matrix.  <a href="#a02ebde6aa19bc11b17960e88e2a9e58b"></a><br/></td></tr>
<tr><td colspan="2"><div class="groupHeader">Miscellaneous</div></td></tr>
<tr><td class="memTemplParams" colspan="2">template&lt;class VEC &gt; </td></tr>
<tr><td class="memTemplItemLeft" align="right" valign="top">void&#160;</td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#ac0f4a363fb29bf340e64ab9af6231d7b">permuteVector</a> (const VEC &amp;in_vector, VEC &amp;out_result)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Returns a random permutation of a vector: all the elements of the input vector are in the output but at random positions.  <a href="#ac0f4a363fb29bf340e64ab9af6231d7b"></a><br/></td></tr>
<tr><td colspan="2"><h2><a name="pro-methods"></a>
Protected Member Functions</h2></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#aef6819d05b148c234c3921181fbb8e54">MT19937_generateNumbers</a> ()</td></tr>
<tr><td class="memItemLeft" align="right" valign="top">void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#ad1852e43a441086367edaf4b8d461966">MT19937_initializeGenerator</a> (const uint32_t &amp;seed)</td></tr>
<tr><td colspan="2"><h2><a name="pro-attribs"></a>
Protected Attributes</h2></td></tr>
<tr><td class="memItemLeft" align="right" valign="top">struct <br class="typebreak"/>
<a class="el" href="structmrpt_1_1random_1_1_c_random_generator_1_1_t_m_t19937__data.html">mrpt::random::CRandomGenerator::TMT19937_data</a>&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#a80c8fcac9c7b3b0548c3328637487f33">m_MT19937_data</a></td></tr>
</table>
<hr/><h2>Constructor &amp; Destructor Documentation</h2>
<a class="anchor" id="a9dd3aa1b262e296450419370123866d1"></a><!-- doxytag: member="mrpt::random::CRandomGenerator::CRandomGenerator" ref="a9dd3aa1b262e296450419370123866d1" args="()" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">mrpt::random::CRandomGenerator::CRandomGenerator </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td><code> [inline]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Default constructor: initialize random seed based on current time. </p>

<p>Definition at line <a class="el" href="_random_generators_8h_source.html#l00075">75</a> of file <a class="el" href="_random_generators_8h_source.html">RandomGenerators.h</a>.</p>

</div>
</div>
<a class="anchor" id="a5134b7ac823d79b9f0f555ffdba7bd86"></a><!-- doxytag: member="mrpt::random::CRandomGenerator::CRandomGenerator" ref="a5134b7ac823d79b9f0f555ffdba7bd86" args="(const uint32_t seed)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">mrpt::random::CRandomGenerator::CRandomGenerator </td>
          <td>(</td>
          <td class="paramtype">const uint32_t&#160;</td>
          <td class="paramname"><em>seed</em></td><td>)</td>
          <td><code> [inline]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Constructor for providing a custom random seed to initialize the PRNG. </p>

<p>Definition at line <a class="el" href="_random_generators_8h_source.html#l00078">78</a> of file <a class="el" href="_random_generators_8h_source.html">RandomGenerators.h</a>.</p>

</div>
</div>
<hr/><h2>Member Function Documentation</h2>
<a class="anchor" id="aff719f0ca610030fc41a75e2b2373822"></a><!-- doxytag: member="mrpt::random::CRandomGenerator::drawDefinitePositiveMatrix" ref="aff719f0ca610030fc41a75e2b2373822" args="(const size_t dim, const double std_scale=1.0, const double diagonal_epsilon=1e&#45;8)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname"><a class="el" href="namespacemrpt_1_1math.html#a3814c2b868f059d6a7ab0d8ecd2311d6">CMatrixDouble</a> mrpt::random::CRandomGenerator::drawDefinitePositiveMatrix </td>
          <td>(</td>
          <td class="paramtype">const size_t&#160;</td>
          <td class="paramname"><em>dim</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const double&#160;</td>
          <td class="paramname"><em>std_scale</em> = <code>1.0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const double&#160;</td>
          <td class="paramname"><em>diagonal_epsilon</em> = <code>1e-8</code>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Generates a random definite-positive matrix of the given size, using the formula C = v*v^t + epsilon*I, with "v" being a vector of gaussian random samples. </p>

</div>
</div>
<a class="anchor" id="a3eab704e20a481c7ebf9884b06726cec"></a><!-- doxytag: member="mrpt::random::CRandomGenerator::drawGaussian1D" ref="a3eab704e20a481c7ebf9884b06726cec" args="(const double mean, const double std)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">double mrpt::random::CRandomGenerator::drawGaussian1D </td>
          <td>(</td>
          <td class="paramtype">const double&#160;</td>
          <td class="paramname"><em>mean</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const double&#160;</td>
          <td class="paramname"><em>std</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td><code> [inline]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Generate a normally distributed pseudo-random number. </p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table class="params">
    <tr><td class="paramname">mean</td><td>The mean value of desired normal distribution </td></tr>
    <tr><td class="paramname">std</td><td>The standard deviation value of desired normal distribution </td></tr>
  </table>
  </dd>
</dl>

<p>Definition at line <a class="el" href="_random_generators_8h_source.html#l00140">140</a> of file <a class="el" href="_random_generators_8h_source.html">RandomGenerators.h</a>.</p>

</div>
</div>
<a class="anchor" id="a174c76f98b4213166fb87b577fdf2aaa"></a><!-- doxytag: member="mrpt::random::CRandomGenerator::drawGaussian1D_normalized" ref="a174c76f98b4213166fb87b577fdf2aaa" args="(double *likelihood=NULL)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">double mrpt::random::CRandomGenerator::drawGaussian1D_normalized </td>
          <td>(</td>
          <td class="paramtype">double *&#160;</td>
          <td class="paramname"><em>likelihood</em> = <code>NULL</code></td><td>)</td>
          <td></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Generate a normalized (mean=0, std=1) normally distributed sample. </p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table class="params">
    <tr><td class="paramname">likelihood</td><td>If desired, pass a pointer to a double which will receive the likelihood of the given sample to have been obtained, that is, the value of the normal pdf at the sample value. </td></tr>
  </table>
  </dd>
</dl>

<p>Referenced by <a class="el" href="_random_generators_8h_source.html#l00346">mrpt::random::matrixRandomNormal()</a>, and <a class="el" href="_random_generators_8h_source.html#l00360">mrpt::random::vectorRandomNormal()</a>.</p>

</div>
</div>
<a class="anchor" id="a63ed9d57fc7fe778bd50842f49077dda"></a><!-- doxytag: member="mrpt::random::CRandomGenerator::drawGaussian1DMatrix" ref="a63ed9d57fc7fe778bd50842f49077dda" args="(MAT &amp;matrix, const double mean=0, const double std=1)" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class MAT &gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">void mrpt::random::CRandomGenerator::drawGaussian1DMatrix </td>
          <td>(</td>
          <td class="paramtype">MAT &amp;&#160;</td>
          <td class="paramname"><em>matrix</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const double&#160;</td>
          <td class="paramname"><em>mean</em> = <code>0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const double&#160;</td>
          <td class="paramname"><em>std</em> = <code>1</code>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td><code> [inline]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Fills the given matrix with independent, 1D-normally distributed samples. </p>
<p>Matrix classes can be CMatrixTemplateNumeric or CMatrixFixedNumeric </p>
<dl class="see"><dt><b>See also:</b></dt><dd><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#a3eab704e20a481c7ebf9884b06726cec" title="Generate a normally distributed pseudo-random number.">drawGaussian1D</a> </dd></dl>

<p>Definition at line <a class="el" href="_random_generators_8h_source.html#l00149">149</a> of file <a class="el" href="_random_generators_8h_source.html">RandomGenerators.h</a>.</p>

<p>References <a class="el" href="eigen__plugins_8h_source.html#l00373">mean()</a>.</p>

</div>
</div>
<a class="anchor" id="acbe63466320842a1ceb738bae1a062e4"></a><!-- doxytag: member="mrpt::random::CRandomGenerator::drawGaussian1DVector" ref="acbe63466320842a1ceb738bae1a062e4" args="(VEC &amp;v, const double mean=0, const double std=1)" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class VEC &gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">void mrpt::random::CRandomGenerator::drawGaussian1DVector </td>
          <td>(</td>
          <td class="paramtype">VEC &amp;&#160;</td>
          <td class="paramname"><em>v</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const double&#160;</td>
          <td class="paramname"><em>mean</em> = <code>0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const double&#160;</td>
          <td class="paramname"><em>std</em> = <code>1</code>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td><code> [inline]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Fills the given vector with independent, 1D-normally distributed samples. </p>
<dl class="see"><dt><b>See also:</b></dt><dd><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#a3eab704e20a481c7ebf9884b06726cec" title="Generate a normally distributed pseudo-random number.">drawGaussian1D</a> </dd></dl>

<p>Definition at line <a class="el" href="_random_generators_8h_source.html#l00167">167</a> of file <a class="el" href="_random_generators_8h_source.html">RandomGenerators.h</a>.</p>

<p>References <a class="el" href="eigen__plugins_8h_source.html#l00373">mean()</a>.</p>

</div>
</div>
<a class="anchor" id="a7e74a5bba69f5a49b40ed38f32499c9d"></a><!-- doxytag: member="mrpt::random::CRandomGenerator::drawGaussianMultivariate" ref="a7e74a5bba69f5a49b40ed38f32499c9d" args="(std::vector&lt; T &gt; &amp;out_result, const CMatrixTemplateNumeric&lt; T &gt; &amp;cov, const std::vector&lt; T &gt; *mean=NULL)" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename T &gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">void mrpt::random::CRandomGenerator::drawGaussianMultivariate </td>
          <td>(</td>
          <td class="paramtype"><a class="el" href="classstd_1_1vector.html">std::vector</a>&lt; T &gt; &amp;&#160;</td>
          <td class="paramname"><em>out_result</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="el" href="classmrpt_1_1math_1_1_c_matrix_template_numeric.html">CMatrixTemplateNumeric</a>&lt; T &gt; &amp;&#160;</td>
          <td class="paramname"><em>cov</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const <a class="el" href="classstd_1_1vector.html">std::vector</a>&lt; T &gt; *&#160;</td>
          <td class="paramname"><em>mean</em> = <code>NULL</code>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Generate multidimensional random samples according to a given covariance matrix. </p>
<p>Mean is assumed to be zero if mean==NULL. </p>
<dl><dt><b>Exceptions:</b></dt><dd>
  <table class="exception">
    <tr><td class="paramname"><a class="el" href="classstd_1_1exception.html" title="STL class.">std::exception</a></td><td>On invalid covariance matrix </td></tr>
  </table>
  </dd>
</dl>
<dl class="see"><dt><b>See also:</b></dt><dd><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#a02ebde6aa19bc11b17960e88e2a9e58b" title="Generate a given number of multidimensional random samples according to a given covariance matrix...">drawGaussianMultivariateMany</a> </dd></dl>

<p>Referenced by <a class="el" href="_random_generators_8h_source.html#l00396">mrpt::random::randomNormalMultiDimensional()</a>.</p>

</div>
</div>
<a class="anchor" id="ae8d65bbc56b2f33acfcfaae4343b79b9"></a><!-- doxytag: member="mrpt::random::CRandomGenerator::drawGaussianMultivariate" ref="ae8d65bbc56b2f33acfcfaae4343b79b9" args="(VECTORLIKE &amp;out_result, const COVMATRIX &amp;cov, const VECTORLIKE *mean=NULL)" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class VECTORLIKE , class COVMATRIX &gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">void mrpt::random::CRandomGenerator::drawGaussianMultivariate </td>
          <td>(</td>
          <td class="paramtype">VECTORLIKE &amp;&#160;</td>
          <td class="paramname"><em>out_result</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const COVMATRIX &amp;&#160;</td>
          <td class="paramname"><em>cov</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const VECTORLIKE *&#160;</td>
          <td class="paramname"><em>mean</em> = <code>NULL</code>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td><code> [inline]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Generate multidimensional random samples according to a given covariance matrix. </p>
<p>Mean is assumed to be zero if mean==NULL. </p>
<dl><dt><b>Exceptions:</b></dt><dd>
  <table class="exception">
    <tr><td class="paramname"><a class="el" href="classstd_1_1exception.html" title="STL class.">std::exception</a></td><td>On invalid covariance matrix </td></tr>
  </table>
  </dd>
</dl>
<dl class="see"><dt><b>See also:</b></dt><dd><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#a02ebde6aa19bc11b17960e88e2a9e58b" title="Generate a given number of multidimensional random samples according to a given covariance matrix...">drawGaussianMultivariateMany</a> </dd></dl>

<p>Definition at line <a class="el" href="_random_generators_8h_source.html#l00196">196</a> of file <a class="el" href="_random_generators_8h_source.html">RandomGenerators.h</a>.</p>

<p>References <a class="el" href="mrpt__macros_8h_source.html#l00282">ASSERT_</a>, <a class="el" href="eigen__plugins_8h_source.html#l00373">mean()</a>, <a class="el" href="mrpt__macros_8h_source.html#l00285">ASSERT_EQUAL_</a>, <a class="el" href="_eigenvalues_source.html#l00220">Eigen::SelfAdjointEigenSolver::eigenvectors()</a>, and <a class="el" href="_eigenvalues_source.html#l00242">Eigen::SelfAdjointEigenSolver::eigenvalues()</a>.</p>

</div>
</div>
<a class="anchor" id="a02ebde6aa19bc11b17960e88e2a9e58b"></a><!-- doxytag: member="mrpt::random::CRandomGenerator::drawGaussianMultivariateMany" ref="a02ebde6aa19bc11b17960e88e2a9e58b" args="(VECTOR_OF_VECTORS &amp;ret, size_t desiredSamples, const COVMATRIX &amp;cov, const typename VECTOR_OF_VECTORS::value_type *mean=NULL)" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;typename VECTOR_OF_VECTORS , typename COVMATRIX &gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">void mrpt::random::CRandomGenerator::drawGaussianMultivariateMany </td>
          <td>(</td>
          <td class="paramtype">VECTOR_OF_VECTORS &amp;&#160;</td>
          <td class="paramname"><em>ret</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">size_t&#160;</td>
          <td class="paramname"><em>desiredSamples</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const COVMATRIX &amp;&#160;</td>
          <td class="paramname"><em>cov</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const typename <a class="el" href="eigen__plugins_8h.html#afd07186978da46f9908364e389f8a403">VECTOR_OF_VECTORS::value_type</a> *&#160;</td>
          <td class="paramname"><em>mean</em> = <code>NULL</code>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td><code> [inline]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Generate a given number of multidimensional random samples according to a given covariance matrix. </p>
<dl><dt><b>Parameters:</b></dt><dd>
  <table class="params">
    <tr><td class="paramname">cov</td><td>The covariance matrix where to draw the samples from. </td></tr>
    <tr><td class="paramname">desiredSamples</td><td>The number of samples to generate. </td></tr>
    <tr><td class="paramname">ret</td><td>The output list of samples </td></tr>
    <tr><td class="paramname">mean</td><td>The mean, or zeros if mean==NULL. </td></tr>
  </table>
  </dd>
</dl>

<p>Definition at line <a class="el" href="_random_generators_8h_source.html#l00239">239</a> of file <a class="el" href="_random_generators_8h_source.html">RandomGenerators.h</a>.</p>

<p>References <a class="el" href="mrpt__macros_8h_source.html#l00285">ASSERT_EQUAL_</a>, <a class="el" href="eigen__plugins_8h_source.html#l00373">mean()</a>, <a class="el" href="_eigenvalues_source.html#l00220">Eigen::SelfAdjointEigenSolver::eigenvectors()</a>, and <a class="el" href="_eigenvalues_source.html#l00242">Eigen::SelfAdjointEigenSolver::eigenvalues()</a>.</p>

<p>Referenced by <a class="el" href="_random_generators_8h_source.html#l00414">mrpt::random::randomNormalMultiDimensionalMany()</a>, and <a class="el" href="transform__gaussian_8h_source.html#l00116">mrpt::math::transform_gaussian_montecarlo()</a>.</p>

</div>
</div>
<a class="anchor" id="a7a4bbaa961f106cd88a872986737a2fb"></a><!-- doxytag: member="mrpt::random::CRandomGenerator::drawUniform" ref="a7a4bbaa961f106cd88a872986737a2fb" args="(const double Min, const double Max)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">double mrpt::random::CRandomGenerator::drawUniform </td>
          <td>(</td>
          <td class="paramtype">const double&#160;</td>
          <td class="paramname"><em>Min</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const double&#160;</td>
          <td class="paramname"><em>Max</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td><code> [inline]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Generate a uniformly distributed pseudo-random number using the MT19937 algorithm, scaled to the selected range. </p>

<p>Definition at line <a class="el" href="_random_generators_8h_source.html#l00093">93</a> of file <a class="el" href="_random_generators_8h_source.html">RandomGenerators.h</a>.</p>

<p>Referenced by <a class="el" href="_p_f__implementations_8h_source.html#l00859">mrpt::slam::PF_implementation::PF_SLAM_aux_perform_one_rejection_sampling_step()</a>, <a class="el" href="_random_generators_8h_source.html#l00317">mrpt::random::matrixRandomUni()</a>, and <a class="el" href="_random_generators_8h_source.html#l00331">mrpt::random::vectorRandomUni()</a>.</p>

</div>
</div>
<a class="anchor" id="aede40e77053b8b4350fd786f1683e260"></a><!-- doxytag: member="mrpt::random::CRandomGenerator::drawUniform32bit" ref="aede40e77053b8b4350fd786f1683e260" args="()" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">uint32_t mrpt::random::CRandomGenerator::drawUniform32bit </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Generate a uniformly distributed pseudo-random number using the MT19937 algorithm, in the whole range of 32-bit integers. </p>
<p>See: <a href="http://en.wikipedia.org/wiki/Mersenne_twister">http://en.wikipedia.org/wiki/Mersenne_twister</a> </p>

<p>Referenced by <a class="el" href="_p_f__implementations_8h_source.html#l00518">mrpt::slam::PF_implementation::PF_SLAM_implementation_pfAuxiliaryPFStandardAndOptimal()</a>, <a class="el" href="_p_f__implementations_8h_source.html#l00859">mrpt::slam::PF_implementation::PF_SLAM_aux_perform_one_rejection_sampling_step()</a>, and <a class="el" href="_random_generators_8h_source.html#l00307">mrpt::random::random_generator_for_STL()</a>.</p>

</div>
</div>
<a class="anchor" id="a2378ba5fdabf270b2c48726dbcb627cc"></a><!-- doxytag: member="mrpt::random::CRandomGenerator::drawUniformMatrix" ref="a2378ba5fdabf270b2c48726dbcb627cc" args="(MAT &amp;matrix, const double unif_min=0, const double unif_max=1)" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class MAT &gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">void mrpt::random::CRandomGenerator::drawUniformMatrix </td>
          <td>(</td>
          <td class="paramtype">MAT &amp;&#160;</td>
          <td class="paramname"><em>matrix</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const double&#160;</td>
          <td class="paramname"><em>unif_min</em> = <code>0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const double&#160;</td>
          <td class="paramname"><em>unif_max</em> = <code>1</code>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td><code> [inline]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Fills the given matrix with independent, uniformly distributed samples. </p>
<p>Matrix classes can be CMatrixTemplateNumeric or CMatrixFixedNumeric </p>
<dl class="see"><dt><b>See also:</b></dt><dd><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#a7a4bbaa961f106cd88a872986737a2fb" title="Generate a uniformly distributed pseudo-random number using the MT19937 algorithm, scaled to the selected range.">drawUniform</a> </dd></dl>

<p>Definition at line <a class="el" href="_random_generators_8h_source.html#l00102">102</a> of file <a class="el" href="_random_generators_8h_source.html">RandomGenerators.h</a>.</p>

</div>
</div>
<a class="anchor" id="a4ef658fc363148b999c6654c07e8c504"></a><!-- doxytag: member="mrpt::random::CRandomGenerator::drawUniformVector" ref="a4ef658fc363148b999c6654c07e8c504" args="(VEC &amp;v, const double unif_min=0, const double unif_max=1)" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class VEC &gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">void mrpt::random::CRandomGenerator::drawUniformVector </td>
          <td>(</td>
          <td class="paramtype">VEC &amp;&#160;</td>
          <td class="paramname"><em>v</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const double&#160;</td>
          <td class="paramname"><em>unif_min</em> = <code>0</code>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">const double&#160;</td>
          <td class="paramname"><em>unif_max</em> = <code>1</code>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td><code> [inline]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Fills the given vector with independent, uniformly distributed samples. </p>
<dl class="see"><dt><b>See also:</b></dt><dd><a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#a7a4bbaa961f106cd88a872986737a2fb" title="Generate a uniformly distributed pseudo-random number using the MT19937 algorithm, scaled to the selected range.">drawUniform</a> </dd></dl>

<p>Definition at line <a class="el" href="_random_generators_8h_source.html#l00116">116</a> of file <a class="el" href="_random_generators_8h_source.html">RandomGenerators.h</a>.</p>

</div>
</div>
<a class="anchor" id="aef6819d05b148c234c3921181fbb8e54"></a><!-- doxytag: member="mrpt::random::CRandomGenerator::MT19937_generateNumbers" ref="aef6819d05b148c234c3921181fbb8e54" args="()" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">void mrpt::random::CRandomGenerator::MT19937_generateNumbers </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td><code> [protected]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

</div>
</div>
<a class="anchor" id="ad1852e43a441086367edaf4b8d461966"></a><!-- doxytag: member="mrpt::random::CRandomGenerator::MT19937_initializeGenerator" ref="ad1852e43a441086367edaf4b8d461966" args="(const uint32_t &amp;seed)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">void mrpt::random::CRandomGenerator::MT19937_initializeGenerator </td>
          <td>(</td>
          <td class="paramtype">const uint32_t &amp;&#160;</td>
          <td class="paramname"><em>seed</em></td><td>)</td>
          <td><code> [protected]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

</div>
</div>
<a class="anchor" id="ac0f4a363fb29bf340e64ab9af6231d7b"></a><!-- doxytag: member="mrpt::random::CRandomGenerator::permuteVector" ref="ac0f4a363fb29bf340e64ab9af6231d7b" args="(const VEC &amp;in_vector, VEC &amp;out_result)" -->
<div class="memitem">
<div class="memproto">
<div class="memtemplate">
template&lt;class VEC &gt; </div>
      <table class="memname">
        <tr>
          <td class="memname">void mrpt::random::CRandomGenerator::permuteVector </td>
          <td>(</td>
          <td class="paramtype">const VEC &amp;&#160;</td>
          <td class="paramname"><em>in_vector</em>, </td>
        </tr>
        <tr>
          <td class="paramkey"></td>
          <td></td>
          <td class="paramtype">VEC &amp;&#160;</td>
          <td class="paramname"><em>out_result</em>&#160;</td>
        </tr>
        <tr>
          <td></td>
          <td>)</td>
          <td></td><td><code> [inline]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Returns a random permutation of a vector: all the elements of the input vector are in the output but at random positions. </p>

<p>Definition at line <a class="el" href="_random_generators_8h_source.html#l00288">288</a> of file <a class="el" href="_random_generators_8h_source.html">RandomGenerators.h</a>.</p>

<p>Referenced by <a class="el" href="_random_generators_8h_source.html#l00383">mrpt::random::randomPermutation()</a>.</p>

</div>
</div>
<a class="anchor" id="a231ef5bd9387714debad4914e5da6985"></a><!-- doxytag: member="mrpt::random::CRandomGenerator::randomize" ref="a231ef5bd9387714debad4914e5da6985" args="(const uint32_t seed)" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">void mrpt::random::CRandomGenerator::randomize </td>
          <td>(</td>
          <td class="paramtype">const uint32_t&#160;</td>
          <td class="paramname"><em>seed</em></td><td>)</td>
          <td></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Initialize the PRNG from the given random seed. </p>

<p>Referenced by <a class="el" href="_random_generators_8h_source.html#l00373">mrpt::random::Randomize()</a>.</p>

</div>
</div>
<a class="anchor" id="add506d08802a5a6e1b1aa46a76048cd1"></a><!-- doxytag: member="mrpt::random::CRandomGenerator::randomize" ref="add506d08802a5a6e1b1aa46a76048cd1" args="()" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">void mrpt::random::CRandomGenerator::randomize </td>
          <td>(</td>
          <td class="paramname"></td><td>)</td>
          <td></td>
        </tr>
      </table>
</div>
<div class="memdoc">

<p>Randomize the generators, based on current time. </p>

</div>
</div>
<hr/><h2>Member Data Documentation</h2>
<a class="anchor" id="a80c8fcac9c7b3b0548c3328637487f33"></a><!-- doxytag: member="mrpt::random::CRandomGenerator::m_MT19937_data" ref="a80c8fcac9c7b3b0548c3328637487f33" args="" -->
<div class="memitem">
<div class="memproto">
      <table class="memname">
        <tr>
          <td class="memname">struct <a class="el" href="structmrpt_1_1random_1_1_c_random_generator_1_1_t_m_t19937__data.html">mrpt::random::CRandomGenerator::TMT19937_data</a>  <a class="el" href="classmrpt_1_1random_1_1_c_random_generator.html#a80c8fcac9c7b3b0548c3328637487f33">mrpt::random::CRandomGenerator::m_MT19937_data</a><code> [protected]</code></td>
        </tr>
      </table>
</div>
<div class="memdoc">

</div>
</div>
</div>
<br><hr><br> <table border="0" width="100%"> <tr> <td> Page generated by <a href="http://www.doxygen.org" target="_blank">Doxygen 1.7.5</a> for MRPT 0.9.5 SVN: at Sun Sep 25 17:20:18 UTC 2011</td><td></td> <td width="100"> </td> <td width="150">  </td></tr> </table>  </body></html>