ifm3d
struct_o3r_ods_polar_occupancy_grid_v1.hpp
1 // -*- c++ -*-
2 /*
3  * Copyright 2025-present ifm electronic, gmbh
4  * SPDX-License-Identifier: Apache-2.0
5  */
6 
7 #ifndef IFM3D_DESERIALIZE_STRUCT_O3R_ODS_POLAR_OCCUPANCY_GRID_V1_HPP
8 #define IFM3D_DESERIALIZE_STRUCT_O3R_ODS_POLAR_OCCUPANCY_GRID_V1_HPP
9 
10 #include <array>
11 #include <ifm3d/deserialize/deserialize_utils.hpp>
12 #include <ifm3d/device/device.h>
13 #include <ifm3d/device/err.h>
14 #include <ifm3d/fg/buffer.h>
15 #include <ifm3d/fg/organizer_utils.h>
16 
17 namespace ifm3d
18 {
19  namespace
20  {
21  constexpr auto ODS_POLAR_OCCUPANCY_GRID_VERSION_INDEX = 0x0000;
22  constexpr auto ODS_POLAR_OCCUPANCY_GRID_POLAR_OCC_GRID_INDEX = 0x0004;
23  constexpr auto ARRAY_SIZE = 675;
24  constexpr auto ODS_POLAR_OCCUPANCY_GRID_TIMESTAMP_NS_INDEX = 0x054A;
25  };
26 
29  {
30  public:
31  using Ptr = std::shared_ptr<ODSPolarOccupancyGridV1>;
32 
33  static bool
34  IsValid(const uint8_t* data, size_t size)
35  {
36  auto version =
37  mkval<std::uint32_t>(data + ODS_POLAR_OCCUPANCY_GRID_VERSION_INDEX);
38 
39  return size >= ODS_POLAR_OCCUPANCY_GRID_V1_MINIMUM_SIZE && version >= 1;
40  }
41 
42  void
43  Read(const uint8_t* start_ptr, size_t size)
44  {
45  if (!IsValid(start_ptr, size))
46  {
47  throw ifm3d::Error(IFM3D_CORRUPTED_STRUCT);
48  }
49 
50  version = mkval<std::uint32_t>(start_ptr +
51  ODS_POLAR_OCCUPANCY_GRID_VERSION_INDEX);
52  mkarray<uint16_t, ARRAY_SIZE>(
53  start_ptr + ODS_POLAR_OCCUPANCY_GRID_POLAR_OCC_GRID_INDEX,
54  polar_occ_grid);
55  timestamp_ns = mkval<std::uint64_t>(
56  start_ptr + ODS_POLAR_OCCUPANCY_GRID_TIMESTAMP_NS_INDEX);
57  };
58 
59  /*@brief Version number(current 1) of polar occupancy grid*/
60  uint32_t version;
61  /* @brief A compressed version of the grid using polar coordinates.
62  * The index corresponds to the angle slice i*360/675 degree to
63  * (i+1)*360/675 degree. The value is the distance to the nearest occupied
64  * cell on the ray from the vehicle origin, given in [mm]. In case there
65  * are no occupied cells on the ray, the value 65535 is set.
66  */
67  std::array<uint16_t, ARRAY_SIZE> polar_occ_grid;
68  /*@brief Timestamp of polar occupany grid in [ns]*/
69  uint64_t timestamp_ns;
70 
71  private:
72  static constexpr size_t ODS_POLAR_OCCUPANCY_GRID_V1_MINIMUM_SIZE = 1354;
73 
74  public:
76  Deserialize(const Buffer& ods_polar_occupancy_buffer_grid)
77  {
78  ODSPolarOccupancyGridV1 ods_polar_occupancy_grid_v1{};
79 
80  ods_polar_occupancy_grid_v1.Read(
81  ods_polar_occupancy_buffer_grid.Ptr<uint8_t>(0),
82  ods_polar_occupancy_buffer_grid.Size());
83  return ods_polar_occupancy_grid_v1;
84  }
85  };
86 } // end namespace ifm3d
87 
88 #endif // IFM3D_DESERIALIZE_STRUCT_O3R_ODS_POLAR_OCCUPANCY_GRID_V1_HPP
ifm3d::Buffer
The class Buffer represent a STL container to store data from the ifm devices in 2 dimension and supp...
Definition: buffer.h:98
ifm3d::Error
Definition: err.h:114
ifm3d::Buffer::Size
size_t Size() const
Return the size of the buffer in bytes.
ifm3d::Buffer::Ptr
T * Ptr(std::uint32_t row)
returns a pointer to the specified Buffer row.
ifm3d::ODSPolarOccupancyGridV1
Definition: struct_o3r_ods_polar_occupancy_grid_v1.hpp:28