-
Notifications
You must be signed in to change notification settings - Fork 31
/
Copy pathGQ_Characterize.hpp
81 lines (66 loc) · 2.48 KB
/
GQ_Characterize.hpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
#ifndef GQ_CHARACTERIZE_H
#define GQ_CHARACTERIZE_H
#include <Eigen/Eigen>
#include <cfloat>
#include <iostream>
#include <string>
#include "geometry.hpp"
enum GQ_TYPE {UNKNOWN = 0,
ELLIPSOID,
ONE_SHEET_HYPERBOLOID,
TWO_SHEET_HYPERBOLOID,
ELLIPTIC_CONE,
ELLIPTIC_PARABOLOID,
HYPERBOLIC_PARABOLOID,
ELLIPTIC_CYL,
HYPERBOLIC_CYL,
PARABOLIC_CYL};
const std::vector<std::string> _gq_names = {"UNKNOWN",
"ELLIPSOID",
"ONE_SHEET_HYPERBOLOID",
"TWO_SHEET_HYPERBOLOID",
"ELLIPTIC_CONE",
"ELLIPTIC_PARABOLOID",
"HYPERBOLIC_PARABOLOID",
"ELLIPTIC_CYL",
"HYPERBOLIC_CYL",
"PARABOLIC_CYL"};
extern const std::vector<std::string> _gq_names;
class GQ_Characterize{
protected:
// coefficients of the GQ
double A_,B_,C_,D_,E_,F_,G_,H_,J_,K_;
// the cannonical GQ type
GQ_TYPE type;
// translation from the canoncial GQ to final GQ
Vector3d translation;
// rotation matrix from canonical GQ to final GQ
double rotation_mat[9];
// gq transform
Transform transform_;
// tolerance used to determine
// if matrix determinant should be considered zero
const double gq_tol = 1e-6;
const double equivalence_tol = 1e-8;
public:
// Constructor
// Characterizes a general quadratic (GQ) equation of the form:
// A x^2 + B y^2 + C z^2 + D xy + E yz + F xz + G x + H y + J z + K = 0
// into a special quadratic (SQ) with a transformation
GQ_Characterize(double A, double B, double C,
double D, double E, double F,
double G, double H, double J,
double K);
// GQ type accessor
GQ_TYPE get_type() { return type; }
protected:
// reduces GQ coefficients to 2nd order terms, a constant, and a transformation
// to the original origntation when needed
void make_canonical();
// this method reduces a complex GQ to a geometrically equivalent
// and more CAD-friendly form if appropriate
void reduce_type();
// determines GQ type based on characteristic parameters
GQ_TYPE find_type(int rt, int rf, int del, int s, int d);
};
#endif