cartographer源码分析(33)-io-ply_writing_points_processor.h

源码可在https://github.com/learnmoreonce/SLAM 下载


文件:ply_writing_points_processor.h


#include "cartographer/common/lua_parameter_dictionary.h"
#include "cartographer/io/file_writer.h"
#include "cartographer/io/points_processor.h"

namespace cartographer {
namespace io {
/*
PlyWritingPointsProcessor是PointsProcessor的第五个子类(5).
PlyWritingPointsProcessor负责将点云point以PLY的格式写入磁盘.

*/
// Streams a PLY file to disk. The header is written in 'Flush'.
class PlyWritingPointsProcessor : public PointsProcessor {
 public:
  constexpr static const char* kConfigurationFileActionName = "write_ply";

  // 指定文件写入的工厂和流水线next指针。
  PlyWritingPointsProcessor(std::unique_ptr<FileWriter> file,
                            PointsProcessor* next);

  static std::unique_ptr<PlyWritingPointsProcessor> FromDictionary(
      FileWriterFactory file_writer_factory,
      common::LuaParameterDictionary* dictionary, PointsProcessor* next);

  ~PlyWritingPointsProcessor() override {}

  PlyWritingPointsProcessor(const PlyWritingPointsProcessor&) = delete;
  PlyWritingPointsProcessor& operator=(const PlyWritingPointsProcessor&) =
      delete;
//按照ply格式写点云信息 。然后直接流水线到下一PointsProcessor
  void Process(std::unique_ptr<PointsBatch> batch) override;
  FlushResult Flush() override;

 private:
  PointsProcessor* const next_;

  int64 num_points_;
  bool has_colors_;//是否是RGB
  std::unique_ptr<FileWriter> file_;
};

}  // namespace io
}  // namespace cartographer

ply_writing_points_processor.cc


#include "cartographer/io/ply_writing_points_processor.h"

#include <iomanip>
#include <sstream>
#include <string>

#include "cartographer/common/lua_parameter_dictionary.h"
#include "cartographer/common/make_unique.h"
#include "cartographer/io/points_batch.h"
#include "glog/logging.h"

namespace cartographer {
namespace io {

namespace {

/*
按照ply格式写入ply的head信息.此函数在最后写入.
why?num_points_只有最后才知道.之前尚未统计完成.

*/
// Writes the PLY header claiming 'num_points' will follow it into
// 'output_file'.
void WriteBinaryPlyHeader(const bool has_color, const int64 num_points,
                          FileWriter* const file_writer) {
  string color_header = !has_color ? ""
                                   : "property uchar red\n"
                                     "property uchar green\n"
                                     "property uchar blue\n";
  std::ostringstream stream;
  stream << "ply\n"
         << "format binary_little_endian 1.0\n"
         << "comment generated by Cartographer\n"
         << "element vertex " << std::setw(15) << std::setfill('0')
         << num_points << "\n"
         << "property float x\n"
         << "property float y\n"
         << "property float z\n"
         << color_header << "end_header\n";
  const string out = stream.str();
  CHECK(file_writer->WriteHeader(out.data(), out.size()));
}

/*
往file_writer写入某一point对应的{x,y,z}
*/
void WriteBinaryPlyPointCoordinate(const Eigen::Vector3f& point,
                                   FileWriter* const file_writer) {
  char buffer[12];
  memcpy(buffer, &point[0], sizeof(float));
  memcpy(buffer + 4, &point[1], sizeof(float));
  memcpy(buffer + 8, &point[2], sizeof(float));
  CHECK(file_writer->Write(buffer, 12));
}

/*
往file_writer写入rgb值
*/
void WriteBinaryPlyPointColor(const Color& color,
                              FileWriter* const file_writer) {
  CHECK(file_writer->Write(reinterpret_cast<const char*>(color.data()),
                           color.size()));
}

}  // namespace

/*
根据.lua文件的filename创建file_writer_factory
*/
std::unique_ptr<PlyWritingPointsProcessor>
PlyWritingPointsProcessor::FromDictionary(
    FileWriterFactory file_writer_factory,
    common::LuaParameterDictionary* const dictionary,
    PointsProcessor* const next) {
  return common::make_unique<PlyWritingPointsProcessor>(
      file_writer_factory(dictionary->GetString("filename")), next);
}

/*
构造函数,默认点云数是0,无rgb值
*/
PlyWritingPointsProcessor::PlyWritingPointsProcessor(
    std::unique_ptr<FileWriter> file_writer, PointsProcessor* const next)
    : next_(next),
      num_points_(0),
      has_colors_(false),
      file_(std::move(file_writer)) {}

/*
在最后阶段才写入head,但不是在文件最后写入head,而是out_.seekp(0); 偏移到0处
*/
PointsProcessor::FlushResult PlyWritingPointsProcessor::Flush() {
  WriteBinaryPlyHeader(has_colors_, num_points_, file_.get());
  CHECK(file_->Close()) << "Closing PLY file_writer failed.";

  switch (next_->Flush()) {
    case FlushResult::kFinished:
      return FlushResult::kFinished;

    case FlushResult::kRestartStream:
      LOG(FATAL) << "PLY generation must be configured to occur after any "
                    "stages that require multiple passes.";
  }
  LOG(FATAL);
}

/*
真正的写入点云PointsBatch,整个类的核心在这个函数.
*/
void PlyWritingPointsProcessor::Process(std::unique_ptr<PointsBatch> batch) {
  if (batch->points.empty()) { //点云为空,则不写入磁盘,直接进行下一Process环节.
    next_->Process(std::move(batch));
    return;
  }

  if (num_points_ == 0) {//点云num为0则写入rgb,和head
    has_colors_ = !batch->colors.empty();
    WriteBinaryPlyHeader(has_colors_, 0, file_.get());
    //file_.get()获取指针指针对应的raw指针
  }
  if (has_colors_) { //rgb的vector长度和point的vecor长度必须一致.
    CHECK_EQ(batch->points.size(), batch->colors.size())
        << "First PointsBatch had colors, but encountered one without. "
           "frame_id: "
        << batch->frame_id;
  }

//函数核心,开始写入每一个point.
  for (size_t i = 0; i < batch->points.size(); ++i) {
    WriteBinaryPlyPointCoordinate(batch->points[i], file_.get());
    if (has_colors_) {
      WriteBinaryPlyPointColor(batch->colors[i], file_.get());
    }
    ++num_points_;
  }
  next_->Process(std::move(batch)); //继续流水线操作.
}

}  // namespace io
}  // namespace cartographer


本文发于:
* http://www.jianshu.com/u/9e38d2febec1
* https://zhuanlan.zhihu.com/learnmoreonce
* http://blog.youkuaiyun.com/learnmoreonce
* slam源码分析微信公众号:slamcode

