Kmeans.hh
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2014-2016 Open Source Robotics Foundation
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  *
16 */
17 #ifndef _GAZEBO_KMEANS_HH_
18 #define _GAZEBO_KMEANS_HH_
19 
20 #include <vector>
21 #include "gazebo/math/Vector3.hh"
22 #include "gazebo/util/system.hh"
23 
24 namespace gazebo
25 {
26  namespace math
27  {
30 
36  class GZ_MATH_VISIBLE Kmeans
37  {
40  public: Kmeans(const std::vector<Vector3> &_obs);
41 
43  public: virtual ~Kmeans();
44 
47  public: std::vector<Vector3> Observations() const;
48 
52  public: bool Observations(const std::vector<Vector3> &_obs);
53 
57  public: bool AppendObservations(const std::vector<Vector3> &_obs);
58 
70  public: bool Cluster(int _k,
71  std::vector<Vector3> &_centroids,
72  std::vector<unsigned int> &_labels);
73 
77  private: unsigned int ClosestCentroid(const Vector3 &_p) const;
78 
80  private: std::vector<Vector3> obs;
81 
83  private: std::vector<Vector3> centroids;
84 
86  private: std::vector<unsigned int> labels;
87 
89  private: std::vector<Vector3> sums;
90 
92  private: std::vector<unsigned int> counters;
93  };
95  }
96 }
97 
98 #endif
99 
100 
101 
The Vector3 class represents the generic vector containing 3 elements.
Definition: Vector3.hh:39
K-Means clustering algorithm.
Definition: Kmeans.hh:36