diff --git a/vcg/math/matrix44.h b/vcg/math/matrix44.h index 12ced089..8c72f51c 100644 --- a/vcg/math/matrix44.h +++ b/vcg/math/matrix44.h @@ -30,7 +30,7 @@ $LOG$ #ifndef __VCGLIB_MATRIX44 #define __VCGLIB_MATRIX44 -#include +#include #include #include @@ -138,7 +138,7 @@ protected: int index[4]; //hold permutation ///Hold sign of row permutation (used for determinant sign) T d; - void Decompose(); + bool Decompose(); }; /// Apply POST moltiplica la matrice al vettore (e.g. la traslazione deve stare nell'ultima riga) @@ -153,7 +153,8 @@ template Point3 operator*(const Point3 &p, const Matrix44 &m) template Point3 operator*(const Matrix44 &m, const Point3 &p); template Matrix44 &Transpose(Matrix44 &m); -template Matrix44 &Invert(Matrix44 &m); +//return NULL matrix if not invertible +template Matrix44 &Invert(Matrix44 &m); typedef Matrix44 Matrix44s; typedef Matrix44 Matrix44i; @@ -402,7 +403,11 @@ template Matrix44 &Invert(Matrix44 &m) { /* LINEAR SOLVE IMPLEMENTATION */ template LinearSolve::LinearSolve(const Matrix44 &m): Matrix44(m) { - Decompose(); + if(!Decompose()) { + for(int i = 0; i < 4; i++) + index[i] = i; + SetZero(); + } } @@ -418,7 +423,7 @@ template T LinearSolve::Determinant() const { d is +or -1 depeneing of row permutation even or odd.*/ #define TINY 1e-100 -template void LinearSolve::Decompose() { +template bool LinearSolve::Decompose() { d = 1; //no permutation still T scaling[4]; @@ -427,14 +432,14 @@ template void LinearSolve::Decompose() { for(int i = 0; i < 4; i++) { T largest = 0.0; for(int j = 0; j < 4; j++) { - T t = fabs(element(i, j)); + T t = math::Abs(element(i, j)); if (t > largest) largest = t; } if (largest == 0.0) { //oooppps there is a zero row! - return; + return false; } - scaling[i] = 1.0 / largest; + scaling[i] = (T)1.0 / largest; } int imax; @@ -451,7 +456,7 @@ template void LinearSolve::Decompose() { for(int k = 0; k < j; k++) sum -= element(i,k)*element(k,j); element(i,j) = sum; - T t = scaling[i] * fabs(sum); + T t = scaling[i] * math::Abs(sum); if(t >= largest) { largest = t; imax = i; @@ -467,13 +472,14 @@ template void LinearSolve::Decompose() { scaling[imax] = scaling[j]; } index[j]=imax; - if (element(j,j) == 0.0) element(j,j) = TINY; + if (element(j,j) == 0.0) element(j,j) = (T)TINY; if (j != 3) { - T dum = 1.0 / (element(j,j)); + T dum = (T)1.0 / (element(j,j)); for (i = j+1; i < 4; i++) element(i,j) *= dum; } } + return true; } diff --git a/vcg/math/quaternion.h b/vcg/math/quaternion.h index df2ee9a5..8bbf610d 100644 --- a/vcg/math/quaternion.h +++ b/vcg/math/quaternion.h @@ -138,25 +138,25 @@ template void Quaternion::ToMatrix(Matrix44 &m) const { S q22 = V(3)*V(3); S q23 = V(3)*V(0); - m.element(0, 0) = 1.0-(q11 + q22)*2.0; - m.element(1, 0) = (q01 - q23)*2.0; - m.element(2, 0) = (q02 + q13)*2.0; - m.element(3, 0) = 0.0; + m.element(0, 0) = (S)(1.0-(q11 + q22)*2.0); + m.element(1, 0) = (S)((q01 - q23)*2.0); + m.element(2, 0) = (S)((q02 + q13)*2.0); + m.element(3, 0) = (S)0.0; - m.element(0, 1) = (q01 + q23)*2.0; - m.element(1, 1) = 1.0-(q22 + q00)*2.0; - m.element(2, 1) = (q12 - q03)*2.0; - m.element(3, 1) = 0.0; + m.element(0, 1) = (S)((q01 + q23)*2.0); + m.element(1, 1) = (S)(1.0-(q22 + q00)*2.0); + m.element(2, 1) = (S)((q12 - q03)*2.0); + m.element(3, 1) = (S)0.0; - m.element(0, 2) = (q02 - q13)*2.0; - m.element(1, 2) = (q12 + q03)*2.0; - m.element(2, 2) = 1.0-(q11 + q00)*2.0; - m.element(3, 2) = 0.0; + m.element(0, 2) = (S)((q02 - q13)*2.0); + m.element(1, 2) = (S)((q12 + q03)*2.0); + m.element(2, 2) = (S)(1.0-(q11 + q00)*2.0); + m.element(3, 2) = (S)0.0; - m.element(0, 3) = 0.0; - m.element(1, 3) = 0.0; - m.element(2, 3) = 0.0; - m.element(3, 3) = 1.0; + m.element(0, 3) = (S)0.0; + m.element(1, 3) = (S)0.0; + m.element(2, 3) = (S)0.0; + m.element(3, 3) = (S)1.0; }