Visual Computing Library  devel
Loading...
Searching...
No Matches
stat.h
1/*****************************************************************************
2 * VCLib *
3 * Visual Computing Library *
4 * *
5 * Copyright(C) 2021-2025 *
6 * Visual Computing Lab *
7 * ISTI - Italian National Research Council *
8 * *
9 * All rights reserved. *
10 * *
11 * This program is free software; you can redistribute it and/or modify *
12 * it under the terms of the Mozilla Public License Version 2.0 as published *
13 * by the Mozilla Foundation; either version 2 of the License, or *
14 * (at your option) any later version. *
15 * *
16 * This program is distributed in the hope that it will be useful, *
17 * but WITHOUT ANY WARRANTY; without even the implied warranty of *
18 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the *
19 * Mozilla Public License Version 2.0 *
20 * (https://www.mozilla.org/en-US/MPL/2.0/) for more details. *
21 ****************************************************************************/
22
23#ifndef VCL_ALGORITHMS_CORE_STAT_H
24#define VCL_ALGORITHMS_CORE_STAT_H
25
26#include <vclib/space/core.h>
27
28#include <vector>
29
30namespace vcl {
31
37template<Point3Concept PointType>
38auto covarianceMatrixOfPointCloud(const std::vector<PointType>& pointVec)
39{
40 Matrix33<typename PointType::ScalarType> m;
41 m.setZero();
42 PointType barycenter = Polygon<PointType>::barycenter(pointVec);
43
44 // compute covariance matrix
45 for (const PointType& p : pointVec) {
46 PointType e = p - barycenter;
47 m += e.outerProduct(e);
48 }
49 return m;
50}
51
58template<Point3Concept PointType>
59auto weightedCovarianceMatrixOfPointCloud(
60 const std::vector<PointType>& pointVec,
61 const std::vector<typename PointType::ScalarType>& weights)
62{
63 Matrix33<typename PointType::ScalarType> m;
64 m.setZero();
65 PointType barycenter =
67
68 // compute covariance matrix
69 typename PointType::ScalarType wsum = 0;
70 for (uint i = 0; i < pointVec.size(); ++i) {
71 PointType e = (pointVec[i] - barycenter) * weights[i];
72 m += e.outerProduct(e);
73 wsum += weights[i];
74 }
75 return m / wsum;
76}
77
78} // namespace vcl
79
80#endif // VCL_ALGORITHMS_CORE_STAT_H
PointT weightedBarycenter(WIterator wBegin) const
Computes the weighted barycenter of the polygon.
Definition polygon.h:215
PointT barycenter() const
Computes the barycenter of the polygon.
Definition polygon.h:200