热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【cartographer_ros】七:主要配置参数说明

【cartographer_ros】七:主要配置参数说明-上一节介绍了路标Landmark数据的订阅和发布,各类数据的发布和订阅基本阐述完毕。本节会介绍cartographer

上一节介绍了路标Landmark数据的订阅和发布,各类数据的发布和订阅基本阐述完毕。

本节会介绍cartographer的主要配置参数,研究这些参数的使用和对算法的影响。

目录

1,map_builder.lua

2,pose_graph.lua

3,trajectory_builder.lua

4,trajectory_builder_2d.lua


首先还是得回到Ros运行demo(第二节)的launch脚本上。 launch脚本中可以看到demo所用的配置文件是【backpack_2d.lua】
而backpack_2d.lua在一开始通过include语句加载了map_builder和trajectory_builder的配置:

    include "map_builder.lua"
    include "trajectory_builder.lua"

所以从这两个配置文件先入手


1,map_builder.lua

从名字可以看出【map_builder.lua】是对于类MapBuilder的参数配置。具体参数如下:

include "pose_graph.lua"

MAP_BUILDER = {
  use_trajectory_builder_2d = false,		--使用2d轨迹
  use_trajectory_builder_3d = false,		--使用3d轨迹
  num_background_threads = 4,				--核心线程数
  pose_graph = POSE_GRAPH,					--位置图赋值
  collate_by_trajectory = false,			--是否根据轨迹构建修正器
}


2,pose_graph.lua

【map_builder.lua 】中引入了【pose_graph.lua】,【pose_graph.lua】是全局位姿优化。具体参数如下:

POSE_GRAPH = {
  optimize_every_n_nodes = 90, 				--每次整体优化间隔nodes数
  constraint_builder = {
    sampling_ratio = 0.3, 					--全局约束采样比率(nodes)
    max_constraint_distance = 15.,			--全局约束最大间距(当前node与当前submap之间的距离)
    min_score = 0.55,						--全局约束当前最小得分(当前node与当前submap的匹配得分)
    global_localization_min_score = 0.6,	--全局约束全局最小得分(当前node与全局submap的匹配得分)
    loop_closure_translation_weight = 1.1e4,--闭环检测平移权重
    loop_closure_rotation_weight = 1e5,		--闭环检测旋转权重
    log_matches = true,						--是否打开直方图约束
    fast_correlative_scan_matcher = {
      linear_search_window = 7.,			--fast_CSM匹配搜索距离
      angular_search_window = math.rad(30.),--fast_CSM匹配搜索角度
      branch_and_bound_depth = 7,			--fast_CSM分支定界深度
    },
    ceres_scan_matcher = {
      occupied_space_weight = 20., 			--ceres_scan匹配占据空间权重
      translation_weight = 10., 			--ceres_scan匹配平移权重
      rotation_weight = 1., 				--ceres_scan匹配旋转权重
      ceres_solver_optiOns= {
        use_nonmonotonic_steps = true,		--是否使用梯度下降策略
        max_num_iteratiOns= 10, 			--最大迭代次数
        num_threads = 1,					--使用线程数
      },
    },
    fast_correlative_scan_matcher_3d = {
      branch_and_bound_depth = 8,
      full_resolution_depth = 3,
      min_rotational_score = 0.77,
      min_low_resolution_score = 0.55,
      linear_xy_search_window = 5.,
      linear_z_search_window = 1.,
      angular_search_window = math.rad(15.),
    },
    ceres_scan_matcher_3d = {
      occupied_space_weight_0 = 5.,
      occupied_space_weight_1 = 30.,
      translation_weight = 10.,
      rotation_weight = 1.,
      only_optimize_yaw = false,
      ceres_solver_optiOns= {
        use_nonmonotonic_steps = false,
        max_num_iteratiOns= 10,
        num_threads = 1,
      },
    },
  },
  matcher_translation_weight = 5e2, 		--匹配平移约束(当前submap与在当前submap内的某个node)
  matcher_rotation_weight = 1.6e3,			--匹配旋转约束(当前submap与在当前submap内的某个node)
  optimization_problem = {
    huber_scale = 1e1, 						--Huber因子(与离群值(错误的数据)对整体的影响正相关)。
    acceleration_weight = 1e3,  			--IMU加速度的权重
    rotation_weight = 3e5, 					--IMU旋转项的权重
    local_slam_pose_translation_weight = 1e5,	--平移约束权重(前后两个node之间的局部观测与全局优化)
    local_slam_pose_rotation_weight = 1e5,	--旋转约束权重(前后两个node之间的局部观测与全局优化)
    odometry_translation_weight = 1e5,		--平移约束权重(前后两个node之阿的局部观测与里程计观测)
    odometry_rotation_weight = 1e5,			--旋转约束权重(前后两个node之阿的局部观测与里程计观测)
    fixed_frame_pose_translation_weight = 1e1, 	
    fixed_frame_pose_rotation_weight = 1e2, 	
    fixed_frame_pose_use_tolerant_loss = false, 
    fixed_frame_pose_tolerant_loss_param_a = 1, 
    fixed_frame_pose_tolerant_loss_param_b = 1, 
    log_solver_summary = false,				--是否记录Ceres全局优化的结果
    use_online_imu_extrinsics_in_3d = true,	--是否在线标定imu的外参
    fix_z_in_3d = false, 
    ceres_solver_optiOns= {
      use_nonmonotonic_steps = false,		--是否使用梯度下降策略
      max_num_iteratiOns= 50,				--最大迭代次数
      num_threads = 7,						--使用线程数
    },
  },
  max_num_final_iteratiOns= 200, 			--建图结束后最终优化迭代次数
  global_sampling_ratio = 0.003, 			--全局地图匹配约束采样比率(nodes)
  log_residual_histograms = true, 			--是否输出残差直方图
  global_constraint_search_after_n_secOnds= 10., 	--全局匹配间隔时长
  --  overlapping_submaps_trimmer_2d = {
  --    fresh_submaps_count = 1,
  --    min_covered_area = 2,
  --    min_added_submaps_count = 5,
  --  },
}

