Sophie

Sophie

distrib > Fedora > 14 > x86_64 > media > updates > by-pkgid > e7618febbb9cbed15bb79e326774c050 > files > 300

ompl-devel-0.9.5-1.fc14.i686.rpm

<!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>OMPL: ompl::BinaryHeap&lt; _T, LessThan &gt; Class Template Reference</title>
<meta name="author" content="Ioan A. Șucan, Mark Moll, Lydia E. Kavraki">
<link rel="stylesheet" href="../css/screen.css" type="text/css" media="screen, projection">
<link rel="stylesheet" href="../css/print.css" type="text/css" media="print">
<!--[if lt IE 7]>
<script type="text/javascript" src="../js/jquery/jquery.js"></script>
<script type="text/javascript" src="../js/jquery/jquery.dropdown.js"></script>
<![endif]-->
<script type="text/javaScript" src="search/search.js"></script>
<script type="text/javascript">
  var _gaq = _gaq || [];
  _gaq.push(['_setAccount', 'UA-9156598-2']);
  _gaq.push(['_trackPageview']);
  (function() {
    var ga = document.createElement('script'); ga.type = 'text/javascript'; ga.async = true;
    ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
    var s = document.getElementsByTagName('script')[0]; s.parentNode.insertBefore(ga, s);
  })();
</script>
</head>
<body onload='searchBox.OnSelectItem(0);'>
<script type="text/javascript"><!--
var searchBox = new SearchBox("searchBox", "search",false,'Search API');
--></script>
<div class="navigation" id="top">
  <div class="tabs" id="ompltitle">
    <ul class="tablist">
      <li>The Open Motion Planning Library</li>
      <li id="searchli">
        <div id="MSearchBox" class="MSearchBoxInactive">
        <span class="left">
          <img id="MSearchSelect" src="search/mag_sel.png"
               onmouseover="return searchBox.OnSearchSelectShow()"
               onmouseout="return searchBox.OnSearchSelectHide()"
               alt=""/>
          <input type="text" id="MSearchField" value="Search API" accesskey="S"
               onfocus="searchBox.OnSearchFieldFocus(true)"
               onblur="searchBox.OnSearchFieldFocus(false)"
               onkeyup="searchBox.OnSearchFieldChange(event)"/>
          </span><span class="right">
            <a id="MSearchClose" href="javascript:searchBox.CloseResultsWindow()"><img id="MSearchCloseImg" border="0" src="search/close.png" alt=""/></a>
          </span>
        </div>
      </li>
    </ul>
  </div>

  <ul id="nav" class="dropdown">
    <li class="first"><a href="index.html">Home</a></li>
    <li><a href="download.html">Download</a></li>
    <li><a href="documentation.html">Documentation</a></li>
    <li><span class="dir">Code API</span>
      <ul>
        <li><a href="api_overview.html">API Overview</a></li>
        <li><a href="namespaces.html">Namespaces</a></li>
        <li><a href="annotated.html">Classes</a></li>
        <li><a href="files.html">Files</a></li>
        <li><a href="dirs.html">Directories</a></li>
      </ul>
    </li>
    <li><span class="dir">Community</span>
      <ul>
        <li><a href="developers.html">Developers</a></li>
        <li><a href="thirdparty.html">Contributions</a></li>
        <li><a href="education.html">Education</a></li>
        <li><a href="gallery.html">Gallery</a></li>
      </ul>
    </li>
    <li><span class="dir">About</span>
      <ul>
        <li><a href="license.html">License</a></li>
        <li><a href="citations.html">Citations</a></li>
        <li><a href="acknowledgements.html">Acknowledgments</a></li>
        <li><a href="contact.html">Contact Us</a></li>
      </ul>
    </li>
  </ul>
</div>

<!--- window showing the filter options -->
<div id="MSearchSelectWindow"
  onmouseover="return searchBox.OnSearchSelectShow()"
  onmouseout="return searchBox.OnSearchSelectHide()"
  onkeydown="return searchBox.OnSearchSelectKey(event)">
<a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(0)"><span class="SelectionMark">&#160;</span>All</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(1)"><span class="SelectionMark">&#160;</span>Classes</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(2)"><span class="SelectionMark">&#160;</span>Namespaces</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(3)"><span class="SelectionMark">&#160;</span>Functions</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(4)"><span class="SelectionMark">&#160;</span>Variables</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(5)"><span class="SelectionMark">&#160;</span>Typedefs</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(6)"><span class="SelectionMark">&#160;</span>Enumerations</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(7)"><span class="SelectionMark">&#160;</span>Enumerator</a></div>

