12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758 |
- #include <adc_planner/dubins_planner.h>
- #include <adc_tools/transfer.h>
- #include <adc_tools/parameter_status.h>
- #include <common/constants.h>
- #include <math.h>
- std::vector<iv::GPSData> iv::decition::DubinsPlanner::gpsMap;
- iv::decition::DubinsPlanner::DubinsPlanner(){
- this->planner_id = 2;
- this->planner_name = "Dubins";
- }
- iv::decition::DubinsPlanner::~DubinsPlanner(){
- }
- std::vector<iv::Point2D> iv::decition::DubinsPlanner::getPath(GPS_INS now_gps_ins, const std::vector<GPSData>& gpsMapLine, int PathPoint, double offset, iv::LidarGridPtr lidarGridPtr){
- std::vector<iv::Point2D> trace;
- double L = 2.6;
- double R = L/sin(10.0*M_PI/180.0);
- std::cout<<" R = "<<R<<std::endl;
- gpsMap.clear();
- double q0[] = { now_gps_ins.gps_x, now_gps_ins.gps_y, now_gps_ins.ins_heading_angle};
- double q1[] = { gpsMapLine[PathPoint]->gps_x, gpsMapLine[PathPoint]->gps_y ,gpsMapLine[PathPoint]->ins_heading_angle };
- double turning_radius = 10.0;
- DubinsPath path;
- dubins_shortest_path( &path, q0, q1, turning_radius);
- dubins_path_sample_many( &path, 0.1, printConfiguration, NULL);
- }
- int iv::decition::DubinsPlanner::printConfiguration(double q[3], double x, void* user_data) {
- GPSData gps;
- gps->roadMode=5;
- gps->gps_x=q[0];
- gps->gps_y=q[1];
- gps->ins_heading_angle=q[3];
- gpsMap.push_back(gps);
- return 0;
- }
|