// This file is part of libigl, a simple c++ geometry processing library. // // Copyright (C) 2014 Daniele Panozzo // // This Source Code Form is subject to the terms of the Mozilla Public License // v. 2.0. If a copy of the MPL was not distributed with this file, You can // obtain one at http://mozilla.org/MPL/2.0/. #ifndef IGL_DOT_ROW_H #define IGL_DOT_ROW_H #include "igl/igl_inline.h" #include namespace igl { /// Compute the dot product between each row of A and B /// /// @tparam DerivedV derived from vertex positions matrix type: i.e. MatrixXd /// @param[in] A eigen matrix r by c /// @param[in] B eigen matrix r by c /// @param[out] d a column vector with r entries that contains the dot product of each corresponding row of A and B /// /// \note Unfortunately, Eigen does not support `A.rowwise().dot(B.rowwise())` /// so this function is a wrapper around the less obvious and less convenient /// `(A.array() * B.array()).rowwise().sum()`. template IGL_INLINE DerivedV dot_row( const Eigen::PlainObjectBase& A, const Eigen::PlainObjectBase& B); } #ifndef IGL_STATIC_LIBRARY # include "dot_row.cpp" #endif #endif