123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107 |
- // Copyright (C) 2012, 2019 Austin Robot Technology, Piyush Khandelwal, Joshua Whitley
- // All rights reserved.
- //
- // Software License Agreement (BSD License 2.0)
- //
- // Redistribution and use in source and binary forms, with or without
- // modification, are permitted provided that the following conditions
- // are met:
- //
- // * Redistributions of source code must retain the above copyright
- // notice, this list of conditions and the following disclaimer.
- // * Redistributions in binary form must reproduce the above
- // copyright notice, this list of conditions and the following
- // disclaimer in the documentation and/or other materials provided
- // with the distribution.
- // * Neither the name of {copyright_holder} nor the names of its
- // contributors may be used to endorse or promote products derived
- // from this software without specific prior written permission.
- //
- // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
- // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
- // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
- // FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
- // COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
- // INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
- // BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
- // LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
- // CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
- // LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
- // ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
- // POSSIBILITY OF SUCH DAMAGE.
- #ifndef VELODYNE_POINTCLOUD_CALIBRATION_H
- #define VELODYNE_POINTCLOUD_CALIBRATION_H
- #include <map>
- #include <vector>
- #include <string>
- namespace velodyne_pointcloud
- {
- /** \brief correction values for a single laser
- *
- * Correction values for a single laser (as provided by db.xml from
- * Velodyne). Includes parameters for Velodyne HDL-64E S2.1.
- *
- * http://velodynelidar.com/lidar/products/manual/63-HDL64E%20S2%20Manual_Rev%20D_2011_web.pdf
- */
- /** \brief Correction information for a single laser. */
- struct LaserCorrection
- {
- /** parameters in db.xml */
- float rot_correction;
- float vert_correction;
- float dist_correction;
- bool two_pt_correction_available;
- float dist_correction_x;
- float dist_correction_y;
- float vert_offset_correction;
- float horiz_offset_correction;
- int max_intensity;
- int min_intensity;
- float focal_distance;
- float focal_slope;
- /** cached values calculated when the calibration file is read */
- float cos_rot_correction; ///< cosine of rot_correction
- float sin_rot_correction; ///< sine of rot_correction
- float cos_vert_correction; ///< cosine of vert_correction
- float sin_vert_correction; ///< sine of vert_correction
- int laser_ring; ///< ring number for this laser
- };
- /** \brief Calibration information for the entire device. */
- class Calibration
- {
- public:
- float distance_resolution_m;
- std::map<int, LaserCorrection> laser_corrections_map;
- std::vector<LaserCorrection> laser_corrections;
- int num_lasers;
- bool initialized;
- // bool ros_info;
- public:
- explicit Calibration(bool info = true)
- : distance_resolution_m(0.002f),
- num_lasers(0),
- initialized(false) {}
- explicit Calibration(
- const std::string& calibration_file,
- bool info = true)
- : distance_resolution_m(0.002f)
- {
- read(calibration_file);
- }
- void read(const std::string& calibration_file);
- void write(const std::string& calibration_file);
- };
- } // namespace velodyne_pointcloud
- #endif // VELODYNE_POINTCLOUD_CALIBRATION_H
|