当前位置: 首页>>代码示例>>C++>>正文


C++ Vector3f::maxCoeff方法代码示例

本文整理汇总了C++中eigen::Vector3f::maxCoeff方法的典型用法代码示例。如果您正苦于以下问题:C++ Vector3f::maxCoeff方法的具体用法?C++ Vector3f::maxCoeff怎么用?C++ Vector3f::maxCoeff使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在eigen::Vector3f的用法示例。


在下文中一共展示了Vector3f::maxCoeff方法的2个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: F

IGL_INLINE bool igl::embree::unproject_onto_mesh(
  const Eigen::Vector2f& pos,
  const Eigen::MatrixXi& F,
  const Eigen::Matrix4f& model,
  const Eigen::Matrix4f& proj,
  const Eigen::Vector4f& viewport,
  const EmbreeIntersector & ei,
  int& fid,
  int& vid)
{
  Eigen::Vector3f bc;
  bool hit = unproject_onto_mesh(pos,F,model,proj,viewport,ei,fid,bc);
  int i;
  if (hit)
  {
    bc.maxCoeff(&i);
    vid = F(fid,i);
  }
  return hit;
}
开发者ID:cugwhp,项目名称:libigl,代码行数:20,代码来源:unproject_onto_mesh.cpp

示例2: if

bool LcmTranslator::
toLcm(const PointCloudView& iView, drc::map_cloud_t& oMessage,
      const float iQuantMax, const bool iCompress) {
  oMessage.view_id = iView.getId();

  // find extrema of cloud and transform points
  maps::PointCloud::PointType maxPoint, minPoint;
  pcl::getMinMax3D(*(iView.getPointCloud()), minPoint, maxPoint);
  Eigen::Vector3f offset = minPoint.getVector3fMap();
  Eigen::Vector3f scale = maxPoint.getVector3fMap() - offset;
  int bits = 8;
  if (iQuantMax == 0) {
    bits = 32;
    scale << 1,1,1;
  }
  else {
    if (iQuantMax > 0) {
      bits = ceil(std::log2(scale.maxCoeff()/iQuantMax));
      bits = std::min(bits, 16);
      bits = std::max(bits, 0);
    }
    scale /= ((1 << bits) - 1);
  }
  Eigen::Affine3f normalizerInv = Eigen::Affine3f::Identity();
  for (int i = 0; i < 3; ++i) {
    normalizerInv(i,i) = scale[i];
    normalizerInv(i,3) = offset[i];
  }
  Eigen::Affine3f normalizer = normalizerInv.inverse();
  maps::PointCloud cloud;
  pcl::transformPointCloud(*(iView.getPointCloud()), cloud, normalizer);

  // store to blob
  int totalSize = cloud.points.size()*3;
  std::vector<uint8_t> data(totalSize*sizeof(float));
  float* ptr = (float*)(&data[0]);
  for (int i = 0; i < cloud.size(); ++i) {
    maps::PointCloud::PointType pt = cloud.points[i];
    ptr[i*3+0] = pt.x + 0.5f;  // add 0.5 for better rounding
    ptr[i*3+1] = pt.y + 0.5f;
    ptr[i*3+2] = pt.z + 0.5f;
  }
  DataBlob::Spec spec;
  spec.mDimensions.push_back(3);
  spec.mDimensions.push_back(cloud.size());
  spec.mStrideBytes.push_back(sizeof(float));
  spec.mStrideBytes.push_back(3*sizeof(float));
  spec.mCompressionType = DataBlob::CompressionTypeNone;
  spec.mDataType = DataBlob::DataTypeFloat32;
  DataBlob blob;
  blob.setData(data, spec);

  // compress and convert
  DataBlob::CompressionType compressionType =
    iCompress ? DataBlob::CompressionTypeZlib : DataBlob::CompressionTypeNone;
  DataBlob::DataType dataType;
  if (bits <= 8) dataType = DataBlob::DataTypeUint8;
  else if (bits <= 16) dataType = DataBlob::DataTypeUint16;
  else dataType = DataBlob::DataTypeFloat32;
  if (!blob.convertTo(compressionType, dataType)) {
    std::cout << "LcmTranslator: cannot compress data" << std::endl;
    return false;
  }

  // pack blob into message
  if (!toLcm(blob, oMessage.blob)) return false;

  // transform
  Eigen::Projective3f fromRef = normalizer*iView.getTransform();
  for (int i = 0; i < 4; ++i) {
    for (int j = 0; j < 4; ++j) {
      oMessage.transform[i][j] = fromRef(i,j);
    }
  }

  // done
  // NOTE: map_id not set
  return true;
}
开发者ID:Gastd,项目名称:oh-distro,代码行数:79,代码来源:LcmTranslator.cpp


注:本文中的eigen::Vector3f::maxCoeff方法示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。