1 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
4 <meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
5 <title>Boost.Geometry (aka GGL, Generic Geometry Library)</title>
6 <link href="doxygen.css" rel="stylesheet" type="text/css">
7 <link href="tabs.css" rel="stylesheet" type="text/css">
9 <table cellpadding="2" width="100%">
13 <img alt="Boost.Geometry" src="images/ggl-logo-big.png" height="80" width="200">
16 <td valign="top" align="right">
17 <a href="http://www.boost.org">
18 <img alt="Boost C++ Libraries" src="images/accepted_by_boost.png" height="80" width="230" border="0">
24 <!-- Generated by Doxygen 1.8.6 -->
25 <div id="navrow1" class="tabs">
27 <li><a href="index.html"><span>Main Page</span></a></li>
28 <li><a href="pages.html"><span>Related Pages</span></a></li>
29 <li><a href="modules.html"><span>Modules</span></a></li>
30 <li><a href="namespaces.html"><span>Namespaces</span></a></li>
31 <li class="current"><a href="annotated.html"><span>Classes</span></a></li>
32 <li><a href="files.html"><span>Files</span></a></li>
33 <li><a href="examples.html"><span>Examples</span></a></li>
36 <div id="navrow2" class="tabs2">
38 <li><a href="annotated.html"><span>Class List</span></a></li>
39 <li><a href="classes.html"><span>Class Index</span></a></li>
40 <li><a href="hierarchy.html"><span>Class Hierarchy</span></a></li>
41 <li><a href="functions.html"><span>Class Members</span></a></li>
44 <div id="nav-path" class="navpath">
46 <li class="navelem"><a class="el" href="namespaceboost.html">boost</a></li><li class="navelem"><a class="el" href="namespaceboost_1_1geometry.html">geometry</a></li><li class="navelem"><a class="el" href="namespaceboost_1_1geometry_1_1strategy.html">strategy</a></li><li class="navelem"><a class="el" href="namespaceboost_1_1geometry_1_1strategy_1_1convex__hull.html">convex_hull</a></li><li class="navelem"><a class="el" href="classboost_1_1geometry_1_1strategy_1_1convex__hull_1_1graham__andrew.html">graham_andrew</a></li> </ul>
51 <a href="#nested-classes">Classes</a> |
52 <a href="#pub-types">Public Types</a> |
53 <a href="#pub-methods">Public Member Functions</a> |
54 <a href="classboost_1_1geometry_1_1strategy_1_1convex__hull_1_1graham__andrew-members.html">List of all members</a> </div>
55 <div class="headertitle">
56 <div class="title">boost::geometry::strategy::convex_hull::graham_andrew< InputGeometry, OutputPoint > Class Template Reference<div class="ingroups"><a class="el" href="group__strategies.html">strategies: strategies</a></div></div> </div>
58 <div class="contents">
60 <p>Graham scan strategy to calculate convex hull.
61 <a href="classboost_1_1geometry_1_1strategy_1_1convex__hull_1_1graham__andrew.html#details">More...</a></p>
62 <table class="memberdecls">
63 <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-types"></a>
64 Public Types</h2></td></tr>
65 <tr class="memitem:a456c123d0655ecf2c4409b38b95668c7"><td class="memItemLeft" align="right" valign="top">typedef InputGeometry </td><td class="memItemRight" valign="bottom"><a class="el" href="classboost_1_1geometry_1_1strategy_1_1convex__hull_1_1graham__andrew.html#a456c123d0655ecf2c4409b38b95668c7">geometry_type</a></td></tr>
66 <tr class="separator:a456c123d0655ecf2c4409b38b95668c7"><td class="memSeparator" colspan="2"> </td></tr>
67 <tr class="memitem:a2678e51becdbb307f68bccc89f2f62c0"><td class="memItemLeft" align="right" valign="top">typedef OutputPoint </td><td class="memItemRight" valign="bottom"><a class="el" href="classboost_1_1geometry_1_1strategy_1_1convex__hull_1_1graham__andrew.html#a2678e51becdbb307f68bccc89f2f62c0">point_type</a></td></tr>
68 <tr class="separator:a2678e51becdbb307f68bccc89f2f62c0"><td class="memSeparator" colspan="2"> </td></tr>
69 <tr class="memitem:a550176a736837847b6df1b46ef6f6b3f"><td class="memItemLeft" align="right" valign="top">typedef partitions </td><td class="memItemRight" valign="bottom"><a class="el" href="classboost_1_1geometry_1_1strategy_1_1convex__hull_1_1graham__andrew.html#a550176a736837847b6df1b46ef6f6b3f">state_type</a></td></tr>
70 <tr class="separator:a550176a736837847b6df1b46ef6f6b3f"><td class="memSeparator" colspan="2"> </td></tr>
71 </table><table class="memberdecls">
72 <tr class="heading"><td colspan="2"><h2 class="groupheader"><a name="pub-methods"></a>
73 Public Member Functions</h2></td></tr>
74 <tr class="memitem:ab8fbeb9a58c503ac5803a27eedab9f12"><td class="memItemLeft" align="right" valign="top">void </td><td class="memItemRight" valign="bottom"><a class="el" href="classboost_1_1geometry_1_1strategy_1_1convex__hull_1_1graham__andrew.html#ab8fbeb9a58c503ac5803a27eedab9f12">apply</a> (InputGeometry const &geometry, partitions &state) const </td></tr>
75 <tr class="separator:ab8fbeb9a58c503ac5803a27eedab9f12"><td class="memSeparator" colspan="2"> </td></tr>
76 <tr class="memitem:a354c3eb0a5083c5695e7225ac431f588"><td class="memTemplParams" colspan="2">template<typename OutputIterator > </td></tr>
77 <tr class="memitem:a354c3eb0a5083c5695e7225ac431f588"><td class="memTemplItemLeft" align="right" valign="top">void </td><td class="memTemplItemRight" valign="bottom"><a class="el" href="classboost_1_1geometry_1_1strategy_1_1convex__hull_1_1graham__andrew.html#a354c3eb0a5083c5695e7225ac431f588">result</a> (partitions const &state, OutputIterator out, bool <a class="el" href="group__enum.html#gga0af1c124acb76f0892024d6d4ab2bc8ca29458b1c5c6f01e41bc529cff7cdbec2">clockwise</a>, bool <a class="el" href="group__enum.html#gga7d33eca9a5389952bdf719972eb802b6a17768d8af3fcc199a847d70965cbf9c5">closed</a>) const </td></tr>
78 <tr class="separator:a354c3eb0a5083c5695e7225ac431f588"><td class="memSeparator" colspan="2"> </td></tr>
80 <a name="details" id="details"></a><h2 class="groupheader">Detailed Description</h2>
81 <div class="textblock"><h3>template<typename InputGeometry, typename OutputPoint><br/>
82 class boost::geometry::strategy::convex_hull::graham_andrew< InputGeometry, OutputPoint ></h3>
84 <p>Graham scan strategy to calculate convex hull. </p>
85 <dl class="section note"><dt>Note</dt><dd>Completely reworked version inspired on the sources listed below </dd></dl>
86 <dl class="section see"><dt>See Also</dt><dd><a href="http://www.ddj.com/architect/201806315">http://www.ddj.com/architect/201806315</a> </dd>
88 <a href="http://marknelson.us/2007/08/22/convex">http://marknelson.us/2007/08/22/convex</a> </dd></dl>
89 </div><h2 class="groupheader">Member Typedef Documentation</h2>
90 <a class="anchor" id="a2678e51becdbb307f68bccc89f2f62c0"></a>
92 <div class="memproto">
93 <div class="memtemplate">
94 template<typename InputGeometry , typename OutputPoint > </div>
95 <table class="memname">
97 <td class="memname">typedef OutputPoint <a class="el" href="classboost_1_1geometry_1_1strategy_1_1convex__hull_1_1graham__andrew.html">boost::geometry::strategy::convex_hull::graham_andrew</a>< InputGeometry, OutputPoint >::<a class="el" href="classboost_1_1geometry_1_1strategy_1_1convex__hull_1_1graham__andrew.html#a2678e51becdbb307f68bccc89f2f62c0">point_type</a></td>
100 </div><div class="memdoc">
104 <a class="anchor" id="a456c123d0655ecf2c4409b38b95668c7"></a>
105 <div class="memitem">
106 <div class="memproto">
107 <div class="memtemplate">
108 template<typename InputGeometry , typename OutputPoint > </div>
109 <table class="memname">
111 <td class="memname">typedef InputGeometry <a class="el" href="classboost_1_1geometry_1_1strategy_1_1convex__hull_1_1graham__andrew.html">boost::geometry::strategy::convex_hull::graham_andrew</a>< InputGeometry, OutputPoint >::<a class="el" href="classboost_1_1geometry_1_1strategy_1_1convex__hull_1_1graham__andrew.html#a456c123d0655ecf2c4409b38b95668c7">geometry_type</a></td>
114 </div><div class="memdoc">
118 <a class="anchor" id="a550176a736837847b6df1b46ef6f6b3f"></a>
119 <div class="memitem">
120 <div class="memproto">
121 <div class="memtemplate">
122 template<typename InputGeometry , typename OutputPoint > </div>
123 <table class="memname">
125 <td class="memname">typedef partitions <a class="el" href="classboost_1_1geometry_1_1strategy_1_1convex__hull_1_1graham__andrew.html">boost::geometry::strategy::convex_hull::graham_andrew</a>< InputGeometry, OutputPoint >::<a class="el" href="classboost_1_1geometry_1_1strategy_1_1convex__hull_1_1graham__andrew.html#a550176a736837847b6df1b46ef6f6b3f">state_type</a></td>
128 </div><div class="memdoc">
132 <h2 class="groupheader">Member Function Documentation</h2>
133 <a class="anchor" id="ab8fbeb9a58c503ac5803a27eedab9f12"></a>
134 <div class="memitem">
135 <div class="memproto">
136 <div class="memtemplate">
137 template<typename InputGeometry , typename OutputPoint > </div>
138 <table class="memname">
140 <td class="memname">void <a class="el" href="classboost_1_1geometry_1_1strategy_1_1convex__hull_1_1graham__andrew.html">boost::geometry::strategy::convex_hull::graham_andrew</a>< InputGeometry, OutputPoint >::apply </td>
142 <td class="paramtype">InputGeometry const & </td>
143 <td class="paramname"><em>geometry</em>, </td>
146 <td class="paramkey"></td>
148 <td class="paramtype">partitions & </td>
149 <td class="paramname"><em>state</em> </td>
154 <td></td><td> const</td>
157 </div><div class="memdoc">
161 <a class="anchor" id="a354c3eb0a5083c5695e7225ac431f588"></a>
162 <div class="memitem">
163 <div class="memproto">
164 <div class="memtemplate">
165 template<typename InputGeometry , typename OutputPoint > </div>
166 <div class="memtemplate">
167 template<typename OutputIterator > </div>
168 <table class="memname">
170 <td class="memname">void <a class="el" href="classboost_1_1geometry_1_1strategy_1_1convex__hull_1_1graham__andrew.html">boost::geometry::strategy::convex_hull::graham_andrew</a>< InputGeometry, OutputPoint >::result </td>
172 <td class="paramtype">partitions const & </td>
173 <td class="paramname"><em>state</em>, </td>
176 <td class="paramkey"></td>
178 <td class="paramtype">OutputIterator </td>
179 <td class="paramname"><em>out</em>, </td>
182 <td class="paramkey"></td>
184 <td class="paramtype">bool </td>
185 <td class="paramname"><em>clockwise</em>, </td>
188 <td class="paramkey"></td>
190 <td class="paramtype">bool </td>
191 <td class="paramname"><em>closed</em> </td>
196 <td></td><td> const</td>
199 </div><div class="memdoc">
203 </div><!-- contents -->
208 <td align="left"><small>
213 Copyright © 2007-2011 Barend Gehrels, Amsterdam, the Netherlands<br>
214 Copyright © 2008-2011 Bruno Lalande, Paris, France<br>
215 Copyright © 2009-2010 Mateusz Loskot, London, UK<br>
221 <address style="text-align: right;"><small>
222 Documentation is generated by <a href="http://www.doxygen.org/index.html">Doxygen</a>