Skip to content

Latest commit

 

History

History
62 lines (43 loc) · 3.85 KB

CHANGELOG.md

File metadata and controls

62 lines (43 loc) · 3.85 KB

Changelog

v0.5.0 -> v0.5.1

  • Fixes a bug, where the conversion of larger to smaller types results in a false buffer interpretation.

v0.5.0-rc.3 -> v0.5.0

  • PointConvertible trait is now unsafe since the offset is used for raw memory access, where safety can not be guaranteed by the compiler.
  • Fixes clippy on nightly.
  • Fixes a bug when attempting to write larger types than available in the message. This now results in a ExhaustedSource error.
  • Adds repr(C) to docs where custom conversions are explained to encourage best practices for raw type descriptions.

v0.5.0-rc.2 -> v0.5.0-rc.3

  • Bump r2r to 0.9.
  • Fixed building in no_std environments.
  • Removed expect calls.

v0.5.0-rc.1 -> v0.5.0-rc.2

  • PointConvertible now includes the information for TypeLayout and Fields, which reduces boilerplate code for custom points. The respective derive macro is updated to work with the updated trait.
  • _vec functions now work without the derive feature and thus are always available.
  • The derive feature now is disabled by default but it is still strongly recommended for custom points to avoid layout errors. This also makes procmacro dependencies optional for the functionality, since every conversion can be called without them.
  • The alignment of all predefined points is increased for SSE optimization and optimized copies between C++ PCL and Rust.

v0.4.0 -> v0.5.0-rc.1

Most of the library is rewritten to be simpler and more expandable while adding mostly performance focused features to motivate the breaking changes.

Why?

The previous concept of the Convert struct for both directions of conversion leads to use cases, where the behavior is unexpected for the user.

What changed?

Nearly every public function is changed to be easier to work with and faster at runtime and adaptable for different scenarios.

It is easier to update to the new version by looking at it as a new crate and starting with the documentation.

Breaking

  • Switched from FallibleIterator to Iterator, since all possible errors are checked before returning the type.
  • Renamed pcl_utils module to points to make the module more a general toolkit and less a PCL compatibility layer.
  • Renamed ros_types module to ros since types are inferred.
  • Removed Convert struct. The PointCloud2Msg now directly offers try_from_iter and try_into_iter functions.
  • Dimensions and PointMeta in PointConvertible are merged to types, that are mostly deducted to minimize the needed code (see the docs for a custom point example).
  • Conversions can not fail per point in PointConvertible, so TryFrom -> From.
  • RGB is now stored as a union to allow direct copy with _vec functions without packing it manually per point. There are setters and getters for safety and usability.
  • ros_types::TimeMsg (now ros::TimeMsg) uses nanosec instead of nsec naming to conform with ROS2. This also removes the type alias for rosrust. Instead, there is a impl From<rosrust::Time> for TimeMsg now.

Added features

  • [from|into]_vec enabled by derive for memory heavy applications (enabled by default).
  • [from|into]_par_iter enabled by rayon for processing heavy applications.
  • derive macros for minimizing code for custom point conversions (enabled by default).
  • xyz() getter enabled by nalgebra for all predefined points.
  • prelude::* re-export module for quickly importing common types in point cloud processing projects.
  • Lightweight: no_std compatibility for iter conversions and dependency-free builds when only needing iter conversions.
  • Overall speed up thanks to more vectorizable iterator conversions and the new vec and par_iter functions. See the comparison with PCL for more info.
  • More type deduction in public facing functions, leading to less code for the user of the library.
  • More documentation.