Test matrix condition number computation.
#include <iostream>
#include <stdlib.h>
#include <visp3/core/vpMatrix.h>
int test_condition_number(
const std::string &test_name,
const vpMatrix &M)
{
double precision = 1e-6;
double inducedL2_norm_inv = 0, cond_inv = 0;
double cond_pinv = inducedL2_norm * inducedL2_norm_pinv;
double rank = M.
kernel(kerMt);
if (is_square) {
cond_inv = inducedL2_norm * inducedL2_norm_inv;
}
M.
print(std::cout, 4, test_name);
std::cout << " Matrix rank: " << rank << std::endl;
std::cout << " Matrix induced L2 norm ||M||_L2: " << inducedL2_norm << std::endl;
if (is_square) {
std::cout << " Inverse induced L2 norm ||M^-1||_L2: " << inducedL2_norm_inv << std::endl;
}
std::cout << " Pseudo inverse induced L2 norm norm ||M^+||_L2: " << inducedL2_norm_pinv << std::endl;
if (is_square) {
std::cout << " Condition number such as cond(M)=||M||_L2 * ||M^-1||_L2: " << cond_inv << std::endl;
}
std::cout << " Condition number such as cond(M)=||M||_L2 * ||M^+||_L2: " << cond_pinv << std::endl;
std::cout << " Condition number cond(M): " << cond << std::endl;
std::cout << " Condition number differ from the one computed with the pseudo inverse" << std::endl;
return EXIT_FAILURE;
}
if (is_square) {
std::cout << " Condition number differ from the one computed with the inverse" << std::endl;
return EXIT_FAILURE;
}
}
return EXIT_SUCCESS;
}
int main()
{
#if defined(VISP_HAVE_LAPACK) || defined(VISP_HAVE_EIGEN3) || defined(VISP_HAVE_OPENCV)
if (test_condition_number("* Test square matrix M", M)) {
std::cout << " - Condition number computation fails" << std::endl;
return EXIT_FAILURE;
}
else {
std::cout << " + Condition number computation succeed" << std::endl;
}
M[0][0] = 1; M[0][1] = 2; M[0][2] = 3;
M[1][0] = 4; M[1][1] = 5; M[1][2] = 6;
if (test_condition_number("* Test rect matrix M", M)) {
std::cout << " - Condition number computation fails" << std::endl;
return EXIT_FAILURE;
}
else {
std::cout << " + Condition number computation succeed" << std::endl;
}
if (test_condition_number("* Test rect matrix M", M)) {
std::cout << " - Condition number computation fails" << std::endl;
return EXIT_FAILURE;
}
else {
std::cout << " + Condition number computation succeed" << std::endl;
}
M[0][0] = 1; M[0][1] = 2; M[0][2] = 3; M[0][3] = 0;
M[1][0] = 4; M[1][1] = 5; M[1][2] = 6; M[1][3] = 0;
M[2][0] = 0; M[2][1] = 0; M[2][2] = 0; M[2][3] = 0;
if (test_condition_number("* Test rect matrix M", M)) {
std::cout << " - Condition number computation fails" << std::endl;
return EXIT_FAILURE;
}
else {
std::cout << " + Condition number computation succeed" << std::endl;
}
if (test_condition_number("* Test rect matrix M", M)) {
std::cout << " - Condition number computation fails" << std::endl;
return EXIT_FAILURE;
}
else {
std::cout << " + Condition number computation succeed" << std::endl;
}
std::cout << "Test succeed" << std::endl;
#else
std::cout << "Test ignored: install Lapack, Eigen3 or OpenCV" << std::endl;
#endif
return EXIT_SUCCESS;
}