當前位置: 首頁>>代碼示例>>C++>>正文


C++ VectorXd::block方法代碼示例

本文整理匯總了C++中eigen::VectorXd::block方法的典型用法代碼示例。如果您正苦於以下問題:C++ VectorXd::block方法的具體用法?C++ VectorXd::block怎麽用?C++ VectorXd::block使用的例子?那麽, 這裏精選的方法代碼示例或許可以為您提供幫助。您也可以進一步了解該方法所在eigen::VectorXd的用法示例。


在下文中一共展示了VectorXd::block方法的8個代碼示例,這些例子默認根據受歡迎程度排序。您可以為喜歡或者感覺有用的代碼點讚,您的評價將有助於係統推薦出更棒的C++代碼示例。

示例1: computeGeneralizedForce

void GravityCompensation::computeGeneralizedForce(Eigen::VectorXd& tau)
{
  tau = Eigen::VectorXd::Zero(robot_->getDOF());
  uint32_t macro_dof = robot_->getMacroManipulatorDOF();

  mnp_ = robot_->getManipulator().begin()->second;
  for(uint32_t i = 0; i < macro_dof; ++i)
  {
    tau.block(0, 0, macro_dof, 1) -= mnp_->getLink(i)->m * mnp_->getJacobian()[i].block(0, 0, 3, macro_dof).transpose() * param_->getG();
  }

  uint32_t offset = 0;

  for(uint32_t i = 0; i < mnp_name_.size(); ++i)
  {
    mnp_ = robot_->getManipulator(mnp_name_[i]);
    uint32_t mini_dof = mnp_->getDOF() - macro_dof;

    for(uint32_t j = 0; j < mini_dof; ++j)
    {
      tau.block(macro_dof + offset, 0, mini_dof, 1) -= mnp_->getLink(j + macro_dof)->m * mnp_->getJacobian()[j + macro_dof].block(0, macro_dof, 3, mini_dof).transpose() * param_->getG();
    }

    offset += mini_dof;
  }

  tau_ = tau;
}
開發者ID:bilynbk,項目名稱:ahl_wbc,代碼行數:28,代碼來源:gravity_compensation.cpp

示例2: control

void YouBot::control(const ros::TimerEvent&)
{
  try
  {
    boost::mutex::scoped_lock lock(mutex_);

    if(gazebo_interface_->subscribed())
    {
      Eigen::VectorXd q = gazebo_interface_->getJointStates();
      robot_->update(q);
      joint_updated_ = true;

      q_base_ = q.block(0, 0, robot_->getMacroManipulatorDOF(), 1);
    }

    if(!model_updated_) return;

    Eigen::VectorXd tau = Eigen::VectorXd::Zero(robot_->getDOF());
    controller_->computeGeneralizedForce(tau);
    gazebo_interface_->applyJointEfforts(tau);

    tau_base_ = tau.block(0, 0, robot_->getMacroManipulatorDOF(), 1);
  }
  catch(ahl_robot::Exception& e)
  {
    ROS_ERROR_STREAM(e.what());
  }
  catch(ahl_ctrl::Exception& e)
  {
    ROS_ERROR_STREAM(e.what());
  }
}
開發者ID:ChefOtter,項目名稱:ahl_ros_pkg,代碼行數:32,代碼來源:youbot.cpp

示例3: unflattenSymmetric

Eigen::MatrixXd unflattenSymmetric(Eigen::VectorXd flat)
{
  //todo: other data types?
  //todo: safety/size checking?

  int num_rows = (-1 + sqrt(1 + 4 * 2 * flat.rows())) / 2; //solve for number of rows using quadratic eq
  Eigen::MatrixXd symm(num_rows, num_rows);
  int count = 0;
  for (int i = 0; i < num_rows; i++) {
    int ltcsz = num_rows - i;
    symm.block(i, i, ltcsz, 1) = flat.block(count, 0, ltcsz, 1);
    symm.block(i, i, 1, ltcsz) = flat.block(count, 0, ltcsz, 1).transpose();
    count += ltcsz;
  }
  return symm;
}
開發者ID:andybarry,項目名稱:pronto-distro,代碼行數:16,代碼來源:eigen_utils_common.cpp

示例4: deleteVectorBlock

