Visual Computing Library
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/matrix.h>
27#include <vclib/space/core/polygon.h>
28
29#include <vector>
30
31namespace vcl {
32
38template<Point3Concept PointType>
39auto covarianceMatrixOfPointCloud(const std::vector<PointType>& pointVec)
40{
41 Matrix33<typename PointType::ScalarType> m;
42 m.setZero();
43 PointType barycenter = Polygon<PointType>::barycenter(pointVec);
44
45 // compute covariance matrix
46 for (const PointType& p : pointVec) {
47 PointType e = p - barycenter;
48 m += e.outerProduct(e);
49 }
50 return m;
51}
52
59template<Point3Concept PointType>
60auto weightedCovarianceMatrixOfPointCloud(
61 const std::vector<PointType>& pointVec,
62 const std::vector<typename PointType::ScalarType>& weights)
63{
64 Matrix33<typename PointType::ScalarType> m;
65 m.setZero();
66 PointType barycenter =
68
69 // compute covariance matrix
70 typename PointType::ScalarType wsum = 0;
71 for (uint i = 0; i < pointVec.size(); ++i) {
72 PointType e = (pointVec[i] - barycenter) * weights[i];
73 m += e.outerProduct(e);
74 wsum += weights[i];
75 }
76 return m / wsum;
77}
78
79} // namespace vcl
80
81#endif // VCL_ALGORITHMS_CORE_STAT_H
PointT weightedBarycenter(WIterator wBegin) const
Computes the weighted barycenter of the polygon.
Definition polygon.h:218
PointT barycenter() const
Computes the barycenter of the polygon.
Definition polygon.h:203