3atv精品不卡视频,97人人超碰国产精品最新,中文字幕av一区二区三区人妻少妇,久久久精品波多野结衣,日韩一区二区三区精品

歡迎訪問 生活随笔!

生活随笔

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

编程问答

百度apollo自动驾驶planning代码学习-Apollo\modules\planning\common\Obstacle类代码详解

發布時間:2024/3/24 编程问答 51 豆豆
生活随笔 收集整理的這篇文章主要介紹了 百度apollo自动驾驶planning代码学习-Apollo\modules\planning\common\Obstacle类代码详解 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

概述

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

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

注:
/nudge在apollo里代表橫向上輕輕繞一下避開?
sl_boundary_理解為障礙物的SL邊界,其實就是邊界盒坐標轉化為SL坐標形式?
ObjectDecisionType modules\planning\proto\decision.proto中定義的message類,針對該障礙物對象決策:停車/繞行/減速避讓等

從代碼來看Obstacle類主要是實現:

obstacle.h

#pragma once#include <list> #include <memory> #include <string> #include <unordered_map> #include <vector>#include "modules/common/configs/proto/vehicle_config.pb.h" #include "modules/common/math/box2d.h" #include "modules/common/math/vec2d.h" #include "modules/perception/proto/perception_obstacle.pb.h" #include "modules/planning/common/indexed_list.h" #include "modules/planning/common/speed/st_boundary.h" #include "modules/planning/proto/decision.pb.h" #include "modules/planning/proto/sl_boundary.pb.h" #include "modules/planning/reference_line/reference_line.h" #include "modules/prediction/proto/prediction_obstacle.pb.h"namespace apollo { namespace planning {/*** @class Obstacle* @brief 這是一個連接障礙物路徑及其所在path屬性的類* 一個障礙物的路徑屬性包括frenet系下s,l的值* 障礙物的決策也屬于一個路徑path的屬性* 決策分為兩種:橫向決策和縱向決策* 橫向決策包括:忽略ignore/輕微繞行nudge* 橫向決策安全優先級:nudge > ignore* 縱向決策包括:停止stop/減速避讓yield/跟車follow/超車overtake/忽略ignore* 縱向決策的安全優先級:stop > yield >= follow > overtake > ignore* ignore決策同時屬于縱向和橫向決策,其優先級最低*/ class Obstacle {public:Obstacle() = default;//障礙物類帶參構造函數,輸入參數id,感知障礙物類對象,障礙物優先級,是否為靜態障礙物去構造一個障礙物實例對象Obstacle(const std::string& id,const perception::PerceptionObstacle& perception_obstacle,const prediction::ObstaclePriority::Priority& obstacle_priority,const bool is_static);//Obstacle類的帶參構造函數重載,輸入參數不同 //輸入參數跟上面差不多,就多了一個預測軌跡類對象trajectory Obstacle(const std::string& id,const perception::PerceptionObstacle& perception_obstacle,const prediction::Trajectory& trajectory,const prediction::ObstaclePriority::Priority& obstacle_priority,const bool is_static);//設置/獲取障礙物id_,也就是其類成員const std::string& Id() const { return id_; }void SetId(const std::string& id) { id_ = id; }//獲取障礙物的速度speed_,也就是其數據成員double speed() const { return speed_; }//獲取數據成員感知障礙物id perception_id_int32_t PerceptionId() const { return perception_id_; }//返回障礙物是否為靜止的標志位,類數據成員is_static_bool IsStatic() const { return is_static_; }//返回障礙物是否為虛擬的標志位,類數據成員is_virtual_ bool IsVirtual() const { return is_virtual_; }//根據時間查詢預測軌跡點 //輸入參數是相對時間relative_timecommon::TrajectoryPoint GetPointAtTime(const double time) const;//獲取障礙物的2維邊界盒,輸入參數是預測軌跡點?其實就是軌跡點作為幾何中心點其x,y,theta信息加上數據成員感知障礙物的長寬構建二維邊界盒common::math::Box2d GetBoundingBox(const common::TrajectoryPoint& point) const;//返回感知障礙物的邊界盒,類數據成員perception_bounding_box_const common::math::Box2d& PerceptionBoundingBox() const {return perception_bounding_box_;}//返回感知障礙物的多邊形,類的數據成員perception_polygon_const common::math::Polygon2d& PerceptionPolygon() const {return perception_polygon_;}//獲取障礙物的預測軌跡,返回類的數據成員trajectory_const prediction::Trajectory& Trajectory() const { return trajectory_; }common::TrajectoryPoint* AddTrajectoryPoint() {return trajectory_.add_trajectory_point();}//返回障礙物是否有軌跡?bool HasTrajectory() const {return !(trajectory_.trajectory_point().empty());}//返回感知障礙物對象,屬于Obstacle類成員const perception::PerceptionObstacle& Perception() const {return perception_obstacle_;}/*** @brief 這是一個輔助函數可以創建障礙物來自預測數據* 預測原始對于每個障礙物可能有多個軌跡?* 這個函數會針對每個軌跡創建一個障礙物?* @param predictions 預測結果* @return obstacles 障礙物對象列表*/ //創建障礙物類對象指針列表,輸入參數是預測障礙物列表 //其實就是從預測障礙物對象中提取出有效的障礙物和有效的軌跡等信息,塞入障礙物類對象指針列表返回static std::list<std::unique_ptr<Obstacle>> CreateObstacles(const prediction::PredictionObstacles& predictions);//創建虛擬障礙物函數 //輸入參數id,二維障礙物邊界盒static std::unique_ptr<Obstacle> CreateStaticVirtualObstacles(const std::string& id, const common::math::Box2d& obstacle_box);//判斷是否為有效的感知障礙物,輸入參數是感知障礙物類對象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_;}// const Obstacle* obstacle() const;/*** 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 AddLongitudinalDecision(const std::string& decider_tag,const ObjectDecisionType& decision);//針對該障礙物增加一個橫向決策,輸入參數決策標簽字符串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);private:std::string id_;int32_t perception_id_ = 0;bool is_static_ = false;bool is_virtual_ = false;double speed_ = 0.0;bool path_st_boundary_initialized_ = false;prediction::Trajectory trajectory_;perception::PerceptionObstacle perception_obstacle_;common::math::Box2d perception_bounding_box_;common::math::Polygon2d perception_polygon_;std::vector<ObjectDecisionType> decisions_;std::vector<std::string> decider_tags_;SLBoundary sl_boundary_; //其實就是障礙物邊界點相對于道路參考線的SL坐標STBoundary reference_line_st_boundary_;STBoundary path_st_boundary_;ObjectDecisionType lateral_decision_;ObjectDecisionType longitudinal_decision_;// for keep_clear usage onlybool is_blocking_obstacle_ = false;bool is_lane_blocking_ = false;bool is_lane_change_blocking_ = false;bool is_caution_level_obstacle_ = false;double min_radius_stop_distance_ = -1.0;struct ObjectTagCaseHash {size_t operator()(const planning::ObjectDecisionType::ObjectTagCase tag) const {return static_cast<size_t>(tag);}};static const std::unordered_map<ObjectDecisionType::ObjectTagCase, int,ObjectTagCaseHash>s_lateral_decision_safety_sorter_;static const std::unordered_map<ObjectDecisionType::ObjectTagCase, int,ObjectTagCaseHash>s_longitudinal_decision_safety_sorter_; };typedef IndexedList<std::string, Obstacle> IndexedObstacles; typedef ThreadSafeIndexedList<std::string, Obstacle> ThreadSafeIndexedObstacles;} // namespace planning } // namespace apollo

obstacle.cc

