日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Apollo:modules/planning/common/obstacle.cc分析

發布時間:2024/3/24 编程问答 55 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Apollo:modules/planning/common/obstacle.cc分析 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

Obstacle類是apollo planning模塊下modules\planning\common\obstacle.cc/.h實現

從名字來看,是障礙物類,表示將一個障礙物的所有相關信息封裝成這個類。

成員變量

成員類型變量名說明
std::stringid_;障礙物 id
int32_tperception_id_ = 0;感知障礙物id
boolis_static_ = false;障礙物是否為靜止
boolis_virtual_ = false;障礙物是否為虛擬的
doublespeed_ = 0.0;障礙物的速度
boolpath_st_boundary_initialized_ = false;st邊界初始化標志位
prediction::Trajectorytrajectory_;障礙物的預測軌跡
perception::PerceptionObstacleperception_obstacle_;
common::math::Box2dperception_bounding_box_;感知障礙物的邊界盒
common::math::Polygon2dperception_polygon_;感知障礙物多邊形邊界
std::vector< ObjectDecisionType>decisions_;障礙物決策
std::vector< std::string>decider_tags_;決策器標簽
SLBoundarysl_boundary_;st邊界
STBoundaryreference_line_st_boundary_;參考線st邊界
STBoundarypath_st_boundary_;路徑st邊界
ObjectDecisionTypelateral_decision_;橫向決策
ObjectDecisionTypelongitudinal_decision_;  縱向決策
boolis_blocking_obstacle_ = false;是不是阻塞了
boolis_lane_blocking_ = false;車道阻斷標志位
boolis_lane_change_blocking_ = false;交通阻斷標志位
boolis_caution_level_obstacle_ = false;注意級標志位
doublemin_radius_stop_distance_ = -1.0;最小半徑停止距離

障礙物的基本信息包括 id、速度、BoundingBox、預測軌跡;

除上述信息外,Obstacle 類成員變量還包括決策信息、SL/ST邊界

成員函數

//返回障礙物是否有軌跡?bool HasTrajectory() const {return !(trajectory_.trajectory_point().empty());}//返回感知障礙物對象,屬于Obstacle類成員const perception::PerceptionObstacle& Perception() const {return perception_obstacle_;}//判斷是否為有效的感知障礙物,輸入參數是感知障礙物類對象static bool IsValidPerceptionObstacle(const perception::PerceptionObstacle& obstacle);//判斷是否為有效的軌跡點,輸入參數是一個軌跡點類型對象 //只要軌跡點沒有路徑點 或 x/y/z/kappa/s/dkappa/ddkappa/v/a/relative_time里只要有 //一個為nan(not a number)就說明這個軌跡點是無效的,否則有效static bool IsValidTrajectoryPoint(const common::TrajectoryPoint& point);//內聯函數,返回障礙物是否為注意等級的障礙物?inline bool IsCautionLevelObstacle() const {return is_caution_level_obstacle_;}/*** return 融合的橫向決策(成員函數)* Lateral decision is one of {Nudge, Ignore}**/ //返回Obstacle類數據成員,針對這個障礙物的橫向決策const ObjectDecisionType& LateralDecision() const;/*** @brief return 融合的縱向決策(成員函數)* Longitudinal decision is one of {Stop, Yield, Follow, Overtake, Ignore}**/const ObjectDecisionType& LongitudinalDecision() const;//返回debug字符串std::string DebugString() const;/獲取該感知障礙物的sl邊界盒?是感知障礙物邊界在參考線上的投影?const SLBoundary& PerceptionSLBoundary() const;//獲取數據成員 參考線ST邊界const STBoundary& reference_line_st_boundary() const;//獲取數據成員 路徑ST邊界,是指該障礙物所占據的的路徑邊界?const STBoundary& path_st_boundary() const;//返回數據成員,決策標簽?一個字符串的vector,decider_tags_const std::vector<std::string>& decider_tags() const;//返回目標決策類型列表?const std::vector<ObjectDecisionType>& decisions() const;//針對該障礙物增加一個橫向決策,輸入參數決策標簽字符串decider_tag //以及目標決策類型對象decision //其實就是將輸入的目標橫向決策類型對象與之前類里儲存的進行融合。 //類的數據成員決策列表decisions_和決策標簽列表decider_tags_里再增加一個void AddLateralDecision(const std::string& decider_tag,const ObjectDecisionType& decision);//檢查針對該障礙物是否有橫向決策?bool HasLateralDecision() const;//設定路徑的ST邊界,也就是針對該障礙物的ST邊界?void set_path_st_boundary(const STBoundary& boundary);//返回數據成員 路徑ST邊界被初始化?bool is_path_st_boundary_initialized() {return path_st_boundary_initialized_;}//設置ST邊界類型?void SetStBoundaryType(const STBoundary::BoundaryType type);//擦除類里儲存的路徑ST邊界void EraseStBoundary();//設定道路參考線的ST邊界void SetReferenceLineStBoundary(const STBoundary& boundary);//設定道路參考線ST邊界類型void SetReferenceLineStBoundaryType(const STBoundary::BoundaryType type);//擦除類里儲存的道路參考線ST邊界void EraseReferenceLineStBoundary();//檢查針對該障礙物是否有縱向決策?bool HasLongitudinalDecision() const;//針對該障礙物的決策是否不可忽略bool HasNonIgnoreDecision() const;/*** @brief* 用自車的最小轉彎半徑去計算到該障礙物的停止距離*/double MinRadiusStopDistance(const common::VehicleParam& vehicle_param) const;/*** @brief* 檢查該障礙物是否可以被安全的忽略* 目標可以被忽略僅當縱向和橫向決策都是可以忽略的時候*/bool IsIgnore() const;bool IsLongitudinalIgnore() const;bool IsLateralIgnore() const;//針對障礙物對象建立自車參考線的ST邊界,輸入參數是道路參考線類對象,以及adc自車的起始s坐標,將障礙物投影到自車的ST圖上void BuildReferenceLineStBoundary(const ReferenceLine& reference_line,const double adc_start_s);//設置障礙物的SL邊界也就是Frenet系的橫縱坐標的邊界類對象sl_boundary //輸入參數就是SLBoundary SL邊界類對象 //就是將參數拷貝給類數據成員sl_boundary_ 其實就是障礙物邊界點相對于道路參考線的SL坐標void SetPerceptionSlBoundary(const SLBoundary& sl_boundary);/*** @brief * 是否為縱向決策,有ignore,有stop/yield/follow/overtake都是**/static bool IsLongitudinalDecision(const ObjectDecisionType& decision);//nudge在apollo里代表橫向上輕輕繞一下避開? //判斷目標決策類型對象是橫向決策?如果有ignore或nudge就認為是static bool IsLateralDecision(const ObjectDecisionType& decision);//設置該障礙物為阻塞障礙物?void SetBlockingObstacle(bool blocking) { is_blocking_obstacle_ = blocking; }//返回該障礙物是否為阻塞自車的障礙物?bool IsBlockingObstacle() const { return is_blocking_obstacle_; }/** @brief IsLaneBlocking is only meaningful when IsStatic() == true.* 只有當障礙物為靜態時,判斷車道是否被阻塞*/bool IsLaneBlocking() const { return is_lane_blocking_; }void CheckLaneBlocking(const ReferenceLine& reference_line);bool IsLaneChangeBlocking() const { return is_lane_change_blocking_; }void SetLaneChangeBlocking(const bool is_distance_clear);private:FRIEND_TEST(MergeLongitudinalDecision, AllDecisions);static ObjectDecisionType MergeLongitudinalDecision(const ObjectDecisionType& lhs, const ObjectDecisionType& rhs);FRIEND_TEST(MergeLateralDecision, AllDecisions);static ObjectDecisionType MergeLateralDecision(const ObjectDecisionType& lhs,const ObjectDecisionType& rhs);//建立軌跡的ST邊界 //輸入參數 參考線類對象,自車起始的frenet系縱坐標s,第三個參數用以存放得到的結果 //這個函數的實現代碼沒太看明白,大致就是根據參考線,自車的縱向坐標s,用動態感知障礙物對象及其預測軌跡去修改之前的自車參考線ST邊界,起始就是用該障礙物信息去修正ST圖中搜索的可行域?將動態障礙物投影到自車的ST圖上。bool BuildTrajectoryStBoundary(const ReferenceLine& reference_line,const double adc_start_s,STBoundary* const st_boundary);//是否為有效的障礙物,主要是看感知障礙物的長寬是否為nan(not a number)或者過于小了,是的話就說明是無效的障礙物bool IsValidObstacle(const perception::PerceptionObstacle& perception_obstacle); namespace { //又定義了個namespace防止其他程序引用該類時出現重名重復定義現象。 //定義了3個常量 //ST邊界s的差值閾值 0.2m? const double kStBoundaryDeltaS = 0.2; // meters //ST邊界的逃離s的差值 1.0m? const double kStBoundarySparseDeltaS = 1.0; // meters //ST邊界的時間差值閾值0.05s const double kStBoundaryDeltaT = 0.05; // seconds } // namespace//定義了一個無序map s_longitudinal_decision_safety_sorter_,存放目標場景標簽和縱向距離的映射? //這個map的名字字面意義來看,縱向決策安全分類? const std::unordered_map<ObjectDecisionType::ObjectTagCase, int,Obstacle::ObjectTagCaseHash>Obstacle::s_longitudinal_decision_safety_sorter_ = {{ObjectDecisionType::kIgnore, 0}, //忽略?{ObjectDecisionType::kOvertake, 100}, //超車{ObjectDecisionType::kFollow, 300}, //跟車{ObjectDecisionType::kYield, 400}, //避讓{ObjectDecisionType::kStop, 500}}; //停車//定義了一個無序map s_lateral_decision_safety_sorter_,存放目標場景標簽和橫向距離的映射? //這個map的名字字面意義來看,橫向決策安全分類? const std::unordered_map<ObjectDecisionType::ObjectTagCase, int,Obstacle::ObjectTagCaseHash>Obstacle::s_lateral_decision_safety_sorter_ = {//橫向決策忽略,Nudge是靠邊避讓?{ObjectDecisionType::kIgnore, 0}, {ObjectDecisionType::kNudge, 100}};

