• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1<html>
2<head>
3<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
4<title>return_centroid</title>
5<link rel="stylesheet" href="../../../../../../../../doc/src/boostbook.css" type="text/css">
6<meta name="generator" content="DocBook XSL Stylesheets V1.79.1">
7<link rel="home" href="../../../../index.html" title="Chapter 1. Geometry">
8<link rel="up" href="../centroid.html" title="centroid">
9<link rel="prev" href="centroid_2.html" title="centroid">
10<link rel="next" href="return_centroid_2_with_strategy.html" title="return_centroid (with strategy)">
11</head>
12<body bgcolor="white" text="black" link="#0000FF" vlink="#840084" alink="#0000FF">
13<table cellpadding="2" width="100%"><tr>
14<td valign="top"><img alt="Boost C++ Libraries" width="277" height="86" src="../../../../../../../../boost.png"></td>
15<td align="center"><a href="../../../../../../../../index.html">Home</a></td>
16<td align="center"><a href="../../../../../../../../libs/libraries.htm">Libraries</a></td>
17<td align="center"><a href="http://www.boost.org/users/people.html">People</a></td>
18<td align="center"><a href="http://www.boost.org/users/faq.html">FAQ</a></td>
19<td align="center"><a href="../../../../../../../../more/index.htm">More</a></td>
20</tr></table>
21<hr>
22<div class="spirit-nav">
23<a accesskey="p" href="centroid_2.html"><img src="../../../../../../../../doc/src/images/prev.png" alt="Prev"></a><a accesskey="u" href="../centroid.html"><img src="../../../../../../../../doc/src/images/up.png" alt="Up"></a><a accesskey="h" href="../../../../index.html"><img src="../../../../../../../../doc/src/images/home.png" alt="Home"></a><a accesskey="n" href="return_centroid_2_with_strategy.html"><img src="../../../../../../../../doc/src/images/next.png" alt="Next"></a>
24</div>
25<div class="section">
26<div class="titlepage"><div><div><h5 class="title">
27<a name="geometry.reference.algorithms.centroid.return_centroid_1"></a><a class="link" href="return_centroid_1.html" title="return_centroid">return_centroid</a>
28</h5></div></div></div>
29<p>
30            <a class="indexterm" name="idm45635705421872"></a>
31Calculates the centroid of a geometry.
32          </p>
33<h6>
34<a name="geometry.reference.algorithms.centroid.return_centroid_1.h0"></a>
35            <span class="phrase"><a name="geometry.reference.algorithms.centroid.return_centroid_1.description"></a></span><a class="link" href="return_centroid_1.html#geometry.reference.algorithms.centroid.return_centroid_1.description">Description</a>
36          </h6>
37<p>
38            The free function centroid calculates the geometric center (or: center
39            of mass) of a geometry. This version with the return_ prefix returns
40            the centroid, and a template parameter must therefore be specified in
41            the call..
42          </p>
43<h6>
44<a name="geometry.reference.algorithms.centroid.return_centroid_1.h1"></a>
45            <span class="phrase"><a name="geometry.reference.algorithms.centroid.return_centroid_1.synopsis"></a></span><a class="link" href="return_centroid_1.html#geometry.reference.algorithms.centroid.return_centroid_1.synopsis">Synopsis</a>
46          </h6>
47<p>
48</p>
49<pre class="programlisting"><span class="keyword">template</span><span class="special">&lt;</span><span class="keyword">typename</span> <span class="identifier">Point</span><span class="special">,</span> <span class="keyword">typename</span> <span class="identifier">Geometry</span><span class="special">&gt;</span>
50<span class="identifier">Point</span> <span class="identifier">return_centroid</span><span class="special">(</span><span class="identifier">Geometry</span> <span class="keyword">const</span> <span class="special">&amp;</span> <span class="identifier">geometry</span><span class="special">)</span></pre>
51<p>
52          </p>
53<h6>
54<a name="geometry.reference.algorithms.centroid.return_centroid_1.h2"></a>
55            <span class="phrase"><a name="geometry.reference.algorithms.centroid.return_centroid_1.parameters"></a></span><a class="link" href="return_centroid_1.html#geometry.reference.algorithms.centroid.return_centroid_1.parameters">Parameters</a>
56          </h6>
57<div class="informaltable"><table class="table">
58<colgroup>
59<col>
60<col>
61<col>
62<col>
63</colgroup>
64<thead><tr>
65<th>
66                    <p>
67                      Type
68                    </p>
69                  </th>
70<th>
71                    <p>
72                      Concept
73                    </p>
74                  </th>
75<th>
76                    <p>
77                      Name
78                    </p>
79                  </th>
80<th>
81                    <p>
82                      Description
83                    </p>
84                  </th>
85</tr></thead>
86<tbody>
87<tr>
88<td>
89                    <p>
90                      Point
91                    </p>
92                  </td>
93<td>
94                    <p>
95                      Any type fulfilling a Point Concept
96                    </p>
97                  </td>
98<td>
99                    <p>
100                      -
101                    </p>
102                  </td>
103<td>
104                    <p>
105                      Must be specified
106                    </p>
107                  </td>
108</tr>
109<tr>
110<td>
111                    <p>
112                      Geometry const &amp;
113                    </p>
114                  </td>
115<td>
116                    <p>
117                      Any type fulfilling a Geometry Concept
118                    </p>
119                  </td>
120<td>
121                    <p>
122                      geometry
123                    </p>
124                  </td>
125<td>
126                    <p>
127                      A model of the specified concept
128                    </p>
129                  </td>
130</tr>
131</tbody>
132</table></div>
133<h6>
134<a name="geometry.reference.algorithms.centroid.return_centroid_1.h3"></a>
135            <span class="phrase"><a name="geometry.reference.algorithms.centroid.return_centroid_1.returns"></a></span><a class="link" href="return_centroid_1.html#geometry.reference.algorithms.centroid.return_centroid_1.returns">Returns</a>
136          </h6>
137<p>
138            The calculated centroid
139          </p>
140<h6>
141<a name="geometry.reference.algorithms.centroid.return_centroid_1.h4"></a>
142            <span class="phrase"><a name="geometry.reference.algorithms.centroid.return_centroid_1.header"></a></span><a class="link" href="return_centroid_1.html#geometry.reference.algorithms.centroid.return_centroid_1.header">Header</a>
143          </h6>
144<p>
145            Either
146          </p>
147<p>
148            <code class="computeroutput"><span class="preprocessor">#include</span> <span class="special">&lt;</span><span class="identifier">boost</span><span class="special">/</span><span class="identifier">geometry</span><span class="special">.</span><span class="identifier">hpp</span><span class="special">&gt;</span></code>
149          </p>
150<p>
151            Or
152          </p>
153<p>
154            <code class="computeroutput"><span class="preprocessor">#include</span> <span class="special">&lt;</span><span class="identifier">boost</span><span class="special">/</span><span class="identifier">geometry</span><span class="special">/</span><span class="identifier">algorithms</span><span class="special">/</span><span class="identifier">centroid</span><span class="special">.</span><span class="identifier">hpp</span><span class="special">&gt;</span></code>
155          </p>
156<h6>
157<a name="geometry.reference.algorithms.centroid.return_centroid_1.h5"></a>
158            <span class="phrase"><a name="geometry.reference.algorithms.centroid.return_centroid_1.conformance"></a></span><a class="link" href="return_centroid_1.html#geometry.reference.algorithms.centroid.return_centroid_1.conformance">Conformance</a>
159          </h6>
160<p>
161            The function centroid implements function Centroid from the <a href="http://www.opengeospatial.org/standards/sfa" target="_top">OGC
162            Simple Feature Specification</a>.
163          </p>
164<h6>
165<a name="geometry.reference.algorithms.centroid.return_centroid_1.h6"></a>
166            <span class="phrase"><a name="geometry.reference.algorithms.centroid.return_centroid_1.behavior"></a></span><a class="link" href="return_centroid_1.html#geometry.reference.algorithms.centroid.return_centroid_1.behavior">Behavior</a>
167          </h6>
168<div class="informaltable"><table class="table">
169<colgroup>
170<col>
171<col>
172</colgroup>
173<thead><tr>
174<th>
175                    <p>
176                      Case
177                    </p>
178                  </th>
179<th>
180                    <p>
181                      Behavior
182                    </p>
183                  </th>
184</tr></thead>
185<tbody>
186<tr>
187<td>
188                    <p>
189                      Point
190                    </p>
191                  </td>
192<td>
193                    <p>
194                      Returns the point itself as the centroid
195                    </p>
196                  </td>
197</tr>
198<tr>
199<td>
200                    <p>
201                      Multi Point
202                    </p>
203                  </td>
204<td>
205                    <p>
206                      Calculates centroid (based on average)
207                    </p>
208                  </td>
209</tr>
210<tr>
211<td>
212                    <p>
213                      linear (e.g. linestring)
214                    </p>
215                  </td>
216<td>
217                    <p>
218                      Calculates centroid (based on weighted length)
219                    </p>
220                  </td>
221</tr>
222<tr>
223<td>
224                    <p>
225                      areal (e.g. polygon)
226                    </p>
227                  </td>
228<td>
229                    <p>
230                      Calculates centroid
231                    </p>
232                  </td>
233</tr>
234<tr>
235<td>
236                    <p>
237                      Empty (e.g. polygon without points)
238                    </p>
239                  </td>
240<td>
241                    <p>
242                      Throws a <a class="link" href="../../exceptions/centroid_exception.html" title="centroid_exception">centroid_exception</a>
243                    </p>
244                  </td>
245</tr>
246<tr>
247<td>
248                    <p>
249                      Cartesian
250                    </p>
251                  </td>
252<td>
253                    <p>
254                      Implemented
255                    </p>
256                  </td>
257</tr>
258<tr>
259<td>
260                    <p>
261                      Spherical
262                    </p>
263                  </td>
264<td>
265                    <p>
266                      Calculates the centroid as if based on Cartesian coordinates
267                    </p>
268                  </td>
269</tr>
270</tbody>
271</table></div>
272<h6>
273<a name="geometry.reference.algorithms.centroid.return_centroid_1.h7"></a>
274            <span class="phrase"><a name="geometry.reference.algorithms.centroid.return_centroid_1.supported_geometries"></a></span><a class="link" href="return_centroid_1.html#geometry.reference.algorithms.centroid.return_centroid_1.supported_geometries">Supported
275            geometries</a>
276          </h6>
277<div class="informaltable"><table class="table">
278<colgroup>
279<col>
280<col>
281<col>
282</colgroup>
283<thead><tr>
284<th>
285                  </th>
286<th>
287                    <p>
288                      2D
289                    </p>
290                  </th>
291<th>
292                    <p>
293                      3D
294                    </p>
295                  </th>
296</tr></thead>
297<tbody>
298<tr>
299<td>
300                    <p>
301                      Point
302                    </p>
303                  </td>
304<td>
305                    <p>
306                      <span class="inlinemediaobject"><img src="../../../../img/ok.png" alt="ok"></span>
307                    </p>
308                  </td>
309<td>
310                    <p>
311                      <span class="inlinemediaobject"><img src="../../../../img/ok.png" alt="ok"></span>
312                    </p>
313                  </td>
314</tr>
315<tr>
316<td>
317                    <p>
318                      Segment
319                    </p>
320                  </td>
321<td>
322                    <p>
323                      <span class="inlinemediaobject"><img src="../../../../img/ok.png" alt="ok"></span>
324                    </p>
325                  </td>
326<td>
327                    <p>
328                      <span class="inlinemediaobject"><img src="../../../../img/ok.png" alt="ok"></span>
329                    </p>
330                  </td>
331</tr>
332<tr>
333<td>
334                    <p>
335                      Box
336                    </p>
337                  </td>
338<td>
339                    <p>
340                      <span class="inlinemediaobject"><img src="../../../../img/ok.png" alt="ok"></span>
341                    </p>
342                  </td>
343<td>
344                    <p>
345                      <span class="inlinemediaobject"><img src="../../../../img/ok.png" alt="ok"></span>
346                    </p>
347                  </td>
348</tr>
349<tr>
350<td>
351                    <p>
352                      Linestring
353                    </p>
354                  </td>
355<td>
356                    <p>
357                      <span class="inlinemediaobject"><img src="../../../../img/ok.png" alt="ok"></span>
358                    </p>
359                  </td>
360<td>
361                    <p>
362                      <span class="inlinemediaobject"><img src="../../../../img/nyi.png" alt="nyi"></span>
363                    </p>
364                  </td>
365</tr>
366<tr>
367<td>
368                    <p>
369                      Ring
370                    </p>
371                  </td>
372<td>
373                    <p>
374                      <span class="inlinemediaobject"><img src="../../../../img/ok.png" alt="ok"></span>
375                    </p>
376                  </td>
377<td>
378                    <p>
379                      <span class="inlinemediaobject"><img src="../../../../img/nyi.png" alt="nyi"></span>
380                    </p>
381                  </td>
382</tr>
383<tr>
384<td>
385                    <p>
386                      Polygon
387                    </p>
388                  </td>
389<td>
390                    <p>
391                      <span class="inlinemediaobject"><img src="../../../../img/ok.png" alt="ok"></span>
392                    </p>
393                  </td>
394<td>
395                    <p>
396                      <span class="inlinemediaobject"><img src="../../../../img/nyi.png" alt="nyi"></span>
397                    </p>
398                  </td>
399</tr>
400<tr>
401<td>
402                    <p>
403                      MultiPoint
404                    </p>
405                  </td>
406<td>
407                    <p>
408                      <span class="inlinemediaobject"><img src="../../../../img/ok.png" alt="ok"></span>
409                    </p>
410                  </td>
411<td>
412                    <p>
413                      <span class="inlinemediaobject"><img src="../../../../img/ok.png" alt="ok"></span>
414                    </p>
415                  </td>
416</tr>
417<tr>
418<td>
419                    <p>
420                      MultiLinestring
421                    </p>
422                  </td>
423<td>
424                    <p>
425                      <span class="inlinemediaobject"><img src="../../../../img/ok.png" alt="ok"></span>
426                    </p>
427                  </td>
428<td>
429                    <p>
430                      <span class="inlinemediaobject"><img src="../../../../img/nyi.png" alt="nyi"></span>
431                    </p>
432                  </td>
433</tr>
434<tr>
435<td>
436                    <p>
437                      MultiPolygon
438                    </p>
439                  </td>
440<td>
441                    <p>
442                      <span class="inlinemediaobject"><img src="../../../../img/ok.png" alt="ok"></span>
443                    </p>
444                  </td>
445<td>
446                    <p>
447                      <span class="inlinemediaobject"><img src="../../../../img/nyi.png" alt="nyi"></span>
448                    </p>
449                  </td>
450</tr>
451</tbody>
452</table></div>
453<h6>
454<a name="geometry.reference.algorithms.centroid.return_centroid_1.h8"></a>
455            <span class="phrase"><a name="geometry.reference.algorithms.centroid.return_centroid_1.complexity"></a></span><a class="link" href="return_centroid_1.html#geometry.reference.algorithms.centroid.return_centroid_1.complexity">Complexity</a>
456          </h6>
457<p>
458            Linear
459          </p>
460</div>
461<table xmlns:rev="http://www.cs.rpi.edu/~gregod/boost/tools/doc/revision" width="100%"><tr>
462<td align="left"></td>
463<td align="right"><div class="copyright-footer">Copyright © 2009-2019 Barend Gehrels, Bruno Lalande, Mateusz Loskot, Adam
464      Wulkiewicz, Oracle and/or its affiliates<p>
465        Distributed under the Boost Software License, Version 1.0. (See accompanying
466        file LICENSE_1_0.txt or copy at <a href="http://www.boost.org/LICENSE_1_0.txt" target="_top">http://www.boost.org/LICENSE_1_0.txt</a>)
467      </p>
468</div></td>
469</tr></table>
470<hr>
471<div class="spirit-nav">
472<a accesskey="p" href="centroid_2.html"><img src="../../../../../../../../doc/src/images/prev.png" alt="Prev"></a><a accesskey="u" href="../centroid.html"><img src="../../../../../../../../doc/src/images/up.png" alt="Up"></a><a accesskey="h" href="../../../../index.html"><img src="../../../../../../../../doc/src/images/home.png" alt="Home"></a><a accesskey="n" href="return_centroid_2_with_strategy.html"><img src="../../../../../../../../doc/src/images/next.png" alt="Next"></a>
473</div>
474</body>
475</html>
476