<!-- iframe showing the search results (closed by default) -->
<div id="MSearchResultsWindow">
  <iframe src="" frameborder="0"name="MSearchResults" id="MSearchResults"></iframe>
</div>

<div class="container">
  <div class="span-22 push-2 first last">
  <div>
<!-- Generated by Doxygen 1.7.4 -->
<script type="text/javascript"><!--
var searchBox = new SearchBox("searchBox", "search",false,'Search');
--></script>
  <div id="nav-path" class="navpath">
    <ul>
      <li class="navelem"><a class="el" href="namespaceompl.html">ompl</a>      </li>
      <li class="navelem"><a class="el" href="classompl_1_1BinaryHeap.html">BinaryHeap</a>      </li>
    </ul>
  </div>
</div>
<div class="header">
  <div class="summary">
<a href="#nested-classes">Classes</a> &#124;
<a href="#pub-types">Public Types</a> &#124;
<a href="#pub-methods">Public Member Functions</a>  </div>
  <div class="headertitle">
<div class="title">ompl::BinaryHeap&lt; _T, LessThan &gt; Class Template Reference</div>  </div>
</div>
<div class="contents">
<!-- doxytag: class="ompl::BinaryHeap" -->
<p>This class provides an implementation of an updatable min-heap. Using it is a bit cumbersome, as it requires keeping track of the <a class="el" href="classompl_1_1BinaryHeap_1_1Element.html" title="When an element is added to the heap, an instance of Element* is created. This instance contains the ...">BinaryHeap::Element</a>* type, however, it should be as fast as it gets with an updatable heap.  
 <a href="classompl_1_1BinaryHeap.html#details">More...</a></p>

<p><code>#include &lt;<a class="el" href="BinaryHeap_8h_source.html">BinaryHeap.h</a>&gt;</code></p>

