GCC Code Coverage Report


Directory: ./
File: include/eiquadprog/eiquadprog-utils.hxx
Date: 2024-12-04 10:05:36
Exec Total Coverage
Lines: 8 10 80.0%
Branches: 3 4 75.0%

Line Branch Exec Source
1 #ifndef EIQUADPROG_UTILS_HPP_
2 #define EIQUADPROG_UTILS_HPP_
3
4 #include <Eigen/Core>
5 #include <iostream>
6
7 namespace eiquadprog {
8 namespace utils {
9
10 /// Compute sqrt(a^2 + b^2)
11 template <typename Scalar>
12 19 inline Scalar distance(Scalar a, Scalar b) {
13 Scalar a1, b1, t;
14 19 a1 = std::abs(a);
15 19 b1 = std::abs(b);
16
2/2
✓ Branch 0 taken 9 times.
✓ Branch 1 taken 10 times.
19 if (a1 > b1) {
17 9 t = (b1 / a1);
18 9 return a1 * std::sqrt(1.0 + t * t);
19
1/2
✗ Branch 0 not taken.
✓ Branch 1 taken 10 times.
10 } else if (b1 > a1) {
20 t = (a1 / b1);
21 return b1 * std::sqrt(1.0 + t * t);
22 }
23 10 return a1 * std::sqrt(2.0);
24 }
25
26 template <class Derived>
27 void print_vector(const char *name, Eigen::MatrixBase<Derived> &x) {
28 std::cerr << name << x.transpose() << std::endl;
29 }
30 template <class Derived>
31 void print_matrix(const char *name, Eigen::MatrixBase<Derived> &x) {
32 std::cerr << name << std::endl << x << std::endl;
33 }
34
35 template <class Derived>
36 void print_vector(const char *name, Eigen::MatrixBase<Derived> &x, int /*n*/) {
37 print_vector(name, x);
38 }
39 template <class Derived>
40 void print_matrix(const char *name, Eigen::MatrixBase<Derived> &x, int /*n*/) {
41 print_matrix(name, x);
42 }
43
44 } // namespace utils
45 } // namespace eiquadprog
46
47 #endif
48