Files
EgtGeomKernel/PointsPCA.h
Dario Sassi 8cadda5d91 EgtGeomKernel 2.1e1 :
- superficie rigata ora costruibile con metodo isoparametrica oppure minima distanza
- cambiato metodo di costruzione di superficie Swept
- al termine della costruzione di una superficie chiusa si aggiusta la normale in modo che punti all'esterno
- nelle PolyLine è possibile aggiungere punti anche prima dell'inizio
- migliorato calcolo centro con PCA di poligoni
- ora offset avanzato non dà errore con offset nullo ma copia la curva.
2019-05-06 06:25:48 +00:00

41 lines
1.4 KiB
C++

//----------------------------------------------------------------------------
// EgalTech 2014-2014
//----------------------------------------------------------------------------
// File : PointsPCA.h Data : 12.08.14 Versione : 1.5h3
// Contenuto : Dichiarazione della classe PointsPCA.
//
//
//
// Modifiche : 12.08.14 DS Creazione modulo.
//
//
//----------------------------------------------------------------------------
#pragma once
#include "/EgtDev/Include/EGkPoint3d.h"
#include "/EgtDev/Extern/Eigen/Dense"
//----------------------------------------------------------------------------
class PointsPCA
{
public :
PointsPCA( void) ;
void AddPoint( const Point3d& ptP, double dW = 1) ;
int GetRank( void) ;
bool GetCenter( Point3d& ptCen) ;
bool GetPrincipalComponent( int nId, Vector3d& vtPC) ;
private :
bool Finalize( void) ;
private :
static const int MAX_RANK = 3 ;
private :
double m_dTotW ; // peso totale (se pesi tutti unitari, allora è numero punti)
Point3d m_ptCen ; // baricentro
Eigen::Matrix3d m_CovMat ; // matrice di covarianza
int m_nRank ; // numero delle componenti principali (MAX_RANK = 3)
Vector3d m_vtPC[MAX_RANK] ; // direzioni delle componenti principali
} ;