Go to the documentation of this file.
193 bool& outThereIsObservation,
195 bool& hardwareError);
void initialize()
Turns the laser on.
bool m_I_am_owner_serial_port
mrpt::containers::circular_buffer< uint8_t > m_rx_buffer
Auxiliary buffer for readings.
A "CObservation"-derived class that represents a 2D range scan measurement (typically from a laser sc...
bool turnOff()
Disables the scanning mode (this can be used to turn the device in low energy mode,...
uint32_t m_timeStartUI
Time of the first data packet, for synchronization purposes.
Used in CHokuyoURG::displayVersionInfo.
int m_timeStartSynchDelay
Counter to discard to first few packets before setting the correspondence between device and computer...
void loadConfig_sensorSpecific(const mrpt::config::CConfigFileBase &configSource, const std::string &iniSection)
See the class documentation at the top for expected parameters.
int m_firstRange
The first and last ranges to consider from the scan.
bool receiveResponse(char &rcv_status0, char &rcv_status1)
Waits for a response from the device.
This is the global namespace for all Mobile Robot Programming Toolkit (MRPT) libraries.
#define DEFINE_GENERIC_SENSOR(class_name)
This declaration must be inserted in all CGenericSensor classes definition, within the class declarat...
bool enableSCIP20()
Enables the SCIP2.0 protocol (this must be called at the very begining!).
double d_min
Min/Max ranges, in meters.
bool assureBufferHasBytes(const size_t nDesiredBytes)
Assures a minimum number of bytes in the input buffer, reading from the serial port only if required.
bool ensureStreamIsOpen()
Returns true if there is a valid stream bound to the laser scanner, otherwise it first try to open th...
mrpt::system::TTimeStamp m_timeStartTT
int m_motorSpeed_rpm
The motor speed (default=600rpm)
uint64_t TTimeStamp
A system independent time type, it holds the the number of 100-nanosecond intervals since January 1,...
unsigned int getScanInterval() const
unsigned int m_port_dir
If set to non-empty and m_ip_dir too, the program will try to connect to a Hokuyo using Ethernet comm...
bool m_disable_firmware_timestamp
This is the base, abstract class for "software drivers" interfaces to 2D scanners (laser range finder...
bool switchLaserOn()
Switchs the laser on.
void purgeBuffers()
Empties the RX buffers of the serial port.
void setSerialPort(const std::string &port_name)
If set to non-empty, the serial port will be attempted to be opened automatically when this class is ...
This class allows loading and storing values and vectors of different types from a configuration text...
unsigned int m_scan_interval
A class used to store a 3D pose (a 3D translation + a rotation in 3D).
std::string m_lastSentMeasCmd
The last sent measurement command (MDXXX), including the last 0x0A.
mrpt::gui::CDisplayWindow3D::Ptr m_win
std::shared_ptr< CDisplayWindow3D > Ptr
bool setIntensityMode(bool enabled)
If true scans will capture intensity.
double m_reduced_fov
Used to reduce artificially the interval of scan ranges.
bool displayVersionInfo()
Ask to the device, and print to the debug stream, details about the firmware version,...
bool displaySensorInfo(CHokuyoURG::TSensorInfo *out_data=nullptr)
Ask to the device, and print to the debug stream, details about the sensor model.
int scan_first
First, last, and front step of the scanner angular span.
void sendCmd(const char *str)
bool setHighSensitivityMode(bool enabled)
Changes the high sensitivity mode (HS) (default: false)
std::string m_ip_dir
If set to non-empty and m_port_dir too, the program will try to connect to a Hokuyo using Ethernet co...
const std::string getSerialPort()
Returns the currently set serial port.
void setReducedFOV(const double fov)
If called (before calling "turnOn"), the field of view of the laser is reduced to the given range (in...
int scans_per_360deg
Number of measuremens per 360 degrees.
This software driver implements the protocol SCIP-2.0 for interfacing HOKUYO URG/UTM/UXM/UST laser sc...
std::string m_com_port
If set to non-empty, the serial port will be attempted to be opened automatically when this class is ...
int motor_speed_rpm
Standard motor speed, rpm.
GLsizei const GLchar ** string
bool switchLaserOff()
Switchs the laser off.
void setIPandPort(const std::string &ip, const unsigned int &port)
Set the ip direction and port to connect using Ethernet communication.
std::string model
The sensor model.
std::string m_rcv_data
temp buffer for incoming data packets
virtual ~CHokuyoURG()
Destructor: turns the laser off.
bool setMotorSpeed(int motoSpeed_rpm)
Changes the motor speed in rpm's (default 600rpm)
bool startScanningMode()
Start the continuous scanning mode, using parameters stored in the object (loaded from the ....
void doProcessSimple(bool &outThereIsObservation, mrpt::obs::CObservation2DRangeScan &outObservation, bool &hardwareError)
Specific laser scanner "software drivers" must process here new data from the I/O stream,...
void setScanInterval(unsigned int skipScanCount)
Set the skip scan count (0 means send all scans).
bool turnOn()
Enables the scanning mode (which may depend on the specific laser device); this must be called before...
unsigned __int32 uint32_t
TSensorInfo m_sensor_info
The information gathered when the laser is first open.
bool m_intensity
Get intensity from lidar scan (default: false)
bool setHighBaudrate()
Passes to 115200bps bitrate.
bool m_highSensMode
High sensitivity [HS] mode (default: false)
poses::CPose3D m_sensorPose
The sensor 6D pose:
Page generated by Doxygen 1.8.17 for MRPT 1.9.9 Git: ad3a9d8ae Tue May 1 23:10:22 2018 -0700 at miƩ 12 jul 2023 10:03:34 CEST | |