// SPDX-License-Identifier: LGPL-2.1-or-later // Copyright (C) 2007 Ruben Smits // Version: 1.0 // Author: Ruben Smits // Maintainer: Ruben Smits // URL: http://www.orocos.org/kdl // This library is free software; you can redistribute it and/or // modify it under the terms of the GNU Lesser General Public // License as published by the Free Software Foundation; either // version 2.1 of the License, or (at your option) any later version. // This library is distributed in the hope that it will be useful, // but WITHOUT ANY WARRANTY; without even the implied warranty of // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU // Lesser General Public License for more details. // You should have received a copy of the GNU Lesser General Public // License along with this library; if not, write to the Free Software // Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA #include "chainjnttojacsolver.hpp" namespace KDL { ChainJntToJacSolver::ChainJntToJacSolver(const Chain& _chain): chain(_chain),locked_joints_(chain.getNrOfJoints(),false), nr_of_unlocked_joints_(chain.getNrOfJoints()) { } ChainJntToJacSolver::~ChainJntToJacSolver() { } int ChainJntToJacSolver::setLockedJoints(const std::vector locked_joints) { if(locked_joints.size()!=locked_joints_.size()) return -1; locked_joints_=locked_joints; nr_of_unlocked_joints_=0; for(unsigned int i=0;ichain.getNrOfSegments()) return (error = E_JAC_FAILED); T_tmp = Frame::Identity(); SetToZero(t_tmp); int j=0; int k=0; Frame total; for (unsigned int i=0;i