#include "modules/planning/common/obstacle.h"#include <algorithm> #include <utility>#include "cyber/common/log.h" #include "modules/common/configs/vehicle_config_helper.h" #include "modules/common/math/linear_interpolation.h" #include "modules/common/util/map_util.h" #include "modules/common/util/util.h" #include "modules/planning/common/planning_gflags.h" #include "modules/planning/common/speed/st_boundary.h"namespace apollo { namespace planning {using apollo::common::VehicleConfigHelper; using apollo::common::util::FindOrDie; using apollo::perception::PerceptionObstacle; using apollo::prediction::ObstaclePriority;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}};//Obstacle障礙物類的帶參構造函數 //輸入參數:障礙物id,感知障礙物類對象,障礙物優先級類對象,是否為靜態障礙物? Obstacle::Obstacle(const std::string& id,const PerceptionObstacle& perception_obstacle,const ObstaclePriority::Priority& obstacle_priority,const bool is_static)//用這些輸入參數去初始化Obstacle類自己的數據成員,賦值數據成員id_: id_(id), //賦值數據成員感知障礙物perception_id_perception_id_(perception_obstacle.id()),//賦值數據成員感知障礙物對象perception_obstacle_perception_obstacle_(perception_obstacle),//賦值數據成員感知障礙物的邊界盒perception_bounding_box_perception_bounding_box_({perception_obstacle_.position().x(),perception_obstacle_.position().y()},perception_obstacle_.theta(),perception_obstacle_.length(),perception_obstacle_.width()) {//將這個障礙物的注意等級先初始設定為CAUTION注意is_caution_level_obstacle_ = (obstacle_priority == ObstaclePriority::CAUTION);//定義一個2維多邊形點vectorstd::vector<common::math::Vec2d> polygon_points;//FLAGS_use_navigation_mode是GFLAGS庫的用法,FLAGS_代表去相應的XXX.gflags.cc里取//出use_navigation_mode的值,默認為false,或者多邊形點的數量小于等于2//如果用導航模式或感知障礙物的邊界多邊形點的數目小于等于2,就獲取感知障礙物邊界盒的所有頂//點,頂點就是根據感知的長寬,幾何中心,heading角計算而來if (FLAGS_use_navigation_mode ||perception_obstacle.polygon_point_size() <= 2) {perception_bounding_box_.GetAllCorners(&polygon_points);} else {//既不使用導航模式,感知障礙物的邊界多邊形點數目又大于2的話//把感知障礙物的多邊形點放入vector polygon_pointsACHECK(perception_obstacle.polygon_point_size() > 2)<< "object " << id << "has less than 3 polygon points";for (const auto& point : perception_obstacle.polygon_point()) {polygon_points.emplace_back(point.x(), point.y());}}//計算感知障礙物多邊形點集的凸包,得到的多邊形結果存放在引用變量perception_polygon_感知多邊形里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);//std::hypot 計算 x 和 y 的平方和的平方根,其實就是計算下感知障礙物速度X方向,Y方向//的矢量和speed_ = std::hypot(perception_obstacle.velocity().x(),perception_obstacle.velocity().y()); }//Obstacle類的帶參構造函數重載,輸入參數不同 //輸入參數跟上面差不多,就多了一個預測軌跡類對象trajectory 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_ = trajectory;//取出預測軌跡的軌跡點trajectory_pointsauto& trajectory_points = *trajectory_.mutable_trajectory_point();//初始定義了一個累計縱向距離s cumulative_sdouble cumulative_s = 0.0;//如果軌跡點的數目大于0 軌跡點的第一個點的s設置為0,其實就//相對第一個軌跡點的相對縱坐標sif (trajectory_points.size() > 0) {trajectory_points[0].mutable_path_point()->set_s(0.0);}//從預測軌跡點的第二個點開始遍歷設置相對縱坐標s,第一個點上面已經設置了for (int i = 1; i < trajectory_points.size(); ++i) {//前繼點,第i-1個預測軌跡點prevconst auto& prev = trajectory_points[i - 1];//當前點,第i個預測軌跡點curconst 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);} }//根據時間查詢預測軌跡點 //輸入參數是相對時間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 {//如果該障礙物的預測軌跡點數目 >= 2//這是函數內部又定義了個比較函數comp,比較函數的參數有軌跡點p,和時間time//若p的相對時間小于time就返回pauto comp = [](const common::TrajectoryPoint p, const double time) {return p.relative_time() < time;};//std::lower_bound的用法就是遍歷預測軌跡點,lower_bound代表反向遍歷,找到第一個小于給定時間的軌跡點//那正向遍歷和反向遍歷結果就不一樣,正向遍歷upper_bound就是找到軌跡點中的第一個點了,反向遍歷lower_bound就是找到軌跡點中相對時間剛好小于給定時間的點,下一個點相對時間就要大于給定時間了//那么預測軌跡點里相對時間剛好小于輸入參數給定相對時間relative_time的軌跡點復制給it_lowerauto 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維邊界盒,輸入參數是預測軌跡點?其實就是軌跡點作為幾何中心點其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()); }//判斷是否為有效的感知障礙物,輸入參數是感知障礙物類對象 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; }//創建障礙物類對象指針列表,輸入參數是預測障礙物列表 //其實就是從預測障礙物對象中提取出有效的障礙物和有效的軌跡等信息,塞入障礙物類對下個指針列表返回 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()) {//若第i個障礙物的預測軌跡點上有一個無效點,就設置is_valid_trajectory為無效軌跡,并且直接跳出針對第i個預測障礙物預測軌跡點的遍歷循環if (!IsValidTrajectoryPoint(point)) {AERROR << "obj:" << perception_id<< " TrajectoryPoint: " << trajectory.ShortDebugString()<< " is NOT valid.";is_valid_trajectory = false;break;}}//若第i個預測障礙物的軌跡不是有效的軌跡,則直接跳到下一個障礙物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; }//創建虛擬障礙物函數 //輸入參數id,二維障礙物邊界盒 std::unique_ptr<Obstacle> Obstacle::CreateStaticVirtualObstacles(const std::string& id, const common::math::Box2d& obstacle_box) {//創建一個虛擬的感知障礙物對象perception::PerceptionObstacle perception_obstacle;//id需要一個整數,虛擬障礙物是個負idsize_t negative_id = std::hash<std::string>{}(id);// set the first bit to 1 so negative_id became negative number//size_t是32位?這里將1左移31位,將32位最高位置1代表負數?然后虛擬障礙物id與之按位或negative_id |= (0x1 << 31);//感知障礙物設置id,幾何中心x,y,heading,vx=0,vy=0,長寬高,類型為未知不可移動perception_obstacle.set_id(static_cast<int32_t>(negative_id));perception_obstacle.mutable_position()->set_x(obstacle_box.center().x());perception_obstacle.mutable_position()->set_y(obstacle_box.center().y());perception_obstacle.set_theta(obstacle_box.heading());perception_obstacle.mutable_velocity()->set_x(0);perception_obstacle.mutable_velocity()->set_y(0);perception_obstacle.set_length(obstacle_box.length());perception_obstacle.set_width(obstacle_box.width());perception_obstacle.set_height(FLAGS_virtual_stop_wall_height);perception_obstacle.set_type(perception::PerceptionObstacle::UNKNOWN_UNMOVABLE);//設置感知障礙物的跟蹤時間1.0sperception_obstacle.set_tracking_time(1.0);//定義頂點坐標vectorstd::vector<common::math::Vec2d> corner_points;//獲取輸入參數二維邊界盒的所有頂點放入corner_pointsobstacle_box.GetAllCorners(&corner_points);//遍歷二維邊界盒的所有頂點,將其頂點拷貝給感知障礙物對象的多邊形點for (const auto& corner_point : corner_points) {auto* point = perception_obstacle.add_polygon_point();point->set_x(corner_point.x());point->set_y(corner_point.y());}//通過感知障礙物id,感知障礙物對象,障礙物優先級正常,true代表為靜態障礙物//通過這些信息調用帶參構造函數構建一個障礙物對象指針auto* obstacle =new Obstacle(id, perception_obstacle, ObstaclePriority::NORMAL, true);//設置其屬性為虛擬障礙物obstacle->is_virtual_ = true;//將這個障礙物指針對象返回return std::unique_ptr<Obstacle>(obstacle); }//判斷是否為有效的軌跡點,輸入參數是一個軌跡點類型對象 //只要軌跡點沒有路徑點 或 x/y/z/kappa/s/dkappa/ddkappa/v/a/relative_time里只要有 //一個為nan(not a number)就說明這個軌跡點是無效的,否則有效 bool Obstacle::IsValidTrajectoryPoint(const common::TrajectoryPoint& point) {return !((!point.has_path_point()) || std::isnan(point.path_point().x()) ||std::isnan(point.path_point().y()) ||std::isnan(point.path_point().z()) ||std::isnan(point.path_point().kappa()) ||std::isnan(point.path_point().s()) ||std::isnan(point.path_point().dkappa()) ||std::isnan(point.path_point().ddkappa()) || std::isnan(point.v()) ||std::isnan(point.a()) || std::isnan(point.relative_time())); }//設置障礙物的SL邊界也就是Frenet系的橫縱坐標的邊界類對象sl_boundary //輸入參數就是SLBoundary SL邊界類對象 //就是將參數拷貝給類數據成員sl_boundary_ 其實就是障礙物邊界點相對于道路參考線的SL坐標 void Obstacle::SetPerceptionSlBoundary(const SLBoundary& sl_boundary) {sl_boundary_ = sl_boundary; }//使用自車的最小轉彎半徑計算停車距離?輸入參數是車輛參數類對象 //計算的原理大致如博客末尾附圖 double Obstacle::MinRadiusStopDistance(const common::VehicleParam& vehicle_param) const {//如果針對這個障礙物的最小轉彎半徑的停車距離>0則直接返回?是說明已經設置了嗎?if (min_radius_stop_distance_ > 0) {return min_radius_stop_distance_;}//定義一個停止距離的緩沖區0.5mstatic constexpr double stop_distance_buffer = 0.5;//獲取車輛參數的最小轉彎半徑const 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

附錄

最小轉彎半徑避讓停車距離計算函數

將障礙物投影到自車ST圖(未完全看懂apollo實現細節)
這里的adc_start_s是指自車邊界盒尾部的s坐標?障礙物占據的S上下邊界都是相對自車尾部邊界的縱向距離?真正的停車距離還要考慮一個自身車長?這塊具體怎么在ST圖中應用,看完ST圖相關代碼應該就清楚了。

總結

以上是生活随笔為你收集整理的百度apollo自动驾驶planning代码学习-Apollo\modules\planning\common\Obstacle类代码详解的全部內容,希望文章能夠幫你解決所遇到的問題。

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

