12345678910111213141516171819202122232425262728293031323334353637 |
- #include "rotate_vectors.h"
- IGL_INLINE Eigen::MatrixXd igl::rotate_vectors(
- const Eigen::MatrixXd& V,
- const Eigen::VectorXd& A,
- const Eigen::MatrixXd& B1,
- const Eigen::MatrixXd& B2)
- {
- Eigen::MatrixXd RV(V.rows(),V.cols());
- for (unsigned i=0; i<V.rows();++i)
- {
- double norm = V.row(i).norm();
-
-
- double a = atan2(B2.row(i).dot(V.row(i)),B1.row(i).dot(V.row(i)));
-
- a += (A.size() == 1) ? A(0) : A(i);
-
- RV.row(i) = norm*cos(a) * B1.row(i) + norm*sin(a) * B2.row(i);
- }
- return RV;
- }
- #ifdef IGL_STATIC_LIBRARY
- #endif
|