[INFO] [launch]: All log files can be found below /home/michael/.ros/log/2025-11-13-20-58-01-810975-michael-Legion-Y7000-IRX9-19250 [INFO] [launch]: Default logging verbosity is set to INFO [INFO] [ldlidar-1]: process started with pid [19251] [INFO] [static_transform_publisher-2]: process started with pid [19253] [INFO] [cartographer_node-3]: process started with pid [19255] [INFO] [cartographer_occupancy_grid_node-4]: process started with pid [19257] [ldlidar-1] [INFO] [1763038681.848068170] [rclcpp]: Using port /dev/ttyUSB0 [ldlidar-1] [INFO] [1763038681.848215863] [rclcpp]: LiDAR_LD06 started successfully [static_transform_publisher-2] [INFO] [1763038681.854935283] [static_transform_publisher_rhh6TZQasS30xSPv]: Spinning until stopped - publishing transform [static_transform_publisher-2] translation: ('0.000000', '0.000000', '0.000000') [static_transform_publisher-2] rotation: ('0.000000', '0.000000', '0.000000', '1.000000') [static_transform_publisher-2] from 'base_link' to 'laser' [cartographer_node-3] [INFO] [1763038681.866653454] [cartographer logger]: I1113 20:58:01.000000 19255 configuration_file_resolver.cc:41] Found '/home/michael/ros2_ws/install/ldlidar-ros2/share/ldlidar-ros2/configuration_files/mylaser.lua' for 'mylaser.lua'. [cartographer_node-3] [INFO] [1763038681.866834936] [cartographer logger]: I1113 20:58:01.000000 19255 configuration_file_resolver.cc:41] Found '/opt/ros/humble/share/cartographer/configuration_files/map_builder.lua' for 'map_builder.lua'. [cartographer_node-3] [INFO] [1763038681.866843969] [cartographer logger]: I1113 20:58:01.000000 19255 configuration_file_resolver.cc:41] Found '/opt/ros/humble/share/cartographer/configuration_files/map_builder.lua' for 'map_builder.lua'. [cartographer_node-3] [INFO] [1763038681.866860499] [cartographer logger]: I1113 20:58:01.000000 19255 configuration_file_resolver.cc:41] Found '/opt/ros/humble/share/cartographer/configuration_files/pose_graph.lua' for 'pose_graph.lua'. [cartographer_node-3] [INFO] [1763038681.866866271] [cartographer logger]: I1113 20:58:01.000000 19255 configuration_file_resolver.cc:41] Found '/opt/ros/humble/share/cartographer/configuration_files/pose_graph.lua' for 'pose_graph.lua'. [cartographer_node-3] [INFO] [1763038681.866925744] [cartographer logger]: I1113 20:58:01.000000 19255 configuration_file_resolver.cc:41] Found '/opt/ros/humble/share/cartographer/configuration_files/trajectory_builder.lua' for 'trajectory_builder.lua'. [cartographer_node-3] [INFO] [1763038681.866931863] [cartographer logger]: I1113 20:58:01.000000 19255 configuration_file_resolver.cc:41] Found '/opt/ros/humble/share/cartographer/configuration_files/trajectory_builder.lua' for 'trajectory_builder.lua'. [cartographer_node-3] [INFO] [1763038681.866948391] [cartographer logger]: I1113 20:58:01.000000 19255 configuration_file_resolver.cc:41] Found '/opt/ros/humble/share/cartographer/configuration_files/trajectory_builder_2d.lua' for 'trajectory_builder_2d.lua'. [cartographer_node-3] [INFO] [1763038681.866953836] [cartographer logger]: I1113 20:58:01.000000 19255 configuration_file_resolver.cc:41] Found '/opt/ros/humble/share/cartographer/configuration_files/trajectory_builder_2d.lua' for 'trajectory_builder_2d.lua'. [cartographer_node-3] [INFO] [1763038681.867004255] [cartographer logger]: I1113 20:58:01.000000 19255 configuration_file_resolver.cc:41] Found '/opt/ros/humble/share/cartographer/configuration_files/trajectory_builder_3d.lua' for 'trajectory_builder_3d.lua'. [cartographer_node-3] [INFO] [1763038681.867010139] [cartographer logger]: I1113 20:58:01.000000 19255 configuration_file_resolver.cc:41] Found '/opt/ros/humble/share/cartographer/configuration_files/trajectory_builder_3d.lua' for 'trajectory_builder_3d.lua'. [cartographer_node-3] F1113 20:58:01.867271 19255 lua_parameter_dictionary.cc:399] Check failed: HasKey(key) Key 'rangefinder_sampling_ratio' not in dictionary: [cartographer_node-3] { [cartographer_node-3] lookup_transform_timeout_sec = 0.200000, [cartographer_node-3] map_builder = { [cartographer_node-3] collate_by_trajectory = false, [cartographer_node-3] num_background_threads = 4.000000, [cartographer_node-3] pose_graph = { [cartographer_node-3] constraint_builder = { [cartographer_node-3] ceres_scan_matcher = { [cartographer_node-3] ceres_solver_options = { [cartographer_node-3] max_num_iterations = 10.000000, [cartographer_node-3] num_threads = 1.000000, [cartographer_node-3] use_nonmonotonic_steps = true, [cartographer_node-3] }, [cartographer_node-3] occupied_space_weight = 20.000000, [cartographer_node-3] rotation_weight = 1.000000, [cartographer_node-3] translation_weight = 10.000000, [cartographer_node-3] }, [cartographer_node-3] ceres_scan_matcher_3d = { [cartographer_node-3] ceres_solver_options = { [cartographer_node-3] max_num_iterations = 10.000000, [cartographer_node-3] num_threads = 1.000000, [cartographer_node-3] use_nonmonotonic_steps = false, [cartographer_node-3] }, [cartographer_node-3] occupied_space_weight_0 = 5.000000, [cartographer_node-3] occupied_space_weight_1 = 30.000000, [cartographer_node-3] only_optimize_yaw = false, [cartographer_node-3] rotation_weight = 1.000000, [cartographer_node-3] translation_weight = 10.000000, [cartographer_node-3] }, [cartographer_node-3] fast_correlative_scan_matcher = { [cartographer_node-3] angular_search_window = 0.523599, [cartographer_node-3] branch_and_bound_depth = 7.000000, [cartographer_node-3] linear_search_window = 7.000000, [cartographer_node-3] }, [cartographer_node-3] fast_correlative_scan_matcher_3d = { [cartographer_node-3] angular_search_window = 0.261799, [cartographer_node-3] branch_and_bound_depth = 8.000000, [cartographer_node-3] full_resolution_depth = 3.000000, [cartographer_node-3] linear_xy_search_window = 5.000000, [cartographer_node-3] linear_z_search_window = 1.000000, [cartographer_node-3] min_low_resolution_score = 0.550000, [cartographer_node-3] min_rotational_score = 0.770000, [cartographer_node-3] }, [cartographer_node-3] global_localization_min_score = 0.600000, [cartographer_node-3] log_matches = true, [cartographer_node-3] loop_closure_rotation_weight = 100000.000000, [cartographer_node-3] loop_closure_translation_weight = 11000.000000, [cartographer_node-3] max_constraint_distance = 15.000000, [cartographer_node-3] min_score = 0.650000, [cartographer_node-3] sampling_ratio = 0.300000, [cartographer_node-3] }, [cartographer_node-3] global_constraint_search_after_n_seconds = 10.000000, [cartographer_node-3] global_sampling_ratio = 0.003000, [cartographer_node-3] log_residual_histograms = true, [cartographer_node-3] matcher_rotation_weight = 1600.000000, [cartographer_node-3] matcher_translation_weight = 500.000000, [cartographer_node-3] max_num_final_iterations = 200.000000, [cartographer_node-3] optimization_problem = { [cartographer_node-3] acceleration_weight = 110.000000, [cartographer_node-3] ceres_solver_options = { [cartographer_node-3] max_num_iterations = 50.000000, [cartographer_node-3] num_threads = 7.000000, [cartographer_node-3] use_nonmonotonic_steps = false, [cartographer_node-3] }, [cartographer_node-3] fix_z_in_3d = false, [cartographer_node-3] fixed_frame_pose_rotation_weight = 100.000000, [cartographer_node-3] fixed_frame_pose_tolerant_loss_param_a = 1.000000, [cartographer_node-3] fixed_frame_pose_tolerant_loss_param_b = 1.000000, [cartographer_node-3] fixed_frame_pose_translation_weight = 10.000000, [cartographer_node-3] fixed_frame_pose_use_tolerant_loss = false, [cartographer_node-3] huber_scale = 100.000000, [cartographer_node-3] local_slam_pose_rotation_weight = 100000.000000, [cartographer_node-3] local_slam_pose_translation_weight = 100000.000000, [cartographer_node-3] log_solver_summary = false, [cartographer_node-3] odometry_rotation_weight = 100000.000000, [cartographer_node-3] odometry_translation_weight = 100000.000000, [cartographer_node-3] rotation_weight = 16000.000000, [cartographer_node-3] use_online_imu_extrinsics_in_3d = true, [cartographer_node-3] }, [cartographer_node-3] optimize_every_n_nodes = 35.000000, [cartographer_node-3] }, [cartographer_node-3] use_trajectory_builder_2d = true, [cartographer_node-3] use_trajectory_builder_3d = false, [cartographer_node-3] }, [cartographer_node-3] map_frame = "map", [cartographer_node-3] num_laser_scans = 1.000000, [cartographer_node-3] num_multi_echo_laser_scans = 0.000000, [cartographer_node-3] num_point_clouds = 0.000000, [cartographer_node-3] num_subdivisions_per_laser_scan = 1.000000, [cartographer_node-3] odom_frame = "odom", [cartographer_node-3] pose_publish_period_sec = 0.005000, [cartographer_node-3] provide_odom_frame = false, [cartographer_node-3] publish_frame_projected_to_2d = false, [cartographer_node-3] published_frame = "laser", [cartographer_node-3] submap_publish_period_sec = 0.300000, [cartographer_node-3] tracking_frame = "laser", [cartographer_node-3] trajectory_builder = { [cartographer_node-3] collate_fixed_frame = true, [cartographer_node-3] collate_landmarks = false, [cartographer_node-3] trajectory_builder_2d = { [cartographer_node-3] adaptive_voxel_filter = { [cartographer_node-3] max_length = 0.500000, [cartographer_node-3] max_range = 50.000000, [cartographer_node-3] min_num_points = 200.000000, [cartographer_node-3] }, [cartographer_node-3] ceres_scan_matcher = { [cartographer_node-3] ceres_solver_options = { [cartographer_node-3] max_num_iterations = 20.000000, [cartographer_node-3] num_threads = 1.000000, [cartographer_node-3] use_nonmonotonic_steps = false, [cartographer_node-3] }, [cartographer_node-3] occupied_space_weight = 1.000000, [cartographer_node-3] rotation_weight = 40.000000, [cartographer_node-3] translation_weight = 10.000000, [cartographer_node-3] }, [cartographer_node-3] imu_gravity_time_constant = 10.000000, [cartographer_node-3] loop_closure_adaptive_voxel_filter = { [cartographer_node-3] max_length = 0.900000, [cartographer_node-3] max_range = 50.000000, [cartographer_node-3] min_num_points = 100.000000, [cartographer_node-3] }, [cartographer_node-3] max_range = 12.000000, [cartographer_node-3] max_z = 2.000000, [cartographer_node-3] min_range = 0.100000, [cartographer_node-3] min_z = -0.800000, [cartographer_node-3] missing_data_ray_length = 5.000000, [cartographer_node-3] motion_filter = { [cartographer_node-3] max_angle_radians = 0.017453, [cartographer_node-3] max_distance_meters = 0.200000, [cartographer_node-3] max_time_seconds = 5.000000, [cartographer_node-3] }, [cartographer_node-3] num_accumulated_range_data = 1.000000, [cartographer_node-3] pose_extrapolator = { [cartographer_node-3] constant_velocity = { [cartographer_node-3] imu_gravity_time_constant = 10.000000, [cartographer_node-3] pose_queue_duration = 0.001000, [cartographer_node-3] }, [cartographer_node-3] imu_based = { [cartographer_node-3] gravity_constant = 9.806000, [cartographer_node-3] imu_acceleration_weight = 1.000000, [cartographer_node-3] imu_rotation_weight = 1.000000, [cartographer_node-3] odometry_rotation_weight = 1.000000, [cartographer_node-3] odometry_translation_weight = 1.000000, [cartographer_node-3] pose_queue_duration = 5.000000, [cartographer_node-3] pose_rotation_weight = 1.000000, [cartographer_node-3] pose_translation_weight = 1.000000, [cartographer_node-3] solver_options = { [cartographer_node-3] max_num_iterations = 10.000000, [cartographer_node-3] num_threads = 1.000000, [cartographer_node-3] use_nonmonotonic_steps = false, [cartographer_node-3] }, [cartographer_node-3] }, [cartographer_node-3] use_imu_based = false, [cartographer_node-3] }, [cartographer_node-3] real_time_correlative_scan_matcher = { [cartographer_node-3] angular_search_window = 0.349066, [cartographer_node-3] linear_search_window = 0.100000, [cartographer_node-3] rotation_delta_cost_weight = 0.100000, [cartographer_node-3] translation_delta_cost_weight = 10.000000, [cartographer_node-3] }, [cartographer_node-3] submaps = { [cartographer_node-3] grid_options_2d = { [cartographer_node-3] grid_type = "PROBABILITY_GRID", [cartographer_node-3] resolution = 0.050000, [cartographer_node-3] }, [cartographer_node-3] num_range_data = 35.000000, [cartographer_node-3] range_data_inserter = { [cartographer_node-3] probability_grid_range_data_inserter = { [cartographer_node-3] hit_probability = 0.550000, [cartographer_node-3] insert_free_space = true, [cartographer_node-3] miss_probability = 0.490000, [cartographer_node-3] }, [cartographer_node-3] range_data_inserter_type = "PROBABILITY_GRID_INSERTER_2D", [cartographer_node-3] tsdf_range_data_inserter = { [cartographer_node-3] maximum_weight = 10.000000, [cartographer_node-3] normal_estimation_options = { [cartographer_node-3] num_normal_samples = 4.000000, [cartographer_node-3] sample_radius = 0.500000, [cartographer_node-3] }, [cartographer_node-3] project_sdf_distance_to_scan_normal = true, [cartographer_node-3] truncation_distance = 0.300000, [cartographer_node-3] update_free_space = false, [cartographer_node-3] update_weight_angle_scan_normal_to_ray_kernel_bandwidth = 0.500000, [cartographer_node-3] update_weight_distance_cell_to_hit_kernel_bandwidth = 0.500000, [cartographer_node-3] update_weight_range_exponent = 0.000000, [cartographer_node-3] }, [cartographer_node-3] }, [cartographer_node-3] }, [cartographer_node-3] use_imu_data = false, [cartographer_node-3] use_online_correlative_scan_matching = true, [cartographer_node-3] voxel_filter_size = 0.025000, [cartographer_node-3] }, [cartographer_node-3] trajectory_builder_3d = { [cartographer_node-3] ceres_scan_matcher = { [cartographer_node-3] ceres_solver_options = { [cartographer_node-3] max_num_iterations = 12.000000, [cartographer_node-3] num_threads = 1.000000, [cartographer_node-3] use_nonmonotonic_steps = false, [cartographer_node-3] }, [cartographer_node-3] intensity_cost_function_options_0 = { [cartographer_node-3] huber_scale = 0.300000, [cartographer_node-3] intensity_threshold = 40.000000, [cartographer_node-3] weight = 0.500000, [cartographer_node-3] }, [cartographer_node-3] occupied_space_weight_0 = 1.000000, [cartographer_node-3] occupied_space_weight_1 = 6.000000, [cartographer_node-3] only_optimize_yaw = false, [cartographer_node-3] rotation_weight = 400.000000, [cartographer_node-3] translation_weight = 5.000000, [cartographer_node-3] }, [cartographer_node-3] high_resolution_adaptive_voxel_filter = { [cartographer_node-3] max_length = 2.000000, [cartographer_node-3] max_range = 15.000000, [cartographer_node-3] min_num_points = 150.000000, [cartographer_node-3] }, [cartographer_node-3] imu_gravity_time_constant = 10.000000, [cartographer_node-3] low_resolution_adaptive_voxel_filter = { [cartographer_node-3] max_length = 4.000000, [cartographer_node-3] max_range = 60.000000, [cartographer_node-3] min_num_points = 200.000000, [cartographer_node-3] }, [cartographer_node-3] max_range = 60.000000, [cartographer_node-3] min_range = 1.000000, [cartographer_node-3] motion_filter = { [cartographer_node-3] max_angle_radians = 0.004000, [cartographer_node-3] max_distance_meters = 0.100000, [cartographer_node-3] max_time_seconds = 0.500000, [cartographer_node-3] }, [cartographer_node-3] num_accumulated_range_data = 1.000000, [cartographer_node-3] pose_extrapolator = { [cartographer_node-3] constant_velocity = { [cartographer_node-3] imu_gravity_time_constant = 10.000000, [cartographer_node-3] pose_queue_duration = 0.001000, [cartographer_node-3] }, [cartographer_node-3] imu_based = { [cartographer_node-3] gravity_constant = 9.806000, [cartographer_node-3] imu_acceleration_weight = 1.000000, [cartographer_node-3] imu_rotation_weight = 1.000000, [cartographer_node-3] odometry_rotation_weight = 1.000000, [cartographer_node-3] odometry_translation_weight = 1.000000, [cartographer_node-3] pose_queue_duration = 5.000000, [cartographer_node-3] pose_rotation_weight = 1.000000, [cartographer_node-3] pose_translation_weight = 1.000000, [cartographer_node-3] solver_options = { [cartographer_node-3] max_num_iterations = 10.000000, [cartographer_node-3] num_threads = 1.000000, [cartographer_node-3] use_nonmonotonic_steps = false, [cartographer_node-3] }, [cartographer_node-3] }, [cartographer_node-3] use_imu_based = false, [cartographer_node-3] }, [cartographer_node-3] real_time_correlative_scan_matcher = { [cartographer_node-3] angular_search_window = 0.017453, [cartographer_node-3] linear_search_window = 0.150000, [cartographer_node-3] rotation_delta_cost_weight = 0.100000, [cartographer_node-3] translation_delta_cost_weight = 0.100000, [cartographer_node-3] }, [cartographer_node-3] rotational_histogram_size = 120.000000, [cartographer_node-3] submaps = { [cartographer_node-3] high_resolution = 0.100000, [cartographer_node-3] high_resolution_max_range = 20.000000, [cartographer_node-3] low_resolution = 0.450000, [cartographer_node-3] num_range_data = 160.000000, [cartographer_node-3] range_data_inserter = { [cartographer_node-3] hit_probability = 0.550000, [cartographer_node-3] intensity_threshold = 40.000000, [cartographer_node-3] miss_probability = 0.490000, [cartographer_node-3] num_free_space_voxels = 2.000000, [cartographer_node-3] }, [cartographer_node-3] }, [cartographer_node-3] use_intensities = false, [cartographer_node-3] use_online_correlative_scan_matching = false, [cartographer_node-3] voxel_filter_size = 0.150000, [cartographer_node-3] }, [cartographer_node-3] }, [cartographer_node-3] trajectory_publish_period_sec = 0.030000, [cartographer_node-3] use_landmarks = false, [cartographer_node-3] use_nav_sat = false, [cartographer_node-3] use_odometry = false, [cartographer_node-3] use_pose_extrapolator = false, [cartographer_node-3] } [cartographer_node-3] [FATAL] [1763038681.867573928] [cartographer logger]: F1113 20:58:01.000000 19255 lua_parameter_dictionary.cc:399] Check failed: HasKey(key) Key 'rangefinder_sampling_ratio' not in dictionary: [cartographer_node-3] { [cartographer_node-3] lookup_transform_timeout_sec = 0.200000, [cartographer_node-3] map_builder = { [cartographer_node-3] collate_by_trajectory = false, [cartographer_node-3] num_background_threads = 4.000000, [cartographer_node-3] pose_graph = { [cartographer_node-3] constraint_builder = { [cartographer_node-3] ceres_scan_matcher = { [cartographer_node-3] ceres_solver_options = { [cartographer_node-3] max_num_iterations = 10.000000, [cartographer_node-3] num_threads = 1.000000, [cartographer_node-3] use_nonmonotonic_steps = true, [cartographer_node-3] }, [cartographer_node-3] occupied_space_weight = 20.000000, [cartographer_node-3] rotation_weight = 1.000000, [cartographer_node-3] translation_weight = 10.000000, [cartographer_node-3] }, [cartographer_node-3] ceres_scan_matcher_3d = { [cartographer_node-3] ceres_solver_options = { [cartographer_node-3] max_num_iterations = 10.000000, [cartographer_node-3] num_threads = 1.000000, [cartographer_node-3] use_nonmonotonic_steps = false, [cartographer_node-3] }, [cartographer_node-3] occupied_space_weight_0 = 5.000000, [cartographer_node-3] occupied_space_weight_1 = 30.000000, [cartographer_node-3] only_optimize_yaw = false, [cartographer_node-3] rotation_weight = 1.000000, [cartographer_node-3] translation_weight = 10.000000, [cartographer_node-3] }, [cartographer_node-3] fast_correlative_scan_matcher = { [cartographer_node-3] angular_search_window = 0.523599, [cartographer_node-3] branch_and_bound_depth = 7.000000, [cartographer_node-3] linear_search_window = 7.000000, [cartographer_node-3] }, [cartographer_node-3] fast_correlative_scan_matcher_3d = { [cartographer_node-3] angular_search_window = 0.261799, [cartographer_node-3] branch_and_bound_depth = 8.000000, [cartographer_node-3] full_resolution_depth = 3.000000, [cartographer_node-3] linear_xy_search_window = 5.000000, [cartographer_node-3] linear_z_search_window = 1.000000, [cartographer_node-3] min_low_resolution_score = 0.550000, [cartographer_node-3] min_rotational_score = 0.770000, [cartographer_node-3] }, [cartographer_node-3] global_localization_min_score = 0.600000, [cartographer_node-3] log_matches = true, [cartographer_node-3] loop_closure_rotation_weight = 100000.000000, [cartographer_node-3] loop_closure_translation_weight = 11000.000000, [cartographer_node-3] max_constraint_distance = 15.000000, [cartographer_node-3] min_score = 0.650000, [cartographer_node-3] sampling_ratio = 0.300000, [cartographer_node-3] }, [cartographer_node-3] global_constraint_search_after_n_seconds = 10.000000, [cartographer_node-3] global_sampling_ratio = 0.003000, [cartographer_node-3] log_residual_histograms = true, [cartographer_node-3] matcher_rotation_weight = 1600.000000, [cartographer_node-3] matcher_translation_weight = 500.000000, [cartographer_node-3] max_num_final_iterations = 200.000000, [cartographer_node-3] optimization_problem = { [cartographer_node-3] acceleration_weight = 110.000000, [cartographer_node-3] ceres_solver_options = { [cartographer_node-3] max_num_iterations = 50.000000, [cartographer_node-3] num_threads = 7.000000, [cartographer_node-3] use_nonmonotonic_steps = false, [cartographer_node-3] }, [cartographer_node-3] fix_z_in_3d = false, [cartographer_node-3] fixed_frame_pose_rotation_weight = 100.000000, [cartographer_node-3] fixed_frame_pose_tolerant_loss_param_a = 1.000000, [cartographer_node-3] fixed_frame_pose_tolerant_loss_param_b = 1.000000, [cartographer_node-3] fixed_frame_pose_translation_weight = 10.000000, [cartographer_node-3] fixed_frame_pose_use_tolerant_loss = false, [cartographer_node-3] huber_scale = 100.000000, [cartographer_node-3] local_slam_pose_rotation_weight = 100000.000000, [cartographer_node-3] local_slam_pose_translation_weight = 100000.000000, [cartographer_node-3] log_solver_summary = false, [cartographer_node-3] odometry_rotation_weight = 100000.000000, [cartographer_node-3] odometry_translation_weight = 100000.000000, [cartographer_node-3] rotation_weight = 16000.000000, [cartographer_node-3] use_online_imu_extrinsics_in_3d = true, [cartographer_node-3] }, [cartographer_node-3] optimize_every_n_nodes = 35.000000, [cartographer_node-3] }, [cartographer_node-3] use_trajectory_builder_2d = true, [cartographer_node-3] use_trajectory_builder_3d = false, [cartographer_node-3] }, [cartographer_node-3] map_frame = "map", [cartographer_node-3] num_laser_scans = 1.000000, [cartographer_node-3] num_multi_echo_laser_scans = 0.000000, [cartographer_node-3] num_point_clouds = 0.000000, [cartographer_node-3] num_subdivisions_per_laser_scan = 1.000000, [cartographer_node-3] odom_frame = "odom", [cartographer_node-3] pose_publish_period_sec = 0.005000, [cartographer_node-3] provide_odom_frame = false, [cartographer_node-3] publish_frame_projected_to_2d = false, [cartographer_node-3] published_frame = "laser", [cartographer_node-3] submap_publish_period_sec = 0.300000, [cartographer_node-3] tracking_frame = "laser", [cartographer_node-3] trajectory_builder = { [cartographer_node-3] collate_fixed_frame = true, [cartographer_node-3] collate_landmarks = false, [cartographer_node-3] trajectory_builder_2d = { [cartographer_node-3] adaptive_voxel_filter = { [cartographer_node-3] max_length = 0.500000, [cartographer_node-3] max_range = 50.000000, [cartographer_node-3] min_num_points = 200.000000, [cartographer_node-3] }, [cartographer_node-3] ceres_scan_matcher = { [cartographer_node-3] ceres_solver_options = { [cartographer_node-3] max_num_iterations = 20.000000, [cartographer_node-3] num_threads = 1.000000, [cartographer_node-3] use_nonmonotonic_steps = false, [cartographer_node-3] }, [cartographer_node-3] occupied_space_weight = 1.000000, [cartographer_node-3] rotation_weight = 40.000000, [cartographer_node-3] translation_weight = 10.000000, [cartographer_node-3] }, [cartographer_node-3] imu_gravity_time_constant = 10.000000, [cartographer_node-3] loop_closure_adaptive_voxel_filter = { [cartographer_node-3] max_length = 0.900000, [cartographer_node-3] max_range = 50.000000, [cartographer_node-3] min_num_points = 100.000000, [cartographer_node-3] }, [cartographer_node-3] max_range = 12.000000, [cartographer_node-3] max_z = 2.000000, [cartographer_node-3] min_range = 0.100000, [cartographer_node-3] min_z = -0.800000, [cartographer_node-3] missing_data_ray_length = 5.000000, [cartographer_node-3] motion_filter = { [cartographer_node-3] max_angle_radians = 0.017453, [cartographer_node-3] max_distance_meters = 0.200000, [cartographer_node-3] max_time_seconds = 5.000000, [cartographer_node-3] }, [cartographer_node-3] num_accumulated_range_data = 1.000000, [cartographer_node-3] pose_extrapolator = { [cartographer_node-3] constant_velocity = { [cartographer_node-3] imu_gravity_time_constant = 10.000000, [cartographer_node-3] pose_queue_duration = 0.001000, [cartographer_node-3] }, [cartographer_node-3] imu_based = { [cartographer_node-3] gravity_constant = 9.806000, [cartographer_node-3] imu_acceleration_weight = 1.000000, [cartographer_node-3] imu_rotation_weight = 1.000000, [cartographer_node-3] odometry_rotation_weight = 1.000000, [cartographer_node-3] odometry_translation_weight = 1.000000, [cartographer_node-3] pose_queue_duration = 5.000000, [cartographer_node-3] pose_rotation_weight = 1.000000, [cartographer_node-3] pose_translation_weight = 1.000000, [cartographer_node-3] solver_options = { [cartographer_node-3] max_num_iterations = 10.000000, [cartographer_node-3] num_threads = 1.000000, [cartographer_node-3] use_nonmonotonic_steps = false, [cartographer_node-3] }, [cartographer_node-3] }, [cartographer_node-3] use_imu_based = false, [cartographer_node-3] }, [cartographer_node-3] real_time_correlative_scan_matcher = { [cartographer_node-3] angular_search_window = 0.349066, [cartographer_node-3] linear_search_window = 0.100000, [cartographer_node-3] rotation_delta_cost_weight = 0.100000, [cartographer_node-3] translation_delta_cost_weight = 10.000000, [cartographer_node-3] }, [cartographer_node-3] submaps = { [cartographer_node-3] grid_options_2d = { [cartographer_node-3] grid_type = "PROBABILITY_GRID", [cartographer_node-3] resolution = 0.050000, [cartographer_node-3] }, [cartographer_node-3] num_range_data = 35.000000, [cartographer_node-3] range_data_inserter = { [cartographer_node-3] probability_grid_range_data_inserter = { [cartographer_node-3] hit_probability = 0.550000, [cartographer_node-3] insert_free_space = true, [cartographer_node-3] miss_probability = 0.490000, [cartographer_node-3] }, [cartographer_node-3] range_data_inserter_type = "PROBABILITY_GRID_INSERTER_2D", [cartographer_node-3] tsdf_range_data_inserter = { [cartographer_node-3] maximum_weight = 10.000000, [cartographer_node-3] normal_estimation_options = { [cartographer_node-3] num_normal_samples = 4.000000, [cartographer_node-3] sample_radius = 0.500000, [cartographer_node-3] }, [cartographer_node-3] project_sdf_distance_to_scan_normal = true, [cartographer_node-3] truncation_distance = 0.300000, [cartographer_node-3] update_free_space = false, [cartographer_node-3] update_weight_angle_scan_normal_to_ray_kernel_bandwidth = 0.500000, [cartographer_node-3] update_weight_distance_cell_to_hit_kernel_bandwidth = 0.500000, [cartographer_node-3] update_weight_range_exponent = 0.000000, [cartographer_node-3] }, [cartographer_node-3] }, [cartographer_node-3] }, [cartographer_node-3] use_imu_data = false, [cartographer_node-3] use_online_correlative_scan_matching = true, [cartographer_node-3] voxel_filter_size = 0.025000, [cartographer_node-3] }, [cartographer_node-3] trajectory_builder_3d = { [cartographer_node-3] ceres_scan_matcher = { [cartographer_node-3] ceres_solver_options = { [cartographer_node-3] max_num_iterations = 12.000000, [cartographer_node-3] num_threads = 1.000000, [cartographer_node-3] use_nonmonotonic_steps = false, [cartographer_node-3] }, [cartographer_node-3] intensity_cost_function_options_0 = { [cartographer_node-3] huber_scale = 0.300000, [cartographer_node-3] intensity_threshold = 40.000000, [cartographer_node-3] weight = 0.500000, [cartographer_node-3] }, [cartographer_node-3] occupied_space_weight_0 = 1.000000, [cartographer_node-3] occupied_space_weight_1 = 6.000000, [cartographer_node-3] only_optimize_yaw = false, [cartographer_node-3] rotation_weight = 400.000000, [cartographer_node-3] translation_weight = 5.000000, [cartographer_node-3] }, [cartographer_node-3] high_resolution_adaptive_voxel_filter = { [cartographer_node-3] max_length = 2.000000, [cartographer_node-3] max_range = 15.000000, [cartographer_node-3] min_num_points = 150.000000, [cartographer_node-3] }, [cartographer_node-3] imu_gravity_time_constant = 10.000000, [cartographer_node-3] low_resolution_adaptive_voxel_filter = { [cartographer_node-3] max_length = 4.000000, [cartographer_node-3] max_range = 60.000000, [cartographer_node-3] min_num_points = 200.000000, [cartographer_node-3] }, [cartographer_node-3] max_range = 60.000000, [cartographer_node-3] min_range = 1.000000, [cartographer_node-3] motion_filter = { [cartographer_node-3] max_angle_radians = 0.004000, [cartographer_node-3] max_distance_meters = 0.100000, [cartographer_node-3] max_time_seconds = 0.500000, [cartographer_node-3] }, [cartographer_node-3] num_accumulated_range_data = 1.000000, [cartographer_node-3] pose_extrapolator = { [cartographer_node-3] constant_velocity = { [cartographer_node-3] imu_gravity_time_constant = 10.000000, [cartographer_node-3] pose_queue_duration = 0.001000, [cartographer_node-3] }, [cartographer_node-3] imu_based = { [cartographer_node-3] gravity_constant = 9.806000, [cartographer_node-3] imu_acceleration_weight = 1.000000, [cartographer_node-3] imu_rotation_weight = 1.000000, [cartographer_node-3] odometry_rotation_weight = 1.000000, [cartographer_node-3] odometry_translation_weight = 1.000000, [cartographer_node-3] pose_queue_duration = 5.000000, [cartographer_node-3] pose_rotation_weight = 1.000000, [cartographer_node-3] pose_translation_weight = 1.000000, [cartographer_node-3] solver_options = { [cartographer_node-3] max_num_iterations = 10.000000, [cartographer_node-3] num_threads = 1.000000, [cartographer_node-3] use_nonmonotonic_steps = false, [cartographer_node-3] }, [cartographer_node-3] }, [cartographer_node-3] use_imu_based = false, [cartographer_node-3] }, [cartographer_node-3] real_time_correlative_scan_matcher = { [cartographer_node-3] angular_search_window = 0.017453, [cartographer_node-3] linear_search_window = 0.150000, [cartographer_node-3] rotation_delta_cost_weight = 0.100000, [cartographer_node-3] translation_delta_cost_weight = 0.100000, [cartographer_node-3] }, [cartographer_node-3] rotational_histogram_size = 120.000000, [cartographer_node-3] submaps = { [cartographer_node-3] high_resolution = 0.100000, [cartographer_node-3] high_resolution_max_range = 20.000000, [cartographer_node-3] low_resolution = 0.450000, [cartographer_node-3] num_range_data = 160.000000, [cartographer_node-3] range_data_inserter = { [cartographer_node-3] hit_probability = 0.550000, [cartographer_node-3] intensity_threshold = 40.000000, [cartographer_node-3] miss_probability = 0.490000, [cartographer_node-3] num_free_space_voxels = 2.000000, [cartographer_node-3] }, [cartographer_node-3] }, [cartographer_node-3] use_intensities = false, [cartographer_node-3] use_online_correlative_scan_matching = false, [cartographer_node-3] voxel_filter_size = 0.150000, [cartographer_node-3] }, [cartographer_node-3] }, [cartographer_node-3] trajectory_publish_period_sec = 0.030000, [cartographer_node-3] use_landmarks = false, [cartographer_node-3] use_nav_sat = false, [cartographer_node-3] use_odometry = false, [cartographer_node-3] use_pose_extrapolator = false, [cartographer_node-3] } [cartographer_node-3] *** Check failure stack trace: *** [cartographer_node-3] @ 0x70013805eb03 google::LogMessage::Fail() [cartographer_node-3] @ 0x7001380669d1 google::LogMessage::SendToLog() [cartographer_node-3] @ 0x70013805e7c2 google::LogMessage::Flush() [cartographer_node-3] @ 0x70013806078f google::LogMessageFatal::~LogMessageFatal() [cartographer_node-3] @ 0x6244d3d20ce7 (unknown) [cartographer_node-3] @ 0x6244d3d20d66 (unknown) [cartographer_node-3] @ 0x6244d3d20ff3 (unknown) [cartographer_node-3] @ 0x6244d3d071d4 (unknown) [cartographer_node-3] @ 0x6244d3c6d7b3 (unknown) [cartographer_node-3] @ 0x700137029d90 (unknown) [cartographer_node-3] @ 0x700137029e40 __libc_start_main [cartographer_node-3] @ 0x6244d3c70d35 (unknown) [ERROR] [cartographer_node-3]: process has died [pid 19255, exit code -6, cmd '/opt/ros/humble/lib/cartographer_ros/cartographer_node -configuration_directory /home/michael/ros2_ws/install/ldlidar-ros2/share/ldlidar-ros2/configuration_files -configuration_basename mylaser.lua --ros-args --params-file /tmp/launch_params_5v_a720m -r scan:=scan'].
最新发布
11-14
[INFO] [launch]: Default logging verbosity is set to INFO [INFO] [ldlidar-1]: process started with pid [15427] [INFO] [static_transform_publisher-2]: process started with pid [15429] [INFO] [cartographer_node-3]: process started with pid [15431] [INFO] [cartographer_occupancy_grid_node-4]: process started with pid [15433] [ldlidar-1] [INFO] [1763038059.187611175] [rclcpp]: Using port /dev/ttyUSB0 [ldlidar-1] [INFO] [1763038059.187726982] [rclcpp]: LiDAR_LD06 started successfully [static_transform_publisher-2] [INFO] [1763038059.188207187] [static_transform_publisher_ftaCOqre9ghey78j]: Spinning until stopped - publishing transform [static_transform_publisher-2] translation: ('0.000000', '0.000000', '0.000000') [static_transform_publisher-2] rotation: ('0.000000', '0.000000', '0.000000', '1.000000') [static_transform_publisher-2] from 'base_link' to 'laser' [cartographer_node-3] [INFO] [1763038059.199601261] [cartographer logger]: I1113 20:47:39.000000 15431 configuration_file_resolver.cc:41] Found '/home/michael/ros2_ws/install/ldlidar-ros2/share/ldlidar-ros2/configuration_files/mylaser.lua' for 'mylaser.lua'. [cartographer_node-3] [INFO] [1763038059.200177820] [cartographer logger]: I1113 20:47:39.000000 15431 configuration_file_resolver.cc:41] Found '/opt/ros/humble/share/cartographer/configuration_files/map_builder.lua' for 'map_builder.lua'. [cartographer_node-3] [INFO] [1763038059.200197413] [cartographer logger]: I1113 20:47:39.000000 15431 configuration_file_resolver.cc:41] Found '/opt/ros/humble/share/cartographer/configuration_files/map_builder.lua' for 'map_builder.lua'. [cartographer_node-3] [INFO] [1763038059.200339857] [cartographer logger]: I1113 20:47:39.000000 15431 configuration_file_resolver.cc:41] Found '/opt/ros/humble/share/cartographer/configuration_files/pose_graph.lua' for 'pose_graph.lua'. [cartographer_node-3] [INFO] [1763038059.200346358] [cartographer logger]: I1113 20:47:39.000000 15431 configuration_file_resolver.cc:41] Found '/opt/ros/humble/share/cartographer/configuration_files/pose_graph.lua' for 'pose_graph.lua'. [cartographer_node-3] [INFO] [1763038059.200466435] [cartographer logger]: I1113 20:47:39.000000 15431 configuration_file_resolver.cc:41] Found '/opt/ros/humble/share/cartographer/configuration_files/trajectory_builder.lua' for 'trajectory_builder.lua'. [cartographer_node-3] [INFO] [1763038059.200473333] [cartographer logger]: I1113 20:47:39.000000 15431 configuration_file_resolver.cc:41] Found '/opt/ros/humble/share/cartographer/configuration_files/trajectory_builder.lua' for 'trajectory_builder.lua'. [cartographer_node-3] [INFO] [1763038059.200556552] [cartographer logger]: I1113 20:47:39.000000 15431 configuration_file_resolver.cc:41] Found '/opt/ros/humble/share/cartographer/configuration_files/trajectory_builder_2d.lua' for 'trajectory_builder_2d.lua'. [cartographer_node-3] [INFO] [1763038059.200562403] [cartographer logger]: I1113 20:47:39.000000 15431 configuration_file_resolver.cc:41] Found '/opt/ros/humble/share/cartographer/configuration_files/trajectory_builder_2d.lua' for 'trajectory_builder_2d.lua'. [cartographer_node-3] [INFO] [1763038059.200685653] [cartographer logger]: I1113 20:47:39.000000 15431 configuration_file_resolver.cc:41] Found '/opt/ros/humble/share/cartographer/configuration_files/trajectory_builder_3d.lua' for 'trajectory_builder_3d.lua'. [cartographer_node-3] [INFO] [1763038059.200691488] [cartographer logger]: I1113 20:47:39.000000 15431 configuration_file_resolver.cc:41] Found '/opt/ros/humble/share/cartographer/configuration_files/trajectory_builder_3d.lua' for 'trajectory_builder_3d.lua'. [cartographer_node-3] F1113 20:47:39.201540 15431 lua_parameter_dictionary.cc:399] Check failed: HasKey(key) Key 'rangefinder_sampling_ratio' not in dictionary: [cartographer_node-3] { [cartographer_node-3] lookup_transform_timeout_sec = 0.200000, [cartographer_node-3] map_builder = { [cartographer_node-3] collate_by_trajectory = false, [cartographer_node-3] num_background_threads = 4.000000, [cartographer_node-3] pose_graph = { [cartographer_node-3] constraint_builder = { [cartographer_node-3] ceres_scan_matcher = { [cartographer_node-3] ceres_solver_options = { [cartographer_node-3] max_num_iterations = 10.000000, [cartographer_node-3] num_threads = 1.000000, [cartographer_node-3] use_nonmonotonic_steps = true, [cartographer_node-3] }, [cartographer_node-3] occupied_space_weight = 20.000000, [cartographer_node-3] rotation_weight = 1.000000, [cartographer_node-3] translation_weight = 10.000000, [cartographer_node-3] }, [cartographer_node-3] ceres_scan_matcher_3d = { [cartographer_node-3] ceres_solver_options = { [cartographer_node-3] max_num_iterations = 10.000000, [cartographer_node-3] num_threads = 1.000000, [cartographer_node-3] use_nonmonotonic_steps = false, [cartographer_node-3] }, [cartographer_node-3] occupied_space_weight_0 = 5.000000, [cartographer_node-3] occupied_space_weight_1 = 30.000000, [cartographer_node-3] only_optimize_yaw = false, [cartographer_node-3] rotation_weight = 1.000000, [cartographer_node-3] translation_weight = 10.000000, [cartographer_node-3] }, [cartographer_node-3] fast_correlative_scan_matcher = { [cartographer_node-3] angular_search_window = 0.523599, [cartographer_node-3] branch_and_bound_depth = 7.000000, [cartographer_node-3] linear_search_window = 7.000000, [cartographer_node-3] }, [cartographer_node-3] fast_correlative_scan_matcher_3d = { [cartographer_node-3] angular_search_window = 0.261799, [cartographer_node-3] branch_and_bound_depth = 8.000000, [cartographer_node-3] full_resolution_depth = 3.000000, [cartographer_node-3] linear_xy_search_window = 5.000000, [cartographer_node-3] linear_z_search_window = 1.000000, [cartographer_node-3] min_low_resolution_score = 0.550000, [cartographer_node-3] min_rotational_score = 0.770000, [cartographer_node-3] }, [cartographer_node-3] global_localization_min_score = 0.600000, [cartographer_node-3] log_matches = true, [cartographer_node-3] loop_closure_rotation_weight = 100000.000000, [cartographer_node-3] loop_closure_translation_weight = 11000.000000, [cartographer_node-3] max_constraint_distance = 15.000000, [cartographer_node-3] min_score = 0.650000, [cartographer_node-3] sampling_ratio = 0.300000, [cartographer_node-3] }, [cartographer_node-3] global_constraint_search_after_n_seconds = 10.000000, [cartographer_node-3] global_sampling_ratio = 0.003000, [cartographer_node-3] log_residual_histograms = true, [cartographer_node-3] matcher_rotation_weight = 1600.000000, [cartographer_node-3] matcher_translation_weight = 500.000000, [cartographer_node-3] max_num_final_iterations = 200.000000, [cartographer_node-3] optimization_problem = { [cartographer_node-3] acceleration_weight = 110.000000, [cartographer_node-3] ceres_solver_options = { [cartographer_node-3] max_num_iterations = 50.000000, [cartographer_node-3] num_threads = 7.000000, [cartographer_node-3] use_nonmonotonic_steps = false, [cartographer_node-3] }, [cartographer_node-3] fix_z_in_3d = false, [cartographer_node-3] fixed_frame_pose_rotation_weight = 100.000000, [cartographer_node-3] fixed_frame_pose_tolerant_loss_param_a = 1.000000, [cartographer_node-3] fixed_frame_pose_tolerant_loss_param_b = 1.000000, [cartographer_node-3] fixed_frame_pose_translation_weight = 10.000000, [cartographer_node-3] fixed_frame_pose_use_tolerant_loss = false, [cartographer_node-3] huber_scale = 100.000000, [cartographer_node-3] local_slam_pose_rotation_weight = 100000.000000, [cartographer_node-3] local_slam_pose_translation_weight = 100000.000000, [cartographer_node-3] log_solver_summary = false, [cartographer_node-3] odometry_rotation_weight = 100000.000000, [cartographer_node-3] odometry_translation_weight = 100000.000000, [cartographer_node-3] rotation_weight = 16000.000000, [cartographer_node-3] use_online_imu_extrinsics_in_3d = true, [cartographer_node-3] }, [cartographer_node-3] optimize_every_n_nodes = 35.000000, [cartographer_node-3] }, [cartographer_node-3] use_trajectory_builder_2d = true, [cartographer_node-3] use_trajectory_builder_3d = false, [cartographer_node-3] }, [cartographer_node-3] map_frame = "map", [cartographer_node-3] num_laser_scans = 1.000000, [cartographer_node-3] num_multi_echo_laser_scans = 0.000000, [cartographer_node-3] num_point_clouds = 0.000000, [cartographer_node-3] num_subdivisions_per_laser_scan = 1.000000, [cartographer_node-3] odom_frame = "odom", [cartographer_node-3] pose_publish_period_sec = 0.005000, [cartographer_node-3] provide_odom_frame = false, [cartographer_node-3] publish_frame_projected_to_2d = false, [cartographer_node-3] published_frame = "laser", [cartographer_node-3] submap_publish_period_sec = 0.300000, [cartographer_node-3] tracking_frame = "laser", [cartographer_node-3] trajectory_builder = { [cartographer_node-3] collate_fixed_frame = true, [cartographer_node-3] collate_landmarks = false, [cartographer_node-3] trajectory_builder_2d = { [cartographer_node-3] adaptive_voxel_filter = { [cartographer_node-3] max_length = 0.500000, [cartographer_node-3] max_range = 50.000000, [cartographer_node-3] min_num_points = 200.000000, [cartographer_node-3] }, [cartographer_node-3] ceres_scan_matcher = { [cartographer_node-3] ceres_solver_options = { [cartographer_node-3] max_num_iterations = 20.000000, [cartographer_node-3] num_threads = 1.000000, [cartographer_node-3] use_nonmonotonic_steps = false, [cartographer_node-3] }, [cartographer_node-3] occupied_space_weight = 1.000000, [cartographer_node-3] rotation_weight = 40.000000, [cartographer_node-3] translation_weight = 10.000000, [cartographer_node-3] }, [cartographer_node-3] imu_gravity_time_constant = 10.000000, [cartographer_node-3] loop_closure_adaptive_voxel_filter = { [cartographer_node-3] max_length = 0.900000, [cartographer_node-3] max_range = 50.000000, [cartographer_node-3] min_num_points = 100.000000, [cartographer_node-3] }, [cartographer_node-3] max_range = 12.000000, [cartographer_node-3] max_z = 2.000000, [cartographer_node-3] min_range = 0.100000, [cartographer_node-3] min_z = -0.800000, [cartographer_node-3] missing_data_ray_length = 5.000000, [cartographer_node-3] motion_filter = { [cartographer_node-3] max_angle_radians = 0.017453, [cartographer_node-3] max_distance_meters = 0.200000, [cartographer_node-3] max_time_seconds = 5.000000, [cartographer_node-3] }, [cartographer_node-3] num_accumulated_range_data = 1.000000, [cartographer_node-3] pose_extrapolator = { [cartographer_node-3] constant_velocity = { [cartographer_node-3] imu_gravity_time_constant = 10.000000, [cartographer_node-3] pose_queue_duration = 0.001000, [cartographer_node-3] }, [cartographer_node-3] imu_based = { [cartographer_node-3] gravity_constant = 9.806000, [cartographer_node-3] imu_acceleration_weight = 1.000000, [cartographer_node-3] imu_rotation_weight = 1.000000, [cartographer_node-3] odometry_rotation_weight = 1.000000, [cartographer_node-3] odometry_translation_weight = 1.000000, [cartographer_node-3] pose_queue_duration = 5.000000, [cartographer_node-3] pose_rotation_weight = 1.000000, [cartographer_node-3] pose_translation_weight = 1.000000, [cartographer_node-3] solver_options = { [cartographer_node-3] max_num_iterations = 10.000000, [cartographer_node-3] num_threads = 1.000000, [cartographer_node-3] use_nonmonotonic_steps = false, [cartographer_node-3] }, [cartographer_node-3] }, [cartographer_node-3] use_imu_based = false, [cartographer_node-3] }, [cartographer_node-3] real_time_correlative_scan_matcher = { [cartographer_node-3] angular_search_window = 0.349066, [cartographer_node-3] linear_search_window = 0.100000, [cartographer_node-3] rotation_delta_cost_weight = 0.100000, [cartographer_node-3] translation_delta_cost_weight = 10.000000, [cartographer_node-3] }, [cartographer_node-3] submaps = { [cartographer_node-3] grid_options_2d = { [cartographer_node-3] grid_type = "PROBABILITY_GRID", [cartographer_node-3] resolution = 0.050000, [cartographer_node-3] }, [cartographer_node-3] num_range_data = 35.000000, [cartographer_node-3] range_data_inserter = { [cartographer_node-3] probability_grid_range_data_inserter = { [cartographer_node-3] hit_probability = 0.550000, [cartographer_node-3] insert_free_space = true, [cartographer_node-3] miss_probability = 0.490000, [cartographer_node-3] }, [cartographer_node-3] range_data_inserter_type = "PROBABILITY_GRID_INSERTER_2D", [cartographer_node-3] tsdf_range_data_inserter = { [cartographer_node-3] maximum_weight = 10.000000, [cartographer_node-3] normal_estimation_options = { [cartographer_node-3] num_normal_samples = 4.000000, [cartographer_node-3] sample_radius = 0.500000, [cartographer_node-3] }, [cartographer_node-3] project_sdf_distance_to_scan_normal = true, [cartographer_node-3] truncation_distance = 0.300000, [cartographer_node-3] update_free_space = false, [cartographer_node-3] update_weight_angle_scan_normal_to_ray_kernel_bandwidth = 0.500000, [cartographer_node-3] update_weight_distance_cell_to_hit_kernel_bandwidth = 0.500000, [cartographer_node-3] update_weight_range_exponent = 0.000000, [cartographer_node-3] }, [cartographer_node-3] }, [cartographer_node-3] }, [cartographer_node-3] use_imu_data = false, [cartographer_node-3] use_online_correlative_scan_matching = true, [cartographer_node-3] voxel_filter_size = 0.025000, [cartographer_node-3] }, [cartographer_node-3] trajectory_builder_3d = { [cartographer_node-3] ceres_scan_matcher = { [cartographer_node-3] ceres_solver_options = { [cartographer_node-3] max_num_iterations = 12.000000, [cartographer_node-3] num_threads = 1.000000, [cartographer_node-3] use_nonmonotonic_steps = false, [cartographer_node-3] }, [cartographer_node-3] intensity_cost_function_options_0 = { [cartographer_node-3] huber_scale = 0.300000, [cartographer_node-3] intensity_threshold = 40.000000, [cartographer_node-3] weight = 0.500000, [cartographer_node-3] }, [cartographer_node-3] occupied_space_weight_0 = 1.000000, [cartographer_node-3] occupied_space_weight_1 = 6.000000, [cartographer_node-3] only_optimize_yaw = false, [cartographer_node-3] rotation_weight = 400.000000, [cartographer_node-3] translation_weight = 5.000000, [cartographer_node-3] }, [cartographer_node-3] high_resolution_adaptive_voxel_filter = { [cartographer_node-3] max_length = 2.000000, [cartographer_node-3] max_range = 15.000000, [cartographer_node-3] min_num_points = 150.000000, [cartographer_node-3] }, [cartographer_node-3] imu_gravity_time_constant = 10.000000, [cartographer_node-3] low_resolution_adaptive_voxel_filter = { [cartographer_node-3] max_length = 4.000000, [cartographer_node-3] max_range = 60.000000, [cartographer_node-3] min_num_points = 200.000000, [cartographer_node-3] }, [cartographer_node-3] max_range = 60.000000, [cartographer_node-3] min_range = 1.000000, [cartographer_node-3] motion_filter = { [cartographer_node-3] max_angle_radians = 0.004000, [cartographer_node-3] max_distance_meters = 0.100000, [cartographer_node-3] max_time_seconds = 0.500000, [cartographer_node-3] }, [cartographer_node-3] num_accumulated_range_data = 1.000000, [cartographer_node-3] pose_extrapolator = { [cartographer_node-3] constant_velocity = { [cartographer_node-3] imu_gravity_time_constant = 10.000000, [cartographer_node-3] pose_queue_duration = 0.001000, [cartographer_node-3] }, [cartographer_node-3] imu_based = { [cartographer_node-3] gravity_constant = 9.806000, [cartographer_node-3] imu_acceleration_weight = 1.000000, [cartographer_node-3] imu_rotation_weight = 1.000000, [cartographer_node-3] odometry_rotation_weight = 1.000000, [cartographer_node-3] odometry_translation_weight = 1.000000, [cartographer_node-3] pose_queue_duration = 5.000000, [cartographer_node-3] pose_rotation_weight = 1.000000, [cartographer_node-3] pose_translation_weight = 1.000000, [cartographer_node-3] solver_options = { [cartographer_node-3] max_num_iterations = 10.000000, [cartographer_node-3] num_threads = 1.000000, [cartographer_node-3] use_nonmonotonic_steps = false, [cartographer_node-3] }, [cartographer_node-3] }, [cartographer_node-3] use_imu_based = false, [cartographer_node-3] }, [cartographer_node-3] real_time_correlative_scan_matcher = { [cartographer_node-3] angular_search_window = 0.017453, [cartographer_node-3] linear_search_window = 0.150000, [cartographer_node-3] rotation_delta_cost_weight = 0.100000, [cartographer_node-3] translation_delta_cost_weight = 0.100000, [cartographer_node-3] }, [cartographer_node-3] rotational_histogram_size = 120.000000, [cartographer_node-3] submaps = { [cartographer_node-3] high_resolution = 0.100000, [cartographer_node-3] high_resolution_max_range = 20.000000, [cartographer_node-3] low_resolution = 0.450000, [cartographer_node-3] num_range_data = 160.000000, [cartographer_node-3] range_data_inserter = { [cartographer_node-3] hit_probability = 0.550000, [cartographer_node-3] intensity_threshold = 40.000000, [cartographer_node-3] miss_probability = 0.490000, [cartographer_node-3] num_free_space_voxels = 2.000000, [cartographer_node-3] }, [cartographer_node-3] }, [cartographer_node-3] use_intensities = false, [cartographer_node-3] use_online_correlative_scan_matching = false, [cartographer_node-3] voxel_filter_size = 0.150000, [cartographer_node-3] }, [cartographer_node-3] }, [cartographer_node-3] trajectory_publish_period_sec = 0.030000, [cartographer_node-3] use_landmarks = false, [cartographer_node-3] use_nav_sat = false, [cartographer_node-3] use_odometry = false, [cartographer_node-3] use_pose_extrapolator = false, [cartographer_node-3] } [cartographer_node-3] [FATAL] [1763038059.201849458] [cartographer logger]: F1113 20:47:39.000000 15431 lua_parameter_dictionary.cc:399] Check failed: HasKey(key) Key 'rangefinder_sampling_ratio' not in dictionary: [cartographer_node-3] { [cartographer_node-3] lookup_transform_timeout_sec = 0.200000, [cartographer_node-3] map_builder = { [cartographer_node-3] collate_by_trajectory = false, [cartographer_node-3] num_background_threads = 4.000000, [cartographer_node-3] pose_graph = { [cartographer_node-3] constraint_builder = { [cartographer_node-3] ceres_scan_matcher = { [cartographer_node-3] ceres_solver_options = { [cartographer_node-3] max_num_iterations = 10.000000, [cartographer_node-3] num_threads = 1.000000, [cartographer_node-3] use_nonmonotonic_steps = true, [cartographer_node-3] }, [cartographer_node-3] occupied_space_weight = 20.000000, [cartographer_node-3] rotation_weight = 1.000000, [cartographer_node-3] translation_weight = 10.000000, [cartographer_node-3] }, [cartographer_node-3] ceres_scan_matcher_3d = { [cartographer_node-3] ceres_solver_options = { [cartographer_node-3] max_num_iterations = 10.000000, [cartographer_node-3] num_threads = 1.000000, [cartographer_node-3] use_nonmonotonic_steps = false, [cartographer_node-3] }, [cartographer_node-3] occupied_space_weight_0 = 5.000000, [cartographer_node-3] occupied_space_weight_1 = 30.000000, [cartographer_node-3] only_optimize_yaw = false, [cartographer_node-3] rotation_weight = 1.000000, [cartographer_node-3] translation_weight = 10.000000, [cartographer_node-3] }, [cartographer_node-3] fast_correlative_scan_matcher = { [cartographer_node-3] angular_search_window = 0.523599, [cartographer_node-3] branch_and_bound_depth = 7.000000, [cartographer_node-3] linear_search_window = 7.000000, [cartographer_node-3] }, [cartographer_node-3] fast_correlative_scan_matcher_3d = { [cartographer_node-3] angular_search_window = 0.261799, [cartographer_node-3] branch_and_bound_depth = 8.000000, [cartographer_node-3] full_resolution_depth = 3.000000, [cartographer_node-3] linear_xy_search_window = 5.000000, [cartographer_node-3] linear_z_search_window = 1.000000, [cartographer_node-3] min_low_resolution_score = 0.550000, [cartographer_node-3] min_rotational_score = 0.770000, [cartographer_node-3] }, [cartographer_node-3] global_localization_min_score = 0.600000, [cartographer_node-3] log_matches = true, [cartographer_node-3] loop_closure_rotation_weight = 100000.000000, [cartographer_node-3] loop_closure_translation_weight = 11000.000000, [cartographer_node-3] max_constraint_distance = 15.000000, [cartographer_node-3] min_score = 0.650000, [cartographer_node-3] sampling_ratio = 0.300000, [cartographer_node-3] }, [cartographer_node-3] global_constraint_search_after_n_seconds = 10.000000, [cartographer_node-3] global_sampling_ratio = 0.003000, [cartographer_node-3] log_residual_histograms = true, [cartographer_node-3] matcher_rotation_weight = 1600.000000, [cartographer_node-3] matcher_translation_weight = 500.000000, [cartographer_node-3] max_num_final_iterations = 200.000000, [cartographer_node-3] optimization_problem = { [cartographer_node-3] acceleration_weight = 110.000000, [cartographer_node-3] ceres_solver_options = { [cartographer_node-3] max_num_iterations = 50.000000, [cartographer_node-3] num_threads = 7.000000, [cartographer_node-3] use_nonmonotonic_steps = false, [cartographer_node-3] }, [cartographer_node-3] fix_z_in_3d = false, [cartographer_node-3] fixed_frame_pose_rotation_weight = 100.000000, [cartographer_node-3] fixed_frame_pose_tolerant_loss_param_a = 1.000000, [cartographer_node-3] fixed_frame_pose_tolerant_loss_param_b = 1.000000, [cartographer_node-3] fixed_frame_pose_translation_weight = 10.000000, [cartographer_node-3] fixed_frame_pose_use_tolerant_loss = false, [cartographer_node-3] huber_scale = 100.000000, [cartographer_node-3] local_slam_pose_rotation_weight = 100000.000000, [cartographer_node-3] local_slam_pose_translation_weight = 100000.000000, [cartographer_node-3] log_solver_summary = false, [cartographer_node-3] odometry_rotation_weight = 100000.000000, [cartographer_node-3] odometry_translation_weight = 100000.000000, [cartographer_node-3] rotation_weight = 16000.000000, [cartographer_node-3] use_online_imu_extrinsics_in_3d = true, [cartographer_node-3] }, [cartographer_node-3] optimize_every_n_nodes = 35.000000, [cartographer_node-3] }, [cartographer_node-3] use_trajectory_builder_2d = true, [cartographer_node-3] use_trajectory_builder_3d = false, [cartographer_node-3] }, [cartographer_node-3] map_frame = "map", [cartographer_node-3] num_laser_scans = 1.000000, [cartographer_node-3] num_multi_echo_laser_scans = 0.000000, [cartographer_node-3] num_point_clouds = 0.000000, [cartographer_node-3] num_subdivisions_per_laser_scan = 1.000000, [cartographer_node-3] odom_frame = "odom", [cartographer_node-3] pose_publish_period_sec = 0.005000, [cartographer_node-3] provide_odom_frame = false, [cartographer_node-3] publish_frame_projected_to_2d = false, [cartographer_node-3] published_frame = "laser", [cartographer_node-3] submap_publish_period_sec = 0.300000, [cartographer_node-3] tracking_frame = "laser", [cartographer_node-3] trajectory_builder = { [cartographer_node-3] collate_fixed_frame = true, [cartographer_node-3] collate_landmarks = false, [cartographer_node-3] trajectory_builder_2d = { [cartographer_node-3] adaptive_voxel_filter = { [cartographer_node-3] max_length = 0.500000, [cartographer_node-3] max_range = 50.000000, [cartographer_node-3] min_num_points = 200.000000, [cartographer_node-3] }, [cartographer_node-3] ceres_scan_matcher = { [cartographer_node-3] ceres_solver_options = { [cartographer_node-3] max_num_iterations = 20.000000, [cartographer_node-3] num_threads = 1.000000, [cartographer_node-3] use_nonmonotonic_steps = false, [cartographer_node-3] }, [cartographer_node-3] occupied_space_weight = 1.000000, [cartographer_node-3] rotation_weight = 40.000000, [cartographer_node-3] translation_weight = 10.000000, [cartographer_node-3] }, [cartographer_node-3] imu_gravity_time_constant = 10.000000, [cartographer_node-3] loop_closure_adaptive_voxel_filter = { [cartographer_node-3] max_length = 0.900000, [cartographer_node-3] max_range = 50.000000, [cartographer_node-3] min_num_points = 100.000000, [cartographer_node-3] }, [cartographer_node-3] max_range = 12.000000, [cartographer_node-3] max_z = 2.000000, [cartographer_node-3] min_range = 0.100000, [cartographer_node-3] min_z = -0.800000, [cartographer_node-3] missing_data_ray_length = 5.000000, [cartographer_node-3] motion_filter = { [cartographer_node-3] max_angle_radians = 0.017453, [cartographer_node-3] max_distance_meters = 0.200000, [cartographer_node-3] max_time_seconds = 5.000000, [cartographer_node-3] }, [cartographer_node-3] num_accumulated_range_data = 1.000000, [cartographer_node-3] pose_extrapolator = { [cartographer_node-3] constant_velocity = { [cartographer_node-3] imu_gravity_time_constant = 10.000000, [cartographer_node-3] pose_queue_duration = 0.001000, [cartographer_node-3] }, [cartographer_node-3] imu_based = { [cartographer_node-3] gravity_constant = 9.806000, [cartographer_node-3] imu_acceleration_weight = 1.000000, [cartographer_node-3] imu_rotation_weight = 1.000000, [cartographer_node-3] odometry_rotation_weight = 1.000000, [cartographer_node-3] odometry_translation_weight = 1.000000, [cartographer_node-3] pose_queue_duration = 5.000000, [cartographer_node-3] pose_rotation_weight = 1.000000, [cartographer_node-3] pose_translation_weight = 1.000000, [cartographer_node-3] solver_options = { [cartographer_node-3] max_num_iterations = 10.000000, [cartographer_node-3] num_threads = 1.000000, [cartographer_node-3] use_nonmonotonic_steps = false, [cartographer_node-3] }, [cartographer_node-3] }, [cartographer_node-3] use_imu_based = false, [cartographer_node-3] }, [cartographer_node-3] real_time_correlative_scan_matcher = { [cartographer_node-3] angular_search_window = 0.349066, [cartographer_node-3] linear_search_window = 0.100000, [cartographer_node-3] rotation_delta_cost_weight = 0.100000, [cartographer_node-3] translation_delta_cost_weight = 10.000000, [cartographer_node-3] }, [cartographer_node-3] submaps = { [cartographer_node-3] grid_options_2d = { [cartographer_node-3] grid_type = "PROBABILITY_GRID", [cartographer_node-3] resolution = 0.050000, [cartographer_node-3] }, [cartographer_node-3] num_range_data = 35.000000, [cartographer_node-3] range_data_inserter = { [cartographer_node-3] probability_grid_range_data_inserter = { [cartographer_node-3] hit_probability = 0.550000, [cartographer_node-3] insert_free_space = true, [cartographer_node-3] miss_probability = 0.490000, [cartographer_node-3] }, [cartographer_node-3] range_data_inserter_type = "PROBABILITY_GRID_INSERTER_2D", [cartographer_node-3] tsdf_range_data_inserter = { [cartographer_node-3] maximum_weight = 10.000000, [cartographer_node-3] normal_estimation_options = { [cartographer_node-3] num_normal_samples = 4.000000, [cartographer_node-3] sample_radius = 0.500000, [cartographer_node-3] }, [cartographer_node-3] project_sdf_distance_to_scan_normal = true, [cartographer_node-3] truncation_distance = 0.300000, [cartographer_node-3] update_free_space = false, [cartographer_node-3] update_weight_angle_scan_normal_to_ray_kernel_bandwidth = 0.500000, [cartographer_node-3] update_weight_distance_cell_to_hit_kernel_bandwidth = 0.500000, [cartographer_node-3] update_weight_range_exponent = 0.000000, [cartographer_node-3] }, [cartographer_node-3] }, [cartographer_node-3] }, [cartographer_node-3] use_imu_data = false, [cartographer_node-3] use_online_correlative_scan_matching = true, [cartographer_node-3] voxel_filter_size = 0.025000, [cartographer_node-3] }, [cartographer_node-3] trajectory_builder_3d = { [cartographer_node-3] ceres_scan_matcher = { [cartographer_node-3] ceres_solver_options = { [cartographer_node-3] max_num_iterations = 12.000000, [cartographer_node-3] num_threads = 1.000000, [cartographer_node-3] use_nonmonotonic_steps = false, [cartographer_node-3] }, [cartographer_node-3] intensity_cost_function_options_0 = { [cartographer_node-3] huber_scale = 0.300000, [cartographer_node-3] intensity_threshold = 40.000000, [cartographer_node-3] weight = 0.500000, [cartographer_node-3] }, [cartographer_node-3] occupied_space_weight_0 = 1.000000, [cartographer_node-3] occupied_space_weight_1 = 6.000000, [cartographer_node-3] only_optimize_yaw = false, [cartographer_node-3] rotation_weight = 400.000000, [cartographer_node-3] translation_weight = 5.000000, [cartographer_node-3] }, [cartographer_node-3] high_resolution_adaptive_voxel_filter = { [cartographer_node-3] max_length = 2.000000, [cartographer_node-3] max_range = 15.000000, [cartographer_node-3] min_num_points = 150.000000, [cartographer_node-3] }, [cartographer_node-3] imu_gravity_time_constant = 10.000000, [cartographer_node-3] low_resolution_adaptive_voxel_filter = { [cartographer_node-3] max_length = 4.000000, [cartographer_node-3] max_range = 60.000000, [cartographer_node-3] min_num_points = 200.000000, [cartographer_node-3] }, [cartographer_node-3] max_range = 60.000000, [cartographer_node-3] min_range = 1.000000, [cartographer_node-3] motion_filter = { [cartographer_node-3] max_angle_radians = 0.004000, [cartographer_node-3] max_distance_meters = 0.100000, [cartographer_node-3] max_time_seconds = 0.500000, [cartographer_node-3] }, [cartographer_node-3] num_accumulated_range_data = 1.000000, [cartographer_node-3] pose_extrapolator = { [cartographer_node-3] constant_velocity = { [cartographer_node-3] imu_gravity_time_constant = 10.000000, [cartographer_node-3] pose_queue_duration = 0.001000, [cartographer_node-3] }, [cartographer_node-3] imu_based = { [cartographer_node-3] gravity_constant = 9.806000, [cartographer_node-3] imu_acceleration_weight = 1.000000, [cartographer_node-3] imu_rotation_weight = 1.000000, [cartographer_node-3] odometry_rotation_weight = 1.000000, [cartographer_node-3] odometry_translation_weight = 1.000000, [cartographer_node-3] pose_queue_duration = 5.000000, [cartographer_node-3] pose_rotation_weight = 1.000000, [cartographer_node-3] pose_translation_weight = 1.000000, [cartographer_node-3] solver_options = { [cartographer_node-3] max_num_iterations = 10.000000, [cartographer_node-3] num_threads = 1.000000, [cartographer_node-3] use_nonmonotonic_steps = false, [cartographer_node-3] }, [cartographer_node-3] }, [cartographer_node-3] use_imu_based = false, [cartographer_node-3] }, [cartographer_node-3] real_time_correlative_scan_matcher = { [cartographer_node-3] angular_search_window = 0.017453, [cartographer_node-3] linear_search_window = 0.150000, [cartographer_node-3] rotation_delta_cost_weight = 0.100000, [cartographer_node-3] translation_delta_cost_weight = 0.100000, [cartographer_node-3] }, [cartographer_node-3] rotational_histogram_size = 120.000000, [cartographer_node-3] submaps = { [cartographer_node-3] high_resolution = 0.100000, [cartographer_node-3] high_resolution_max_range = 20.000000, [cartographer_node-3] low_resolution = 0.450000, [cartographer_node-3] num_range_data = 160.000000, [cartographer_node-3] range_data_inserter = { [cartographer_node-3] hit_probability = 0.550000, [cartographer_node-3] intensity_threshold = 40.000000, [cartographer_node-3] miss_probability = 0.490000, [cartographer_node-3] num_free_space_voxels = 2.000000, [cartographer_node-3] }, [cartographer_node-3] }, [cartographer_node-3] use_intensities = false, [cartographer_node-3] use_online_correlative_scan_matching = false, [cartographer_node-3] voxel_filter_size = 0.150000, [cartographer_node-3] }, [cartographer_node-3] }, [cartographer_node-3] trajectory_publish_period_sec = 0.030000, [cartographer_node-3] use_landmarks = false, [cartographer_node-3] use_nav_sat = false, [cartographer_node-3] use_odometry = false, [cartographer_node-3] use_pose_extrapolator = false, [cartographer_node-3] } [cartographer_node-3] *** Check failure stack trace: *** [cartographer_node-3] @ 0x77439608db03 google::LogMessage::Fail() [cartographer_node-3] @ 0x7743960959d1 google::LogMessage::SendToLog() [cartographer_node-3] @ 0x77439608d7c2 google::LogMessage::Flush() [cartographer_node-3] @ 0x77439608f78f google::LogMessageFatal::~LogMessageFatal() [cartographer_node-3] @ 0x58318646ace7 (unknown) [cartographer_node-3] @ 0x58318646ad66 (unknown) [cartographer_node-3] @ 0x58318646aff3 (unknown) [cartographer_node-3] @ 0x5831864511d4 (unknown) [cartographer_node-3] @ 0x5831863b77b3 (unknown) [cartographer_node-3] @ 0x774395029d90 (unknown) [cartographer_node-3] @ 0x774395029e40 __libc_start_main [cartographer_node-3] @ 0x5831863bad35 (unknown) [ERROR] [cartographer_node-3]: process has died [pid 15431, exit code -6, cmd '/opt/ros/humble/lib/cartographer_ros/cartographer_node -configuration_directory /home/michael/ros2_ws/install/ldlidar-ros2/share/ldlidar-ros2/configuration_files -configuration_basename mylaser.lua --ros-args --params-file /tmp/launch_params_0_aev13x -r scan:=scan'].
11-14
Cartographer主要理论是通过闭环检测来消除构图过程中产生的累积误差[1]。用于闭环检测的基本单元是submap。一个submap是由一定数量的laser scan构成。将一个laser scan插入其对应的submap时,会基于submap已有的laser scan及其它传感器数据估计其在该submap中的最佳位置。submap的创建在短时间内的误差累积被认为是足够小的。然而随着时间推移,越来越多的submap被创建后,submap间的误差累积则会越来越大。因此需要通过闭环检测适当的优化这些submap的位姿进而消除这些累积误差,这就将问题转化成一个位姿优化问题。当一个submap的构建完成时,也就是不会再有新的laser scan插入到该submap时,该submap就会加入到闭环检测中。闭环检测会考虑所有的已完成创建的submap。当一个新的laser scan加入到地图中时,如果该laser scan的估计位姿与地图中某个submap的某个laser scan的位姿比较接近的话,那么通过某种 scan match策略就会找到该闭环。Cartographer中的scan match策略通过在新加入地图的laser scan的估计位姿附近取一个窗口,进而在该窗口内寻找该laser scan的一个可能的匹配,如果找到了一个足够好的匹配,则会将该匹配的闭环约束加入到位姿优化问题中。Cartographer的重点内容就是融合多传感器数据的局部submap创建以及用于闭环检测的scan match策略的实现。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值