123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161 |
- #ifndef FRENET_PLANNER_H
- #define FRENET_PLANNER_H
- #include "base_planner.h"
- namespace iv{
- namespace decition{
-
-
-
-
- struct FrenetPoint{
- double x;
- double y;
- double s;
- double d;
- double tangent_Ang;
- };
- class Quintic_polynomial
- {
- public:
- Quintic_polynomial(double xs, double vxs, double axs, double xe, double vxe, double axe, double T);
- ~Quintic_polynomial();
- private:
-
- double xs;
- double vxs;
- double axs;
- double xe;
- double vxe;
- double axe;
- double a0;
- double a1;
- double a2;
- double a3;
- double a4;
- double a5;
- public:
- double calc_point(double t);
- double calc_first_derivative(double t);
- double calc_second_derivative(double t);
- double calc_third_derivative(double t);
- };
- class Quartic_polynomial
- {
- public:
- Quartic_polynomial(double xs, double vxs, double axs, double vxe, double axe, double T);
- ~Quartic_polynomial();
- private:
-
- double xs;
- double vxs;
- double axs;
- double vxe;
- double axe;
- double a0;
- double a1;
- double a2;
- double a3;
- double a4;
- public:
- double calc_point(double t);
- double calc_first_derivative(double t);
- double calc_second_derivative(double t);
- double calc_third_derivative(double t);
- };
- class Frenet_path
- {
- public:
- std::vector<double> t;
- std::vector<double> d;
- std::vector<double> d_d;
- std::vector<double> d_dd;
- std::vector<double> d_ddd;
- std::vector<double> s;
- std::vector<double> s_d;
- std::vector<double> s_dd;
- std::vector<double> s_ddd;
- int roadflag = -1;
- double cd = 0.0;
- double cv = 0.0;
- double cf = 0.0;
- std::vector<double> x;
- std::vector<double> y;
- std::vector<double> yaw;
- std::vector<double> ds;
- std::vector<double> c;
- };
- class FrenetPlanner : public BasePlanner{
- public:
- int aimRoadByFrenet = -1;
- int roadNow = -1;
- double leftWidth = 0.0;
- double rightWidth = 0.0;
- GPS_INS now_gps_ins;
- std::vector<GPSData> gpsMapLine;
- int PathPoint = 0;
- iv::LidarGridPtr lidarGridPtr;
- public:
- FrenetPlanner();
- ~FrenetPlanner();
-
- std::vector<iv::Point2D> getPath(GPS_INS now_gps_ins, const std::vector<GPSData>& gpsMapLine, int PathPoint, double offset, iv::LidarGridPtr lidarGridPtr);
- int chooseRoadByFrenet(GPS_INS now_gps_ins, const std::vector<GPSData>& gpsMapLine, int PathPoint, double offsetL, double offsetR, iv::LidarGridPtr lidarGridPtr,int roadNow);
- static iv::decition::FrenetPoint XY2Frenet(double x, double y, const std::vector<Point2D>& gpsTracet);
- static void Frenet2XY(double *x, double *y, double s, double d, const std::vector<iv::decition::FrenetPoint>& frenetTrace);
- static double distance(double x1, double y1, double x2, double y2);
- static int ClosestWaypoint(double x, double y, const std::vector<Point2D>& gpsTrace);
- static FrenetPoint getFrenetfromXY(double x, double y, const std::vector<iv::Point2D>& gpsTrace,const std::vector<iv::GPSData>& gpsMap,int pathpoint,GPS_INS nowGps);
- static void getXYfromFrenet(double *res_x, double *res_y, double s, double d, const std::vector<iv::decition::FrenetPoint>& frenetTrace,const std::vector<iv::GPSData>& gpsMap,int pathpoint,GPS_INS nowGps);
- static bool comp(const iv::decition::Frenet_path &a,const iv::decition::Frenet_path &b);
- private:
- std::vector<iv::Point2D> getGpsTrace_AfterCalcFrenetTrace(const std::vector<iv::Point2D>& gpsTrace,double realsecSpeed);
- std::vector<iv::Point2D> frenet_optimal_planning(FrenetPoint car_now_frenet_point,
- const std::vector<FrenetPoint>& frenet_s,
- double c_speed, double c_d_d, double c_d_dd);
- std::vector<Frenet_path> calc_frenet_paths(double c_speed, double c_d, double c_d_d, double c_d_dd, double s0);
- void calc_global_paths(std::vector<Frenet_path>& fplist,const std::vector<FrenetPoint>& frenet_s);
- void calc_global_single_path(Frenet_path& fp,const std::vector<FrenetPoint>& frenet_s);
- std::vector<Frenet_path> check_paths(const std::vector<Frenet_path>& fplist);
- bool check_single_path(const Frenet_path &fp);
- bool check_collision(const Frenet_path &frenet_path);
- std::vector<Point2D> frenet_path_to_gpsTrace(const Frenet_path& frenet_path);
- };
- }
- }
- #endif
|