国产成人综合在线女婷五月99播放 | 天天拍夜夜添久久精品大 | 女人被男人躁得好爽免费视频 | 免费人成在线观看网站 | 人人澡人人妻人人爽人人蜜桃 | 久青草影院在线观看国产 | 亚洲成av人片在线观看无码不卡 | 国产激情无码一区二区app | 久久精品国产一区二区三区肥胖 | 日本爽爽爽爽爽爽在线观看免 | 国产在线精品一区二区高清不卡 | 中文字幕无码人妻少妇免费 | av无码电影一区二区三区 | 国产片av国语在线观看 | 四十如虎的丰满熟妇啪啪 | 亚洲成a人片在线观看无码 | 亚洲国产av美女网站 | 国产后入清纯学生妹 | 国内综合精品午夜久久资源 | 色综合久久网 | 女人被男人爽到呻吟的视频 | 午夜免费福利小电影 | 欧美老妇交乱视频在线观看 | 女人色极品影院 | 性欧美疯狂xxxxbbbb | 日日摸天天摸爽爽狠狠97 | 一本精品99久久精品77 | 亚洲欧洲中文日韩av乱码 | 亚洲熟悉妇女xxx妇女av | 十八禁视频网站在线观看 | 精品国产精品久久一区免费式 | 亚洲午夜福利在线观看 | 国内少妇偷人精品视频 | 精品夜夜澡人妻无码av蜜桃 | 国产精品亚洲一区二区三区喷水 | 国产精品丝袜黑色高跟鞋 | 亚欧洲精品在线视频免费观看 | 麻花豆传媒剧国产免费mv在线 | 成人精品天堂一区二区三区 | 免费播放一区二区三区 | 国产精品无码mv在线观看 | 精品久久综合1区2区3区激情 | 日本精品人妻无码77777 天堂一区人妻无码 | 亚洲最大成人网站 | 99精品久久毛片a片 | 久久无码人妻影院 | 狠狠cao日日穞夜夜穞av | 激情爆乳一区二区三区 | 4hu四虎永久在线观看 | 野狼第一精品社区 | 少妇高潮一区二区三区99 | 1000部夫妻午夜免费 | 久久aⅴ免费观看 | 国色天香社区在线视频 | 天堂无码人妻精品一区二区三区 | 国产内射老熟女aaaa | 欧美激情内射喷水高潮 | 动漫av一区二区在线观看 | √8天堂资源地址中文在线 | 亚洲 a v无 码免 费 成 人 a v | 国产另类ts人妖一区二区 | 未满成年国产在线观看 | 国产精品毛片一区二区 | 玩弄少妇高潮ⅹxxxyw | 全球成人中文在线 | 香蕉久久久久久av成人 | 亚洲精品国产a久久久久久 | 精品国产青草久久久久福利 | 青青草原综合久久大伊人精品 | 捆绑白丝粉色jk震动捧喷白浆 | 男人的天堂av网站 | 国产99久久精品一区二区 | 国产精品久久久久无码av色戒 | 国产性生交xxxxx无码 | 日韩无套无码精品 | 日韩人妻少妇一区二区三区 | 国产一区二区三区精品视频 | 爱做久久久久久 | 欧美老人巨大xxxx做受 | 成人免费视频一区二区 | 国产成人人人97超碰超爽8 | 偷窥日本少妇撒尿chinese | 精品国精品国产自在久国产87 | 波多野结衣 黑人 | 无套内谢的新婚少妇国语播放 | 午夜精品久久久久久久 | 人人爽人人爽人人片av亚洲 | 亚洲精品国产第一综合99久久 | 久久精品99久久香蕉国产色戒 | 亚洲一区二区三区 | 欧美日韩视频无码一区二区三 | 清纯唯美经典一区二区 | 自拍偷自拍亚洲精品被多人伦好爽 | 国产精品爱久久久久久久 | 人人澡人人妻人人爽人人蜜桃 | 国产尤物精品视频 | 人人妻人人澡人人爽人人精品浪潮 | 国产无av码在线观看 | 少妇性荡欲午夜性开放视频剧场 | 无码人妻出轨黑人中文字幕 | 青青久在线视频免费观看 | 老子影院午夜伦不卡 | 精品一区二区不卡无码av | 亚洲s码欧洲m码国产av | 亚洲爆乳大丰满无码专区 | 久久精品国产大片免费观看 | 国产av一区二区三区最新精品 | 女人色极品影院 | 性开放的女人aaa片 | 98国产精品综合一区二区三区 | 亚洲小说春色综合另类 | 久久精品女人的天堂av | 兔费看少妇性l交大片免费 | 国产一区二区三区四区五区加勒比 | 免费国产成人高清在线观看网站 | 人妻无码久久精品人妻 | 97久久超碰中文字幕 | 51国偷自产一区二区三区 | 欧美兽交xxxx×视频 | 少妇性荡欲午夜性开放视频剧场 | 特大黑人娇小亚洲女 | 久久久精品人妻久久影视 | 伊人久久大香线蕉av一区二区 | 激情国产av做激情国产爱 | 特级做a爰片毛片免费69 | 亚洲精品成人福利网站 | 无遮挡国产高潮视频免费观看 | 大屁股大乳丰满人妻 | 中文字幕人成乱码熟女app | 九九热爱视频精品 | 国产午夜无码视频在线观看 | 双乳奶水饱满少妇呻吟 | 亚洲精品国偷拍自产在线麻豆 | 人妻少妇精品无码专区二区 | 色诱久久久久综合网ywww | 国産精品久久久久久久 | 国产成人综合在线女婷五月99播放 | 精品偷自拍另类在线观看 | 国产乱码精品一品二品 | 一本加勒比波多野结衣 | 一本无码人妻在中文字幕免费 | 国产色精品久久人妻 | √天堂资源地址中文在线 | 亚洲春色在线视频 | 国产人妻久久精品二区三区老狼 | 免费国产成人高清在线观看网站 | 狠狠色噜噜狠狠狠7777奇米 | 成人欧美一区二区三区 | 精品日本一区二区三区在线观看 | 性生交大片免费看女人按摩摩 | 国产亚洲精品久久久久久 | 亚洲国产av精品一区二区蜜芽 | 国产精品福利视频导航 | av无码久久久久不卡免费网站 | 成人精品天堂一区二区三区 | 六月丁香婷婷色狠狠久久 | 久久久久人妻一区精品色欧美 | 波多野结衣乳巨码无在线观看 | 国产成人一区二区三区别 | 亚洲人成网站在线播放942 | 亚洲成a人片在线观看无码3d | 自拍偷自拍亚洲精品被多人伦好爽 | 成在人线av无码免费 | 男人和女人高潮免费网站 | 小sao货水好多真紧h无码视频 | 亚洲精品一区二区三区四区五区 | 欧美午夜特黄aaaaaa片 | 麻豆人妻少妇精品无码专区 | 亚洲欧美日韩综合久久久 | 亚洲精品久久久久avwww潮水 | 亚洲综合伊人久久大杳蕉 | 在线精品国产一区二区三区 | 午夜精品久久久久久久 | 国产精品无码久久av | 亚洲高清偷拍一区二区三区 | 亚洲国产av精品一区二区蜜芽 | 波多野结衣一区二区三区av免费 | 国产极品美女高潮无套在线观看 | 久久无码专区国产精品s | 亚洲精品一区国产 | 欧美日韩人成综合在线播放 | 国产农村乱对白刺激视频 | 人人爽人人爽人人片av亚洲 | 午夜精品久久久内射近拍高清 | 欧美精品免费观看二区 | 日韩欧美群交p片內射中文 | 中文久久乱码一区二区 | 性生交大片免费看l | 99麻豆久久久国产精品免费 | 欧美成人高清在线播放 | 国产深夜福利视频在线 | www国产亚洲精品久久久日本 | 国产成人无码一二三区视频 | 波多野结衣高清一区二区三区 | 又色又爽又黄的美女裸体网站 | 亚洲色偷偷男人的天堂 | 波多野结衣av一区二区全免费观看 | 67194成是人免费无码 | 欧美肥老太牲交大战 | 国产网红无码精品视频 | 一区二区三区乱码在线 | 欧洲 | 亚洲日本在线电影 | 3d动漫精品啪啪一区二区中 | 亚无码乱人伦一区二区 | 国产sm调教视频在线观看 | 无码帝国www无码专区色综合 | 国产精品美女久久久网av | 国产99久久精品一区二区 | 1000部夫妻午夜免费 | 国产亚洲精品久久久久久国模美 | 亚洲区小说区激情区图片区 | 欧美xxxxx精品 | 午夜福利一区二区三区在线观看 | 任你躁在线精品免费 | 国色天香社区在线视频 | 国产精品久久久久久久影院 | 亚洲欧美综合区丁香五月小说 | 久久国产精品二国产精品 | 丰满人妻被黑人猛烈进入 | 正在播放东北夫妻内射 | 国产农村乱对白刺激视频 | 亚洲爆乳大丰满无码专区 | 亚洲啪av永久无码精品放毛片 | 亚洲成a人片在线观看无码 | 久久99精品国产麻豆蜜芽 | 一本久久伊人热热精品中文字幕 | 日本精品高清一区二区 | 中文字幕无码日韩欧毛 | 中文字幕色婷婷在线视频 | 久久伊人色av天堂九九小黄鸭 | 国产日产欧产精品精品app | 久久人人97超碰a片精品 | 思思久久99热只有频精品66 | 四虎影视成人永久免费观看视频 | 国产成人一区二区三区别 | 国产在热线精品视频 | 全球成人中文在线 | 亚洲色成人中文字幕网站 | 亚洲经典千人经典日产 | 爽爽影院免费观看 | 欧美人与牲动交xxxx | 蜜桃臀无码内射一区二区三区 | 欧美日本免费一区二区三区 | 噜噜噜亚洲色成人网站 | 爆乳一区二区三区无码 | 国内少妇偷人精品视频免费 | 欧美日韩色另类综合 | 欧洲美熟女乱又伦 | 色欲综合久久中文字幕网 | 久久午夜无码鲁丝片午夜精品 | 亚洲欧洲日本无在线码 | 亚洲gv猛男gv无码男同 | 中文亚洲成a人片在线观看 | а天堂中文在线官网 | 97久久超碰中文字幕 | 欧美人与动性行为视频 | 波多野结衣av在线观看 | 一区二区三区乱码在线 | 欧洲 | 亚洲日韩av片在线观看 | 色五月五月丁香亚洲综合网 | 欧美日本日韩 | 午夜精品久久久久久久 | 无码人妻出轨黑人中文字幕 | 内射白嫩少妇超碰 | 国产精品人妻一区二区三区四 | 亚洲小说春色综合另类 | 波多野结衣一区二区三区av免费 | 97人妻精品一区二区三区 | 日本丰满熟妇videos | 日本一卡2卡3卡四卡精品网站 | 亚洲中文字幕av在天堂 | 国产精品无码成人午夜电影 | 麻豆果冻传媒2021精品传媒一区下载 | 人妻天天爽夜夜爽一区二区 | 亚洲国产精品成人久久蜜臀 | 日欧一片内射va在线影院 | 亚洲经典千人经典日产 | 日欧一片内射va在线影院 | 久久久久成人精品免费播放动漫 | 真人与拘做受免费视频一 | 美女毛片一区二区三区四区 | 六十路熟妇乱子伦 | 国产香蕉尹人综合在线观看 | 国产成人无码a区在线观看视频app | 无码精品国产va在线观看dvd | 噜噜噜亚洲色成人网站 | 国产精品二区一区二区aⅴ污介绍 | 人人爽人人澡人人人妻 | 东北女人啪啪对白 | 成人免费视频视频在线观看 免费 | 一二三四在线观看免费视频 | 丰满妇女强制高潮18xxxx | 国产精品鲁鲁鲁 | 久久午夜无码鲁丝片秋霞 | 2019午夜福利不卡片在线 | 亚洲日韩乱码中文无码蜜桃臀网站 | 鲁大师影院在线观看 | 内射爽无广熟女亚洲 | 欧美人与物videos另类 | 无码乱肉视频免费大全合集 | 97色伦图片97综合影院 | 亚洲自偷自偷在线制服 | 久久久无码中文字幕久... | 亚洲男女内射在线播放 | 99精品国产综合久久久久五月天 | 好爽又高潮了毛片免费下载 | 久久精品女人的天堂av | 久久久久se色偷偷亚洲精品av | 欧美日韩人成综合在线播放 | 日韩成人一区二区三区在线观看 | 55夜色66夜色国产精品视频 | 国产欧美熟妇另类久久久 | 国产精品久久国产精品99 | 4hu四虎永久在线观看 | 蜜桃臀无码内射一区二区三区 | 俺去俺来也www色官网 | 精品欧洲av无码一区二区三区 | 精品aⅴ一区二区三区 | 国产精品久久福利网站 | 水蜜桃亚洲一二三四在线 | 国产激情艳情在线看视频 | 欧美一区二区三区视频在线观看 | 精品日本一区二区三区在线观看 | 蜜臀aⅴ国产精品久久久国产老师 | 国产区女主播在线观看 | 精品久久久久久亚洲精品 | 国产精品二区一区二区aⅴ污介绍 | 精品少妇爆乳无码av无码专区 | 亚洲区欧美区综合区自拍区 | 日韩少妇白浆无码系列 | 亚洲精品www久久久 | 强辱丰满人妻hd中文字幕 | 国产情侣作爱视频免费观看 | 国产人妻精品一区二区三区 | 麻豆国产丝袜白领秘书在线观看 | 亚洲精品国产精品乱码视色 | 狠狠色噜噜狠狠狠狠7777米奇 | 99精品视频在线观看免费 | 中文字幕无码免费久久99 | 国产av久久久久精东av | 国产欧美亚洲精品a | 久久99精品国产麻豆蜜芽 | 一个人看的视频www在线 | 无码av最新清无码专区吞精 | 乱人伦人妻中文字幕无码久久网 | 在线观看国产一区二区三区 | 久久精品中文闷骚内射 | 中国女人内谢69xxxxxa片 | 国产成人一区二区三区别 | 国产精品a成v人在线播放 | 中国大陆精品视频xxxx | 3d动漫精品啪啪一区二区中 | 小泽玛莉亚一区二区视频在线 | 欧美阿v高清资源不卡在线播放 | 色婷婷香蕉在线一区二区 | 亚洲啪av永久无码精品放毛片 | 狠狠色丁香久久婷婷综合五月 | 久久久久久久女国产乱让韩 | a国产一区二区免费入口 | 18禁黄网站男男禁片免费观看 | 亚洲天堂2017无码中文 | 性欧美牲交在线视频 | 77777熟女视频在线观看 а天堂中文在线官网 | 亚洲色www成人永久网址 | 鲁大师影院在线观看 | 国产一精品一av一免费 | 永久黄网站色视频免费直播 | 日本护士毛茸茸高潮 | 国产精品无码一区二区三区不卡 | 成人片黄网站色大片免费观看 | 国产精品无码mv在线观看 | 精品无码国产一区二区三区av | 西西人体www44rt大胆高清 | 野外少妇愉情中文字幕 | 又大又黄又粗又爽的免费视频 | 国产精品第一国产精品 | 亚洲热妇无码av在线播放 | 国产三级精品三级男人的天堂 | 国产乱码精品一品二品 | 久久99热只有频精品8 | 小鲜肉自慰网站xnxx | 爆乳一区二区三区无码 | 色综合久久久无码中文字幕 | 国产人妻精品一区二区三区 | 又湿又紧又大又爽a视频国产 | 国产免费久久久久久无码 | 亚洲中文无码av永久不收费 | 1000部夫妻午夜免费 | 久久综合九色综合欧美狠狠 | 在线精品国产一区二区三区 | 88国产精品欧美一区二区三区 | www国产亚洲精品久久久日本 | 国产激情精品一区二区三区 | 国产sm调教视频在线观看 | 亚洲午夜福利在线观看 | 偷窥日本少妇撒尿chinese | 色婷婷av一区二区三区之红樱桃 | 久久精品国产99精品亚洲 | 色五月五月丁香亚洲综合网 | 精品水蜜桃久久久久久久 | 国产suv精品一区二区五 | 精品欧洲av无码一区二区三区 | 久久久久成人精品免费播放动漫 | 精品无码一区二区三区的天堂 | 沈阳熟女露脸对白视频 | 久久久久久亚洲精品a片成人 | 午夜男女很黄的视频 | 久久亚洲a片com人成 | 噜噜噜亚洲色成人网站 | 99在线 | 亚洲 | 免费播放一区二区三区 | 色妞www精品免费视频 | 亚无码乱人伦一区二区 | 国产亚洲精品久久久久久久久动漫 | 欧美 日韩 人妻 高清 中文 | 精品一区二区三区无码免费视频 | 女高中生第一次破苞av | 18无码粉嫩小泬无套在线观看 | 亚洲高清偷拍一区二区三区 | 日韩精品无码一区二区中文字幕 | аⅴ资源天堂资源库在线 | 精品无码国产一区二区三区av | 国产猛烈高潮尖叫视频免费 | 成年美女黄网站色大免费视频 | 国产真实伦对白全集 | 久久国产精品精品国产色婷婷 | 四虎影视成人永久免费观看视频 | 久久国产劲爆∧v内射 | 国产精品嫩草久久久久 | 国产麻豆精品一区二区三区v视界 | 久久婷婷五月综合色国产香蕉 | 亚洲精品一区二区三区大桥未久 | 东京一本一道一二三区 | 97久久国产亚洲精品超碰热 | 中文字幕日产无线码一区 | 午夜不卡av免费 一本久久a久久精品vr综合 | 国内精品一区二区三区不卡 | 国产乱人无码伦av在线a | 国产成人午夜福利在线播放 | 夜精品a片一区二区三区无码白浆 | 国产明星裸体无码xxxx视频 | 亚洲精品欧美二区三区中文字幕 | 国产做国产爱免费视频 | 国产香蕉尹人综合在线观看 | 麻豆成人精品国产免费 | 亚洲综合另类小说色区 | 精品熟女少妇av免费观看 | 欧洲极品少妇 | 亚洲人成影院在线无码按摩店 | 精品午夜福利在线观看 | 亚洲国产欧美国产综合一区 | 色婷婷综合中文久久一本 | 成人免费无码大片a毛片 | 亚洲中文无码av永久不收费 | 精品国产麻豆免费人成网站 | 图片小说视频一区二区 | 久久天天躁狠狠躁夜夜免费观看 | 色 综合 欧美 亚洲 国产 | 久久精品国产99久久6动漫 | 国产精品.xx视频.xxtv | 色狠狠av一区二区三区 | 福利一区二区三区视频在线观看 | 人人澡人人妻人人爽人人蜜桃 | 国产午夜无码视频在线观看 | 免费国产成人高清在线观看网站 | 亚洲欧美日韩国产精品一区二区 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 人妻无码αv中文字幕久久琪琪布 | 色综合视频一区二区三区 | 狠狠亚洲超碰狼人久久 | 男女下面进入的视频免费午夜 | 一本色道久久综合狠狠躁 | 亚洲爆乳精品无码一区二区三区 | 国产成人无码一二三区视频 | 国产激情艳情在线看视频 | 无码国产激情在线观看 | 一本无码人妻在中文字幕免费 | 黑人巨大精品欧美黑寡妇 | 妺妺窝人体色www在线小说 | 日本护士毛茸茸高潮 | 欧美阿v高清资源不卡在线播放 | 国产激情无码一区二区 | 国产偷自视频区视频 | 中文无码成人免费视频在线观看 | 国产亚洲欧美日韩亚洲中文色 | 真人与拘做受免费视频一 | 国产一区二区三区四区五区加勒比 | 日韩人妻无码一区二区三区久久99 | 亚洲啪av永久无码精品放毛片 | 免费无码一区二区三区蜜桃大 | 日本精品高清一区二区 | 久久97精品久久久久久久不卡 | 亚洲自偷精品视频自拍 | 在线成人www免费观看视频 | 国产亚洲精品久久久久久久久动漫 | 麻豆国产丝袜白领秘书在线观看 | 国内精品久久久久久中文字幕 | 男人扒开女人内裤强吻桶进去 | 东京一本一道一二三区 | 青草视频在线播放 | 免费中文字幕日韩欧美 | 亚洲色大成网站www国产 | 99精品久久毛片a片 | 欧美亚洲日韩国产人成在线播放 | 久久久久久久久蜜桃 | 亚洲中文字幕无码中文字在线 | 亚洲日韩中文字幕在线播放 | 我要看www免费看插插视频 | 强开小婷嫩苞又嫩又紧视频 | 亲嘴扒胸摸屁股激烈网站 | 国产猛烈高潮尖叫视频免费 | 高清不卡一区二区三区 | 免费观看黄网站 | 亚洲另类伦春色综合小说 | 国产偷自视频区视频 | 亚洲中文字幕va福利 | 中文无码成人免费视频在线观看 | 免费观看的无遮挡av | 激情五月综合色婷婷一区二区 | 精品国产国产综合精品 | 亚洲中文字幕在线无码一区二区 | 激情亚洲一区国产精品 | 老熟女乱子伦 | 性欧美videos高清精品 | 国产精品久久久久影院嫩草 | 国产精品亚洲lv粉色 | 无码国产激情在线观看 | 亚洲精品成人福利网站 | 日韩精品乱码av一区二区 | 99精品国产综合久久久久五月天 | 日本大乳高潮视频在线观看 | 无人区乱码一区二区三区 | 永久黄网站色视频免费直播 | 国产av人人夜夜澡人人爽麻豆 | 乱人伦人妻中文字幕无码久久网 | 亚洲国产高清在线观看视频 | 亚洲小说图区综合在线 | 国产手机在线αⅴ片无码观看 | 少妇性荡欲午夜性开放视频剧场 | 99久久人妻精品免费二区 | 欧美阿v高清资源不卡在线播放 | 中文字幕乱码人妻无码久久 | 日本乱偷人妻中文字幕 | 夜夜躁日日躁狠狠久久av | 无码一区二区三区在线 | 一本加勒比波多野结衣 | 亚洲日本va午夜在线电影 | 免费人成网站视频在线观看 | 亚洲成a人片在线观看无码3d | 国产亚洲人成a在线v网站 | 色综合久久久无码中文字幕 | 色窝窝无码一区二区三区色欲 | 欧美性猛交内射兽交老熟妇 | 欧美freesex黑人又粗又大 | 狠狠亚洲超碰狼人久久 | 美女毛片一区二区三区四区 | 日本免费一区二区三区最新 | 男女猛烈xx00免费视频试看 | 秋霞成人午夜鲁丝一区二区三区 | 狠狠亚洲超碰狼人久久 | 领导边摸边吃奶边做爽在线观看 | 最近免费中文字幕中文高清百度 | 亚洲午夜久久久影院 | 天干天干啦夜天干天2017 | 欧美日韩视频无码一区二区三 | 色爱情人网站 | 人人妻人人澡人人爽人人精品 | 国产欧美精品一区二区三区 | 成人精品视频一区二区 | 亚洲日本va午夜在线电影 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 亚洲人成影院在线无码按摩店 | 久久午夜无码鲁丝片午夜精品 | 最新国产乱人伦偷精品免费网站 | 精品乱子伦一区二区三区 | 中文字幕无线码 | 四虎国产精品一区二区 | 在线天堂新版最新版在线8 | 天天躁日日躁狠狠躁免费麻豆 | 国内精品一区二区三区不卡 | 国产精品爱久久久久久久 | 亚洲一区二区三区含羞草 | 少妇性l交大片欧洲热妇乱xxx | www国产精品内射老师 | 女人高潮内射99精品 | 国产成人无码av一区二区 | 国产午夜视频在线观看 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 999久久久国产精品消防器材 | 乌克兰少妇性做爰 | 无遮挡国产高潮视频免费观看 | 中文字幕精品av一区二区五区 | 四虎4hu永久免费 | 国产精品永久免费视频 | 乱人伦中文视频在线观看 | 国产av久久久久精东av | 久久综合九色综合欧美狠狠 | а√天堂www在线天堂小说 | 免费观看又污又黄的网站 | 亚洲精品国产精品乱码视色 | 国产人妻精品一区二区三区不卡 | 大屁股大乳丰满人妻 | 亚洲精品一区国产 | 女高中生第一次破苞av | 亚洲一区二区观看播放 | 国产精品久久久久久久9999 | 日本爽爽爽爽爽爽在线观看免 | 午夜福利不卡在线视频 | 色综合久久中文娱乐网 | 无码国内精品人妻少妇 | 波多野结衣 黑人 | 欧美三级a做爰在线观看 | 亚洲中文字幕无码中文字在线 | 国产性生交xxxxx无码 | 国产精品鲁鲁鲁 | 精品乱码久久久久久久 | 国产香蕉尹人视频在线 | 精品国产av色一区二区深夜久久 | 精品国产乱码久久久久乱码 | 少妇被粗大的猛进出69影院 | 精品乱子伦一区二区三区 | 又湿又紧又大又爽a视频国产 | 人妻无码久久精品人妻 | 一本色道久久综合狠狠躁 | 欧美精品免费观看二区 | 波多野结衣高清一区二区三区 | 亚洲欧美日韩国产精品一区二区 | 国产超级va在线观看视频 | 日韩在线不卡免费视频一区 | 亚洲欧美国产精品久久 | 欧洲精品码一区二区三区免费看 | 久久久久亚洲精品男人的天堂 | 成人精品视频一区二区三区尤物 | 内射后入在线观看一区 | 久久久久se色偷偷亚洲精品av | 天天拍夜夜添久久精品 | 性生交大片免费看l | 成人无码精品一区二区三区 | 奇米影视7777久久精品 | 131美女爱做视频 | 免费人成在线观看网站 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 国产熟妇高潮叫床视频播放 | 亚洲乱码中文字幕在线 | 最近免费中文字幕中文高清百度 | 成人女人看片免费视频放人 | 国产精品怡红院永久免费 | 国产成人无码av一区二区 | 人妻天天爽夜夜爽一区二区 | 精品无码国产一区二区三区av | 欧美怡红院免费全部视频 | 国精品人妻无码一区二区三区蜜柚 | 十八禁真人啪啪免费网站 | 国产成人精品一区二区在线小狼 | 亚洲精品一区二区三区婷婷月 | 国产精品高潮呻吟av久久4虎 | 国产激情艳情在线看视频 | 天天综合网天天综合色 | 免费无码一区二区三区蜜桃大 | 丰满肥臀大屁股熟妇激情视频 | 亚洲精品中文字幕乱码 | 国产特级毛片aaaaaa高潮流水 | 久久精品视频在线看15 | 任你躁国产自任一区二区三区 | 国产成人午夜福利在线播放 | 老子影院午夜伦不卡 | 色五月五月丁香亚洲综合网 | 美女毛片一区二区三区四区 | 三级4级全黄60分钟 | 欧美性生交xxxxx久久久 | 粗大的内捧猛烈进出视频 | 色狠狠av一区二区三区 | 18无码粉嫩小泬无套在线观看 | 亚洲日韩av一区二区三区四区 | 天堂在线观看www | 成人精品天堂一区二区三区 | 亚洲色欲久久久综合网东京热 | 狠狠色噜噜狠狠狠狠7777米奇 | 国产suv精品一区二区五 | 国产xxx69麻豆国语对白 | 亚洲精品综合五月久久小说 | 久久亚洲日韩精品一区二区三区 | 丁香花在线影院观看在线播放 | 中国女人内谢69xxxx | 久久亚洲国产成人精品性色 | 欧美性黑人极品hd | 日本一区二区三区免费高清 | 国产av一区二区三区最新精品 | 狠狠cao日日穞夜夜穞av | 99精品国产综合久久久久五月天 | 精品人妻中文字幕有码在线 | 女人高潮内射99精品 | 久久综合久久自在自线精品自 | 曰韩无码二三区中文字幕 | 天堂久久天堂av色综合 | 日韩av无码一区二区三区不卡 | 亚洲综合伊人久久大杳蕉 | 日日摸夜夜摸狠狠摸婷婷 | 亚洲一区二区观看播放 | 色窝窝无码一区二区三区色欲 | 亚洲一区二区三区在线观看网站 | 日韩精品一区二区av在线 | 国产精品久久福利网站 | 300部国产真实乱 | 窝窝午夜理论片影院 | 精品一区二区三区无码免费视频 | 中文字幕 人妻熟女 | 88国产精品欧美一区二区三区 | 成人免费视频在线观看 | 蜜臀aⅴ国产精品久久久国产老师 | 国产激情综合五月久久 | 国产精品多人p群无码 | 又大又黄又粗又爽的免费视频 | 熟女体下毛毛黑森林 | 蜜臀av无码人妻精品 | 宝宝好涨水快流出来免费视频 | 我要看www免费看插插视频 | 欧美 日韩 人妻 高清 中文 | 国产精品亚洲五月天高清 | 大乳丰满人妻中文字幕日本 | 亚洲国产欧美在线成人 | 欧美国产日韩亚洲中文 | 丝袜 中出 制服 人妻 美腿 | 日本va欧美va欧美va精品 | 青草青草久热国产精品 | 性欧美熟妇videofreesex | 欧美日韩在线亚洲综合国产人 | 成年女人永久免费看片 | 玩弄人妻少妇500系列视频 | 在线欧美精品一区二区三区 | 久久aⅴ免费观看 | 久久综合网欧美色妞网 | 亚洲精品国偷拍自产在线麻豆 | 偷窥日本少妇撒尿chinese | 国产精品内射视频免费 | 久久精品中文字幕大胸 | 中文字幕av伊人av无码av | 精品久久综合1区2区3区激情 | 日日摸天天摸爽爽狠狠97 | 午夜精品一区二区三区在线观看 | 成人精品视频一区二区三区尤物 | 东京无码熟妇人妻av在线网址 | 国产精品手机免费 | 欧美老妇与禽交 | 国产精品99久久精品爆乳 | 沈阳熟女露脸对白视频 | 精品久久8x国产免费观看 | 国精品人妻无码一区二区三区蜜柚 | 国内揄拍国内精品人妻 | 午夜精品久久久久久久 | 国产 精品 自在自线 | 国产精品18久久久久久麻辣 | 四虎影视成人永久免费观看视频 | 国产av一区二区精品久久凹凸 | 日韩视频 中文字幕 视频一区 | 亚洲成在人网站无码天堂 | 国产在线精品一区二区三区直播 | 在线观看国产一区二区三区 | 亚洲成av人片在线观看无码不卡 | 小鲜肉自慰网站xnxx | 午夜精品久久久久久久 | 国产欧美亚洲精品a | 国产猛烈高潮尖叫视频免费 | 亚无码乱人伦一区二区 | 亚洲日韩精品欧美一区二区 | 亚洲gv猛男gv无码男同 | 久久久久久久女国产乱让韩 | 国产无遮挡又黄又爽免费视频 | 日韩精品无码免费一区二区三区 | 欧美性猛交内射兽交老熟妇 | av人摸人人人澡人人超碰下载 | 麻豆果冻传媒2021精品传媒一区下载 | 蜜臀aⅴ国产精品久久久国产老师 | 无码精品人妻一区二区三区av | аⅴ资源天堂资源库在线 | 亚洲精品国偷拍自产在线麻豆 | 中文字幕久久久久人妻 | 成人无码精品一区二区三区 | 国产69精品久久久久app下载 | 久久久久成人精品免费播放动漫 | 丁香花在线影院观看在线播放 | 久久久久亚洲精品男人的天堂 | 国产无套粉嫩白浆在线 | 98国产精品综合一区二区三区 | 好屌草这里只有精品 | 97精品国产97久久久久久免费 | 国产三级精品三级男人的天堂 | 欧美性猛交内射兽交老熟妇 | 激情内射日本一区二区三区 | 国产亚洲精品久久久久久国模美 | 窝窝午夜理论片影院 | 四虎影视成人永久免费观看视频 | 久久精品人人做人人综合 | 中文字幕无码日韩专区 | 国产又爽又猛又粗的视频a片 | 日韩少妇白浆无码系列 | 国产欧美熟妇另类久久久 | 2020久久香蕉国产线看观看 | 无码人妻丰满熟妇区五十路百度 | 青青青爽视频在线观看 | 亚洲一区二区三区含羞草 | 久久精品中文字幕大胸 | 亚洲高清偷拍一区二区三区 | 国产激情综合五月久久 | 狂野欧美性猛交免费视频 | 激情综合激情五月俺也去 | 欧美zoozzooz性欧美 | 国产又粗又硬又大爽黄老大爷视 | 国产av人人夜夜澡人人爽麻豆 | 欧美国产日韩久久mv | 99视频精品全部免费免费观看 | 婷婷五月综合激情中文字幕 | 一区二区三区乱码在线 | 欧洲 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 亚洲成a人片在线观看无码3d | √天堂中文官网8在线 | 中文无码伦av中文字幕 | 在线a亚洲视频播放在线观看 | 日本丰满护士爆乳xxxx | 人人妻人人澡人人爽人人精品浪潮 | 亚洲国产av精品一区二区蜜芽 | 日日天干夜夜狠狠爱 | 一本久道久久综合婷婷五月 | 最新国产乱人伦偷精品免费网站 | 伊人色综合久久天天小片 | 色窝窝无码一区二区三区色欲 | 亚洲精品久久久久久久久久久 | 精品少妇爆乳无码av无码专区 | 国产午夜福利亚洲第一 | 久久综合香蕉国产蜜臀av | 国产手机在线αⅴ片无码观看 | 免费看少妇作爱视频 | 久久久久久a亚洲欧洲av冫 | 人人妻人人澡人人爽欧美一区九九 | 四虎影视成人永久免费观看视频 | 激情国产av做激情国产爱 | 国产成人精品三级麻豆 | 精品人妻人人做人人爽夜夜爽 | ass日本丰满熟妇pics | 好爽又高潮了毛片免费下载 | 熟女少妇人妻中文字幕 | 亚洲色在线无码国产精品不卡 | 国产舌乚八伦偷品w中 | 亚洲中文字幕无码中文字在线 | 1000部夫妻午夜免费 | 精品夜夜澡人妻无码av蜜桃 | 2020久久超碰国产精品最新 | 久久无码人妻影院 | 亚洲欧美综合区丁香五月小说 | 粉嫩少妇内射浓精videos | 久久综合久久自在自线精品自 | 乱人伦人妻中文字幕无码 | 99re在线播放 | 老子影院午夜精品无码 | 欧美熟妇另类久久久久久多毛 | 67194成是人免费无码 | 亚洲 日韩 欧美 成人 在线观看 | 久久精品人人做人人综合试看 | 无套内谢老熟女 | 美女扒开屁股让男人桶 | 午夜精品久久久内射近拍高清 | 无码人妻精品一区二区三区下载 | 老熟女乱子伦 | 性欧美videos高清精品 | 亚洲中文无码av永久不收费 | 无遮挡国产高潮视频免费观看 | 亚洲精品久久久久久久久久久 | 少妇久久久久久人妻无码 | 国产精品无码mv在线观看 | 亚洲中文字幕在线无码一区二区 | 伊人久久婷婷五月综合97色 | 老子影院午夜伦不卡 | 亚洲另类伦春色综合小说 | 亚洲精品一区二区三区大桥未久 | 桃花色综合影院 | 人人妻人人澡人人爽欧美一区 | 高潮毛片无遮挡高清免费视频 | 中文字幕日产无线码一区 | 天天摸天天透天天添 | 国产艳妇av在线观看果冻传媒 | 成人亚洲精品久久久久软件 | 国产手机在线αⅴ片无码观看 | 国产av剧情md精品麻豆 | 67194成是人免费无码 | 99riav国产精品视频 | 欧美精品国产综合久久 | 国内少妇偷人精品视频免费 | 国产情侣作爱视频免费观看 | 少女韩国电视剧在线观看完整 | 狂野欧美激情性xxxx | 牲欲强的熟妇农村老妇女 | 中文字幕久久久久人妻 | 国产尤物精品视频 | 亚洲色大成网站www国产 | 日韩av无码一区二区三区不卡 | 少妇被粗大的猛进出69影院 | 国产三级精品三级男人的天堂 | 在线成人www免费观看视频 | 熟女少妇人妻中文字幕 | 亚洲欧美国产精品久久 | 欧美性猛交内射兽交老熟妇 | 精品乱子伦一区二区三区 | 97无码免费人妻超级碰碰夜夜 | 性色av无码免费一区二区三区 | 又大又硬又黄的免费视频 | 成人精品一区二区三区中文字幕 | 亚洲日韩av一区二区三区中文 | 人妻插b视频一区二区三区 | 任你躁国产自任一区二区三区 | 亚洲s码欧洲m码国产av | 久久精品国产大片免费观看 | 大胆欧美熟妇xx | 国产综合久久久久鬼色 | 亚洲欧美日韩综合久久久 | 老熟女重囗味hdxx69 | 精品久久久久久亚洲精品 | 老熟妇仑乱视频一区二区 | 国产乱人伦av在线无码 | 少妇的肉体aa片免费 | 婷婷丁香五月天综合东京热 | 永久免费观看美女裸体的网站 | 蜜桃av抽搐高潮一区二区 | 无码人妻丰满熟妇区毛片18 | 国产高潮视频在线观看 | 国产国语老龄妇女a片 | 18精品久久久无码午夜福利 | 一本大道伊人av久久综合 | 国产欧美精品一区二区三区 | 巨爆乳无码视频在线观看 | 亚洲国产精品久久久天堂 | 国产一区二区三区日韩精品 | 人人澡人人妻人人爽人人蜜桃 | 特黄特色大片免费播放器图片 | 51国偷自产一区二区三区 | 黑人巨大精品欧美一区二区 | 国产精品va在线观看无码 | 亚洲日韩乱码中文无码蜜桃臀网站 | 高潮毛片无遮挡高清免费视频 | 欧美日韩色另类综合 | 久久久久se色偷偷亚洲精品av | 99久久人妻精品免费二区 | 日本www一道久久久免费榴莲 | 中文字幕人成乱码熟女app | 精品乱子伦一区二区三区 | 久久国产精品二国产精品 | 男女爱爱好爽视频免费看 | 1000部啪啪未满十八勿入下载 | 波多野结衣av一区二区全免费观看 | 在线播放免费人成毛片乱码 | 在教室伦流澡到高潮hnp视频 | 偷窥日本少妇撒尿chinese | 国产在线精品一区二区高清不卡 | 久久精品国产精品国产精品污 | 无码人妻丰满熟妇区五十路百度 | 日日鲁鲁鲁夜夜爽爽狠狠 | 日韩在线不卡免费视频一区 | 欧美国产亚洲日韩在线二区 | 97夜夜澡人人爽人人喊中国片 | 国产凸凹视频一区二区 | 免费网站看v片在线18禁无码 | 久久精品人人做人人综合试看 | 国产熟妇高潮叫床视频播放 | 亚洲国产精品一区二区第一页 | 亚洲精品欧美二区三区中文字幕 | 久久人妻内射无码一区三区 | 亚洲精品午夜无码电影网 | 亚洲国产精品久久人人爱 | 白嫩日本少妇做爰 | 国产两女互慰高潮视频在线观看 | 伊人久久大香线蕉亚洲 | 97久久国产亚洲精品超碰热 | 亚洲日韩精品欧美一区二区 | 久久精品女人天堂av免费观看 | 国产亚洲精品久久久ai换 | 熟妇人妻无乱码中文字幕 | 免费乱码人妻系列无码专区 | 日韩精品a片一区二区三区妖精 | 亚洲中文字幕无码中文字在线 | 天天av天天av天天透 | 激情国产av做激情国产爱 | 好男人www社区 | 红桃av一区二区三区在线无码av | 激情内射日本一区二区三区 | 国产高潮视频在线观看 | 天下第一社区视频www日本 | a片在线免费观看 | 好男人www社区 | 在线播放无码字幕亚洲 | 久久精品国产亚洲精品 | 精品亚洲韩国一区二区三区 | 在线成人www免费观看视频 | 精品成人av一区二区三区 | 免费无码肉片在线观看 | 国色天香社区在线视频 | 国产成人精品三级麻豆 | 真人与拘做受免费视频一 | 在线天堂新版最新版在线8 | 精品厕所偷拍各类美女tp嘘嘘 | 欧美人与禽zoz0性伦交 | 久久无码专区国产精品s | 初尝人妻少妇中文字幕 | 日韩无套无码精品 | 美女毛片一区二区三区四区 | 狠狠色色综合网站 | 77777熟女视频在线观看 а天堂中文在线官网 | 在线观看国产一区二区三区 | 午夜免费福利小电影 | 国产精品香蕉在线观看 | 樱花草在线播放免费中文 | 中文字幕乱码人妻无码久久 | 亚洲精品国产品国语在线观看 | 日韩av无码一区二区三区不卡 | 99久久精品午夜一区二区 | 国产精品va在线观看无码 | 伊人久久大香线焦av综合影院 | 国产成人午夜福利在线播放 | 亚洲精品无码国产 | 亚洲无人区午夜福利码高清完整版 | 国产麻豆精品精东影业av网站 | 国产午夜无码精品免费看 | 精品久久久久香蕉网 | 樱花草在线社区www | 国产福利视频一区二区 | 蜜臀av无码人妻精品 | 国产卡一卡二卡三 | 99久久99久久免费精品蜜桃 | 日本xxxx色视频在线观看免费 | 天下第一社区视频www日本 | www国产精品内射老师 | 青青青爽视频在线观看 | 国产精品理论片在线观看 | 亚洲日本在线电影 | 一本无码人妻在中文字幕免费 | 色综合视频一区二区三区 | 性欧美疯狂xxxxbbbb | 强辱丰满人妻hd中文字幕 | 中国大陆精品视频xxxx | 国产黄在线观看免费观看不卡 | 亚洲精品无码国产 | www国产亚洲精品久久久日本 | 欧美熟妇另类久久久久久多毛 | 国产亚洲精品久久久久久大师 | 亚洲一区二区观看播放 | 国产另类ts人妖一区二区 | 亚洲aⅴ无码成人网站国产app | 香港三级日本三级妇三级 | 亚洲а∨天堂久久精品2021 | 色婷婷欧美在线播放内射 | 亚洲自偷自偷在线制服 | 欧美一区二区三区视频在线观看 | 青青久在线视频免费观看 | 国产办公室秘书无码精品99 | 久久婷婷五月综合色国产香蕉 | 亚洲一区二区观看播放 | 国语自产偷拍精品视频偷 | 国产亚洲日韩欧美另类第八页 | 久久精品99久久香蕉国产色戒 | 中文无码伦av中文字幕 | 久久久久久久女国产乱让韩 | 亚洲综合久久一区二区 | 东京热一精品无码av | 男女作爱免费网站 | 在线精品国产一区二区三区 | 欧美一区二区三区视频在线观看 | 亚洲午夜福利在线观看 | 亚洲天堂2017无码中文 | 国内精品久久久久久中文字幕 | 国产精品欧美成人 | 国产偷抇久久精品a片69 | 国产精品福利视频导航 | 丰满少妇高潮惨叫视频 | 亚洲日本va中文字幕 | 麻豆蜜桃av蜜臀av色欲av | 精品久久久久久人妻无码中文字幕 | 国产成人精品一区二区在线小狼 | 少妇无码av无码专区在线观看 | 午夜成人1000部免费视频 | 日韩视频 中文字幕 视频一区 | 精品久久久久久人妻无码中文字幕 | 亚洲一区二区三区在线观看网站 | 一区二区传媒有限公司 | 国产成人精品无码播放 | 国产精品99久久精品爆乳 | 久久综合给合久久狠狠狠97色 | 久久午夜无码鲁丝片 | 亚洲国产欧美日韩精品一区二区三区 | 成人性做爰aaa片免费看不忠 | 国产成人精品视频ⅴa片软件竹菊 | 国产精品福利视频导航 | 久久天天躁夜夜躁狠狠 | 欧洲欧美人成视频在线 | 嫩b人妻精品一区二区三区 | 精品一区二区不卡无码av | 一本色道婷婷久久欧美 | 久激情内射婷内射蜜桃人妖 | 色综合久久中文娱乐网 | 99精品无人区乱码1区2区3区 | 奇米影视7777久久精品 | 亚洲男女内射在线播放 | 国产超级va在线观看视频 | 色欲av亚洲一区无码少妇 | 麻豆md0077饥渴少妇 | 国产又粗又硬又大爽黄老大爷视 | 熟妇人妻激情偷爽文 | 伊人久久大香线蕉av一区二区 | 精品国产国产综合精品 | a片免费视频在线观看 | 欧美xxxx黑人又粗又长 | 国产午夜手机精彩视频 | 扒开双腿吃奶呻吟做受视频 | 亚洲 另类 在线 欧美 制服 | 奇米影视7777久久精品人人爽 | 成熟妇人a片免费看网站 | 一本色道婷婷久久欧美 | 亚洲色欲久久久综合网东京热 | 4hu四虎永久在线观看 | 亚洲七七久久桃花影院 | 国产精品久久国产三级国 | 国产舌乚八伦偷品w中 | 免费观看激色视频网站 | 人妻中文无码久热丝袜 | 国产精品久久久午夜夜伦鲁鲁 | 亚洲综合无码久久精品综合 | 欧美黑人乱大交 | 色窝窝无码一区二区三区色欲 | 女人被男人躁得好爽免费视频 | 少妇性荡欲午夜性开放视频剧场 | 亚洲一区av无码专区在线观看 | 黑人巨大精品欧美黑寡妇 | 国产成人一区二区三区别 | 欧美日韩综合一区二区三区 | 2019nv天堂香蕉在线观看 | 男女猛烈xx00免费视频试看 | 天海翼激烈高潮到腰振不止 | 日本精品久久久久中文字幕 | 波多野结衣乳巨码无在线观看 | 人妻少妇被猛烈进入中文字幕 | 欧美激情综合亚洲一二区 | 亚洲欧美日韩国产精品一区二区 | 久久久久99精品成人片 | 波多野结衣aⅴ在线 | 99在线 | 亚洲 | 中文久久乱码一区二区 | 亚洲精品国产第一综合99久久 | 漂亮人妻洗澡被公强 日日躁 | 伊人久久大香线焦av综合影院 | 国产香蕉尹人综合在线观看 | 性做久久久久久久免费看 | 亚洲精品国产第一综合99久久 | 国内揄拍国内精品少妇国语 | 国产色在线 | 国产 | 久久国产精品二国产精品 | 亚洲精品欧美二区三区中文字幕 | 中文字幕日韩精品一区二区三区 | 亚洲中文字幕va福利 | 人妻少妇被猛烈进入中文字幕 | 蜜桃视频韩日免费播放 | 少妇性荡欲午夜性开放视频剧场 | 久久久久免费精品国产 | 少妇无码av无码专区在线观看 | 99久久亚洲精品无码毛片 | 久久久久久久久蜜桃 | 国产亚洲tv在线观看 | 精品水蜜桃久久久久久久 | 99久久婷婷国产综合精品青草免费 | 精品国产精品久久一区免费式 | 国产激情一区二区三区 | 国产人成高清在线视频99最全资源 | 欧美成人家庭影院 | 亚洲欧洲中文日韩av乱码 | 丰满诱人的人妻3 | 国产猛烈高潮尖叫视频免费 | 一二三四社区在线中文视频 | 性生交大片免费看女人按摩摩 | 国产精品美女久久久 | 给我免费的视频在线观看 | 国产熟女一区二区三区四区五区 | 亚洲国产午夜精品理论片 | 美女极度色诱视频国产 | 亚欧洲精品在线视频免费观看 | 欧美人妻一区二区三区 | 日韩人妻系列无码专区 | 国产成人无码av片在线观看不卡 | 国产精品久久久久久亚洲影视内衣 | 131美女爱做视频 | 亚洲精品成人福利网站 | 高清国产亚洲精品自在久久 | 亚洲国产精品毛片av不卡在线 | 亚洲国产欧美国产综合一区 | 成人欧美一区二区三区黑人免费 | 日本丰满护士爆乳xxxx | 无码任你躁久久久久久久 | 国产精品人妻一区二区三区四 | 亚洲一区二区三区四区 | 在线观看国产一区二区三区 | 亚洲欧美日韩国产精品一区二区 | 国产精品国产自线拍免费软件 | 无码国模国产在线观看 | 国内少妇偷人精品视频免费 | 国产精品美女久久久 | 在线观看免费人成视频 | 成人免费视频视频在线观看 免费 | 欧美三级不卡在线观看 | 在线成人www免费观看视频 | 窝窝午夜理论片影院 | 无码国产激情在线观看 | 又大又硬又爽免费视频 | 国产精品对白交换视频 | 国产激情综合五月久久 | 国产精品va在线观看无码 | 巨爆乳无码视频在线观看 | 亚洲熟妇自偷自拍另类 | 欧美丰满熟妇xxxx | 1000部啪啪未满十八勿入下载 | 日韩精品乱码av一区二区 | 人妻中文无码久热丝袜 | 天海翼激烈高潮到腰振不止 | 丰满岳乱妇在线观看中字无码 | 天堂а√在线地址中文在线 | 国产亚洲精品久久久久久 | 久久婷婷五月综合色国产香蕉 | 亚洲成a人片在线观看无码 | 色欲综合久久中文字幕网 | 日韩精品久久久肉伦网站 | 国产香蕉97碰碰久久人人 | 十八禁真人啪啪免费网站 | 精品无人区无码乱码毛片国产 | 国产熟妇高潮叫床视频播放 | 国产亲子乱弄免费视频 | 欧美freesex黑人又粗又大 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 中文字幕无码免费久久9一区9 | √天堂中文官网8在线 | 久久99久久99精品中文字幕 | 国产精品福利视频导航 | 日本一卡2卡3卡四卡精品网站 | 丝袜足控一区二区三区 | 中文字幕av日韩精品一区二区 | 狠狠综合久久久久综合网 | 欧美人与禽猛交狂配 | 国产午夜手机精彩视频 | 国产69精品久久久久app下载 | 无码毛片视频一区二区本码 | 亚洲人成人无码网www国产 | 国产亲子乱弄免费视频 | 亚洲中文字幕无码一久久区 | 久热国产vs视频在线观看 | 午夜时刻免费入口 | v一区无码内射国产 | 激情国产av做激情国产爱 | 中文字幕无码乱人伦 | 人人妻人人澡人人爽欧美一区九九 | 久久精品国产日本波多野结衣 | 全黄性性激高免费视频 | 色偷偷av老熟女 久久精品人妻少妇一区二区三区 | 精品国偷自产在线视频 | 午夜丰满少妇性开放视频 | 黑森林福利视频导航 | 亚洲国产欧美日韩精品一区二区三区 | 无码人妻丰满熟妇区五十路百度 | 少妇人妻大乳在线视频 | 亚洲成色www久久网站 | 日本又色又爽又黄的a片18禁 | 无码人妻丰满熟妇区毛片18 | 国产精品久久久久久无码 | 丝袜足控一区二区三区 | 国产精品成人av在线观看 | 无码任你躁久久久久久久 | 真人与拘做受免费视频一 | 自拍偷自拍亚洲精品被多人伦好爽 | 亚洲国产精品无码一区二区三区 | 水蜜桃色314在线观看 | 亚洲熟妇色xxxxx亚洲 | 波多野结衣av在线观看 | 欧美日韩在线亚洲综合国产人 | 欧美日本免费一区二区三区 | 熟女体下毛毛黑森林 | 亚洲精品中文字幕乱码 | 狠狠色色综合网站 | 成人无码精品一区二区三区 | 国产亚洲tv在线观看 | 天天躁日日躁狠狠躁免费麻豆 | 国产三级精品三级男人的天堂 | 国产午夜亚洲精品不卡下载 | 国产激情无码一区二区 | 在线天堂新版最新版在线8 | 亚洲精品国产品国语在线观看 | 国产精品成人av在线观看 | 日本高清一区免费中文视频 | 国产手机在线αⅴ片无码观看 | 1000部夫妻午夜免费 | 久久午夜无码鲁丝片秋霞 | av小次郎收藏 | 国产精品人妻一区二区三区四 | 西西人体www44rt大胆高清 | 国产精品美女久久久久av爽李琼 | 久久久久亚洲精品中文字幕 | 亚洲a无码综合a国产av中文 | 帮老师解开蕾丝奶罩吸乳网站 | 999久久久国产精品消防器材 | 亚洲 欧美 激情 小说 另类 | 亚洲精品久久久久久久久久久 | 午夜福利一区二区三区在线观看 | 亚洲自偷自偷在线制服 | 国内精品九九久久久精品 | 日日躁夜夜躁狠狠躁 | 欧美兽交xxxx×视频 | 无码精品人妻一区二区三区av | 综合人妻久久一区二区精品 | 精品久久久久香蕉网 | 麻豆人妻少妇精品无码专区 | 国产三级久久久精品麻豆三级 | 国语自产偷拍精品视频偷 | 国产精品成人av在线观看 | 久久亚洲中文字幕无码 | 男人的天堂av网站 | 帮老师解开蕾丝奶罩吸乳网站 | 亚洲色偷偷男人的天堂 | 狂野欧美激情性xxxx | 国产午夜亚洲精品不卡下载 | 精品偷拍一区二区三区在线看 | 亚洲自偷精品视频自拍 | 曰韩少妇内射免费播放 | 欧美放荡的少妇 | 国产精品美女久久久网av | av无码久久久久不卡免费网站 | 精品无人国产偷自产在线 | 色欲人妻aaaaaaa无码 | 狠狠综合久久久久综合网 | 日产国产精品亚洲系列 | 亚洲中文字幕久久无码 | 中文字幕乱码人妻无码久久 | 亚洲小说图区综合在线 | 日日麻批免费40分钟无码 | 领导边摸边吃奶边做爽在线观看 | 免费观看黄网站 | 亚洲国产av美女网站 | 自拍偷自拍亚洲精品10p | 四虎永久在线精品免费网址 | 精品国产青草久久久久福利 | 亚洲熟妇色xxxxx欧美老妇y | 精品国偷自产在线 | 无码国产色欲xxxxx视频 | 巨爆乳无码视频在线观看 | 精品国产一区av天美传媒 | 欧美日韩综合一区二区三区 | 色五月五月丁香亚洲综合网 | 国色天香社区在线视频 | 国产农村乱对白刺激视频 | 久久精品丝袜高跟鞋 | 亚洲第一网站男人都懂 | 国产精品人人爽人人做我的可爱 | 精品无人区无码乱码毛片国产 | 300部国产真实乱 | 欧美一区二区三区视频在线观看 | 帮老师解开蕾丝奶罩吸乳网站 | 国产午夜福利100集发布 | 狠狠色噜噜狠狠狠7777奇米 | 四虎国产精品免费久久 | 麻豆蜜桃av蜜臀av色欲av | 无码人妻精品一区二区三区下载 | 国产精品久久久久无码av色戒 | 人人妻人人澡人人爽人人精品 | 亚洲 高清 成人 动漫 | 日韩人妻无码中文字幕视频 | 亚洲の无码国产の无码步美 | 久久午夜无码鲁丝片午夜精品 | 久久无码人妻影院 | 国产明星裸体无码xxxx视频 | 狠狠噜狠狠狠狠丁香五月 | 一本久道久久综合狠狠爱 | 波多野结衣乳巨码无在线观看 | 99久久精品午夜一区二区 | 亚洲の无码国产の无码影院 | 天下第一社区视频www日本 | 丝袜足控一区二区三区 | 日韩av无码一区二区三区不卡 | 波多野结衣av一区二区全免费观看 | 久久99精品国产.久久久久 | 99久久精品国产一区二区蜜芽 | 免费无码肉片在线观看 | 中文字幕亚洲情99在线 | 国产农村妇女高潮大叫 | 国产精品理论片在线观看 | 最近的中文字幕在线看视频 | 无码吃奶揉捏奶头高潮视频 | 成人一在线视频日韩国产 | 国产熟女一区二区三区四区五区 | 国产精品久久国产精品99 | 国产性猛交╳xxx乱大交 国产精品久久久久久无码 欧洲欧美人成视频在线 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 久9re热视频这里只有精品 | 久久国产精品_国产精品 | 麻豆国产97在线 | 欧洲 | 岛国片人妻三上悠亚 | 日韩无码专区 | 成人无码精品一区二区三区 | 国产无遮挡又黄又爽免费视频 | 青青久在线视频免费观看 | 色 综合 欧美 亚洲 国产 | 精品厕所偷拍各类美女tp嘘嘘 | 国语精品一区二区三区 | 动漫av网站免费观看 | 大地资源网第二页免费观看 | 日产精品高潮呻吟av久久 | 久久这里只有精品视频9 | 在线观看欧美一区二区三区 | 国产在线精品一区二区高清不卡 | 中文字幕乱码人妻二区三区 | 老子影院午夜精品无码 | 精品 日韩 国产 欧美 视频 | 男女超爽视频免费播放 | 亚洲欧美精品伊人久久 | 高潮毛片无遮挡高清免费 | 亚洲 a v无 码免 费 成 人 a v | 国精产品一品二品国精品69xx | 亚洲爆乳无码专区 | 久久精品人妻少妇一区二区三区 | 亚洲精品国产精品乱码视色 | 扒开双腿吃奶呻吟做受视频 | 日本熟妇浓毛 | 一本色道婷婷久久欧美 | 日韩精品a片一区二区三区妖精 | 欧美丰满老熟妇xxxxx性 | 伊人久久大香线蕉午夜 | 国产精品无码永久免费888 | 东京热男人av天堂 | 欧美激情综合亚洲一二区 | 国产无遮挡又黄又爽免费视频 | 沈阳熟女露脸对白视频 | 免费国产黄网站在线观看 | 99久久人妻精品免费一区 | 女人被爽到呻吟gif动态图视看 | 红桃av一区二区三区在线无码av | 久久婷婷五月综合色国产香蕉 | 中文字幕无码人妻少妇免费 | 永久免费观看美女裸体的网站 | 国产无遮挡又黄又爽又色 | 99久久婷婷国产综合精品青草免费 | 久久久久久九九精品久 | 无码午夜成人1000部免费视频 | 丰满少妇熟乱xxxxx视频 | 奇米影视7777久久精品人人爽 | 亚洲狠狠婷婷综合久久 | 久久国语露脸国产精品电影 | 亚洲第一无码av无码专区 | 又紧又大又爽精品一区二区 | 日本爽爽爽爽爽爽在线观看免 | 亚洲色在线无码国产精品不卡 | 狂野欧美性猛交免费视频 | 国产精品亚洲一区二区三区喷水 | 夜夜高潮次次欢爽av女 | a在线亚洲男人的天堂 | 又色又爽又黄的美女裸体网站 | ass日本丰满熟妇pics | 精品国产成人一区二区三区 | 欧美阿v高清资源不卡在线播放 | 中文字幕人妻无码一区二区三区 | 日本熟妇大屁股人妻 | 乱人伦人妻中文字幕无码久久网 | 2019nv天堂香蕉在线观看 | 女人被爽到呻吟gif动态图视看 | 图片区 小说区 区 亚洲五月 | 鲁鲁鲁爽爽爽在线视频观看 | 东北女人啪啪对白 | 中文无码成人免费视频在线观看 | 又紧又大又爽精品一区二区 | 性色欲网站人妻丰满中文久久不卡 | 亚洲国产综合无码一区 | 无遮挡国产高潮视频免费观看 | 在线观看国产午夜福利片 | 中文字幕无码热在线视频 | 久青草影院在线观看国产 | 久久精品人人做人人综合 | 97精品国产97久久久久久免费 | 国产精品二区一区二区aⅴ污介绍 | 日韩精品久久久肉伦网站 | 日本精品人妻无码免费大全 | 波多野42部无码喷潮在线 | 毛片内射-百度 | 精品人妻人人做人人爽夜夜爽 | 97夜夜澡人人双人人人喊 | 日韩成人一区二区三区在线观看 | 亚洲精品国产精品乱码视色 | 成人无码精品一区二区三区 | 精品国产国产综合精品 | 国产精品无码久久av | 国产一精品一av一免费 | 国产福利视频一区二区 | 精品国产麻豆免费人成网站 | 无码人妻av免费一区二区三区 | 少妇被粗大的猛进出69影院 | 国产成人无码区免费内射一片色欲 | 久久99精品国产麻豆蜜芽 | 久久久久亚洲精品中文字幕 | 久久国产劲爆∧v内射 | 久久精品人人做人人综合 | 少妇性俱乐部纵欲狂欢电影 | 国产超碰人人爽人人做人人添 | 国产亚洲日韩欧美另类第八页 | 亚洲色成人中文字幕网站 | 性色av无码免费一区二区三区 | 熟妇女人妻丰满少妇中文字幕 | 国产日产欧产精品精品app | 国产性生大片免费观看性 | 亚洲日韩乱码中文无码蜜桃臀网站 | 日韩精品久久久肉伦网站 | 国产极品美女高潮无套在线观看 | 99久久精品日本一区二区免费 | 97夜夜澡人人双人人人喊 | 熟妇人妻无乱码中文字幕 | 无码免费一区二区三区 | 日日碰狠狠丁香久燥 | 精品久久久无码人妻字幂 | 国产精品国产三级国产专播 | 国产精品久久久午夜夜伦鲁鲁 | 免费看少妇作爱视频 | 欧美激情内射喷水高潮 | 99精品无人区乱码1区2区3区 | 丰满人妻翻云覆雨呻吟视频 | 欧美丰满熟妇xxxx | 99久久久无码国产aaa精品 | 国产精品办公室沙发 | 亚洲国产欧美国产综合一区 | 我要看www免费看插插视频 | 国产成人精品视频ⅴa片软件竹菊 | 理论片87福利理论电影 | 在线播放无码字幕亚洲 | 国产亚洲人成在线播放 | 97久久国产亚洲精品超碰热 | 99久久久国产精品无码免费 | 久久 国产 尿 小便 嘘嘘 | 久久久精品欧美一区二区免费 | 水蜜桃色314在线观看 | 性欧美videos高清精品 | 麻豆精产国品 | 精品人人妻人人澡人人爽人人 | 日本一卡二卡不卡视频查询 | 熟女少妇人妻中文字幕 | 午夜熟女插插xx免费视频 | 成人欧美一区二区三区黑人免费 | 18精品久久久无码午夜福利 | 久久99精品久久久久婷婷 | 老司机亚洲精品影院 | 婷婷综合久久中文字幕蜜桃三电影 | 成人精品天堂一区二区三区 | 国色天香社区在线视频 | 精品一二三区久久aaa片 | 国产综合久久久久鬼色 | 一本无码人妻在中文字幕免费 | 国产又爽又猛又粗的视频a片 | 天天摸天天透天天添 | 麻豆国产丝袜白领秘书在线观看 | 成在人线av无码免费 | 日本一卡2卡3卡四卡精品网站 | 亚洲啪av永久无码精品放毛片 | aⅴ亚洲 日韩 色 图网站 播放 | 性欧美牲交xxxxx视频 | 成年美女黄网站色大免费全看 | 欧美激情综合亚洲一二区 | 色综合视频一区二区三区 | 色窝窝无码一区二区三区色欲 | 窝窝午夜理论片影院 | 熟妇人妻无乱码中文字幕 | yw尤物av无码国产在线观看 | 久久久久成人精品免费播放动漫 | 亚洲中文字幕乱码av波多ji | 中文字幕av日韩精品一区二区 | 国产免费久久精品国产传媒 | 亚洲人成影院在线无码按摩店 | 女人和拘做爰正片视频 | 国产激情精品一区二区三区 | 亚洲熟悉妇女xxx妇女av | 青青青爽视频在线观看 | 亚洲熟妇色xxxxx欧美老妇y | 国产网红无码精品视频 | 中文字幕色婷婷在线视频 | 亚欧洲精品在线视频免费观看 | 全黄性性激高免费视频 | 亚洲成a人片在线观看无码3d | www一区二区www免费 | 国产欧美精品一区二区三区 | 亚洲七七久久桃花影院 | 一本久久a久久精品vr综合 | 国产卡一卡二卡三 | 国产亚洲精品久久久久久国模美 | 精品久久久无码人妻字幂 | 久久国产自偷自偷免费一区调 | 国产精品人人妻人人爽 | yw尤物av无码国产在线观看 | 玩弄中年熟妇正在播放 | 大屁股大乳丰满人妻 | 国产人成高清在线视频99最全资源 | 日本xxxx色视频在线观看免费 | 日韩人妻无码一区二区三区久久99 | 美女毛片一区二区三区四区 | 99久久精品无码一区二区毛片 | 中文字幕久久久久人妻 | 亚洲一区av无码专区在线观看 | 亚洲精品久久久久avwww潮水 | 无码av中文字幕免费放 | 国产激情无码一区二区app | 日韩av无码一区二区三区不卡 | 亚洲伊人久久精品影院 | 永久免费观看美女裸体的网站 | 久久久久免费看成人影片 | 未满小14洗澡无码视频网站 | 蜜桃av抽搐高潮一区二区 | 色综合视频一区二区三区 | 久久久久se色偷偷亚洲精品av | 国内少妇偷人精品视频 | 国产综合色产在线精品 | 动漫av一区二区在线观看 | 国产一区二区不卡老阿姨 | 99视频精品全部免费免费观看 | 国产精品福利视频导航 | 天天躁日日躁狠狠躁免费麻豆 | 亚洲中文字幕无码一久久区 | 中文字幕av日韩精品一区二区 | 狠狠色丁香久久婷婷综合五月 | 国产午夜手机精彩视频 | 国产成人综合在线女婷五月99播放 | 中文字幕+乱码+中文字幕一区 | 国产超级va在线观看视频 | 好男人社区资源 | 亚洲精品国偷拍自产在线麻豆 | 无码国产激情在线观看 | 亚洲国产综合无码一区 | 国产精品亚洲lv粉色 | 亚洲 激情 小说 另类 欧美 | 成人片黄网站色大片免费观看 | 夜夜高潮次次欢爽av女 | 免费人成在线视频无码 | 少妇性l交大片欧洲热妇乱xxx | 99精品国产综合久久久久五月天 | 内射爽无广熟女亚洲 | 一个人看的视频www在线 | 成 人影片 免费观看 | 国产一区二区三区精品视频 | 99久久无码一区人妻 | 国产明星裸体无码xxxx视频 | 国产亚洲精品久久久久久久久动漫 | 熟女少妇在线视频播放 | 欧美日韩亚洲国产精品 | 香港三级日本三级妇三级 | 大肉大捧一进一出视频出来呀 | 色一情一乱一伦 | 人妻有码中文字幕在线 | 亚欧洲精品在线视频免费观看 | 亚洲日本一区二区三区在线 | 沈阳熟女露脸对白视频 | 日韩成人一区二区三区在线观看 | 四虎影视成人永久免费观看视频 | www一区二区www免费 | 粉嫩少妇内射浓精videos | 国产一区二区不卡老阿姨 | 国产亚洲精品久久久闺蜜 | 国产偷自视频区视频 | 亚洲gv猛男gv无码男同 | av无码久久久久不卡免费网站 | 亚洲精品国产a久久久久久 | 日本一卡2卡3卡四卡精品网站 | 欧美日本精品一区二区三区 | 内射白嫩少妇超碰 | v一区无码内射国产 | 精品一二三区久久aaa片 | 久久综合给久久狠狠97色 | 亚洲精品一区三区三区在线观看 | 成年美女黄网站色大免费视频 | 亚洲男女内射在线播放 | 300部国产真实乱 | 国产后入清纯学生妹 | 樱花草在线社区www | 性欧美大战久久久久久久 | 荫蒂被男人添的好舒服爽免费视频 | 中文亚洲成a人片在线观看 |