Commit Graph

486 Commits (c5416068dd06ac4ca732ed53db225204b25ec05b)

Author SHA1 Message Date
Wolfgang Hess c5416068dd
Move proto files out of 2d/3d directories. (#1749)
This is to make it possible to use the proto definitions
from Python where the directory structure otherwise
prevents them from being imported in the usual way.

Signed-off-by: Wolfgang Hess <whess@lyft.com>
2020-09-14 12:17:15 +02:00
Wolfgang Hess a20db758cd
Add intensity data to TimedPointCloudData. (#1742)
Adds a new field intensities to TimedPointCloudData.
RangeDataCollator now also takes intensities into account.
AddRangeData now takes a point cloud by value instead of
const reference as we would later make a copy of it anyway.

Signed-off-by: Wolfgang Hess <whess@lyft.com>
2020-08-28 10:12:04 +02:00
Wolfgang Hess da779339fa
Add IntensityHybridGrid. (#1739)
Adds a new structure IntensityHybridGrid, similar to HybridGrid
but which stores intensities instead of probabilities.
InterpolatedGrid is adapted to handle both types of HybridGrids.

Signed-off-by: Wolfgang Hess <whess@lyft.com>
2020-08-26 14:35:20 +02:00
Michael Grupp 01cb6b1d6f
Add gauge metric for current number of submap scan matchers. (#1738)
Useful for analyzing memory-related issues.
See: #1737

Signed-off-by: Michael Grupp <grupp@magazino.eu>
2020-08-25 11:04:59 +02:00
Michael Grupp 98d957ae43
Remove legacy compatibility proto files. (#1736)
Not needed anymore after the recent removal of that feature, see #1709.

Signed-off-by: Michael Grupp <grupp@magazino.eu>
2020-08-21 14:20:31 +02:00
Wolfgang Hess 1c8c1d144e
Remove struct TimedRangeData. (#1735)
It was only used in a unit test which can be improved
by removing it.

Signed-off-by: Wolfgang Hess <whess@lyft.com>
2020-08-20 11:07:25 +02:00
Michael Grupp 9b405c3dc8
Deactivate memory-critical histogram backwards compatibility. (#1710)
It's essentially leading to buffering all submaps twice, which
is a high (~2x) peak in memory consumption during deserialization.

Don't convert anymore since this affects _all_ pbstreams and not only
the (probably few) old pbstreams that require the conversion.

Signed-off-by: Michael Grupp <grupp@magazino.eu>
2020-08-17 19:34:35 +02:00
Martin Schwörer 6c889490e2
Integrate imu based extrapolator (#1732)
This integrates the imu based extrapolator implementation, adds lua configuration and conversions from lua to proto. Note that the parameters of the imu based extrapolator are not tuned yet and the default is still the constant-velocity extrapolator.

Signed-off-by: mschworer <mschworer@lyft.com>
2020-07-30 13:52:08 +02:00
Martin Schwörer d3794a420a
Extrapolator Result for motion compensation (#1731)
This makes use of the ExtrapolationResult returned by the pose extrapolator. ExtrapolationResult contains poses corresponding to the timestamps of range data measurements to be used for motion compensation. When using the PoseExtrapolator implementation there is no functional difference. This PR prepares the integration of ImuBasedPoseExtrapolator, which requires using ExtrapolationResult returned by ExtrapolatePosesWithGravity to run efficiently.

Signed-off-by: mschworer <mschworer@lyft.com>
2020-07-30 09:14:02 +02:00
Martin Schwörer efc64934d6
use extrapolator interface (#1730)
This integrates the extrapolator interface into the 3D trajectory builder. The construction is now done within the interface and local trajectory builder 3D just makes use of the interface. No functional changes.

Signed-off-by: mschworer <mschworer@lyft.com>
2020-07-29 19:15:15 +02:00
Martin Schwörer 23351be571
added imu based extrapolator impl (#1728)
This adds an alternative implementation for pose extrapolation which uses imu integration as well as past local SLAM results (and odometry data) to predict a pose. This allows to perform motion compensation and initialize scan matching afterwards.

Using imu data for pose extrapolation and motion compensation is more accurate, because it does not make a constant velocity assumption like the PoseExtrapolator implementation. Next steps are the integration into local trajectory builder as well as tuning the parameters for existing datasets.

This PR is quite large but was already reviewed in smaller chunks internally and combines contributions from @danielsievers, @wohe and @schwoere.

Signed-off-by: mschworer <mschworer@lyft.com>
2020-07-29 14:48:01 +02:00
Martin Schwörer 32dad63edd
extracted eigen quaterniond from 2 vectors for faster compilation (#1729)
Signed-off-by: mschworer <mschworer@lyft.com>
2020-07-29 14:08:40 +02:00
Michael Grupp 1cae11593d
Add gauge metric for pose graph work queue size. (#1727)
Signed-off-by: Michael Grupp <grupp@magazino.eu>
2020-07-29 11:53:14 +02:00
Martin Schwörer 340a9ac21a
add pose extrapolator interface and extrapolator options (#1726)
This adds an interface around the extrapolator without further integration into any call sides.

Currently there is only a constant-velocity extrapolator implementation. The next step is to add an extrapolator implementation which integrates imu measurements for pose extrapolation.

Signed-off-by: mschworer <mschworer@lyft.com>
2020-07-28 22:53:12 +02:00
Wolfgang Hess 595ffba0ce
Small improvements to 2D fixed frame pose support. (#1714)
This is a follow up to #1580.

Signed-off-by: Wolfgang Hess <whess@lyft.com>
2020-07-08 14:50:02 +02:00
Jihoon Lee 5899bff425
FixedFramePose in optimization 2d (#1580) 2020-07-07 13:18:53 +02:00
Wolfgang Hess 21a8299caa
Add Ubuntu 20.04 to the install scripts, CI, docs. (#1706)
Signed-off-by: Wolfgang Hess <whess@lyft.com>
2020-06-18 14:44:58 +02:00
Michael Grupp 82a3970f76
Handle multiple frozen trajectories as one connected component. (#1610)
This fixes local constraint search in frozen maps built from multiple trajectories.

Local constraint search from a localization trajectory to a set of frozen trajectories
(i.e. the map) is done only among trajectories that are transitively connected in the
same connected component. If we set an initial pose, we create such a connection
to one frozen trajectory, but we were so far not able to do a local constraint search
w.r.t. to other frozen trajectories because they're not connected among each other.
Any constraints between them are not loaded (because they’re frozen).
2020-06-17 10:59:39 +02:00
Wolfgang Hess e8c1d840e6
Small fixes needed for focal support. (#1704)
Signed-off-by: Wolfgang Hess <whess@lyft.com>
2020-06-17 10:09:14 +02:00
Susanne Pielawa b38b1cefa0
Allow using TolerantLoss for INS in pose graph optimization (#1700)
This PR adds the possibility to use the TolerantLoss function for INS in pose graph optimization. This is currently switched off, and so there's not functional change. 

The ceres TolerantLoss function (see [description](http://ceres-solver.org/nnls_modeling.html), and [implementation](https://github.com/ceres-solver/ceres-solver/blob/master/internal/ceres/loss_function.cc)) has the following property

- for large values of x it approaches a quadratic loss ("null loss") with the specified weight (fixed_frame_pose_translation_weight)
- for small values of x it approaches a quadratic loss with a smaller weight
- there's a crossover at some value x_c. The function is convex everywhere.
2020-06-15 10:56:23 +02:00
Phil 36afcb5590
Fix typo in tsdf_range_data_inserter_2d.cc (#1612)
Fix typo in RangeDataSorter.
2020-06-15 10:13:54 +02:00
Mariia Gladkova d973a084f7
Fix MapById::lower_bound function and implement test to reproduce the bug (#1616)
This fixes the bug that has been faced during localization with an initial pose and a trimmed map (OverlappingSubmapsTrimmer2D has been used). A small test is added that reproduces the problem (an infinite loop) where a trimmed trajectory (MapById instance) is used.
2020-06-12 12:17:54 +02:00
jie 47b80c9a3f
Fix crashes in median() if all spans in a level are short (#1668) 2020-06-02 11:29:37 +02:00
jie ad216d49c9
Fix the dead loop. (#1586)
Fix the bug in RotateHistogram which may cause dead loop by numerical error.
2020-05-28 19:28:15 +02:00
Michael Grupp c999c3012b Fix a small description typo in constraints metrics. (#1562) 2019-04-10 15:31:33 +02:00
Michael Grupp 035162d865 Update clang-format to new Google style. (#1564)
Apparently the format bot uses a bleeding edge clang-format that uses
the new Google style and reformats a bunch of files in every PR. This is
an empty commit to trigger this in a separate commit.

See 62e3198c4f
2019-04-10 13:04:57 +02:00
damienrg 3b941ee126 Add `collate_by_trajectory` support in lua config (#1334)
This commit add support of specifying the option to collate data by
trajectory introduced in #828 in the lua configuration files.
The value is set to false as when a boolean option is not specified it
is initialized to false.
2019-03-08 15:36:30 +01:00
damienrg 856e9c924a Rename kNumberOfValues to kValueCount (#1535)
Done as it reads a bit better.
2019-03-08 12:28:48 +01:00
damienrg 301a72fa42 Reserve memory for cells in probability_values.cc (#1531)
Done to avoid unnecessary reallocation.
2019-03-08 10:57:10 +01:00
Kevin Daun d06b0ab63f Initialize RangeData in NormalEstimation tests. (#1532)
Resolving https://github.com/googlecartographer/cartographer/issues/1530
Same as https://github.com/googlecartographer/cartographer/pull/1520
2019-03-07 16:43:05 +01:00
damienrg a60cca4a43 Refactor number of cells magic number (#1522) 2019-03-07 11:56:01 +01:00
Kevin Daun d7b4656741 Initialize RangeData in TSDF tests. (#1520)
* Explicitly initialize RangeData.

* Use auto to remove redundancy.

* Ran clang-format.
2019-02-13 15:40:37 +01:00
Michael Grupp 2adeb1f3be Add gauge metrics for submaps in pose graph. (#1511)
Adds a metric family that monitors:

- the number of submaps in frozen trajectories
- the number of submaps in active trajectories
- the number of deleted/trimmed submaps
2019-02-05 17:15:45 +01:00
Jonathan Huber fd67975761 Allow introduction of new landmarks into loaded (frozen) map (#1475)
In the current implementation, as soon as one trajectory is frozen it is not possible to use new landmarks anymore.
In this PR a suggest a change, that allows introducing new landmarks also in the presence of a frozen trajectory. This is done with the following steps:
- Store set of frozen landmarks
- Landmarks that are loaded from a pbstream, with the flag ` load_frozen_state=true` are inserted into the set of frozen landmarks via `setLandmarkPose` function
- frozen landmarks are set constant in the optimization problem
- new landmarks can be introduced and will be optimized in the optimization problem

Motivated by and closes #1470
2019-01-17 16:57:30 +01:00
Alex Millane eec7af0a4f Fix TSD converter include location (#1500)
* Moved value converter include out of internal folder.

* Ran clang-format.
2019-01-16 10:04:57 +01:00
Michael Grupp 53a1f6c2f7 Small fixes for PoseExtrapolator::UpdateVelocitiesFromPoses() (#1492)
- use `pose_queue_duration_` instead of hardcoded "0.001"
  (cartographer_ros sets this to 0.001, probably that's why this
  wasn't noticed)
- queue_delta is in seconds, log message said milliseconds
2019-01-03 10:03:48 +01:00
Andre Gaschler 5182dd1bf9
Correct spelling to bandwidth (#1490)
Previously, two config values were spelled "bandwith".
The assumption is that these values are not used in other
repositories so the rename is harmless.
2019-01-02 13:12:26 +01:00
Juraj Oršulić c370d221d0 Windows build fixes & Azure CI (#1463)
This PR makes libcartographer build on Windows (including tests). Abseil was bumped to avoid a MSVC compiler bug.

I have observed two tests failing:
`MapBuilderTestByGridType/MapBuilderTestByGridType.GlobalSlam2D/1` and `MapBuilderTestByGridType/MapBuilderTestByGridType.LocalizationOnFrozenTrajectory2D/1`.
2018-12-16 17:04:23 +01:00
Michael Grupp e0b2196cec Add gauge metrics for inter-submap constraints. (#1465)
Since the constraint builder metrics are ever-increasing, it makes sense
to add gauges that monitor the current counts of constraints in the pose
graph. The main advantages are that they also take trimming into account
and distinguish constraints within or across trajectories.
2018-11-22 10:25:43 +01:00
gaschler f060815a7f
Fix locking while modifying counter (#1454)
Clang with thread safety does not compile because
num_nodes_since_last_loop_closure_
is modified without holding a mutex.
This fixes it.
2018-10-25 15:30:06 +02:00
gaschler 5253186cbe Fix virtual destructors (#1453)
This is necessary because otherwise derived classes
are potentially deleted incompletely, using the destructor
of the interface.
2018-10-24 18:45:58 +02:00
gaschler ceddabbcbb Improve portability (#1452)
This change improves the portability of Cartographer.
2018-10-24 18:04:55 +02:00
Alexander Belyaev 1905b6bb59 Inline calls to Trim() in id_test. (#1451) 2018-10-24 16:38:41 +02:00
Juraj Oršulić 6ad7b87b67 Inline a couple of 2D grid cell access functions (#1420)
Noticed ToFlatIndex during profiling. Inline a couple of other short functions as well.
2018-10-18 15:21:56 +02:00
Kevin Daun de4886ea4e Read missing option fix_z_in_3d in OptimizationProblemOptions. (#1440) 2018-10-10 11:33:22 +02:00
Alexander Belyaev 5e11365749
[ABSL] Use flat_hash_set instead of unordered_set. (#1442) 2018-10-08 12:43:17 +02:00
Alexander Belyaev bdb6f2db4a
[ABSL] Use flat_hash_map instead of unordered_map. (#1439) 2018-10-08 10:47:28 +02:00
Michael Grupp ba859a6ed5 Add WriteStateToFileResponse. (#1428)
Changes the public map builder API, but is required to not break the ROS API.
See also https://github.com/googlecartographer/cartographer_ros/pull/1014 and #1422
2018-09-15 00:03:30 +02:00
Christoph Schütte f995744c63 Implement MapBuilderService.WriteStateToFile() (#1424) 2018-09-13 14:53:51 +02:00
Michael Grupp a21ecf9b99 Add load_frozen_state also to LoadStateFromFile gRPC requests. (#1423) 2018-09-13 10:13:16 +02:00