構造函數

/** 參數:* id:障礙物id* perception_obstacle: 預測障礙物* obstacle_priority: 障礙物優先級* is_static: 是不是靜態障礙物*/ Obstacle::Obstacle(const std::string& id,const PerceptionObstacle& perception_obstacle,const ObstaclePriority::Priority& obstacle_priority,const bool is_static): id_(id),perception_id_(perception_obstacle.id()),perception_obstacle_(perception_obstacle),perception_bounding_box_({perception_obstacle_.position().x(),perception_obstacle_.position().y()},perception_obstacle_.theta(),perception_obstacle_.length(),perception_obstacle_.width()) {is_caution_level_obstacle_ = (obstacle_priority == ObstaclePriority::CAUTION);std::vector<common::math::Vec2d> polygon_points;if (FLAGS_use_navigation_mode || // 是否是導航模式(默認為false)perception_obstacle.polygon_point_size() <= 2) {//或者預測障礙物多邊形點的數量小于等于2// 獲取感知障礙物邊界盒的所有頂點,頂點就是根據感知的長寬,幾何中心,heading角計算而來perception_bounding_box_.GetAllCorners(&polygon_points);} else {ACHECK(perception_obstacle.polygon_point_size() > 2)<< "object " << id << "has less than 3 polygon points";// 把感知障礙物的多邊形點放入vector polygon_pointsfor (const auto& point : perception_obstacle.polygon_point()) {polygon_points.emplace_back(point.x(), point.y());}}// 計算感知障礙物多邊形點集的凸包,得到的多邊形結果ACHECK(common::math::Polygon2d::ComputeConvexHull(polygon_points,&perception_polygon_))<< "object[" << id << "] polygon is not a valid convex hull.\n"<< perception_obstacle.DebugString();// 判斷是否為靜態 = 是否為靜態 或// 障礙物優先級為可忽略,就是障礙物可忽略的話也可直接視為靜態障礙物is_static_ = (is_static || obstacle_priority == ObstaclePriority::IGNORE);// 是否為虛擬障礙物,若感知障礙物id<0的話則為虛擬障礙物is_virtual_ = (perception_obstacle.id() < 0);// 其實就是計算下感知障礙物速度X方向,Y方向的矢量和speed_ = std::hypot(perception_obstacle.velocity().x(),perception_obstacle.velocity().y()); }Obstacle::Obstacle(const std::string& id,const PerceptionObstacle& perception_obstacle,const prediction::Trajectory& trajectory,const ObstaclePriority::Priority& obstacle_priority,const bool is_static): Obstacle(id, perception_obstacle, obstacle_priority, is_static) {trajectory_ = trajectory;// 取出預測軌跡的軌跡點trajectory_pointsauto& trajectory_points = *trajectory_.mutable_trajectory_point();double cumulative_s = 0.0; // 初始定義了一個累計縱向距離s cumulative_sif (trajectory_points.size() >0) { // 如果軌跡點的數目大于0 軌跡點的第一個點的s設置為0,其實就// 相對第一個軌跡點的相對縱坐標strajectory_points[0].mutable_path_point()->set_s(0.0);}// 從預測軌跡點的第二個點開始遍歷設置相對縱坐標s,第一個點上面已經設置了for (int i = 1; i < trajectory_points.size(); ++i) {const auto& prev = trajectory_points[i - 1];const auto& cur = trajectory_points[i];// 如果前繼點的相對時間 >= 當前點相對時間,報錯if (prev.relative_time() >= cur.relative_time()) {AERROR << "prediction time is not increasing."<< "current point: " << cur.ShortDebugString()<< "previous point: " << prev.ShortDebugString();}// 累計的縱向位置s=上次累計的縱向位置s + 第i-1個點到第i個點的距離cumulative_s +=common::util::DistanceXY(prev.path_point(), cur.path_point());// 設定第i個點的相對起點的縱坐標strajectory_points[i].mutable_path_point()->set_s(cumulative_s);} }

根據時間查詢預測軌跡點:GetPointAtTime

// 根據時間查詢預測軌跡點 // 輸入參數: 相對時間relative_time common::TrajectoryPoint Obstacle::GetPointAtTime(const double relative_time) const {// 首先去預測軌跡trajectory_上取出所有的預測軌跡點const auto& points = trajectory_.trajectory_point();// 如果預測軌跡點個數小于2,那么軌跡點point的s,t,v,a直接設置為0,x,y,z,theta直接設置為當前值返回這個軌跡點if (points.size() < 2) {common::TrajectoryPoint point;point.mutable_path_point()->set_x(perception_obstacle_.position().x());point.mutable_path_point()->set_y(perception_obstacle_.position().y());point.mutable_path_point()->set_z(perception_obstacle_.position().z());point.mutable_path_point()->set_theta(perception_obstacle_.theta());point.mutable_path_point()->set_s(0.0);point.mutable_path_point()->set_kappa(0.0);point.mutable_path_point()->set_dkappa(0.0);point.mutable_path_point()->set_ddkappa(0.0);point.set_v(0.0);point.set_a(0.0);point.set_relative_time(0.0);return point;} else {// std::lower_bound的用法就是遍歷預測軌跡點,找到第一個小于給定時間的軌跡點auto comp = [](const common::TrajectoryPoint p, const double time) {return p.relative_time() < time;};auto it_lower =std::lower_bound(points.begin(), points.end(), relative_time, comp);// 如果it_lower是預測軌跡里的第一個點/最后一個點就直接返回之if (it_lower == points.begin()) {return *points.begin();} else if (it_lower == points.end()) {return *points.rbegin();}// 如果it_lower不是預測軌跡里的第一個點/最后一個點就用it_lower和其上一個點線性插值得到relative_time對應的軌跡點信息并返回return common::math::InterpolateUsingLinearApproximation(*(it_lower - 1), *it_lower, relative_time);} }

獲取障礙物的2維邊界盒:Obstacle::GetBoundingBox

//其實就是軌跡點作為幾何中心點其x,y,theta信息加上數據成員感知障礙物的長寬構建二維邊界盒 common::math::Box2d Obstacle::GetBoundingBox(const common::TrajectoryPoint& point) const {return common::math::Box2d({point.path_point().x(), point.path_point().y()},point.path_point().theta(),perception_obstacle_.length(),perception_obstacle_.width()); }

是否為有效的感知障礙物:IsValidPerceptionObstacle

//判斷是否為有效的感知障礙物,輸入參數是感知障礙物類對象 bool Obstacle::IsValidPerceptionObstacle(const PerceptionObstacle& obstacle) {//如果感知障礙物的長寬高<=0自然是無效的感知障礙物,直接報錯返回if (obstacle.length() <= 0.0) {AERROR << "invalid obstacle length:" << obstacle.length();return false;}if (obstacle.width() <= 0.0) {AERROR << "invalid obstacle width:" << obstacle.width();return false;}if (obstacle.height() <= 0.0) {AERROR << "invalid obstacle height:" << obstacle.height();return false;}//如果感知障礙物有速度if (obstacle.has_velocity()) {//如果感知障礙物的X方向速度 或 Y方向速度只要有一個為nan(not a number)則直接返回falseif (std::isnan(obstacle.velocity().x()) ||std::isnan(obstacle.velocity().y())) {AERROR << "invalid obstacle velocity:"<< obstacle.velocity().DebugString();return false;}}//上面都不滿足沒有返回,那么遍歷感知障礙物的多邊形點,只要有一個點的x或y坐標為nan(not a number)就直接返回falsefor (auto pt : obstacle.polygon_point()) {if (std::isnan(pt.x()) || std::isnan(pt.y())) {AERROR << "invalid obstacle polygon point:" << pt.DebugString();return false;}}//上面情況都不滿足,說明感知障礙物是個有效的障礙物return true; }

根據預測輸出構造:Obstacle::CreateObstacles

/*** @brief 根據預測數據構建障礙物* @param predictions 預測結果* @return obstacles 障礙物對象列表*/ std::list<std::unique_ptr<Obstacle>> Obstacle::CreateObstacles(const prediction::PredictionObstacles& predictions) {std::list<std::unique_ptr<Obstacle>> obstacles;// 遍歷預測障礙物列表for (const auto& prediction_obstacle : predictions.prediction_obstacle()) {// 判斷預測障礙物的成員感知障礙物是否是有效的感知障礙物,否則報錯并跳到下一個障礙物if (!IsValidPerceptionObstacle(prediction_obstacle.perception_obstacle())) {AERROR << "Invalid perception obstacle: "<< prediction_obstacle.perception_obstacle().DebugString();continue;}// 將第i個被遍歷的預測障礙物的id,軌跡,優先級,是否為靜態障礙物作為參數調用Obstacle類的構造函數,獲得的對象塞到障礙物類對象指針列表obstaclesconst auto perception_id =std::to_string(prediction_obstacle.perception_obstacle().id());if (prediction_obstacle.trajectory().empty()) {obstacles.emplace_back(new Obstacle(perception_id, prediction_obstacle.perception_obstacle(),prediction_obstacle.priority().priority(),prediction_obstacle.is_static()));continue;}// 遍歷第i個預測障礙物的預測軌跡,// 判斷是否都是合法的軌跡,如果不是,則直接跳到下一個障礙物int trajectory_index = 0;for (const auto& trajectory : prediction_obstacle.trajectory()) {bool is_valid_trajectory = true;for (const auto& point :trajectory.trajectory_point()) { // 遍歷預測軌跡點if (!IsValidTrajectoryPoint(point)) {AERROR << "obj:" << perception_id<< " TrajectoryPoint: " << trajectory.ShortDebugString()<< " is NOT valid.";is_valid_trajectory = false;break;}}if (!is_valid_trajectory) {continue;}// 若執行到這里說明第i個障礙物有效,且其預測軌跡是有效的// 那么就將其id,優先級,預測軌跡,是否為靜態障礙物的信息截出來拿去調用Obstacle類的構造函數,得到的障礙物對象塞入障礙物對象列表obstacles待返回const std::string obstacle_id =absl::StrCat(perception_id, "_", trajectory_index);obstacles.emplace_back(new Obstacle(obstacle_id, prediction_obstacle.perception_obstacle(),trajectory, prediction_obstacle.priority().priority(),prediction_obstacle.is_static()));++trajectory_index;}}return obstacles; }

創建虛擬障礙物:Obstacle::CreateStaticVirtualObstacles

判斷是否為有效的軌跡點:Obstacle::IsValidTrajectoryPoint

設置障礙物的SL邊界:Obstacle::SetPerceptionSlBoundary

//設置障礙物的SL邊界也就是Frenet系的橫縱坐標的邊界類對象sl_boundary。其實就是障礙物邊界點相對于道路參考線的SL坐標 void Obstacle::SetPerceptionSlBoundary(const SLBoundary& sl_boundary) {sl_boundary_ = sl_boundary; }

計算停車距離: Obstacle::MinRadiusStopDistance

//使用自車的最小轉彎半徑計算停車距離。輸入參數:車輛參數類對象 double Obstacle::MinRadiusStopDistance(const common::VehicleParam& vehicle_param) const {//如果針對這個障礙物的最小轉彎半徑的停車距離>0則直接返回?是說明已經設置了嗎?if (min_radius_stop_distance_ > 0) {return min_radius_stop_distance_;}static constexpr double stop_distance_buffer = 0.5; //定義一個停止距離的緩沖區0.5mconst double min_turn_radius = VehicleConfigHelper::MinSafeTurnRadius();//獲取車輛參數的最小轉彎半徑//sl_boundary_其實就是障礙物邊界點相對于道路參考線的SL坐標double lateral_diff =vehicle_param.width() / 2.0 + std::max(std::fabs(sl_boundary_.start_l()),std::fabs(sl_boundary_.end_l()));const double kEpison = 1e-5;lateral_diff = std::min(lateral_diff, min_turn_radius - kEpison);//利用勾股定理計算計算最小轉彎半徑下的停車距離double stop_distance =std::sqrt(std::fabs(min_turn_radius * min_turn_radius -(min_turn_radius - lateral_diff) *(min_turn_radius - lateral_diff))) +stop_distance_buffer;stop_distance -= vehicle_param.front_edge_to_center();//對這個停車距離再進行限幅并返回stop_distance = std::min(stop_distance, FLAGS_max_stop_distance_obstacle);stop_distance = std::max(stop_distance, FLAGS_min_stop_distance_obstacle);return stop_distance; } //針對障礙物對象建立自車參考線的ST邊界,輸入參數是道路參考線類對象,以及adc自車的起始s坐標,將障礙物投影到自車的ST圖上 //文字不足以描述,詳細原理見文末附圖 void Obstacle::BuildReferenceLineStBoundary(const ReferenceLine& reference_line,const double adc_start_s) {//獲取ADC 自動駕駛車輛的物理參數配置const auto& adc_param =VehicleConfigHelper::Instance()->GetConfig().vehicle_param();//獲取車輛物理參數中的寬度const double adc_width = adc_param.width();//如果障礙物類成員表明其是靜態障礙物或障礙物預測軌跡點為空,其實就是個靜止障礙物?if (is_static_ || trajectory_.trajectory_point().empty()) {//定義一個存放STPoint點對的vetor point_pairsstd::vector<std::pair<STPoint, STPoint>> point_pairs;//sl_boundary_其實就是障礙物邊界點相對于道路參考線的SL坐標//獲取障礙物在參考線上對應的起始s坐標,其實就是障礙物的尾部邊界點?double start_s = sl_boundary_.start_s();//獲取障礙物在參考線上對應的終點s坐標,其實就是障礙物的頭部邊界點?double end_s = sl_boundary_.end_s();//如果終點s-起點s<閾值0.2m,那么終點s=起點s+0.2mif (end_s - start_s < kStBoundaryDeltaS) {end_s = start_s + kStBoundaryDeltaS;}//參考線道路被阻塞?輸入參數是感知障礙物邊界盒,自車的寬度//檢查是否有邊界盒堵塞了路面。標準是檢查路面上的剩余空間是否大于自車寬度。if (!reference_line.IsBlockRoad(perception_bounding_box_, adc_width)) {return;}//往ST邊界里塞ST點對,起點t 0.0//S分別塞入(障礙物SL邊界起始點s-自車的起始s,0.0) (SL邊界終點s-自車的起始s)//其實就是這個障礙物的S邊界上下限距離自車起始點s的距離//相對時間0對應的S邊界就是自車到障礙物頭部和尾部縱向位置的差值?這個邊界其實還是//障礙物的頭部尾部的相對縱向位置s投影到自車參考線上//其實就是把障礙物投影到自車的ST圖上?//相對時間0也就是當下,直接把現在障礙物頭部尾部所處位置直接放入ST圖point_pairs.emplace_back(STPoint(start_s - adc_start_s, 0.0),STPoint(end_s - adc_start_s, 0.0)); //因為這是一個靜態障礙物(在這個大if里說明是靜態障礙物) ,障礙物會阻塞參考線//s軸上相對自車位置的s坐標8s(最大ST規劃時間?)//認為這8s該障礙物頭部尾部會一直占據start_s到end_s位置 point_pairs.emplace_back(STPoint(start_s - adc_start_s, FLAGS_st_max_t),STPoint(end_s - adc_start_s, FLAGS_st_max_t));//障礙物類成員參考線ST邊界就為這個障礙物相對縱向位置占據8sreference_line_st_boundary_ = STBoundary(point_pairs);} else { //不是靜態障礙物的話,調用建立軌跡ST邊界函數,輸入參數是道路參考線,自車的起始s,求得的st邊界放入reference_line_st_boundary_,起始就是對于這個障礙物對象將其的影響考慮成對參考線ST邊界的影響上,其實就是將動態障礙物映射到ST圖上?if (BuildTrajectoryStBoundary(reference_line, adc_start_s,&reference_line_st_boundary_)) {ADEBUG << "Found st_boundary for obstacle " << id_;ADEBUG << "st_boundary: min_t = " << reference_line_st_boundary_.min_t()<< ", max_t = " << reference_line_st_boundary_.max_t()<< ", min_s = " << reference_line_st_boundary_.min_s()<< ", max_s = " << reference_line_st_boundary_.max_s();} else {ADEBUG << "No st_boundary for obstacle " << id_;}} }//建立軌跡的ST邊界 //輸入參數 參考線類對象,自車起始的frenet系縱坐標s,第三個參數用以存放得到的結果 //這個函數的實現代碼沒太看明白,大致就是根據參考線,自車的縱向坐標s,用動態感知障礙物對象及其預測軌跡去修改之前的自車參考線ST邊界,起始就是用該障礙物信息去修正ST圖中搜索的可行域?將動態障礙物投影到自車的ST圖上。 bool Obstacle::BuildTrajectoryStBoundary(const ReferenceLine& reference_line,const double adc_start_s,STBoundary* const st_boundary) {//如果不是有效的感知障礙物直接返回falseif (!IsValidObstacle(perception_obstacle_)) {AERROR << "Fail to build trajectory st boundary because object is not ""valid. PerceptionObstacle: "<< perception_obstacle_.DebugString();return false;}//獲取這個障礙物的長寬,以及預測軌跡點const double object_width = perception_obstacle_.width();const double object_length = perception_obstacle_.length();const auto& trajectory_points = trajectory_.trajectory_point();//如果預測軌跡點為空直接返回falseif (trajectory_points.empty()) {AWARN << "object " << id_ << " has no trajectory points";return false;}//獲取自車的物理參數,長度,長度一半,寬度const auto& adc_param =VehicleConfigHelper::Instance()->GetConfig().vehicle_param();const double adc_length = adc_param.length();const double adc_half_length = adc_length / 2.0;const double adc_width = adc_param.width();//這里創建了兩個邊界盒對象最小盒,最大盒?沒看到在哪里用?//Box2d構造函數,center中心點,heading,length,widthcommon::math::Box2d min_box({0, 0}, 1.0, 1.0, 1.0);common::math::Box2d max_box({0, 0}, 1.0, 1.0, 1.0);//ST點,就是縱向位置s和時間t構成的點(s,t)//又創建了一個ST點對的vector polygon_points,多邊形點?std::vector<std::pair<STPoint, STPoint>> polygon_points;//又創建了一個SL邊界類對象,last_sl_boundary上一次的sl邊界?SLBoundary last_sl_boundary;//初始定義了上次的索引為0 last_indexint last_index = 0;//從障礙物預測軌跡的第二個點開始遍歷for (int i = 1; i < trajectory_points.size(); ++i) {ADEBUG << "last_sl_boundary: " << last_sl_boundary.ShortDebugString();//traj軌跡 = path路徑 + 速度規劃//障礙物第i-1個預測軌跡點const auto& first_traj_point = trajectory_points[i - 1];//障礙物第i個預測軌跡點const auto& second_traj_point = trajectory_points[i];//障礙物第i-1個預測軌跡點上的路徑點const auto& first_point = first_traj_point.path_point();//障礙物第i個預測軌跡點上的路徑點const auto& second_point = second_traj_point.path_point();//定義了一個物體移動邊界盒長度 = 物體本身長度 + 兩個軌跡點之間的長度,又準備搞障礙物第//i個軌跡點的邊界盒了double object_moving_box_length =object_length + common::util::DistanceXY(first_point, second_point);//定義該障礙物(Obstacle類實例)第i個軌跡點的邊界盒的中心,就是第i個,i-1軌跡點的中點common::math::Vec2d center((first_point.x() + second_point.x()) / 2.0,(first_point.y() + second_point.y()) / 2.0);//構建一個2維邊界盒對象 object_moving_box物體移動邊界盒,center,heading,length,width,headingcommon::math::Box2d object_moving_box(center, first_point.theta(), object_moving_box_length, object_width);//又定義了SL邊界類對象 object_boundary 目標邊界?SLBoundary object_boundary;//Apollo原注釋//注意:這種方法在參考線不是直的時候有誤差,需要雙回路來cover所有的corner cases。//粗糙的跳過距離上次sl邊界盒過近的點?//這里就是計算障礙物第i預測軌跡點和第i-1個點之間的距離//上一個點的索引并不是單純的i-1而是由last_index控制,如果可以忽略的情況下last_index并不會遞增const double distance_xy =common::util::DistanceXY(trajectory_points[last_index].path_point(),trajectory_points[i].path_point());//大致意思是障礙物從i-1個點挪動到第i個軌跡點,橫向上變化量假設最惡劣變化distance_xy兩點間直線距離,都沒有超過上一次的SL邊界,就直接跳到下一個軌跡點?這塊原理不是特別清楚?if (last_sl_boundary.start_l() > distance_xy ||last_sl_boundary.end_l() < -distance_xy) {continue;}//上一次SL邊界的縱向中點const double mid_s =(last_sl_boundary.start_s() + last_sl_boundary.end_s()) / 2.0;const double start_s = std::fmax(0.0, mid_s - 2.0 * distance_xy);const double end_s = (i == 1) ? reference_line.Length(): std::fmin(reference_line.Length(),mid_s + 2.0 * distance_xy);if (!reference_line.GetApproximateSLBoundary(object_moving_box, start_s,end_s, &object_boundary)) {AERROR << "failed to calculate boundary";return false;}// update history recordlast_sl_boundary = object_boundary;last_index = i;//跳過障礙物,如果它在道路參考線的一邊的話,在橫向上相對參考線的偏移大于//自車車寬一半+障礙物車長*0.4那么就忽略這個軌跡點static constexpr double kSkipLDistanceFactor = 0.4;const double skip_l_distance =(object_boundary.end_s() - object_boundary.start_s()) *kSkipLDistanceFactor +adc_width / 2.0; //跳過障礙物,如果它在道路參考線的一邊的話,在橫向上相對參考線的偏移大于//自車車寬一半+障礙物車長*0.4那么就忽略這個軌跡點if (!IsCautionLevelObstacle() &&(std::fmin(object_boundary.start_l(), object_boundary.end_l()) >skip_l_distance ||std::fmax(object_boundary.start_l(), object_boundary.end_l()) <-skip_l_distance)) {continue;}//如果障礙物的level不是Caution需要注意這個級別或者障礙物頭部都在自車后方,這個軌跡點也可忽略if (!IsCautionLevelObstacle() && object_boundary.end_s() < 0) {// skip if behind reference linecontinue;}static constexpr double kSparseMappingS = 20.0;const double st_boundary_delta_s =(std::fabs(object_boundary.start_s() - adc_start_s) > kSparseMappingS)? kStBoundarySparseDeltaS: kStBoundaryDeltaS;const double object_s_diff =object_boundary.end_s() - object_boundary.start_s();if (object_s_diff < st_boundary_delta_s) {continue;}const double delta_t =second_traj_point.relative_time() - first_traj_point.relative_time();double low_s = std::max(object_boundary.start_s() - adc_half_length, 0.0);bool has_low = false;double high_s =std::min(object_boundary.end_s() + adc_half_length, FLAGS_st_max_s);bool has_high = false;while (low_s + st_boundary_delta_s < high_s && !(has_low && has_high)) {if (!has_low) {auto low_ref = reference_line.GetReferencePoint(low_s);has_low = object_moving_box.HasOverlap({low_ref, low_ref.heading(), adc_length,adc_width + FLAGS_nonstatic_obstacle_nudge_l_buffer});low_s += st_boundary_delta_s;}if (!has_high) {auto high_ref = reference_line.GetReferencePoint(high_s);has_high = object_moving_box.HasOverlap({high_ref, high_ref.heading(), adc_length,adc_width + FLAGS_nonstatic_obstacle_nudge_l_buffer});high_s -= st_boundary_delta_s;}}if (has_low && has_high) {low_s -= st_boundary_delta_s;high_s += st_boundary_delta_s;double low_t =(first_traj_point.relative_time() +std::fabs((low_s - object_boundary.start_s()) / object_s_diff) *delta_t);polygon_points.emplace_back(std::make_pair(STPoint{low_s - adc_start_s, low_t},STPoint{high_s - adc_start_s, low_t}));double high_t =(first_traj_point.relative_time() +std::fabs((high_s - object_boundary.start_s()) / object_s_diff) *delta_t);if (high_t - low_t > 0.05) {polygon_points.emplace_back(std::make_pair(STPoint{low_s - adc_start_s, high_t},STPoint{high_s - adc_start_s, high_t}));}}}if (!polygon_points.empty()) {std::sort(polygon_points.begin(), polygon_points.end(),[](const std::pair<STPoint, STPoint>& a,const std::pair<STPoint, STPoint>& b) {return a.first.t() < b.first.t();});auto last = std::unique(polygon_points.begin(), polygon_points.end(),[](const std::pair<STPoint, STPoint>& a,const std::pair<STPoint, STPoint>& b) {return std::fabs(a.first.t() - b.first.t()) <kStBoundaryDeltaT;});polygon_points.erase(last, polygon_points.end());if (polygon_points.size() > 2) {*st_boundary = STBoundary(polygon_points);}} else {return false;}return true; }//獲取數據成員 參考線ST邊界 const STBoundary& Obstacle::reference_line_st_boundary() const {return reference_line_st_boundary_; } //獲取數據成員 路徑ST邊界 const STBoundary& Obstacle::path_st_boundary() const {return path_st_boundary_; }//返回數據成員,決策標簽?一個字符串的vector,decider_tags_ const std::vector<std::string>& Obstacle::decider_tags() const {return decider_tags_; }//返回目標決策類型列表? const std::vector<ObjectDecisionType>& Obstacle::decisions() const {return decisions_; }//nudge在apollo里代表橫向上輕輕繞一下避開? //判斷目標決策類型對象是橫向決策?如果有ignore或nudge就認為是 bool Obstacle::IsLateralDecision(const ObjectDecisionType& decision) {return decision.has_ignore() || decision.has_nudge(); }//是否為縱向決策 //有ignore,有stop/yield/follow/overtake都是 bool Obstacle::IsLongitudinalDecision(const ObjectDecisionType& decision) {return decision.has_ignore() || decision.has_stop() || decision.has_yield() ||decision.has_follow() || decision.has_overtake(); }//融合兩個縱向決策類型對象,保留更保守的那個 //停車/跟車/減速避讓都保留縱向距離更大的那個 //超車保留縱向距離更大的那個 ObjectDecisionType Obstacle::MergeLongitudinalDecision(const ObjectDecisionType& lhs, const ObjectDecisionType& rhs) {if (lhs.object_tag_case() == ObjectDecisionType::OBJECT_TAG_NOT_SET) {return rhs;}if (rhs.object_tag_case() == ObjectDecisionType::OBJECT_TAG_NOT_SET) {return lhs;}//portobuf庫FindOrDie:查找map容器中指定key的value值地址,否則拋出FatalException異常或終止進程const auto lhs_val =FindOrDie(s_longitudinal_decision_safety_sorter_, lhs.object_tag_case());const auto rhs_val =FindOrDie(s_longitudinal_decision_safety_sorter_, rhs.object_tag_case());if (lhs_val < rhs_val) {return rhs;} else if (lhs_val > rhs_val) {return lhs;} else {if (lhs.has_ignore()) {return rhs;} else if (lhs.has_stop()) {return lhs.stop().distance_s() < rhs.stop().distance_s() ? lhs : rhs;} else if (lhs.has_yield()) {return lhs.yield().distance_s() < rhs.yield().distance_s() ? lhs : rhs;} else if (lhs.has_follow()) {return lhs.follow().distance_s() < rhs.follow().distance_s() ? lhs : rhs;} else if (lhs.has_overtake()) {return lhs.overtake().distance_s() > rhs.overtake().distance_s() ? lhs: rhs;} else {DCHECK(false) << "Unknown decision";}}return lhs; // stop compiler complaining }//返回Obstacle類數據成員,針對這個障礙物的縱向決策 const ObjectDecisionType& Obstacle::LongitudinalDecision() const {return longitudinal_decision_; } //返回Obstacle類數據成員,針對這個障礙物的橫向決策 const ObjectDecisionType& Obstacle::LateralDecision() const {return lateral_decision_; }//障礙物可被忽略?調用函數判斷橫/縱向均可被忽略? bool Obstacle::IsIgnore() const {return IsLongitudinalIgnore() && IsLateralIgnore(); }//判斷該障礙物縱向決策是否為可忽略? bool Obstacle::IsLongitudinalIgnore() const {return longitudinal_decision_.has_ignore(); }//判斷該障礙物橫向決策是否為可忽略? bool Obstacle::IsLateralIgnore() const {return lateral_decision_.has_ignore(); }//融合兩個橫向的目標決策類型對象,保留避讓nudge距離大的那個橫向目標決策類型對象并返回 ObjectDecisionType Obstacle::MergeLateralDecision(const ObjectDecisionType& lhs, const ObjectDecisionType& rhs) {if (lhs.object_tag_case() == ObjectDecisionType::OBJECT_TAG_NOT_SET) {return rhs;}if (rhs.object_tag_case() == ObjectDecisionType::OBJECT_TAG_NOT_SET) {return lhs;}const auto lhs_val =FindOrDie(s_lateral_decision_safety_sorter_, lhs.object_tag_case());const auto rhs_val =FindOrDie(s_lateral_decision_safety_sorter_, rhs.object_tag_case());if (lhs_val < rhs_val) {return rhs;} else if (lhs_val > rhs_val) {return lhs;} else {if (lhs.has_ignore()) {return rhs;} else if (lhs.has_nudge()) {DCHECK(lhs.nudge().type() == rhs.nudge().type())<< "could not merge left nudge and right nudge";return std::fabs(lhs.nudge().distance_l()) >std::fabs(rhs.nudge().distance_l())? lhs: rhs;}}DCHECK(false) << "Does not have rule to merge decision: "<< lhs.ShortDebugString()<< " and decision: " << rhs.ShortDebugString();return lhs; }//檢查針對該障礙物是否有橫向決策? bool Obstacle::HasLateralDecision() const {return lateral_decision_.object_tag_case() !=ObjectDecisionType::OBJECT_TAG_NOT_SET; }//檢查針對該障礙物是否有縱向決策? bool Obstacle::HasLongitudinalDecision() const {return longitudinal_decision_.object_tag_case() !=ObjectDecisionType::OBJECT_TAG_NOT_SET; }//針對該障礙物的決策是否不可忽略 bool Obstacle::HasNonIgnoreDecision() const {return (HasLateralDecision() && !IsLateralIgnore()) ||(HasLongitudinalDecision() && !IsLongitudinalIgnore()); }//針對該障礙物增加一個縱向決策,輸入參數決策標簽字符串decider_tag //以及目標決策類型對象decision //其實就是將輸入的目標縱向決策類型對象與之前類里儲存的進行融合。 //類的數據成員決策列表decisions_和決策標簽列表decider_tags_里再增加一個 void Obstacle::AddLongitudinalDecision(const std::string& decider_tag,const ObjectDecisionType& decision) {DCHECK(IsLongitudinalDecision(decision))<< "Decision: " << decision.ShortDebugString()<< " is not a longitudinal decision";longitudinal_decision_ =MergeLongitudinalDecision(longitudinal_decision_, decision);ADEBUG << decider_tag << " added obstacle " << Id()<< " longitudinal decision: " << decision.ShortDebugString()<< ". The merged decision is: "<< longitudinal_decision_.ShortDebugString();decisions_.push_back(decision);decider_tags_.push_back(decider_tag); }//針對該障礙物增加一個橫向決策,輸入參數決策標簽字符串decider_tag //以及目標決策類型對象decision //其實就是將輸入的目標橫向決策類型對象與之前類里儲存的進行融合。 //類的數據成員決策列表decisions_和決策標簽列表decider_tags_里再增加一個 void Obstacle::AddLateralDecision(const std::string& decider_tag,const ObjectDecisionType& decision) {DCHECK(IsLateralDecision(decision))<< "Decision: " << decision.ShortDebugString()<< " is not a lateral decision";lateral_decision_ = MergeLateralDecision(lateral_decision_, decision);ADEBUG << decider_tag << " added obstacle " << Id()<< " a lateral decision: " << decision.ShortDebugString()<< ". The merged decision is: "<< lateral_decision_.ShortDebugString();decisions_.push_back(decision);decider_tags_.push_back(decider_tag); }//返回debug字符串 std::string Obstacle::DebugString() const {std::stringstream ss;ss << "Obstacle id: " << id_;for (size_t i = 0; i < decisions_.size(); ++i) {ss << " decision: " << decisions_[i].DebugString() << ", made by "<< decider_tags_[i];}if (lateral_decision_.object_tag_case() !=ObjectDecisionType::OBJECT_TAG_NOT_SET) {ss << "lateral decision: " << lateral_decision_.ShortDebugString();}if (longitudinal_decision_.object_tag_case() !=ObjectDecisionType::OBJECT_TAG_NOT_SET) {ss << "longitudinal decision: "<< longitudinal_decision_.ShortDebugString();}return ss.str(); }//獲取針對該感知障礙物的SL邊界盒? //sl_boundary_其實就是障礙物邊界點相對于道路參考線的SL坐標 const SLBoundary& Obstacle::PerceptionSLBoundary() const {return sl_boundary_; }//設定路徑的ST邊界,也就是針對該障礙物的ST邊界? void Obstacle::set_path_st_boundary(const STBoundary& boundary) {path_st_boundary_ = boundary;path_st_boundary_initialized_ = true; }//設定ST邊界類型,設置為輸入的類型 void Obstacle::SetStBoundaryType(const STBoundary::BoundaryType type) {path_st_boundary_.SetBoundaryType(type); }//擦除類里儲存的路徑ST邊界 void Obstacle::EraseStBoundary() { path_st_boundary_ = STBoundary(); }//設定道路參考線的ST邊界 void Obstacle::SetReferenceLineStBoundary(const STBoundary& boundary) {reference_line_st_boundary_ = boundary; }//設定道路參考線ST邊界類型 void Obstacle::SetReferenceLineStBoundaryType(const STBoundary::BoundaryType type) {reference_line_st_boundary_.SetBoundaryType(type); }//擦除類里儲存的道路參考線ST邊界 void Obstacle::EraseReferenceLineStBoundary() {reference_line_st_boundary_ = STBoundary(); }//是否為有效的障礙物,主要是看感知障礙物的長寬是否為nan(not a number)或者過于小了,是的話就說明是無效的障礙物 bool Obstacle::IsValidObstacle(const perception::PerceptionObstacle& perception_obstacle) {const double object_width = perception_obstacle.width();const double object_length = perception_obstacle.length();const double kMinObjectDimension = 1.0e-6;return !std::isnan(object_width) && !std::isnan(object_length) &&object_width > kMinObjectDimension &&object_length > kMinObjectDimension; }//檢查車道被該障礙物阻塞?輸入參數是道路參考線類對象 void Obstacle::CheckLaneBlocking(const ReferenceLine& reference_line) {//如果障礙物不是靜止,就沒阻塞,并返回if (!IsStatic()) {is_lane_blocking_ = false;return;}//如果執行到這里說明障礙物已經是是靜態障礙物了DCHECK(sl_boundary_.has_start_s());DCHECK(sl_boundary_.has_end_s());DCHECK(sl_boundary_.has_start_l());DCHECK(sl_boundary_.has_end_l());//sl_boundary_其實就是障礙物邊界點相對于道路參考線的SL坐標 //如果根據該障礙物的SL邊界 //SL邊界是相對道路參考線的,若求出的SL邊界下限L坐標和上限L坐標異號,說明障礙物SL邊界盒占據了道路參考線的兩邊,則認為是阻塞了if (sl_boundary_.start_l() * sl_boundary_.end_l() < 0.0) {is_lane_blocking_ = true;return;}//如果上面沒有返回,說明障礙物是在道路參考線的一側,且是靜態障礙物//駕駛寬度 = 道路參考線計算刨去障礙物邊界盒SL邊界后左右寬度中更大的那個,也就是障礙物的左邊界const double driving_width = reference_line.GetDrivingWidth(sl_boundary_);//獲取車輛物理參數auto vehicle_param = common::VehicleConfigHelper::GetConfig().vehicle_param();//根據道路參考線判斷sl_boundary_也就是該障礙物的SL邊界盒在車道內?且駕駛寬度<小于車輛的寬度+靜態橫向避讓緩沖距離0.3,道路阻塞的標志位is_lane_blocking_為trueif (reference_line.IsOnLane(sl_boundary_) &&driving_width <vehicle_param.width() + FLAGS_static_obstacle_nudge_l_buffer) {is_lane_blocking_ = true;return;}//上面都不滿足的話,該障礙物就沒有阻塞車道is_lane_blocking_ = false; }//設置數據成員,該障礙物阻塞換道?用輸入參數 距離過近is_distance_clear拷貝給數據成員 //is_lane_change_blocking_ void Obstacle::SetLaneChangeBlocking(const bool is_distance_clear) {is_lane_change_blocking_ = is_distance_clear; }} // namespace planning } // namespace apollo

總結

以上是生活随笔為你收集整理的Apollo:modules/planning/common/obstacle.cc分析的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

精品国产免费观看 | av手机版 | 伊人日日干 | 欧美精品视 | 亚洲精品国内 | 韩日精品在线观看 | 欧美a级在线播放 | 国产视频精品视频 | 天天弄天天干 | 91在线91拍拍在线91 | 日韩精品中文字幕久久臀 | 91精品国产99久久久久久久 | 国产伦精品一区二区三区… | 精品久久久久_ | 国产亚洲情侣一区二区无 | 国产短视频在线播放 | 久草在线视频网 | 日本精品中文字幕 | 国产精品观看 | 国产麻豆视频 | 久久精品伊人 | 97在线观看免费高清 | 四虎国产永久在线精品 | 成人aⅴ视频 | 欧美性生活免费看 | 午夜精品福利一区二区三区蜜桃 | 日韩成人精品在线观看 | 国产黄色精品在线 | 亚洲三级在线 | 黄色av一区二区三区 | 色吧久久 | 丁香六月婷 | 午夜精品一区二区三区在线观看 | 国内免费久久久久久久久久久 | 麻豆成人精品视频 | 国产精品1区2区3区 久久免费视频7 | 国产小视频91| 国内成人精品2018免费看 | 中文字幕中文字幕在线中文字幕三区 | 日韩精品免费一区二区三区 | 丁香六月五月婷婷 | 日韩福利在线观看 | 成人h视频 | 亚洲美女精品区人人人人 | 天天综合网久久综合网 | 在线播放国产一区二区三区 | 国产精品永久久久久久久久久 | 久久国产影院 | 欧美色图30p | 中文字幕视频网 | 久久99精品一区二区三区三区 | 精品91在线 | 亚洲精品在线观看视频 | 日本成人a| 99热国产在线 | 成人在线一区二区三区 | 久久不卡免费视频 | 国产午夜三级一区二区三桃花影视 | 久久久久国产精品午夜一区 | 精品免费一区 | 麻豆成人网 | 久草在线久草在线2 | 国产精品久久久久一区二区国产 | 国产香蕉av| 视频三区在线 | 最近中文字幕免费观看 | 天天操天天曰 | 热99在线视频 | 国产成人久久久77777 | 韩国中文三级 | 国产精品女视频 | 日本中文字幕网 | 又长又大又黑又粗欧美 | 人人插人人草 | 91中文视频 | 久久久久久久久久电影 | 美女网站视频色 | 久久久久久久综合色一本 | 国产精品不卡在线观看 | 99夜色 | 成人午夜精品 | 91精品久久久久久久99蜜桃 | 国产一区二区三区视频在线 | 国产在线欧美在线 | 在线看一区二区 | 人人爽人人爽人人爽 | 成人精品一区二区三区电影免费 | 五月激情六月丁香 | 成人久久久电影 | 狠狠操操 | www.玖玖玖 | 99精品久久精品一区二区 | 欧美日韩精品在线播放 | 国产女人18毛片水真多18精品 | 麻豆影视网站 | 人人射人人射 | 99热高清 | 97国产精品 | 免费看黄视频 | 欧美国产日韩激情 | 亚洲jizzjizz日本少妇 | 丁香在线观看完整电影视频 | 国产高清在线a视频大全 | 国产成人精品在线 | 成年人视频免费在线 | 成人一区二区三区在线 | 激情五月看片 | 久草视频在线资源站 | 999久久久| 久av电影| 成人黄色小说网 | 亚洲网久久| 精品人人人人 | 又长又大又黑又粗欧美 | 色综合久久天天 | 国模吧一区 | 在线国产一区二区三区 | 日韩 精品 一区 国产 麻豆 | 国产一级做a爱片久久毛片a | 午夜精品视频免费在线观看 | 黄色三级网站 | 天天爽夜夜爽精品视频婷婷 | 日本aa在线 | 久爱综合| 色狠狠干| 开心激情五月网 | av福利在线看 | 欧美视频99 | www.xxx.性狂虐 | 国产麻豆果冻传媒在线观看 | 很污的网站 | 国产精品麻豆91 | 激情欧美日韩一区二区 | 色偷偷av男人天堂 | 日韩电影在线一区 | 亚洲最新av在线网址 | www.天天成人国产电影 | 黄色片软件网站 | 日韩av片无码一区二区不卡电影 | 天天操偷偷干 | 精品免费一区 | 国产又粗又长的视频 | 精品一区二区电影 | 欧美视频不卡 | 黄色av影视 | 最新极品jizzhd欧美 | 久久成人免费电影 | freejavvideo日本免费 | 天天激情综合网 | 成人午夜久久 | 国产一二三区在线观看 | 久久视讯 | 99999精品| 成人小视频免费在线观看 | 久久久久久久久久久久久久免费看 | 久久精品久久99精品久久 | 欧美aa一级片 | 碰超人人 | 国产黄色精品在线观看 | 欧美一区二区日韩一区二区 | 成人丝袜| 欧美三级在线播放 | 99久久精品免费 | 91伊人影院 | 蜜桃视频精品 | 综合国产视频 | 欧美精品亚洲二区 | 精品a视频 | 男女靠逼app | 在线观看片 | 久久电影色 | 国产视频资源 | 色噜噜日韩精品一区二区三区视频 | 国内精品免费久久影院 | 伊人五月婷 | 亚洲午夜激情网 | 亚洲高清av| 国产看片网站 | 天堂av在线网址 | 九九久久久久久久久激情 | 国产精品久久久久久久久久免费 | 天天爽人人爽 | 国产精品欧美久久久久无广告 | 成人污视频在线观看 | 成人午夜av电影 | 国产福利在线免费观看 | 三级小视频在线观看 | 亚洲清纯国产 | 99热国产在线 | a视频在线看 | 欧美a级免费视频 | 日本中文字幕在线 | 成全免费观看视频 | 国产精品无 | 欧美中文字幕久久 | 超碰97人人射妻 | 国产精品一区二区精品视频免费看 | 国产精久久久 | 国产99久久久国产精品成人免费 | 黄色大片免费播放 | 91视频啊啊啊 | 午夜在线免费观看视频 | 91久久丝袜国产露脸动漫 | 操操操干干干 | 国产亚洲欧美在线视频 | 免费看的黄色的网站 | 中文字幕一区二区三 | 亚洲理论片 | 久久九九影院 | 日韩在线无 | 免费观看一区二区 | 日韩在线观看不卡 | 久久一级片 | 91超在线 | 国产福利精品视频 | 中国一级特黄毛片大片久久 | 在线 国产 亚洲 欧美 | 欧美一级在线 | 久久综合亚洲鲁鲁五月久久 | 日韩高清在线一区二区三区 | 国产精品免费一区二区三区在线观看 | 九九激情视频 | 成年人在线免费看视频 | 亚洲视频网站在线观看 | 成人免费在线播放 | 在线激情电影 | 免费视频91蜜桃 | 中文字幕在线视频一区二区三区 | 国产精品一区免费在线观看 | 久久精品视频在线观看免费 | 亚洲欧美va | 在线视频精品播放 | 国产精品电影一区二区 | 九九九电影免费看 | 免费a v在线 | 天天天天天干 | 91亚洲精 | av免费在线网 | 久久久免费高清视频 | 日韩电影在线一区二区 | 在线 高清 中文字幕 | 日日骑| 日日干夜夜操视频 | 中文字幕电影高清在线观看 | 国产精品成人自产拍在线观看 | 色综合激情久久 | 国产精品久久久久久久久久久不卡 | 夜夜天天干| 夜夜夜精品 | 久久久久国产a免费观看rela | 99精品国产一区二区三区不卡 | 天天操夜夜干 | 亚洲精品国产精品99久久 | 亚洲国产中文字幕在线视频综合 | 99精品在线视频播放 | 色www精品视频在线观看 | 日韩午夜网站 | 天天操天天干天天玩 | 天天操狠狠操网站 | 日韩激情免费视频 | 人人爱在线视频 | 免费a级大片 | 久久久久免费精品国产 | 九九热国产视频 | 一本一道波多野毛片中文在线 | 99精品免费在线观看 | 天天干天天操天天搞 | 一本一本久久a久久精品综合妖精 | a级国产片 | 欧美坐爱视频 | 亚洲在线视频播放 | 在线 视频 一区二区 | 在线国产91| 在线亚洲精品 | 88av视频| 国产一区二区三区 在线 | 色黄www小说 | 日韩网站免费观看 | 999久久国精品免费观看网站 | 免费高清男女打扑克视频 | 亚洲日韩精品欧美一区二区 | 婷婷午夜激情 | 亚洲国产精品久久久久婷婷884 | 国产高清综合 | 中文字幕在线视频一区二区三区 | 久久精品一区二区三区四区 | 人人舔人人 | 婷婷开心久久网 | 婷婷六月天在线 | 亚洲国产精品资源 | 亚洲精品网站在线 | 久久综合色影院 | 成人在线视频免费 | 精品自拍sae8—视频 | 亚洲 欧美 另类人妖 | 欧美日韩国产二区 | 国产精品永久免费 | 国产精品国产亚洲精品看不卡15 | 99视频偷窥在线精品国自产拍 | 成人资源在线播放 | 中文字幕在线免费 | 成全在线视频免费观看 | 精品91视频 | 又色又爽又激情的59视频 | 亚洲精品自拍视频在线观看 | 亚洲年轻女教师毛茸茸 | 亚洲一级黄色大片 | 亚洲一区二区精品视频 | 久久国色夜色精品国产 | jizzjizzjizz亚洲 | 免费在线黄 | 天天操伊人 | 国产精品黄色av | av千婊在线免费观看 | 欧美婷婷综合 | 91中文在线视频 | 日韩在线播放av | 亚洲视频第一页 | 国产91九色视频 | 免费观看久久 | 午夜手机电影 | 亚洲一区二区视频在线 | www四虎影院 | 中文字幕资源网在线观看 | 99在线视频播放 | 国产精品日韩欧美一区二区 | 在线www色| 国产成人av网 | 久久久久福利视频 | 天堂va欧美va亚洲va老司机 | 婷婷成人亚洲综合国产xv88 | 国产精品一区二区麻豆 | 欧美三级高清 | 久久99久久99久久 | 免费看一级黄色 | 国产精品成人一区二区三区吃奶 | 国产拍揄自揄精品视频麻豆 | 亚洲高清不卡av | 成年人精品 | 午夜三级大片 | 五月天婷婷免费视频 | 我要看黄色一级片 | 国产三级精品在线 | 亚州精品在线视频 | 国内精品久久久久久久97牛牛 | 久久精品香蕉视频 | 人人cao| 美女免费网站 | 91九色在线视频 | 欧美男女爱爱视频 | 国产99黄| 久久久久久国产精品 | 免费91在线 | 国产中文字幕大全 | 日韩av中文字幕在线 | 国产高清不卡一区二区三区 | 最近免费中文视频 | 欧美一区二区三区四区夜夜大片 | 网站免费黄 | 亚洲高清在线观看视频 | 国产免费不卡 | 国产精品久久久久久av | 中文字幕在线观看视频免费 | 亚洲黄色免费在线 | 国产一二区视频 | 免费看的黄色网 | 日日爽| 伊人天堂av| 国产精品国产亚洲精品看不卡15 | 免费观看性生活大片3 | 99在线播放 | 久久国产91| 国产精品白丝jk白祙 | 最近高清中文字幕 | 国产精品久久久久久久久久尿 | 国产原创在线 | 国产中文伊人 | 麻豆一区在线观看 | 亚洲视频精品 | a黄色 | 99在线热播精品免费99热 | 日本乱码在线 | 国产成人一二片 | 日韩精品播放 | 国产精品亚州 | 亚洲在线视频播放 | 久久久久久久久久久电影 | 337p日本大胆噜噜噜噜 | 欧美在线视频日韩 | 成人久久久久久久久 | 免费看黄在线 | 激情一区二区三区欧美 | 狠狠综合久久av | 欧美不卡视频在线 | 99精品偷拍视频一区二区三区 | 久久专区 | 中文资源在线播放 | 欧美日韩在线看 | 六月丁香婷婷在线 | 国内少妇自拍视频一区 | 高潮毛片无遮挡高清免费 | 国产小视频免费在线观看 | 中文字幕资源站 | 91亚洲精品国产 | 欧美性生爱 | 日韩综合在线观看 | 久草热久草视频 | 黄色一级影院 | 国产一级片视频 | 国产免费a | 在线精品视频在线观看高清 | 在线播放日韩av | 黄色软件在线观看免费 | 亚洲视频精品 | 国产免费美女 | 欧美激情精品久久久久久免费 | 免费看高清毛片 | 久久免费激情视频 | 国产精品久久久久久电影 | 日韩专区 在线 | 日日草天天干 | 亚洲高清在线 | 日韩一区二区三区在线观看 | 日韩中文在线播放 | 在线观看中文字幕av | 国产精品午夜久久久久久99热 | 欧洲一区二区三区精品 | 欧美美女激情18p | 在线a视频免费观看 | 日韩精品你懂的 | 天天操夜夜看 | 国产精品免费久久久久 | 国产精品欧美久久久久天天影视 | 天天操天天射天天插 | 99精品免费久久久久久日本 | 成人在线播放免费观看 | 97人人添人澡人人爽超碰动图 | 精品国产观看 | 99在线热播 | 免费在线观看亚洲视频 | 久久久久久久久久久久av | 国产视频在线观看一区 | www.香蕉视频在线观看 | 91人人澡 | 欧美日韩一区二区三区视频 | 久久久久久网址 | 中文字幕人成乱码在线观看 | 久久久久久久久久久电影 | 精品产品国产在线不卡 | 99视频在线 | 亚洲第一色 | www.久久久| 91亚洲在线观看 | 在线观看免费色 | 日韩在线视频二区 | 美女黄久久 | 999热视频| 久草久草在线 | 美女视频久久 | 亚洲精品乱码久久久久久久久久 | 成年人免费电影 | 操久在线 | jizz18欧美18 | 91精品免费在线观看 | 中文永久字幕 | 亚洲在线视频网站 | 国产福利一区在线观看 | 国产高清黄 | 国产精品欧美久久久久无广告 | 亚洲专区 国产精品 | 99精品视频免费看 | 99在线观看免费视频精品观看 | 97福利在线观看 | 91污视频在线 | 美女久久久久久久久久久 | 国产黄色av影视 | 美女免费视频一区二区 | 精品国内自产拍在线观看视频 | 亚洲成人网av | 免费看毛片网站 | 欧美巨乳网| 成人网中文字幕 | 国产中文字幕亚洲 | 亚洲国产中文字幕在线观看 | 亚洲丝袜中文 | 亚洲视频999| 欧美亚洲精品在线观看 | 色噜噜在线观看视频 | 麻花豆传媒mv在线观看网站 | 欧美一区免费观看 | 特级西西人体444是什么意思 | www.色国产 | 欧美成人亚洲成人 | 91在线看 | 久久福利影视 | 亚洲传媒在线 | 在线观看av片 | 国产精品系列在线观看 | 欧美孕交vivoestv另类 | 不卡中文字幕在线 | av黄色免费网站 | 日韩啪啪小视频 | 黄色资源网站 | 中文理论片 | 久久综合福利 | 免费观看国产成人 | 91视频午夜 | 有码中文字幕在线观看 | 69精品视频| 免费av观看网站 | 97超碰资源| 九草视频在线观看 | 国产99在线免费 | 日韩69av| 欧美精品一区在线 | 精品国产一区二区三区久久久久久 | 精品在线播放 | 国产99久久九九精品免费 | 亚洲精品网站在线 | 西西444www高清大胆 | 日韩有码中文字幕在线 | 成人免费在线观看av | 国产视频资源在线观看 | 在线看片视频 | 国产亚洲aⅴaaaaaa毛片 | 日韩婷婷 | 91免费视频黄 | 日日操日日插 | 最新中文字幕 | 免费久久99精品国产婷婷六月 | 婷婷去俺也去六月色 | 久艹在线播放 | 99精品免费在线 | 97精品视频在线 | 日韩精品中文字幕在线观看 | 狠狠躁夜夜躁人人爽超碰97香蕉 | 福利视频网址 | 天天干夜夜爽 | 日韩欧美在线观看一区二区 | 久草.com| 国产精品18久久久久久久网站 | 国产精品免费一区二区三区在线观看 | 中文字幕乱码视频 | 国产精品久久久久久久毛片 | 麻豆精品传媒视频 | 91麻豆国产福利在线观看 | 免费在线观看av片 | 国内精品国产三级国产aⅴ久 | 婷婷av色综合 | 在线亚洲高清视频 | 国产亚洲免费观看 | 久久激情五月丁香伊人 | 欧美一级片免费观看 | 久久综合色婷婷 | 亚洲激情av | 欧美午夜激情网 | 日本丰满少妇免费一区 | 高清美女视频 | 91大神电影 | 91视频免费看网站 | 日本在线观看视频一区 | 国产黄色免费电影 | 国产夫妻自拍av | 国产精品99久久久久久久久久久久 | 91网址在线 | 亚洲三级在线播放 | 久热电影 | 欧美激情视频在线免费观看 | 98超碰人人 | 亚洲欧美色婷婷 | 99视频精品免费视频 | 美女视频黄是免费的 | 色一色在线 | 国产一级片直播 | www.97色.com| 久久伊人八月婷婷综合激情 | 亚洲精品一区二区精华 | 亚洲成人黄色网址 | 99se视频在线观看 | 久久国产一区二区三区 | 亚洲精品视频在线观看免费 | 人人藻人人澡人人爽 | 成人黄色在线观看视频 | 麻豆视频大全 | 中文字幕在线影院 | 久久精品一二区 | 国产中文字幕在线免费观看 | 999久久国精品免费观看网站 | 丁香色天天 | 日韩欧美在线免费观看 | 色偷偷中文字幕 | 精品一二三区视频 | 日本精品在线看 | 国产91精品一区二区麻豆网站 | 欧美日韩另类在线观看 | 久草在线免费在线观看 | 久久99视频免费 | 久久99九九99精品 | 成年人在线免费看视频 | 欧美日韩精品免费观看视频 | 日韩天天综合 | 国产在线观看免 | 欧美日韩中文另类 | 国产成人免费网站 | 热久久视久久精品18亚洲精品 | 久久精品毛片 | 日韩成人欧美 | 国产精品久久一区二区三区, | 中文字幕免费观看 | 中文字幕日韩无 | 欧美一级电影 | 国产一区二区中文字幕 | 蜜桃麻豆www久久囤产精品 | 国产一区二区久久 | 涩涩网站在线播放 | 黄色亚洲免费 | 久久再线视频 | 国产成人三级三级三级97 | 人人澡人人草 | 亚洲精品综合一二三区在线观看 | 亚洲资源在线网 | 91精品视频免费看 | 最新国产一区二区三区 | 欧美另类一二三四区 | 日韩亚洲国产中文字幕 | 国产四虎影院 | 国产亚洲精品久久久久久 | 国产精品毛片一区视频播不卡 | 日韩精品中字 | 亚洲日韩精品欧美一区二区 | 国产在线视频资源 | 亚洲专区欧美 | 成人国产综合 | 亚洲精品tv | 久久久影院官网 | 99在线播放 | 91久久国产综合精品女同国语 | 久久久电影网站 | 中文字幕丝袜制服 | 婷婷精品国产一区二区三区日韩 | 国产高清av免费在线观看 | 五月婷婷激情综合 | 久久激情视频 久久 | 国产精品久久99综合免费观看尤物 | 欧美日韩另类视频 | 国产精品2019 | 中文字幕资源网在线观看 | 成人国产电影在线观看 | 婷婷精品国产一区二区三区日韩 | 午夜精品福利一区二区三区蜜桃 | 精品久久久精品 | 国产精品美女在线 | 成人免费共享视频 | 国产a免费 | 婷婷色 亚洲| 蜜桃av久久久亚洲精品 | 探花在线观看 | 午夜久久福利影院 | 午夜18视频在线观看 | 久久久综合色 | 国产在线一卡 | 337p日本欧洲亚洲大胆裸体艺术 | 四虎影视成人永久免费观看视频 | 91麻豆精品国产91久久久无限制版 | 午夜视频久久久 | 免费69视频 | 色婷婷激情电影 | 天天干天天操天天射 | 成人丁香花 | 欧洲精品一区二区 | 蜜臀91丨九色丨蝌蚪老版 | 91成人精品视频 | 亚洲高清视频一区二区三区 | 黄色特一级 | 成人欧美一区二区三区黑人麻豆 | 国产精品日韩 | 在线黄色免费 | 日韩欧美高清视频在线观看 | 日韩精品首页 | 久草在线视频新 | 色999视频| 狠狠伊人| 国产精品色视频 | 99精品一级欧美片免费播放 | 区一区二区三在线观看 | 色综合天天综合网国产成人网 | 人人澡人人干 | 久久午夜免费观看 | 韩日精品在线 | 日韩高清在线观看 | 黄色一级免费电影 | 91在线精品观看 | av成人免费在线看 | 国产黄色电影 | 日本69hd| 免费日韩 精品中文字幕视频在线 | 色综合天天色 | 国产精品18毛片一区二区 | 丁香五月网久久综合 | 亚洲少妇xxxx | 九九99 | 91天天操| 99产精品成人啪免费网站 | 成人一级在线 | 国产日韩精品在线观看 | ww亚洲ww亚在线观看 | 色综合色综合久久综合频道88 | 日韩在线一区二区免费 | 超碰97在线看 | 久久人人97超碰com | 色狠狠操 | 亚洲精品中文字幕在线 | 亚洲国产精品一区二区久久,亚洲午夜 | av黄色在线| 在线观看韩日电影免费 | 99热精品在线 | 久久成人国产精品 | 中文字幕精品三区 | 久久久精品视频成人 | 日韩精品91偷拍在线观看 | 天天色.com | 中文字幕在线播放一区二区 | 天天干夜夜干 | 成人午夜剧场在线观看 | 中文字幕在线免费观看视频 | 精品美女在线观看 | 五月婷婷亚洲 | 久久综合中文字幕 | 久久亚洲欧美 | 亚洲资源在线网 | 99久久精品免费视频 | 96精品视频| 婷婷综合伊人 | 精品久久精品 | 国产香蕉久久精品综合网 | 免费亚洲一区二区 | 亚洲黄色精品 | 久久久久久福利 | 免费开视频 | 亚洲一区二区三区毛片 | 日韩欧美在线免费观看 | 91在线免费观看网站 | 成人黄色小视频 | 国产小视频91 | 高清在线一区二区 | 亚洲天堂在线观看完整版 | 成人免费中文字幕 | av网站有哪些 | 91av在线免费观看 | 五月婷婷久久综合 | 久久久久一区 | 九九九在线观看 | 欧美日本不卡 | 丁香激情婷婷 | 深爱婷婷网 | 久久激五月天综合精品 | 国产尤物视频在线 | 成人免费一区二区三区在线观看 | 日本久久91 | 午夜成人免费影院 | 91成人精品一区在线播放 | 色婷婷九月 | 性色va| 在线免费观看av网站 | 亚洲综合婷婷 | 手机成人av在线 | 免费观看9x视频网站在线观看 | 中文字幕乱视频 | 中文字幕av免费在线观看 | 91在线观看视频 | 免费v片| 久久狠狠婷婷 | 91久久久久久久 | 激情五月网站 | 国产精品大片在线观看 | 久久色在线观看 | 日本在线观看一区二区 | 91成人精品一区在线播放69 | 免费观看全黄做爰大片国产 | 91插插视频| 香蕉一区| 国产免码va在线观看免费 | aaa日本高清在线播放免费观看 | 最近中文字幕大全 | 久久久久久久99精品免费观看 | 亚洲视频电影在线 | 色香com.| 一级黄色免费网站 | 国产69精品久久久久久久久久 | 国产成人精品久久亚洲高清不卡 | 欧美在线视频a | 人人看人人艹 | 亚洲一区日韩精品 | 成人av日韩| 日本免费久久高清视频 | 亚洲精品黄 | 免费午夜在线视频 | 黄色网址在线播放 | a爱爱视频 | 精品女同一区二区三区在线观看 | 亚洲伦理一区二区 | 国产又粗又硬又长又爽的视频 | 中文字幕亚洲五码 | 成年人三级网站 | 欧美最爽乱淫视频播放 | 国产成人精品一二三区 | 成人黄色片在线播放 | 成人久久久久久久久久 | 国产亚洲精品久久 | 色悠悠久久综合 | 欧美一区在线看 | 色午夜影院 | 麻豆视频国产 | 中文在线a天堂 | 狠狠操狠狠操 | av资源免费观看 | 婷婷5月色 | 欧美一级乱黄 | 亚洲97在线| 久热精品国产 | 成人丝袜 | 99精品视频一区 | 美女激情影院 | 99精品免费| 欧美精品在线免费 | 丁香六月伊人 | 在线观看你懂的网址 | 国产色一区 | 亚洲国产精品一区二区久久,亚洲午夜 | 国产亚洲综合性久久久影院 | 99精品国自产在线 | 日韩在线激情 | 免费av大全 | 天天操天天玩 | 亚洲精品小视频在线观看 | 欧美激情第八页 | 国产二级视频 | 伊人五月婷 | 欧美成人性网 | 日韩在线色 | 亚洲精品一区二区久 | 久久亚洲欧美 | 免费福利视频网 | 91亚洲激情 | 黄色av电影网 | www.天天操.com| 国产成人一区二区啪在线观看 | 国产成人精品久久亚洲高清不卡 | 免费在线成人av | 免费看片网址 | 91完整版 | 在线国产视频一区 | 182午夜在线观看 | 黄色三级在线观看 | 天天综合天天做天天综合 | 国产精品久久久久久久久久东京 | 久色网| 欧美日韩另类在线 | 欧美日韩免费看 | 精品久久久国产 | 97超级碰碰碰碰久久久久 | 国产一级二级在线 | 丁香婷婷激情 | 日批在线观看 | 99视屏 | 国色天香第二季 | 亚洲mv大片欧洲mv大片免费 | 亚洲精品一区二区三区新线路 | 在线免费观看黄网站 | 五月激情丁香婷婷 | 最近乱久中文字幕 | 成人午夜精品久久久久久久3d | 国产麻豆果冻传媒在线观看 | 久久久久久毛片精品免费不卡 | 日日干夜夜草 | 欧洲一区精品 | 国产91区| 毛片网在线播放 | 奇米影视8888在线观看大全免费 | 999抗病毒口服液 | 久久爽久久爽久久av东京爽 | 亚一亚二国产专区 | 最近中文字幕大全中文字幕免费 | 久久成人精品视频 | 久草在在线 | 国产最新在线视频 | 波多野结衣视频一区二区三区 | 国产精品黄色影片导航在线观看 | 在线看片日韩 | 国产成人一区二区三区影院在线 | 精品中文字幕在线观看 | 久久婷婷亚洲 | 欧美日韩在线观看一区二区三区 | 亚洲1级片 | 国产色视频123区 | 亚洲视频一| 成人在线视频论坛 | 在线电影中文字幕 | 国产在线日本 | 国产成人精品久 | 啪啪免费观看网站 | 粉嫩aⅴ一区二区三区 | 亚洲精品 在线视频 | 亚洲精品视频免费在线 | 久久久国产精品一区二区三区 | 国产一区二区三区在线免费观看 | 亚洲国产中文字幕 | 99国产精品久久久久老师 | 久碰视频在线观看 | 日韩欧美在线中文字幕 | 亚洲精品美女视频 | 日韩毛片一区 | 欧美成年黄网站色视频 | 91探花视频 | 亚洲国产影院av久久久久 | 免费日韩电影 | 97成人在线免费视频 | 国产成人一区二区啪在线观看 | 日本特黄特色aaa大片免费 | 国产精品99免视看9 国产精品毛片一区视频 | 亚洲精品午夜一区人人爽 | 九九色在线观看 | 丁香婷婷综合网 | 狠狠的日 | 国产成年免费视频 | 久久男人中文字幕资源站 | 女人高潮特级毛片 | 精品国产色 | 日韩精品一区二区三区在线视频 | 91亚洲精品久久久蜜桃网站 | 91超碰在线播放 | 国产一区麻豆 | 国产女人40精品一区毛片视频 | 国产美女主播精品一区二区三区 | 在线观看一区二区视频 | 国产色婷婷 | 国产成人一区二区三区在线观看 | 亚洲精品午夜久久久久久久 | 黄p网站在线观看 | 人人爽久久涩噜噜噜网站 | 国内精品久久久久 | 国产美女无遮挡永久免费 | 国产成人精品一区二区三区福利 | 日韩av黄 | 亚洲成a人片在线观看网站口工 | 精品欧美一区二区三区久久久 | 久久热亚洲 | 免费在线观看日韩 | 黄色网www| 日本中文字幕在线视频 | 国产品久精国精产拍 | 在线观看视频国产一区 | 日韩精品网址 | 制服丝袜在线 | 久久精品视频免费播放 | 99精品视频在线观看免费 | 免费观看第二部31集 | 婷婷精品国产一区二区三区日韩 | 九九热在线精品视频 | 黄色毛片视频免费观看中文 | 亚洲女人av | a色网站| 日韩黄色免费电影 | 色综合久久久网 | 国产不卡在线播放 | 欧美日韩亚洲一 | 国产在线999 | 欧美淫视频 | 亚洲精品视频在 | 国产精品破处视频 | 毛片www | 国产精品一区在线观看你懂的 | 一级片在线 | 久久不色 | 丁香在线观看完整电影视频 | 天天爽天天做 | 狠狠色香婷婷久久亚洲精品 | 国产91在线免费视频 | 在线一区二区三区 | 日本成人中文字幕在线观看 | 亚洲成人精品在线 | 97超碰中文字幕 | 中文字幕国产一区二区 | 国产视频一区精品 | 亚洲波多野结衣 | 日韩免费网址 | 天堂视频一区 | 精品国产免费一区二区三区五区 | 黄网站免费看 | 国产黄免费 | 国产精品99久久久久久久久久久久 | 国产精品久久久久婷婷 | 在线观看av免费观看 | 精品视频专区 | 一区二区 久久 | 日产乱码一二三区别在线 | 欧美人zozo | 91在线免费播放 |