3,trajectory_builder.lua

从名字可以看出【trajectory_builder.lua】是对于类TrajectoryBuilder的参数配置。具体参数如下:

include "trajectory_builder_2d.lua"
include "trajectory_builder_3d.lua"

TRAJECTORY_BUILDER = {
  trajectory_builder_2d = TRAJECTORY_BUILDER_2D,		--2d轨迹赋值
  trajectory_builder_3d = TRAJECTORY_BUILDER_3D,		--3d轨迹赋值
--  pure_localization_trimmer = {
--    max_submaps_to_keep = 3,
--  },
  collate_fixed_frame = true,							--是否通过固定帧修正
  collate_landmarks = false,							--是否通过反光板修正
}


4,trajectory_builder_2d.lua

【trajectory_builder_2d.lua 】中引入了【trajectory_builder_2d.lua】【trajectory_builder_3d.lua】,两个配置内容是大致类似的,但各自有些特有参数。这里主要说明2D轨迹的参数【trajectory_builder_2d.lua】。具体参数如下:

TRAJECTORY_BUILDER_2D = {
  use_imu_data = true, 				--是否使用imu数据
  min_range = 0., 					--激光的最近距离
  max_range = 30.,					--激光的最远距离
  min_z = -0.8, 					--激光的最小高度
  max_z = 2., 						--激光的最大高度
  missing_data_ray_length = 5., 	--激光的默认数值
  num_accumulated_range_data = 1, 	--单个Node节点累积激光帧数
  voxel_filter_size = 0.025, 		--激光的网格滤波大小
  
  adaptive_voxel_filter = { 		--自适应滤波	
    max_length = 0.5, 				--网格滤波的大小
    min_num_points = 200, 			--最小点云数据
    max_range = 50., 				--最远点云距离
  },

  loop_closure_adaptive_voxel_filter = { --闭环检测自适应滤波
    max_length = 0.9, 
    min_num_points = 100, 
    max_range = 50.,
  },

  use_online_correlative_scan_matching = false, 	--是否使用CSM激光匹配
  real_time_correlative_scan_matcher = { 			--快速CSN激光匹配
    linear_search_window = 0.1, 					--平移搜索范围
    angular_search_window = math.rad(20.), 			--角度搜索范围
    translation_delta_cost_weight = 1e-1, 			--平移代价权重
    rotation_delta_cost_weight = 1e-1, 				--旋转代价权重
  },

  ceres_scan_matcher = { 							--ceres优化激光匹配
    occupied_space_weight = 1., 					--占据空间权重
    translation_weight = 10., 						--平移权重
    rotation_weight = 40., 							--旋转权重
    ceres_solver_optiOns= { 						
      use_nonmonotonic_steps = false, 				--是否使用梯度下降策略
      max_num_iteratiOns= 20, 						--最大迭代次数
      num_threads = 1, 								--使用线程数
    },
  },

  motion_filter = { 					--移动滤波
    max_time_secOnds= 5., 				--2帧激光最小间隔
    max_distance_meters = 0.2, 			--2帧激光最小距离
    max_angle_radians = math.rad(1.), 	--2帧激光最小角度
  },

  -- TODO(schwoere,wohe): Remove this constant. This is only kept for ROS.
  imu_gravity_time_cOnstant= 10., 		--imu的重力常数
  pose_extrapolator = { 				
    use_imu_based = false, 				--是否使用3d初始化位姿预估器
    constant_velocity = {
      imu_gravity_time_cOnstant= 10., 	--imu的重力常数
      pose_queue_duration = 0.001,		--位姿时间间隔
    },
    imu_based = { 
      pose_queue_duration = 5., 		--位姿时间间隔
      gravity_cOnstant= 9.806, 		--重力常数
      pose_translation_weight = 1.,		--位姿偏移权重
      pose_rotation_weight = 1., 		--位姿旋转权重
      imu_acceleration_weight = 1., 	--IMU加速度权重
      imu_rotation_weight = 1., 		--IMU旋转权重
      odometry_translation_weight = 1., --里程计平移权重
      odometry_rotation_weight = 1., 	--里程计旋转权重
      solver_optiOns= { 
        use_nonmonotonic_steps = false;
        max_num_iteratiOns= 10;
        num_threads = 1;
      },
    },
  },

  submaps = { 
    num_range_data = 90, 				--子图中Node的数量
    grid_options_2d = {
      grid_type = "PROBABILITY_GRID", 	--概率栅格地图
      resolution = 0.05, 				--分辨率
    },
    range_data_inserter = { 
      range_data_inserter_type = "PROBABILITY_GRID_INSERTER_2D",
      probability_grid_range_data_inserter = {
        insert_free_space = true,		--是否改变改变占用网格中的概率。
        hit_probability = 0.55, 		--hit(占用) 时的概率
        miss_probability = 0.49,		--miss(空闲) 时的概率
      },
      tsdf_range_data_inserter = {
        truncation_distance = 0.3,
        maximum_weight = 10.,
        update_free_space = false,
        normal_estimation_optiOns= {
          num_normal_samples = 4,
          sample_radius = 0.5,
        },
        project_sdf_distance_to_scan_normal = true,
        update_weight_range_expOnent= 0,
        update_weight_angle_scan_normal_to_ray_kernel_bandwidth = 0.5,
        update_weight_distance_cell_to_hit_kernel_bandwidth = 0.5,
      },
    },
  },
}