void deleteVectorBlock( Eigen::VectorXd &matrix, const int block_start_index, const int block_length ){

  assert( 1==matrix.cols() );
  assert( matrix.rows()>=block_start_index+block_length );

  int size = matrix.rows();
  /*
    R
    D
    M
  */

  matrix.block( block_start_index, 0, size-block_start_index-block_length, 1 ) = matrix.block( block_start_index+block_length, 0,  size-block_start_index-block_length, 1 );
  matrix.conservativeResize( size-block_length, 1 );

}
開發者ID:krisoft,項目名稱:panovis,代碼行數:16,代碼來源:matrix_utils.cpp

示例5: addVectorBlock

void addVectorBlock( Eigen::VectorXd &matrix, const int block_length ){
  assert( 1==matrix.cols() );

  int old_size = matrix.rows();
  matrix.conservativeResize( old_size+block_length, 1 );
  matrix.block( old_size, 0, block_length, 1 ) = Eigen::MatrixXd::Zero( block_length, 1);

}
開發者ID:krisoft,項目名稱:panovis,代碼行數:8,代碼來源:matrix_utils.cpp

示例6: computeGeneralizedForce

void FrictionCompensation::computeGeneralizedForce(Eigen::VectorXd& tau)
{
  tau = Eigen::VectorXd::Zero(robot_->getDOF());
  unsigned int macro_dof = robot_->getMacroManipulatorDOF();

  unsigned int offset = 0;
  for(unsigned int i = 0; i < mnp_name_.size(); ++i)
  {
    mnp_ = robot_->getManipulator(mnp_name_[i]);
    unsigned int mini_dof = mnp_->getDOF() - macro_dof;

    tau.block(macro_dof + offset, 0, mini_dof, 1) = b_.block(macro_dof + offset, macro_dof + offset, mini_dof, mini_dof) * mnp_->dq().block(macro_dof, 0, mini_dof, 1);

    offset += mini_dof;
  }

  tau_ = tau;
}
開發者ID:skohlbr,項目名稱:ahl_wbc,代碼行數:18,代碼來源:friction_compensation.cpp

示例7: evaluateErrorImplementation

  /// \brief evaluate the error term and return the weighted squared error e^T invR e
  double ErrorTermTransformation::evaluateErrorImplementation()
  {
    _errorMatrix = _T.toTransformationMatrix()*_prior.inverse().T();

    Eigen::VectorXd errorVector = Eigen::VectorXd::Zero(6);
    errorVector.block(0,0,3,1) = _errorMatrix.block(0,3,3,1);
    errorVector.block(3,0,3,1) = sm::kinematics::R2AxisAngle(_errorMatrix.block(0,0,3,3));
    setError(errorVector);

    if (_debug == 1)
    {
      std::cout << "\n\n\nPriorEstim:\n" << _T.toTransformationMatrix() << "\n";
      std::cout << "PriorGiven:\n" << _prior.T() << "\n";
      std::cout << "invPrior:\n" << _prior.inverse().T() << "\n";

      std::cout << "errorMatrix:\n" << _errorMatrix << "\n";
      std::cout << "error:\n" << error() <<  "\ninvR:\n" << invR() << "\n\n\n";
    }

    return evaluateChiSquaredError();
  }
開發者ID:AnnaDaiZH,項目名稱:Kalibr,代碼行數:22,代碼來源:ErrorTermTransformation.cpp

示例8: copyToFlatVector

        ///  Copy ::Spacy::Vector to flat coefficient vector of %Eigen .
        void copyToFlatVector( const ::Spacy::Vector& x, Eigen::VectorXd& y,
                               unsigned& currentIndex )
        {
            if ( is< Vector >( x ) )
            {
                y.block( currentIndex, 0, cast_ref< Vector >( x ).get().size(), 1 ) =
                    cast_ref< Vector >( x ).get();
                currentIndex += cast_ref< Vector >( x ).get().size();
                return;
            }

            if ( is<::Spacy::ProductSpace::Vector >( x ) )
            {
                for ( unsigned int i = 0;
                      i < cast_ref<::Spacy::ProductSpace::Vector >( x ).numberOfVariables(); ++i )
                {
                    copyToFlatVector( cast_ref<::Spacy::ProductSpace::Vector >( x ).component( i ),
                                      y, currentIndex );
                }
                return;
            }
        }
開發者ID:spacy-dev,項目名稱:Spacy,代碼行數:23,代碼來源:Copy.cpp


注:本文中的eigen::VectorXd::block方法示例由純淨天空整理自Github/MSDocs等開源代碼及文檔管理平台,相關代碼片段篩選自各路編程大神貢獻的開源項目,源碼版權歸原作者所有,傳播和使用請參考對應項目的License;未經允許,請勿轉載。