<p><a href="classompl_1_1BinaryHeap-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">class &#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classompl_1_1BinaryHeap_1_1Element.html">Element</a></td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">When an element is added to the heap, an instance of Element* is created. This instance contains the data that was added and internal information about the position of the data in the heap's internal storage.  <a href="classompl_1_1BinaryHeap_1_1Element.html#details">More...</a><br/></td></tr>
<tr><td colspan="2"><h2><a name="pub-types"></a>
Public Types</h2></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="afd217208dc62566489216f0c5a172259"></a><!-- doxytag: member="ompl::BinaryHeap::EventAfterInsert" ref="afd217208dc62566489216f0c5a172259" args=")(Element *, void *)" -->
typedef void(*&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classompl_1_1BinaryHeap.html#afd217208dc62566489216f0c5a172259">EventAfterInsert</a> )(<a class="el" href="classompl_1_1BinaryHeap_1_1Element.html">Element</a> *, void *)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Event that gets called after an insertion. <br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a35877aaf27acdf33af11defd5ddc3d61"></a><!-- doxytag: member="ompl::BinaryHeap::EventBeforeRemove" ref="a35877aaf27acdf33af11defd5ddc3d61" args=")(Element *, void *)" -->
typedef void(*&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classompl_1_1BinaryHeap.html#a35877aaf27acdf33af11defd5ddc3d61">EventBeforeRemove</a> )(<a class="el" href="classompl_1_1BinaryHeap_1_1Element.html">Element</a> *, void *)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Event that gets called just before a removal. <br/></td></tr>
<tr><td colspan="2"><h2><a name="pub-methods"></a>
Public Member Functions</h2></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="adb5a517c064a3844a47cc873fddea796"></a><!-- doxytag: member="ompl::BinaryHeap::onAfterInsert" ref="adb5a517c064a3844a47cc873fddea796" args="(EventAfterInsert event, void *arg)" -->
void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classompl_1_1BinaryHeap.html#adb5a517c064a3844a47cc873fddea796">onAfterInsert</a> (<a class="el" href="classompl_1_1BinaryHeap.html#afd217208dc62566489216f0c5a172259">EventAfterInsert</a> event, void *arg)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Set the event that gets called after insertion. <br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a5a6368ea8193cdbf545f8a57dbaf02f5"></a><!-- doxytag: member="ompl::BinaryHeap::onBeforeRemove" ref="a5a6368ea8193cdbf545f8a57dbaf02f5" args="(EventBeforeRemove event, void *arg)" -->
void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classompl_1_1BinaryHeap.html#a5a6368ea8193cdbf545f8a57dbaf02f5">onBeforeRemove</a> (<a class="el" href="classompl_1_1BinaryHeap.html#a35877aaf27acdf33af11defd5ddc3d61">EventBeforeRemove</a> event, void *arg)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Set the event that gets called before a removal. <br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a318edd8b65126de610e0f11138f8c147"></a><!-- doxytag: member="ompl::BinaryHeap::clear" ref="a318edd8b65126de610e0f11138f8c147" args="(void)" -->
void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classompl_1_1BinaryHeap.html#a318edd8b65126de610e0f11138f8c147">clear</a> (void)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Clear the heap. <br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a4288f352550d26811383a45b2a9fb6e7"></a><!-- doxytag: member="ompl::BinaryHeap::top" ref="a4288f352550d26811383a45b2a9fb6e7" args="(void) const " -->
<a class="el" href="classompl_1_1BinaryHeap_1_1Element.html">Element</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classompl_1_1BinaryHeap.html#a4288f352550d26811383a45b2a9fb6e7">top</a> (void) const </td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Return the top element. NULL for an empty heap. <br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a75ced2f3f0f1434045afe4d73ee60482"></a><!-- doxytag: member="ompl::BinaryHeap::pop" ref="a75ced2f3f0f1434045afe4d73ee60482" args="(void)" -->
void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classompl_1_1BinaryHeap.html#a75ced2f3f0f1434045afe4d73ee60482">pop</a> (void)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Remove the top element. <br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a56848811174698cd9a907e1128e6ce02"></a><!-- doxytag: member="ompl::BinaryHeap::remove" ref="a56848811174698cd9a907e1128e6ce02" args="(Element *element)" -->
void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classompl_1_1BinaryHeap.html#a56848811174698cd9a907e1128e6ce02">remove</a> (<a class="el" href="classompl_1_1BinaryHeap_1_1Element.html">Element</a> *element)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Remove a specific element. <br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a7712c8909b596a4d12e0080960bd0274"></a><!-- doxytag: member="ompl::BinaryHeap::insert" ref="a7712c8909b596a4d12e0080960bd0274" args="(const _T &amp;data)" -->
<a class="el" href="classompl_1_1BinaryHeap_1_1Element.html">Element</a> *&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classompl_1_1BinaryHeap.html#a7712c8909b596a4d12e0080960bd0274">insert</a> (const _T &amp;data)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Add a new element. <br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a275aa4aab2088b38df1fa2fd2827fffe"></a><!-- doxytag: member="ompl::BinaryHeap::insert" ref="a275aa4aab2088b38df1fa2fd2827fffe" args="(const std::vector&lt; _T &gt; &amp;list)" -->
void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classompl_1_1BinaryHeap.html#a275aa4aab2088b38df1fa2fd2827fffe">insert</a> (const std::vector&lt; _T &gt; &amp;list)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Add a set of elements to the heap. <br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="ac8d1b64b5b7d50cd09380bfa14bbc45d"></a><!-- doxytag: member="ompl::BinaryHeap::buildFrom" ref="ac8d1b64b5b7d50cd09380bfa14bbc45d" args="(const std::vector&lt; _T &gt; &amp;list)" -->
void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classompl_1_1BinaryHeap.html#ac8d1b64b5b7d50cd09380bfa14bbc45d">buildFrom</a> (const std::vector&lt; _T &gt; &amp;list)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Clear the heap, add the set of elements <em>list</em> to it and rebuild it. <br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="aa1e483f2aea8cacf7f0ae4587d212eb2"></a><!-- doxytag: member="ompl::BinaryHeap::rebuild" ref="aa1e483f2aea8cacf7f0ae4587d212eb2" args="(void)" -->
void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classompl_1_1BinaryHeap.html#aa1e483f2aea8cacf7f0ae4587d212eb2">rebuild</a> (void)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Rebuild the heap. <br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a8114dc53c4239fe0e199106386898ce3"></a><!-- doxytag: member="ompl::BinaryHeap::update" ref="a8114dc53c4239fe0e199106386898ce3" args="(Element *element)" -->
void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classompl_1_1BinaryHeap.html#a8114dc53c4239fe0e199106386898ce3">update</a> (<a class="el" href="classompl_1_1BinaryHeap_1_1Element.html">Element</a> *element)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Update an element in the heap. <br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a486a10e941494a63e5dea950e90f39bf"></a><!-- doxytag: member="ompl::BinaryHeap::empty" ref="a486a10e941494a63e5dea950e90f39bf" args="(void) const " -->
bool&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classompl_1_1BinaryHeap.html#a486a10e941494a63e5dea950e90f39bf">empty</a> (void) const </td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Check if the heap is empty. <br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="af04187686dd607db2bca3e8bf45b8d12"></a><!-- doxytag: member="ompl::BinaryHeap::size" ref="af04187686dd607db2bca3e8bf45b8d12" args="(void) const " -->
unsigned int&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classompl_1_1BinaryHeap.html#af04187686dd607db2bca3e8bf45b8d12">size</a> (void) const </td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Get the number of elements in the heap. <br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="a47cbd6ea3b6aa270825ed29a850ffc30"></a><!-- doxytag: member="ompl::BinaryHeap::getContent" ref="a47cbd6ea3b6aa270825ed29a850ffc30" args="(std::vector&lt; _T &gt; &amp;content) const " -->
void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classompl_1_1BinaryHeap.html#a47cbd6ea3b6aa270825ed29a850ffc30">getContent</a> (std::vector&lt; _T &gt; &amp;content) const </td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Get the data stored in this heap. <br/></td></tr>
<tr><td class="memItemLeft" align="right" valign="top"><a class="anchor" id="ad782d92c652443841ebc310d778a22f0"></a><!-- doxytag: member="ompl::BinaryHeap::sort" ref="ad782d92c652443841ebc310d778a22f0" args="(std::vector&lt; _T &gt; &amp;list)" -->
void&#160;</td><td class="memItemRight" valign="bottom"><a class="el" href="classompl_1_1BinaryHeap.html#ad782d92c652443841ebc310d778a22f0">sort</a> (std::vector&lt; _T &gt; &amp;list)</td></tr>
<tr><td class="mdescLeft">&#160;</td><td class="mdescRight">Sort an array of elements. This does not affect the content of the heap. <br/></td></tr>
</table>
<hr/><a name="details" id="details"></a><h2>Detailed Description</h2>
<div class="textblock"><h3>template&lt;typename _T, class LessThan = std::less&lt;_T&gt;&gt;<br/>
class ompl::BinaryHeap&lt; _T, LessThan &gt;</h3>

<p>This class provides an implementation of an updatable min-heap. Using it is a bit cumbersome, as it requires keeping track of the <a class="el" href="classompl_1_1BinaryHeap_1_1Element.html" title="When an element is added to the heap, an instance of Element* is created. This instance contains the ...">BinaryHeap::Element</a>* type, however, it should be as fast as it gets with an updatable heap. </p>

<p>Definition at line <a class="el" href="BinaryHeap_8h_source.html#l00053">53</a> of file <a class="el" href="BinaryHeap_8h_source.html">BinaryHeap.h</a>.</p>
</div><hr/>The documentation for this class was generated from the following file:<ul>
<li>src/ompl/datastructures/<a class="el" href="BinaryHeap_8h_source.html">BinaryHeap.h</a></li>
</ul>
</div>
<!-- window showing the filter options -->
<div id="MSearchSelectWindow"
     onmouseover="return searchBox.OnSearchSelectShow()"
     onmouseout="return searchBox.OnSearchSelectHide()"
     onkeydown="return searchBox.OnSearchSelectKey(event)">
<a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(0)"><span class="SelectionMark">&#160;</span>All</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(1)"><span class="SelectionMark">&#160;</span>Classes</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(2)"><span class="SelectionMark">&#160;</span>Namespaces</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(3)"><span class="SelectionMark">&#160;</span>Functions</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(4)"><span class="SelectionMark">&#160;</span>Variables</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(5)"><span class="SelectionMark">&#160;</span>Typedefs</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(6)"><span class="SelectionMark">&#160;</span>Enumerations</a><a class="SelectItem" href="javascript:void(0)" onclick="searchBox.OnSelectItem(7)"><span class="SelectionMark">&#160;</span>Enumerator</a></div>

<!-- iframe showing the search results (closed by default) -->
<div id="MSearchResultsWindow">
<iframe src="javascript:void(0)" frameborder="0" 
        name="MSearchResults" id="MSearchResults">
</iframe>
</div>

</div>

<div class="footer span-22 push-2 last">
  <a href="http://www.kavrakilab.org">Physical and Biological Computing Group</a> &bull;
  <a href="http://www.cs.rice.edu">Department of Computer Science</a> &bull;
  <a href="http://www.rice.edu">Rice University</a><br>
  <div class="gray">Generated on Sun Oct 9 2011 23:04:41 by&#160;<a href="http://www.doxygen.org/index.html">doxygen</a> 1.7.4</div>
</div>
</div>
</body>
</html>