以上就是cartographer中的主要配置参数,这里只是简单的介绍说明,要更加深入的了解还需要到实际案例中使用或者查看其在代码中的功能作用。

【完】


下一节就结合demo案例一起说明,在Ros中使用这些参数时实际的配置及效果。


推荐阅读
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 本文介绍了P1651题目的描述和要求,以及计算能搭建的塔的最大高度的方法。通过动态规划和状压技术,将问题转化为求解差值的问题,并定义了相应的状态。最终得出了计算最大高度的解法。 ... [详细]
  • 3.223.28周学习总结中的贪心作业收获及困惑
    本文是对3.223.28周学习总结中的贪心作业进行总结,作者在解题过程中参考了他人的代码,但前提是要先理解题目并有解题思路。作者分享了自己在贪心作业中的收获,同时提到了一道让他困惑的题目,即input details部分引发的疑惑。 ... [详细]
  • 本文介绍了最长上升子序列问题的一个变种解法,通过记录拐点的位置,将问题拆分为左右两个LIS问题。详细讲解了算法的实现过程,并给出了相应的代码。 ... [详细]
  • 本文讨论了一个数列求和问题,该数列按照一定规律生成。通过观察数列的规律,我们可以得出求解该问题的算法。具体算法为计算前n项i*f[i]的和,其中f[i]表示数列中有i个数字。根据参考的思路,我们可以将算法的时间复杂度控制在O(n),即计算到5e5即可满足1e9的要求。 ... [详细]
  • 本文介绍了设计师伊振华受邀参与沈阳市智慧城市运行管理中心项目的整体设计,并以数字赋能和创新驱动高质量发展的理念,建设了集成、智慧、高效的一体化城市综合管理平台,促进了城市的数字化转型。该中心被称为当代城市的智能心脏,为沈阳市的智慧城市建设做出了重要贡献。 ... [详细]
  • 向QTextEdit拖放文件的方法及实现步骤
    本文介绍了在使用QTextEdit时如何实现拖放文件的功能,包括相关的方法和实现步骤。通过重写dragEnterEvent和dropEvent函数,并结合QMimeData和QUrl等类,可以轻松实现向QTextEdit拖放文件的功能。详细的代码实现和说明可以参考本文提供的示例代码。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • android listview OnItemClickListener失效原因
    最近在做listview时发现OnItemClickListener失效的问题,经过查找发现是因为button的原因。不仅listitem中存在button会影响OnItemClickListener事件的失效,还会导致单击后listview每个item的背景改变,使得item中的所有有关焦点的事件都失效。本文给出了一个范例来说明这种情况,并提供了解决方法。 ... [详细]
  • 本文介绍了C++中省略号类型和参数个数不确定函数参数的使用方法,并提供了一个范例。通过宏定义的方式,可以方便地处理不定参数的情况。文章中给出了具体的代码实现,并对代码进行了解释和说明。这对于需要处理不定参数的情况的程序员来说,是一个很有用的参考资料。 ... [详细]
  • 本文讨论了使用差分约束系统求解House Man跳跃问题的思路与方法。给定一组不同高度,要求从最低点跳跃到最高点,每次跳跃的距离不超过D,并且不能改变给定的顺序。通过建立差分约束系统,将问题转化为图的建立和查询距离的问题。文章详细介绍了建立约束条件的方法,并使用SPFA算法判环并输出结果。同时还讨论了建边方向和跳跃顺序的关系。 ... [详细]
  • CF:3D City Model(小思维)问题解析和代码实现
    本文通过解析CF:3D City Model问题,介绍了问题的背景和要求,并给出了相应的代码实现。该问题涉及到在一个矩形的网格上建造城市的情景,每个网格单元可以作为建筑的基础,建筑由多个立方体叠加而成。文章详细讲解了问题的解决思路,并给出了相应的代码实现供读者参考。 ... [详细]
  • 本文介绍了在CentOS上安装Python2.7.2的详细步骤,包括下载、解压、编译和安装等操作。同时提供了一些注意事项,以及测试安装是否成功的方法。 ... [详细]
  • Python爬虫中使用正则表达式的方法和注意事项
    本文介绍了在Python爬虫中使用正则表达式的方法和注意事项。首先解释了爬虫的四个主要步骤,并强调了正则表达式在数据处理中的重要性。然后详细介绍了正则表达式的概念和用法,包括检索、替换和过滤文本的功能。同时提到了re模块是Python内置的用于处理正则表达式的模块,并给出了使用正则表达式时需要注意的特殊字符转义和原始字符串的用法。通过本文的学习,读者可以掌握在Python爬虫中使用正则表达式的技巧和方法。 ... [详细]
  • 本文介绍了在wepy中运用小顺序页面受权的计划,包含了用户点击作废后的从新受权计划。 ... [详细]
author-avatar
cfncjl_130
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有