Go to the documentation of this file.
28 #include <boost/shared_ptr.hpp>
29 #include <boost/make_shared.hpp>
30 #include <boost/asio.hpp>
42 using boost::make_shared;
43 using boost::asio::buffer;
89 throw std::invalid_argument(
"Start angle is greater than max");
93 throw std::invalid_argument(
"End angle is greater than max");
97 throw std::invalid_argument(
"Starting angle is less than ending angle");
106 int start_byte = start_beam / 8;
107 int start_bit = start_beam - start_byte * 8;
108 int end_byte = end_beam / 8;
109 int end_bit = end_beam - end_byte * 8;
114 memset(mask, 0, start_byte);
121 mask[start_byte] = ~((1 << start_bit) - 1);
129 memset(mask + start_byte + 1, 0xFF, end_byte - start_byte - 1);
132 mask[end_byte] = (1 << (end_bit + 1)) - 1;
135 memset(mask + end_byte + 1, 0, 87 - end_byte);
165 throw std::invalid_argument(
"Number of beams does not match vector size");
201 throw std::invalid_argument(
"Number of beams does not match vector size");
249 throw std::logic_error(
"IO Packet received with wrong number of items");
251 if (pkt.
getItems()[1].getItemType() != 0x00B1)
253 throw std::logic_error(
"IO Packet received with wrong data type");
266 o_to_t.
rpi = 0x00177FA0;
269 t_to_o.
rpi = 0x00013070;
static const double ANGLE_INC
vector< EIP_UINT > measurement_data
const Connection & getConnection(size_t n)
EIP_UINT getReflectivityFormat()
vector< CPFItem > & getItems()
EIP_UINT range_report_format
MeasurementReportConfig mrc_
EIP_UINT getRangeFormat()
void setSingleAttribute(EIP_USINT class_id, EIP_USINT instance_id, EIP_USINT attribute_id, T v)
MeasurementReport receiveMeasurementReportUDP()
void closeActiveConnection()
static const double DISTANCE_MAX
EIP_UDINT mrc_sequence_num_
T getSingleAttribute(EIP_USINT class_id, EIP_USINT instance_id, EIP_USINT attribute_id, T v)
static void convertToLaserScan(const RangeAndReflectanceMeasurement &rr, sensor_msgs::LaserScan *ls)
vector< EIP_UINT > reflectance_data
RangeAndReflectanceMeasurement getSingleRRScan()
EIP_UINT reflectivity_report_format
static double calcBeamCentre(int beam_num)
EIP_BYTE beam_selection_mask[88]
MeasurementReportHeader header
void setReflectivityFormat(EIP_UINT format)
void sendMeasurmentReportConfigUDP()
static const double ANGLE_MIN
vector< EIP_UINT > range_data
static int calcBeamNumber(double angle)
int createConnection(const EIP_CONNECTION_INFO_T &o_to_t, const EIP_CONNECTION_INFO_T &t_to_o)
static const double DISTANCE_MIN
void sendIOPacket(CPFPacket &pkt)
void selectBeams(double start_angle, double end_angle)
EIP_UINT getItemCount() const
void setRangeFormat(EIP_UINT format)
void setSingleAttributeSerializable(EIP_USINT class_id, EIP_USINT instance_id, EIP_USINT attribute_id, shared_ptr< Serializable > data)
void closeConnection(size_t n)
void calcBeamMask(double start_angle, double end_angle, EIP_BYTE mask[])
CPFPacket receiveIOPacket()
static const double ANGLE_MAX
MeasurementReportHeader header
void getSingleAttributeSerializable(EIP_USINT class_id, EIP_USINT instance_id, EIP_USINT attribute_id, Serializable &result)
void fillLaserScanStaticConfig(sensor_msgs::LaserScan *ls)