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

歡迎訪問 生活随笔!

生活随笔

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

编程问答

2D激光SLAM::ROS-AMCL包源码阅读(三)从main()开始

發布時間:2023/12/20 编程问答 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 2D激光SLAM::ROS-AMCL包源码阅读(三)从main()开始 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

2D激光SLAM::ROS-AMCL包源碼閱讀(三)從main()開始


一、初始化主體部分


int main(): 最主要的作用是創建了 AmclNode對象

int main(int argc, char** argv) {ros::init(argc, argv, "amcl");ros::NodeHandle nh;// Override default sigint handlersignal(SIGINT, sigintHandler);// Make our node available to sigintHandleramcl_node_ptr.reset(new AmclNode());if (argc == 1){// run using ROS inputros::spin();}else if ((argc == 3) && (std::string(argv[1]) == "--run-from-bag")){amcl_node_ptr->runFromBag(argv[2]);}// Without this, our boost locks are not shut down nicelyamcl_node_ptr.reset();// To quote Morgan, Hooray!return(0); }

接下來看類 AmclNode的構造函數

AmclNode::AmclNode()主要內容為:

1、從參數服務器上獲取大量參數

2、updatePoseFromServer() //從參數服務器獲取機器人的初始位置

3、注冊publisher

(1)“amcl-pose"話題

(2)"particlecloud"話題

3、創建服務

(1)“global_localization"服務,注冊回調AmclNode::globalLocalizationCallback():沒有給定初始位姿的情況下在全局范圍內初始化粒子位姿,該Callback調用pf_init_model,然后調用AmclNode::uniformPoseGenerator在地圖的free點隨機生成pf->max_samples個粒子

(2)"request_nomotion_update"服務,注冊回調&AmclNode::nomotionUpdateCallback():運動模型沒有更新的情況下也更新粒子群

(3)"set_map"服務,注冊回調&AmclNode::setMapCallback():

a、handleMapMessage():進行地圖轉換 ,記錄free space ,以及初始化pf_t 結構體,實例化運動模型(odom)和觀測模型(laser) handleMapMessage() 后面會有詳細描述

b、handleInitialPoseMessage(req.initial_pose);?根據接收的初始位姿消息,在該位姿附近高斯采樣重新生成粒子集

?

4 、話題訂閱

(1)”scan" : 消息類型sensor_msgs::LaserScan, 注冊回調AmclNode::laserReceived() :這個回調是amcl的整個主題流程 下一篇會有詳細描述

(2)"initialpose",注冊回調AmclNode::initialPoseReceived() : 調用handleInitialPoseMessage();?根據接收的初始位姿消息,在該位姿附近高斯采樣重新生成粒子集

(3)(這個話題可選)"map",注冊回調AmclNode::mapReceived() : 調用handleMapMessage() 進行地圖轉換 ,記錄free space ,以及初始化pf_t 結構體,實例化運動模型(odom)和觀測模型(laser) handleMapMessage() 這個后面會有詳細描述

?

5、若沒有訂閱話題?"map",則調用requestMap()

(1)調用ros::service::call,請求"static_map"服務,請求獲取地圖

(2)獲取后,調用handleMapMessage( resp.map );【handleMapMessage() 后面會有詳細描述

?

6、創建定時器

一個15秒的定時器:AmclNode::checkLaserReceived,檢查 15上一次收到激光雷達數據至今是否超過15秒,如超過則報錯?

AmclNode::AmclNode() :sent_first_transform_(false),latest_tf_valid_(false),map_(NULL),pf_(NULL),resample_count_(0),odom_(NULL),laser_(NULL),private_nh_("~"),initial_pose_hyp_(NULL),first_map_received_(false),first_reconfigure_call_(true) {boost::recursive_mutex::scoped_lock l(configuration_mutex_);// Grab params off the param server//從參數服務器上獲取大量參數private_nh_.param("use_map_topic", use_map_topic_, false);private_nh_.param("first_map_only", first_map_only_, false);double tmp;private_nh_.param("gui_publish_rate", tmp, -1.0);gui_publish_period = ros::Duration(1.0/tmp);private_nh_.param("save_pose_rate", tmp, 0.5);save_pose_period = ros::Duration(1.0/tmp);private_nh_.param("laser_min_range", laser_min_range_, -1.0);private_nh_.param("laser_max_range", laser_max_range_, -1.0);private_nh_.param("laser_max_beams", max_beams_, 30);private_nh_.param("min_particles", min_particles_, 100);private_nh_.param("max_particles", max_particles_, 5000);private_nh_.param("kld_err", pf_err_, 0.01);private_nh_.param("kld_z", pf_z_, 0.99);private_nh_.param("odom_alpha1", alpha1_, 0.2);private_nh_.param("odom_alpha2", alpha2_, 0.2);private_nh_.param("odom_alpha3", alpha3_, 0.2);private_nh_.param("odom_alpha4", alpha4_, 0.2);private_nh_.param("odom_alpha5", alpha5_, 0.2);private_nh_.param("do_beamskip", do_beamskip_, false);private_nh_.param("beam_skip_distance", beam_skip_distance_, 0.5);private_nh_.param("beam_skip_threshold", beam_skip_threshold_, 0.3);if (private_nh_.hasParam("beam_skip_error_threshold_")){private_nh_.param("beam_skip_error_threshold_", beam_skip_error_threshold_);}else{private_nh_.param("beam_skip_error_threshold", beam_skip_error_threshold_, 0.9);}private_nh_.param("laser_z_hit", z_hit_, 0.95);private_nh_.param("laser_z_short", z_short_, 0.1);private_nh_.param("laser_z_max", z_max_, 0.05);private_nh_.param("laser_z_rand", z_rand_, 0.05);private_nh_.param("laser_sigma_hit", sigma_hit_, 0.2);private_nh_.param("laser_lambda_short", lambda_short_, 0.1);private_nh_.param("laser_likelihood_max_dist", laser_likelihood_max_dist_, 2.0);std::string tmp_model_type;private_nh_.param("laser_model_type", tmp_model_type, std::string("likelihood_field"));if(tmp_model_type == "beam")laser_model_type_ = LASER_MODEL_BEAM;else if(tmp_model_type == "likelihood_field")laser_model_type_ = LASER_MODEL_LIKELIHOOD_FIELD;else if(tmp_model_type == "likelihood_field_prob"){laser_model_type_ = LASER_MODEL_LIKELIHOOD_FIELD_PROB;}else{ROS_WARN("Unknown laser model type \"%s\"; defaulting to likelihood_field model",tmp_model_type.c_str());laser_model_type_ = LASER_MODEL_LIKELIHOOD_FIELD;}private_nh_.param("odom_model_type", tmp_model_type, std::string("diff"));if(tmp_model_type == "diff")odom_model_type_ = ODOM_MODEL_DIFF;else if(tmp_model_type == "omni")odom_model_type_ = ODOM_MODEL_OMNI;else if(tmp_model_type == "diff-corrected")odom_model_type_ = ODOM_MODEL_DIFF_CORRECTED;else if(tmp_model_type == "omni-corrected")odom_model_type_ = ODOM_MODEL_OMNI_CORRECTED;else{ROS_WARN("Unknown odom model type \"%s\"; defaulting to diff model",tmp_model_type.c_str());odom_model_type_ = ODOM_MODEL_DIFF;}private_nh_.param("update_min_d", d_thresh_, 0.2);private_nh_.param("update_min_a", a_thresh_, M_PI/6.0);private_nh_.param("odom_frame_id", odom_frame_id_, std::string("odom"));private_nh_.param("base_frame_id", base_frame_id_, std::string("base_link"));private_nh_.param("global_frame_id", global_frame_id_, std::string("map"));private_nh_.param("resample_interval", resample_interval_, 2);double tmp_tol;private_nh_.param("transform_tolerance", tmp_tol, 0.1);private_nh_.param("recovery_alpha_slow", alpha_slow_, 0.001);private_nh_.param("recovery_alpha_fast", alpha_fast_, 0.1);private_nh_.param("tf_broadcast", tf_broadcast_, true);// For diagnosticsprivate_nh_.param("std_warn_level_x", std_warn_level_x_, 0.2);private_nh_.param("std_warn_level_y", std_warn_level_y_, 0.2);private_nh_.param("std_warn_level_yaw", std_warn_level_yaw_, 0.1);transform_tolerance_.fromSec(tmp_tol);{double bag_scan_period;private_nh_.param("bag_scan_period", bag_scan_period, -1.0);bag_scan_period_.fromSec(bag_scan_period);}odom_frame_id_ = stripSlash(odom_frame_id_);base_frame_id_ = stripSlash(base_frame_id_);global_frame_id_ = stripSlash(global_frame_id_);//get initial pose and init particles from Server//從參數服務器獲取機器人的初始位置updatePoseFromServer();cloud_pub_interval.fromSec(1.0);tfb_.reset(new tf2_ros::TransformBroadcaster());tf_.reset(new tf2_ros::Buffer());tfl_.reset(new tf2_ros::TransformListener(*tf_));//注冊publisher//“amcl-pose"話題pose_pub_ = nh_.advertise<geometry_msgs::PoseWithCovarianceStamped>("amcl_pose", 2, true);//"particlecloud"話題particlecloud_pub_ = nh_.advertise<geometry_msgs::PoseArray>("particlecloud", 2, true);//創建服務//“global_localization"服務,注冊回調AmclNode::globalLocalizationCallback()://沒有給定初始位姿的情況下在全局范圍內初始化粒子位姿,//該Callback調用pf_init_model,//然后調用AmclNode::uniformPoseGenerator在地圖的free點隨機生成pf->max_samples個粒子global_loc_srv_ = nh_.advertiseService("global_localization", &AmclNode::globalLocalizationCallback,this);//"request_nomotion_update"服務,//注冊回調&AmclNode::nomotionUpdateCallback():運動模型沒有更新的情況下也更新粒子群nomotion_update_srv_= nh_.advertiseService("request_nomotion_update", &AmclNode::nomotionUpdateCallback, this);//"set_map"服務,注冊回調&AmclNode::setMapCallback():set_map_srv_= nh_.advertiseService("set_map", &AmclNode::setMapCallback, this);//話題訂閱laser_scan_sub_ = new message_filters::Subscriber<sensor_msgs::LaserScan>(nh_, scan_topic_, 100);laser_scan_filter_ = new tf2_ros::MessageFilter<sensor_msgs::LaserScan>(*laser_scan_sub_,*tf_,odom_frame_id_,100,nh_);laser_scan_filter_->registerCallback(boost::bind(&AmclNode::laserReceived,this, _1));initial_pose_sub_ = nh_.subscribe("initialpose", 2, &AmclNode::initialPoseReceived, this);//若沒有訂閱話題 "map",則調用requestMap()if(use_map_topic_) {map_sub_ = nh_.subscribe("map", 1, &AmclNode::mapReceived, this);ROS_INFO("Subscribed to map topic.");} else {requestMap();}m_force_update = false;dsrv_ = new dynamic_reconfigure::Server<amcl::AMCLConfig>(ros::NodeHandle("~"));dynamic_reconfigure::Server<amcl::AMCLConfig>::CallbackType cb = boost::bind(&AmclNode::reconfigureCB, this, _1, _2);dsrv_->setCallback(cb);// 15s timer to warn on lack of receipt of laser scans, #5209//創建定時器laser_check_interval_ = ros::Duration(15.0);check_laser_timer_ = nh_.createTimer(laser_check_interval_, boost::bind(&AmclNode::checkLaserReceived, this, _1));diagnosic_updater_.setHardwareID("None");diagnosic_updater_.add("Standard deviation", this, &AmclNode::standardDeviationDiagnostics); }

接下來看requestMap(),里面主要調用了handleMapMessage()

AmclNode::requestMap()

1、一直請求服務"static_map"直到成功

2、獲取到地圖數據后,調用handleMapMessage( resp.map );? //處理接收到的地圖數據,初始化粒子濾波器等操作 后面會詳細描述

void AmclNode::requestMap() {boost::recursive_mutex::scoped_lock ml(configuration_mutex_);// get map via RPCnav_msgs::GetMap::Request req;nav_msgs::GetMap::Response resp;ROS_INFO("Requesting the map...");while(!ros::service::call("static_map", req, resp)){ROS_WARN("Request for map failed; trying again...");ros::Duration d(0.5);d.sleep();}handleMapMessage( resp.map ); }

接下來是主要的初始化部分,handleMapMessage():

handleMapMessage() 主要內容為:

1、freeMapDependentMemory(); // 清空map_ ,pf_ , laser_ 這些對象

2、map_=convertMap(msg); // 重新初始化map_對象,將map_msg消息類型轉換為map_t結構體,具體操作為對map_msg.data[]數組的內容變成地圖柵格:0->-1(不是障礙);100->+1(障礙);else->0(不明)后面給出相關內容

3、遍歷地圖所有柵格,將狀態為空閑的柵格的行列號記錄到free_space_indices??

static std::vector<std::pair<int,int> > free_space_indices;

4、pf_ = pf_alloc(最小粒子數,最大粒子數,alpha_slow_,alpha_fast_,粒子初始位姿隨機生成器(這是一個函數,在這里作為變量了),map_)? ?//創建粒子濾波器 后面給出相關內容

5、updatePoseFromServer(); //載入預設的濾波器均值和方差

6、pf_init(pf_, pf_init_pose_mean, pf_init_pose_cov);? //根據上一步載入的均值和方差、以及粒子初始位姿隨機生成器,對粒子濾波器進行初始化,步驟簡述為:??后面給出相關內容

(1)選擇要使用的粒子集合(因為在創建濾波器時,創建了兩份粒子集合,一份使用,另一份用來重采樣緩沖)

(2)pf_kdtree_clear(set->kdtree); //對傳入參數所指向的kdtree進行清空

(3)設置粒子數

(4)pdf = pf_pdf_gaussian_alloc(mean, cov); //使用傳入的均值和方差來初始化高斯分布

(5)對每個粒子的位姿使用高斯分布進行初始化

(6)釋放高斯分布pdf

(7)pf_cluster_stats(pf, set); //對粒子濾波器的粒子集進行聚類

(8)設置聚類收斂為0

7、odom_ = new AMCLOdom(); //創建AMCLOdom對象

8、odom_->SetModel( odom_model_type_, alpha1_, alpha2_, alpha3_, alpha4_, alpha5_ ); //設置里程計模型,傳入參數

9、laser_ = new AMCLLaser(max_beams_, map_); //創建AMCLLaser對象

10、設置激光雷達傳感器模型,默認為LASER_MODEL_LIKELIHOOD_FIELD

laser_->SetModelLikelihoodField(z_hit_, z_rand_, sigma_hit_,laser_likelihood_max_dist_); //根據選擇的激光傳感器模型傳入參數,并設置地圖上障礙物膨脹最大距離

//這里涉及到激光雷達傳感器的概率模型下一篇會給出詳細內容

11、?applyInitialPose();? //當map_變量初始化完成,以及接收到了“initialpose”話題消息后,才會執行這個,里面是pf_init(),意思是,如果又收到新的初始位姿信息,則重新初始化一次粒子濾波器的粒子位姿

void AmclNode::handleMapMessage(const nav_msgs::OccupancyGrid& msg) {boost::recursive_mutex::scoped_lock cfl(configuration_mutex_);ROS_INFO("Received a %d X %d map @ %.3f m/pix\n",msg.info.width,msg.info.height,msg.info.resolution);if(msg.header.frame_id != global_frame_id_)ROS_WARN("Frame_id of map received:'%s' doesn't match global_frame_id:'%s'. This could cause issues with reading published topics",msg.header.frame_id.c_str(),global_frame_id_.c_str());freeMapDependentMemory();// Clear queued laser objects because they hold pointers to the existing// map, #5202.lasers_.clear();lasers_update_.clear();frame_to_laser_.clear();map_ = convertMap(msg);#if NEW_UNIFORM_SAMPLING// Index of free spacefree_space_indices.resize(0);//遍歷地圖所有柵格,將狀態為空閑的柵格的行列號記錄到free_space_indicesfor(int i = 0; i < map_->size_x; i++)for(int j = 0; j < map_->size_y; j++)if(map_->cells[MAP_INDEX(map_,i,j)].occ_state == -1)free_space_indices.push_back(std::make_pair(i,j)); #endif// Create the particle filterpf_ = pf_alloc(min_particles_, max_particles_,alpha_slow_, alpha_fast_,(pf_init_model_fn_t)AmclNode::uniformPoseGenerator,(void *)map_);pf_->pop_err = pf_err_;pf_->pop_z = pf_z_;// Initialize the filterupdatePoseFromServer();pf_vector_t pf_init_pose_mean = pf_vector_zero();pf_init_pose_mean.v[0] = init_pose_[0];pf_init_pose_mean.v[1] = init_pose_[1];pf_init_pose_mean.v[2] = init_pose_[2];pf_matrix_t pf_init_pose_cov = pf_matrix_zero();pf_init_pose_cov.m[0][0] = init_cov_[0];pf_init_pose_cov.m[1][1] = init_cov_[1];pf_init_pose_cov.m[2][2] = init_cov_[2];pf_init(pf_, pf_init_pose_mean, pf_init_pose_cov);pf_init_ = false;// Instantiate the sensor objects// Odometrydelete odom_;odom_ = new AMCLOdom();ROS_ASSERT(odom_);odom_->SetModel( odom_model_type_, alpha1_, alpha2_, alpha3_, alpha4_, alpha5_ );// Laserdelete laser_;laser_ = new AMCLLaser(max_beams_, map_);ROS_ASSERT(laser_);if(laser_model_type_ == LASER_MODEL_BEAM)laser_->SetModelBeam(z_hit_, z_short_, z_max_, z_rand_,sigma_hit_, lambda_short_, 0.0);else if(laser_model_type_ == LASER_MODEL_LIKELIHOOD_FIELD_PROB){ROS_INFO("Initializing likelihood field model; this can take some time on large maps...");laser_->SetModelLikelihoodFieldProb(z_hit_, z_rand_, sigma_hit_,laser_likelihood_max_dist_, do_beamskip_, beam_skip_distance_, beam_skip_threshold_, beam_skip_error_threshold_);ROS_INFO("Done initializing likelihood field model.");}else{ROS_INFO("Initializing likelihood field model; this can take some time on large maps...");laser_->SetModelLikelihoodField(z_hit_, z_rand_, sigma_hit_,laser_likelihood_max_dist_);ROS_INFO("Done initializing likelihood field model.");}// In case the initial pose message arrived before the first map,// try to apply the initial pose now that the map has arrived.applyInitialPose();}

二、一些函數的具體實現

前文描述了AMCL初始化的大體框架,接下來是一些關于初始化的具體函數實現部分


1、convertMap(msg):??

convertMap(msg):??

實現nav_msgs::OccupancyGrid& map_msg 類型數據轉換到代碼定義的 map_t結構體數據類型

主要設置了:

1、地圖的尺寸

2、地圖的尺度(分辨率)

3、地圖原點,注意map_msg.info.origin這個點是地圖的中心點,設置地圖原點時還要加偏移

4、設置地圖的每個柵格的占據狀況

/*** Convert an OccupancyGrid map message into the internal* representation. This allocates a map_t and returns it.*/ map_t* AmclNode::convertMap( const nav_msgs::OccupancyGrid& map_msg ) {map_t* map = map_alloc();ROS_ASSERT(map);map->size_x = map_msg.info.width;map->size_y = map_msg.info.height;map->scale = map_msg.info.resolution;//(map_msg.info.origin.position.x,map_msg.info.origin.position.y) 是柵格地圖(0,0)的世界坐標系坐標map->origin_x = map_msg.info.origin.position.x + (map->size_x / 2) * map->scale;map->origin_y = map_msg.info.origin.position.y + (map->size_y / 2) * map->scale;// Convert to player formatmap->cells = (map_cell_t*)malloc(sizeof(map_cell_t)*map->size_x*map->size_y);ROS_ASSERT(map->cells);for(int i=0;i<map->size_x * map->size_y;i++){//根據map_msg消息來設置地圖對應柵格的狀態occ_state : -1 = free, 0 = unknown, +1 = occif(map_msg.data[i] == 0)map->cells[i].occ_state = -1;else if(map_msg.data[i] == 100)map->cells[i].occ_state = +1;elsemap->cells[i].occ_state = 0;}return map; }

2、pf_alloc(int min_samples, int max_samples,double alpha_slow, double alpha_fast,pf_init_model_fn_t random_pose_fn, void *random_pose_data)

pf_ = pf_alloc(最小粒子數,最大粒子數,alpha_slow_,alpha_fast_,粒子初始位姿隨機生成器(這是一個函數,在這里作為變量了),地圖對象)?

主要作用是創建粒子濾波器,分配內存等

具體實現順序為:

(1)設置濾波器的粒子位姿隨機生成函數

(2)設置濾波器的粒子位姿數據(實際上傳入的是柵格地圖數據)

(3)設置粒子數上下限

(4)設置濾波器參數

(5)對濾波器的兩份粒子集合進行零初始化(分配內存、位姿初始化為0)

(6)對每份粒子集合創建kdtree

(7)初始化聚類數目、最大類別數

(8)初始化粒子集合的均值和方差

(9)設置收斂為0

// Create a new filter pf_t *pf_alloc(int min_samples, int max_samples,double alpha_slow, double alpha_fast,pf_init_model_fn_t random_pose_fn, void *random_pose_data) {int i, j;pf_t *pf;pf_sample_set_t *set;pf_sample_t *sample;srand48(time(NULL));pf = calloc(1, sizeof(pf_t));pf->random_pose_fn = random_pose_fn;pf->random_pose_data = random_pose_data;pf->min_samples = min_samples;pf->max_samples = max_samples;// Control parameters for the population size calculation. [err] is// the max error between the true distribution and the estimated// distribution. [z] is the upper standard normal quantile for (1 -// p), where p is the probability that the error on the estimated// distrubition will be less than [err].pf->pop_err = 0.01;pf->pop_z = 3;pf->dist_threshold = 0.5; pf->current_set = 0;//對濾波器的兩份粒子集合進行初始化for (j = 0; j < 2; j++){set = pf->sets + j;set->sample_count = max_samples;set->samples = calloc(max_samples, sizeof(pf_sample_t));//對粒子集合里面的每個粒子進行初始化for (i = 0; i < set->sample_count; i++){sample = set->samples + i;sample->pose.v[0] = 0.0;sample->pose.v[1] = 0.0;sample->pose.v[2] = 0.0;sample->weight = 1.0 / max_samples;}// HACK: is 3 times max_samples enough?set->kdtree = pf_kdtree_alloc(3 * max_samples);set->cluster_count = 0;set->cluster_max_count = max_samples;set->clusters = calloc(set->cluster_max_count, sizeof(pf_cluster_t));//初始化粒子集合的均值和方差set->mean = pf_vector_zero();set->cov = pf_matrix_zero();}pf->w_slow = 0.0;pf->w_fast = 0.0;pf->alpha_slow = alpha_slow;pf->alpha_fast = alpha_fast;//set converged to 0pf_init_converged(pf);return pf; }

?


3、void pf_init(pf_t *pf, pf_vector_t mean, pf_matrix_t cov)

pf_init(濾波器對象, 均值, 方差)

主要功能是利用高斯分布來初始化粒子濾波器,主要是用來初始化粒子的初始位姿

具體實現順序為:

(1)選擇要使用的粒子集合(因為在創建濾波器時,創建了兩份粒子集合,一份使用,另一份用來重采樣緩沖)

(2)pf_kdtree_clear(set->kdtree); //對傳入參數所指向的kdtree進行清空

(3)設置粒子數

(4)pdf = pf_pdf_gaussian_alloc(mean, cov); //使用傳入的均值和方差來初始化高斯分布

(5)對每個粒子的位姿使用高斯分布進行初始化,然后將每個粒子插入到kdtree中

(6)釋放高斯分布pdf

(7)pf_cluster_stats(pf, set); //對粒子濾波器的粒子集進行聚類 【后面稍微給出相關,本人也不太了解這個聚類】

(8)設置聚類收斂為0

// Initialize the filter using a guassian void pf_init(pf_t *pf, pf_vector_t mean, pf_matrix_t cov) {int i;pf_sample_set_t *set;pf_sample_t *sample;pf_pdf_gaussian_t *pdf;//選擇要使用的粒子集合set = pf->sets + pf->current_set;// Create the kd tree for adaptive samplingpf_kdtreeshe_clear(set->kdtree);//configure particle counts//設置粒子數set->sample_count = pf->max_samples;// Create a gaussian pdf//使用mean和cov來初始化高斯分布pdf = pf_pdf_gaussian_alloc(mean, cov);// Compute the new sample poses//對每個粒子的位姿使用高斯分布進行初始化for (i = 0; i < set->sample_count; i++){sample = set->samples + i;sample->weight = 1.0 / pf->max_samples;sample->pose = pf_pdf_gaussian_sample(pdf);// Add sample to histogram// Insert a pose into the tree.pf_kdtree_insert(set->kdtree, sample->pose, sample->weight);}pf->w_slow = pf->w_fast = 0.0;//release pdfpf_pdf_gaussian_free(pdf);// Re-compute cluster statisticspf_cluster_stats(pf, set); //set converged to 0pf_init_converged(pf);return; }

4、void pf_cluster_stats(pf_t *pf, pf_sample_set_t *set)

pf_cluster_stats(粒子濾波器對象, 粒子集合)

主要功能是對粒子集合進行聚類,將每個粒子歸到所屬類別,并進行統計

實現順序為:

(1)pf_kdtree_cluster(set->kdtree); //對粒子集合進行聚類

(2)對每個類別的統計值進行初始化(初始成0)

(3)對粒子集合的均值和方差進行0值初始化

(4)對每個粒子進行操作:

a、獲取該粒子所屬的集群編號cidx

b、對該集群cidx的粒子數+1,權重+=該粒子權重

c、粒子所屬集群pose均值+=該粒子權重×該粒子pose

d、粒子集的pose均值+=該粒子權重×該粒子pose

(5)對每個集群進行操作:

a、對該集群的pose均值進行歸一化,即pose的每個分量/該集群權重

b、計算方差

(6)對粒子集的全部粒子均值進行歸一化,即粒子集pose均值/粒子集權重

// Re-compute the cluster statistics for a sample set void pf_cluster_stats(pf_t *pf, pf_sample_set_t *set) {int i, j, k, cidx;pf_sample_t *sample;pf_cluster_t *cluster;// Workspacedouble m[4], c[2][2];size_t count;double weight;// Cluster the samplespf_kdtree_cluster(set->kdtree);// Initialize cluster statsset->cluster_count = 0;for (i = 0; i < set->cluster_max_count; i++){cluster = set->clusters + i;cluster->count = 0;cluster->weight = 0;cluster->mean = pf_vector_zero();cluster->cov = pf_matrix_zero();for (j = 0; j < 4; j++)cluster->m[j] = 0.0;for (j = 0; j < 2; j++)for (k = 0; k < 2; k++)cluster->c[j][k] = 0.0;}// Initialize overall filter statscount = 0;weight = 0.0;set->mean = pf_vector_zero();set->cov = pf_matrix_zero();for (j = 0; j < 4; j++)m[j] = 0.0;for (j = 0; j < 2; j++)for (k = 0; k < 2; k++)c[j][k] = 0.0;// Compute cluster statsfor (i = 0; i < set->sample_count; i++){sample = set->samples + i;//printf("%d %f %f %f\n", i, sample->pose.v[0], sample->pose.v[1], sample->pose.v[2]);// Get the cluster label for this sample//獲取該粒子所屬的集群編號cidx = pf_kdtree_get_cluster(set->kdtree, sample->pose);assert(cidx >= 0);if (cidx >= set->cluster_max_count)continue;//如果這個粒子的集群編號大于粒子集的集群數,表示這是一個新的集群if (cidx + 1 > set->cluster_count)set->cluster_count = cidx + 1;//集群選定cluster = set->clusters + cidx;//該集群粒子數+1cluster->count += 1;cluster->weight += sample->weight;count += 1;weight += sample->weight;// Compute meancluster->m[0] += sample->weight * sample->pose.v[0];cluster->m[1] += sample->weight * sample->pose.v[1];cluster->m[2] += sample->weight * cos(sample->pose.v[2]);cluster->m[3] += sample->weight * sin(sample->pose.v[2]);m[0] += sample->weight * sample->pose.v[0];m[1] += sample->weight * sample->pose.v[1];m[2] += sample->weight * cos(sample->pose.v[2]);m[3] += sample->weight * sin(sample->pose.v[2]);// Compute covariance in linear componentsfor (j = 0; j < 2; j++)for (k = 0; k < 2; k++){cluster->c[j][k] += sample->weight * sample->pose.v[j] * sample->pose.v[k];c[j][k] += sample->weight * sample->pose.v[j] * sample->pose.v[k];}}// Normalize//對每個集群的均值進行歸一化for (i = 0; i < set->cluster_count; i++){cluster = set->clusters + i;cluster->mean.v[0] = cluster->m[0] / cluster->weight;cluster->mean.v[1] = cluster->m[1] / cluster->weight;cluster->mean.v[2] = atan2(cluster->m[3], cluster->m[2]);cluster->cov = pf_matrix_zero();// Covariance in linear componentsfor (j = 0; j < 2; j++)for (k = 0; k < 2; k++)cluster->cov.m[j][k] = cluster->c[j][k] / cluster->weight -cluster->mean.v[j] * cluster->mean.v[k];// Covariance in angular components; I think this is the correct// formula for circular statistics.cluster->cov.m[2][2] = -2 * log(sqrt(cluster->m[2] * cluster->m[2] +cluster->m[3] * cluster->m[3]));//printf("cluster %d %d %f (%f %f %f)\n", i, cluster->count, cluster->weight,//cluster->mean.v[0], cluster->mean.v[1], cluster->mean.v[2]);//pf_matrix_fprintf(cluster->cov, stdout, "%e");}// Compute overall filter stats//對粒子集的全部粒子的均值進行歸一化(不分集群)set->mean.v[0] = m[0] / weight;set->mean.v[1] = m[1] / weight;set->mean.v[2] = atan2(m[3], m[2]);// Covariance in linear componentsfor (j = 0; j < 2; j++)for (k = 0; k < 2; k++)set->cov.m[j][k] = c[j][k] / weight - set->mean.v[j] * set->mean.v[k];// Covariance in angular components; I think this is the correct// formula for circular statistics.set->cov.m[2][2] = -2 * log(sqrt(m[2] * m[2] + m[3] * m[3]));return; }

?

?

總結

以上是生活随笔為你收集整理的2D激光SLAM::ROS-AMCL包源码阅读(三)从main()开始的全部內容,希望文章能夠幫你解決所遇到的問題。

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

天堂av在线网站 | 丝袜美腿在线视频 | 日韩欧美综合在线视频 | 在线看成人av | 久久国产精品一二三区 | 97超碰在线资源 | 在线观看91精品视频 | 超碰在线天天 | 日本少妇久久久 | 五月天,com| 99精品久久久久久久久久综合 | 免费又黄又爽视频 | 国产不卡在线视频 | 日本久久久久久久久久 | 成年人在线看片 | 国产精品99久久久久久宅男 | 开心激情婷婷 | 色wwwww | 亚洲砖区区免费 | 99精品视频免费观看 | 99精品久久只有精品 | 99婷婷狠狠成为人免费视频 | 亚洲免费精品视频 | 婷婷色5月 | 欧美一区二区三区在线 | 中文字幕第 | 免费中文字幕视频 | 中文字幕在线观看第三页 | 97日日碰人人模人人澡分享吧 | 国产玖玖精品视频 | 日韩视频a | 99久久影院| 日韩视频一区二区三区在线播放免费观看 | 国产xxxx| 91成人网在线观看 | 91超碰免费在线 | 99爱国产精品 | 国产精品网在线观看 | 在线黄色国产电影 | 国产精品一区二区电影 | www.天天操 | 中文字幕av免费 | 日韩av片免费在线观看 | 久久综合久久综合这里只有精品 | 超碰97人人爱 | 免费黄色一区 | 狠狠狠狠狠狠狠干 | 国产.精品.日韩.另类.中文.在线.播放 | 四虎免费av| 久久精品一区二区三区四区 | 精品免费久久久久 | 久草精品视频在线看网站免费 | 国产免费嫩草影院 | 日本一区二区三区免费观看 | 色成人亚洲 | 又黄又刺激视频 | 中文字幕色播 | 国产中文字幕在线观看 | 久久超碰99 | 欧美成人一区二区 | 人人精久 | 欧美日韩亚洲精品在线 | 久草精品电影 | 99精品久久只有精品 | 午夜视频播放 | 精品欧美一区二区精品久久 | 97精品电影院| 亚洲黄色在线观看 | 人人插人人草 | 亚洲成人午夜在线 | 日韩黄色软件 | 久草视频免费播放 | 深爱激情综合 | 天天婷婷 | 国产伦精品一区二区三区高清 | 在线中文字幕视频 | 久久综合九色99 | 日韩在线播放欧美字幕 | 国产美女免费观看 | 探花系列在线 | 久久精品国产亚洲aⅴ | 91正在播放 | 天天操操操操操 | 日韩大片在线 | 在线韩国电影免费观影完整版 | 久久精品中文字幕少妇 | 天堂成人在线 | 国产黄色片免费观看 | 亚洲激情六月 | 91免费看片黄| 日本中文字幕在线观看 | 日韩大片在线观看 | 久草观看 | 精品久久一区二区三区 | 欧美极品久久 | 色人久久 | 7799av| 成人高清av在线 | 网站在线观看日韩 | 精品99在线视频 | 国产精品入口久久 | 欧美久久久久久久久久 | 91在线小视频 | av电影免费观看 | 亚洲成a人片77777潘金莲 | 久草a视频| 国产99在线播放 | 天天色 天天 | 国产高清亚洲 | 国产精品国产三级国产专区53 | 国产成人一区二区三区电影 | 国产精品自在线拍国产 | 亚洲精品小视频在线观看 | 日韩精品在线播放 | 丁香激情婷婷 | 国产经典 欧美精品 | 久久久久久久久亚洲精品 | 一区二区视| 日本在线观看中文字幕无线观看 | 免费看精品久久片 | 久久人人看 | 美女视频免费精品 | 中文字幕高清av | 亚洲综合在线观看视频 | 国产精品电影一区二区 | 波多野结衣一区二区三区中文字幕 | 国产精品女人网站 | 97香蕉久久超级碰碰高清版 | 日韩三级免费观看 | 中文 一区二区 | 不卡av电影在线 | 黄色毛片大全 | 久草.com | 亚洲久久视频 | 综合网伊人 | 久久a国产 | 国产精品免费久久久久 | 久草在线最新免费 | 一区免费视频 | 精品v亚洲v欧美v高清v | 色在线网 | 波多野结衣在线视频免费观看 | 中文字幕资源网 国产 | av天天干 | 久久婷婷五月综合色丁香 | 日韩精品中文字幕在线观看 | 国产精品久久久久久一区二区三区 | 欧美久久九九 | 天天摸天天舔天天操 | 成人精品一区二区三区中文字幕 | 黄色三级免费 | 免费欧美高清视频 | 亚洲国产精品成人va在线观看 | 成 人 黄 色 视频 免费观看 | 国产精品视频不卡 | 91香蕉视频污在线 | 成人av影视在线 | 日韩在线观看免费 | 日韩理论在线播放 | 国产99久久久国产精品免费看 | 99热精品久久 | 久久综合狠狠综合 | 少妇bbbb| 久久婷婷综合激情 | 日韩视频在线观看免费 | 五月天电影免费在线观看一区 | 狠狠干美女 | a一片一级| 天天干夜夜夜 | 久久激情婷婷 | 中文字幕日韩免费视频 | 国产中的精品av小宝探花 | 玖草在线观看 | 久久精品国产亚洲a | 亚洲精品一区二区三区四区高清 | 免费精品人在线二线三线 | 精品国产一区二区三区久久影院 | 国产精品久久久久久爽爽爽 | 成年人免费观看在线视频 | 欧美日韩中文在线 | 久久国产亚洲 | 久久久资源 | 日韩一区二区三区免费视频 | 91九色视频在线播放 | 日韩欧美高清视频在线观看 | 涩涩在线 | .国产精品成人自产拍在线观看6 | 天天操天天添天天吹 | 激情丁香婷婷 | 337p欧美| 国际精品久久久 | 九九热在线精品 | 国产精品h在线观看 | 国产精品色| 日韩欧美国产成人 | 欧美一区二区三区在线观看 | 日韩精品一区二区在线观看视频 | 天天干,天天草 | 国内精品免费久久影院 | 免费视频一二三区 | 久久久91精品国产一区二区三区 | 草久久久| 97国产情侣爱久久免费观看 | 中文av在线免费观看 | 韩国av一区二区三区在线观看 | 黄色特级一级片 | 国产日本在线观看 | 黄网站免费久久 | 精品国产精品国产偷麻豆 | 99久久精品视频免费 | 一本色道久久综合亚洲二区三区 | 国产精品欧美一区二区三区不卡 | 在线国产精品视频 | 日日爱999 | 字幕网av | 在线免费观看国产精品 | 性色av免费在线观看 | 国产麻豆电影 | 97免费视频在线 | 丁香激情视频 | 免费在线观看一区二区三区 | 97在线资源 | a黄色片| 精品免费观看视频 | 天堂av在线网址 | 91在线一区 | 中文免费在线观看 | 九色精品在线 | 最新日韩视频在线观看 | 成年人在线免费看片 | 国产精品video爽爽爽爽 | 免费一级黄色 | 日韩av快播电影网 | 成人毛片在线观看视频 | 久久夜夜操 | 国产在线国偷精品产拍 | 亚洲精品视频在线观看免费 | 日本电影黄色 | 日韩在线三区 | a视频免费 | 日韩影视精品 | 黄色免费观看网址 | 91禁在线观看| 中文字幕电影网 | 久久久久久免费毛片精品 | 人人澡av| 色网站中文字幕 | 久久理论电影网 | 五月婷婷精品 | 国产精品理论片在线播放 | 五月天天av | 国产精品久久久久久久久搜平片 | 麻豆影视在线免费观看 | 午夜少妇 | 美女视频久久久 | 一级免费观看 | 操久在线 | 国产破处视频在线播放 | 成人av午夜 | 久久久久婷 | 高清不卡一区二区三区 | 在线观看免费视频 | 国产精品一码二码三码在线 | 亚洲一区二区三区四区精品 | 天天操天天干天天操天天干 | 性色av免费看 | 91在线视频免费91 | 国产精品系列在线播放 | 欧洲一区精品 | 亚洲毛片久久 | 天天综合91 | 国产黄色看片 | 日韩精品一区二区三区免费观看视频 | 色婷婷综合在线 | 91中文字幕在线播放 | 欧美不卡视频在线 | 国产精品一区二区av日韩在线 | 久久免费视频在线观看6 | 天堂av在线免费 | 国产一级不卡毛片 | 免费观看国产精品视频 | 最近最新中文字幕视频 | 粉嫩av一区二区三区四区五区 | 在线欧美日韩 | 成年人免费电影在线观看 | a√天堂中文在线 | 五月婷婷中文 | 欧美日韩精品免费观看 | 欧美日韩视频在线一区 | 国产在线播放观看 | 国内精品视频在线播放 | 三级黄色在线 | 超碰夜夜| 在线日韩中文 | 国产少妇在线观看 | 久久一区二 | 激情九九| 精品国产免费观看 | 91免费高清在线观看 | 精品在线看 | 色噜噜日韩精品欧美一区二区 | 色综合久久久久综合体 | 中文字幕在线观看视频一区二区三区 | 福利久久| 精品99视频 | 四虎国产精品成人免费4hu | jizz欧美性9 国产一区高清在线观看 | 国产精品一区二区62 | 色就是色综合 | 丁香五婷| 欧美男男激情videos | 亚洲成人av在线播放 | 国产高清不卡 | 婷婷丁香九月 | 亚洲无线视频 | 91av电影网| 狠狠躁日日躁狂躁夜夜躁 | 亚洲成人午夜av | 日韩成人精品在线观看 | 九九天堂 | 夜夜躁日日躁狠狠久久av | 日韩影视在线观看 | 日韩成人免费在线观看 | 在线观看视频在线观看 | 一级片免费观看视频 | 日本二区三区在线 | 在线免费精品视频 | 亚洲国产精久久久久久久 | 91亚洲精品在线观看 | 成人国产综合 | 91香蕉嫩草 | 国产成人久久精品 | 欧美精品在线免费 | 97香蕉久久超级碰碰高清版 | 免费观看一级成人毛片 | 久久呀 | 久久99久久99精品 | 国产美女精品人人做人人爽 | 色婷婷av在线 | 国产又粗又猛又爽又黄的视频免费 | 国产视频综合在线 | 在线观看av国产 | 91爱看片| 久久久精品二区 | 久草在线免费资源站 | 婷婷视频在线 | 9797在线看片亚洲精品 | 欧美性猛片,| 天天做日日做天天爽视频免费 | 亚洲成人影音 | 精品国产免费观看 | 99精品国产99久久久久久福利 | 五月天婷婷在线观看视频 | 日韩xxxxxxxxx| 人人爽人人干 | 91福利免费| 国产精品女人久久久 | 亚洲精品ww | 国产系列 在线观看 | 91三级视频 | 成人免费91| 91中文字幕在线播放 | 免费大片av| 成人在线免费视频 | 午夜av免费观看 | 久久亚洲精品电影 | 亚洲精品乱码久久久久v最新版 | 精品天堂av | 在线观看免费日韩 | 韩国三级一区 | 国产成人a亚洲精品v | 在线观看视频福利 | 99re视频在线观看 | 免费福利视频网站 | 日日婷婷夜日日天干 | 色综合久久久久综合99 | 五月天久久久久 | 亚洲福利精品 | 久久国产亚洲 | 天天干,天天操,天天射 | av福利超碰网站 | 国产一区二区网址 | 精品视频国产一区 | 中文字幕在线免费 | 亚洲综合爱 | 亚洲最大免费成人网 | 国内偷拍精品视频 | 国产一级在线观看视频 | 国产 在线 高清 精品 | 国产福利91精品一区二区三区 | 丁香婷婷电影 | 国产 日韩 欧美 中文 在线播放 | 色久天 | 久久99国产视频 | 亚洲成人av电影在线 | 日韩大片在线播放 | 国产中年夫妇高潮精品视频 | 在线激情网 | 蜜桃视频精品 | 成人免费观看a | 国产91aaa| 国产中文视频 | 日韩av片无码一区二区不卡电影 | 天天色天| 国产乱码精品一区二区蜜臀 | 天天干,天天射,天天操,天天摸 | 日韩一片| 亚洲国产免费av | a级国产片 | 久操视频在线播放 | 免费人做人爱www的视 | 成人xxxx| 精品99免费| 欧美资源在线观看 | 丁香婷婷在线观看 | 最近中文字幕免费大全 | 国产资源免费在线观看 | 国产黄色大片免费看 | 亚洲va天堂va欧美ⅴa在线 | 国产亚洲欧美日韩高清 | 在线观看视频黄 | 91国内在线 | 国产电影黄色av | 97网在线观看 | 欧美激情精品久久久久久变态 | 亚洲精品视频在线观看免费 | 麻豆国产视频下载 | 成人av免费在线观看 | 婷婷www | 久久人人爽人人爽人人片av软件 | 涩五月婷婷 | 麻豆视频观看 | 久久久综合香蕉尹人综合网 | 综合激情伊人 | 日日碰狠狠添天天爽超碰97久久 | 97香蕉久久超级碰碰高清版 | 黄色三级免费 | 激情九九 | 亚洲欧美激情插 | 欧美极品xxx | 96在线 | 最近中文字幕高清字幕免费mv | 国产大片免费久久 | 久久免费视频一区 | 九九热久久免费视频 | 天天激情天天干 | 人交video另类hd | 国产女人免费看a级丨片 | 在线观看av国产 | 亚洲精品乱码久久久久久写真 | 国产丝袜制服在线 | 成人试看120秒 | 久久玖 | 久久a国产 | 色资源网免费观看视频 | 丁香六月国产 | 国产一区二区播放 | www.天天干.com | 亚洲自拍偷拍色图 | 亚洲欧美日韩国产一区二区三区 | 国产黄色片一级三级 | 久久久91精品国产 | 激情综合久久 | 就要色综合 | 日韩成人在线一区二区 | 亚洲一级片在线看 | 久久国产一二区 | av电影免费看 | 国产第页 | 97超级碰碰 | 狠狠操操操 | 久草在线播放视频 | 在线观看黄色大片 | 国产精品自拍av | 日韩av午夜 | 日韩精品久久中文字幕 | 一本大道久久精品懂色aⅴ 五月婷社区 | 天天躁天天躁天天躁婷 | 色五月成人 | 亚州精品天堂中文字幕 | 天天操天天操天天 | 超碰人人射 | 欧美久久久久 | 91在线公开视频 | 9999精品视频 | 91视频久久久 | 国产91精品看黄网站在线观看动漫 | 欧美aa在线观看 | 久久久久久久久久久久国产精品 | 天天操狠狠操夜夜操 | 久久国产美女视频 | 国产美女免费 | 久久人91精品久久久久久不卡 | 国产v欧美| 久久精品国产第一区二区三区 | 欧美精品久久久久久久久久丰满 | 婷婷久操| 亚州黄色一级 | 亚洲 综合 国产 精品 | 中文字幕在线看视频国产 | a级国产乱理伦片在线观看 亚洲3级 | 91精品毛片 | 欧洲在线免费视频 | 精品电影一区 | 国产成人无码AⅤ片在线观 日韩av不卡在线 | 色婷五月天 | 国产香蕉视频在线观看 | 精品国产一区二区三区久久影院 | 久久99国产精品久久99 | 91精品视频免费在线观看 | 一本一道久久a久久综合蜜桃 | 国产美女视频一区 | 亚洲夜夜网 | 激情网婷婷 | 激情五月婷婷综合 | 中文字幕欧美日韩va免费视频 | 色射爱| 91精品办公室少妇高潮对白 | 97国产超碰 | 一区二区三区在线不卡 | 精品一区 在线 | 在线中文字幕观看 | 久久中文视频 | 免费视频一二三 | 久久久久久久久久久免费av | 欧美 日韩 国产 中文字幕 | 黄色国产精品 | 午夜视频色 | 日韩黄在线观看 | 亚洲 欧洲av| 99爱在线观看 | 日韩欧美精品一区二区 | 91视频网址入口 | 国产精品va在线观看入 | 色在线观看网站 | 日韩一区在线免费观看 | 97人人网| 四虎永久国产精品 | 国产无遮挡又黄又爽馒头漫画 | 九九久久久 | 国产香蕉视频 | 国产精品久久久久久久久久久免费 | 免费成视频 | 91精品国产高清自在线观看 | 精品视频免费在线 | 天天夜夜亚洲 | 久久免费影院 | www.国产高清 | 伊人资源视频在线 | 久久综合日| 国产色久 | 天天干天天射天天爽 | 日韩免费精品 | 日韩欧美在线综合网 | 精品在线视频观看 | 久草精品电影 | 亚洲伦理电影在线 | 亚洲一区二区精品3399 | 久久精品国产成人精品 | 综合激情网 | 欧美日韩亚洲在线观看 | 69xx视频 | 嫩嫩影院理论片 | 亚洲黄色激情小说 | 久草电影在线 | 国产区免费在线 | 黄色三几片 | 九月婷婷人人澡人人添人人爽 | 69久久久 | 国产精品情侣视频 | 精品久久一级片 | 色妞久久福利网 | 97在线超碰 | 久久天天躁狠狠躁亚洲综合公司 | 狠狠干天天 | 国产精品一区二区久久久 | 国产91aaa| 成年在线观看 | 亚洲精品视频二区 | 日韩中文字幕免费看 | 91探花在线 | 国产精品一区在线观看你懂的 | 久久电影色 | a黄色片在线观看 | 国产r级在线观看 | 国产一级二级av | 国产一区二区手机在线观看 | 日韩精品一区电影 | 成人中文字幕+乱码+中文字幕 | 欧美精选一区二区三区 | 深夜免费福利网站 | 日韩午夜电影 | 日韩免费电影在线观看 | 欧美午夜剧场 | 97超碰在线播放 | 日韩一区二区三区高清在线观看 | 一区二区三区四区五区在线 | 久久综合免费 | 91丨九色丨91啦蝌蚪老版 | 最新久久免费视频 | 一级片色播影院 | 91麻豆精品国产自产在线游戏 | 欧美一区二视频在线免费观看 | 午夜视频久久久 | 在线观看国产福利片 | 国产一区二区在线播放 | 日本午夜在线亚洲.国产 | 2019精品手机国产品在线 | 黄色的网站免费看 | av大片免费看 | 亚洲精品观看 | 东方av在线免费观看 | 免费成人av电影 | 久久久久久久福利 | 精品国产免费久久 | 91视频麻豆 | 国产一区在线视频 | 五月天网站在线 | 97日日碰人人模人人澡分享吧 | 一区二区三区在线观看免费 | 亚洲成人av在线播放 | 亚洲日本成人网 | 欧美韩日在线 | 激情中文字幕 | 久久精品视频在线观看免费 | 欧美精品久久久久久 | 精品在线亚洲视频 | 福利视频区 | 婷婷激情在线 | 日日夜夜精品免费 | 中文字幕精品一区久久久久 | 91av在线看| 69精品视频| 一区二区三区视频网站 | 天天综合狠狠精品 | 日韩在线视频线视频免费网站 | 日韩色中色 | 亚洲国产免费 | 午夜久久网站 | 992tv在线 | 日韩视频在线播放 | 国产一区观看 | 日本婷婷色 | 在线观看深夜福利 | 亚洲天堂激情 | 久久最新视频 | 日本精品一区二区三区在线观看 | 久久精品国产成人精品 | 成人午夜网 | 黄av免费 | av三区在线| 成人午夜电影免费在线观看 | 亚洲一级特黄 | av电影在线观看完整版一区二区 | 久久伊人热 | 开心色婷婷 | 91少妇精拍在线播放 | 中文国产字幕在线观看 | 成 人 黄 色 视频免费播放 | 蜜臀av性久久久久av蜜臀妖精 | 日日操夜夜操狠狠操 | 久久久18 | 狠狠狠色丁香综合久久天下网 | 97超碰总站 | 中文字幕丝袜制服 | 国产成人黄色网址 | 成人av免费播放 | 狠狠操狠狠插 | 久久看免费视频 | 一级片免费视频 | 开心丁香婷婷深爱五月 | 97在线观看免费观看高清 | 日日操日日干 | 国产精品1区| 亚洲色影爱久久精品 | 精品久久久久久国产偷窥 | 黄色毛片网站在线观看 | 欧美日韩久 | 国产午夜精品一区二区三区 | 国产视频精选在线 | 久久精品欧美视频 | 蜜臀av.com| 亚洲成人av在线电影 | 高清av免费看 | 97操碰| 亚州人成在线播放 | 国产精品免费一区二区 | 久久综合欧美 | 亚洲蜜桃在线 | 国产91在线观 | 国产精品18久久久久久久网站 | 午夜av剧场 | 在线观看中文字幕亚洲 | 国产精品成人a免费观看 | 97超视频在线观看 | 美女网站黄在线观看 | 免费观看全黄做爰大片国产 | avcom在线 | 色婷婷婷| 在线视频久久 | 波多野结衣视频在线 | 久久婷婷开心 | 五月婷婷激情综合 | 成人免费观看网站 | 婷婷日日| 久久精品91久久久久久再现 | 国产一线二线三线性视频 | 2021国产精品视频 | 欧美色图88| 日韩高清成人 | 蜜臀久久99精品久久久酒店新书 | 热re99久久精品国产99热 | 欧美日韩一区二区视频在线观看 | 国产视频一区二区在线 | 婷婷精品国产欧美精品亚洲人人爽 | 中文字幕亚洲欧美 | 欧洲亚洲女同hd | 天天干天天天 | 狠狠狠色狠狠色综合 | 免费在线观看av网站 | 日日色综合 | 日韩免费电影网站 | 亚洲女欲精品久久久久久久18 | 97视频人人免费看 | 一区二区三区四区在线 | 午夜精品久久久久 | 天天天在线综合网 | 国产精品麻豆视频 | 国产91精品在线播放 | 日韩欧美视频在线播放 | 国产精品一区二区久久精品爱涩 | 日韩欧美有码在线 | 日韩超碰在线 | 久久久久久国产精品999 | 高清av免费看 | 911久久| 亚洲欧美视频在线 | 国产精品黑丝在线观看 | 日日夜夜精品 | 麻豆视传媒官网免费观看 | 亚洲永久精品国产 | 成人午夜网 | 18久久久 | 久久99国产精品二区护士 | 人人爽人人搞 | 91| 国产精品永久久久久久久www | 日本精品久久 | 曰本三级在线 | 波多野结衣视频一区二区 | 在线亚洲精品 | 欧美91精品久久久久国产性生爱 | 91成人午夜 | 亚洲一级国产 | 中文国产成人精品久久一 | 91黄色成人 | 中文字幕在线国产 | 中文字幕在线观看资源 | 最近日本mv字幕免费观看 | 又黄又网站 | 久草视频国产 | 久久综合中文色婷婷 | av久久久| 久草在线久草在线2 | 中文字幕日韩一区二区三区不卡 | 狠狠网| 亚洲美女久久 | 中文字幕视频一区 | 在线观看免费视频 | 中文字幕视频网 | 中文字幕在线字幕中文 | 日韩视频一区二区三区在线播放免费观看 | 亚洲最新视频在线播放 | 美女av免费 | 国产99视频在线观看 | 久久久久久久久久电影 | 人人讲| 三上悠亚一区二区在线观看 | 在线观看中文字幕一区二区 | 国产又粗又猛又色又黄视频 | 欧美日韩三级 | 99九九热只有国产精品 | av在线免费网站 | 在线国产视频 | 久久五月情影视 | 黄色软件网站在线观看 | 久久免费播放视频 | 91视频在线免费 | 国产一区免费视频 | 免费能看的av | 黄色网www| 2021国产在线| 国产精品成人久久久久 | 激情伊人五月天 | 国产又粗又猛又爽 | 久久免费视频6 | 干 操 插 | 久草在线最新视频 | 日韩免费b | 国产成人精品一区在线 | 成人宗合网 | 园产精品久久久久久久7电影 | av电影在线观看完整版一区二区 | 国产五月色婷婷六月丁香视频 | 欧美射射射| 精品国产一区二区三区av性色 | 九九免费观看视频 | 日韩在线观看av | 又黄又爽又湿又无遮挡的在线视频 | 日日狠狠 | 99一级片 | 午夜影院日本 | 日韩成人免费在线电影 | 婷婷av资源| 在线免费观看国产 | 免费在线观看av网站 | 日b视频在线观看网址 | 国产午夜精品久久 | 日本中文字幕在线一区 | 天天色棕合合合合合合 | 奇米影视在线99精品 | 天堂中文在线视频 | 午夜色影院 | 欧美日韩免费视频 | 一级成人在线 | 免费在线成人av电影 | 中国一区二区视频 | 91精品国产成 | 中文字幕刺激在线 | 日韩视频免费 | 伊人www22综合色 | 久久久久久黄色 | 欧美成年网站 | 日韩理论在线播放 | 天天综合狠狠精品 | 日韩在线免费电影 | 日韩av一区二区在线 | 狠狠色丁香久久婷婷综合_中 | 精品在线观看一区二区 | 亚洲视频综合在线 | 五月天com | 999精品视频 | 精品天堂av | 四虎欧美 | 亚洲视频一级 | 天天摸夜夜操 | 免费看黄的视频 | 亚洲高清视频在线观看免费 | 超碰公开在线观看 | 国产在线看 | 亚洲精品国产精品乱码不99热 | 青草视频在线看 | 久久久国产在线视频 | 久久久久影视 | 啪嗒啪嗒免费观看完整版 | 日韩av中文 | 在线观看香蕉视频 | 黄色网免费| 久久99久久久久久 | 亚洲视频久久 | 一区二区三区四区五区在线视频 | 欧美精品少妇xxxxx喷水 | 日日爽天天 | 亚洲精品456在线播放 | 激情网站免费观看 | 岛国av在线| 国产在线观看国语版免费 | 国产精品1024 | 国产精品24小时在线观看 | 韩日精品在线 | 欧美9999 | 99热这里有精品 | 韩日视频在线 | 最近日本韩国中文字幕 | 日韩国产精品久久 | 国内成人精品2018免费看 | 国产精品黄网站在线观看 | 亚洲精品99久久久久中文字幕 | 亚洲黄色免费观看 | 国产成人免费av电影 | 亚洲免费成人 | 亚洲少妇xxxx | 99久久精品国产欧美主题曲 | 成人日韩av | 99爱在线 | 日韩午夜电影网 | 日韩在线免费播放 | 久久久高清 | 成人国产网址 | 精品久久久久久国产偷窥 | 欧洲色综合 | 久久免费精品国产 | 久草免费看 | 欧美污在线观看 | 精品久久久久久国产91 | 国产色婷婷精品综合在线手机播放 | 91在线看黄| 国产直播av | 免费观看91 | 国产高潮久久 | 一区二区三区四区在线 | 久久久久久美女 | 成人观看视频 | 日日干天夜夜 | 亚洲91视频 | 日日操网 | 久久久精选 | 精品夜夜嗨av一区二区三区 | 国产精品18久久久 | 国产精品露脸在线 | 久久免费播放视频 | 亚洲理论在线观看电影 | 免费在线h | 日韩理论在线视频 | 国产香蕉视频在线播放 | 中文字幕电影一区 | 亚洲一级黄色片 | 一区二区三区免费网站 | 久色 网| 天天骚夜夜操 | 天天干天天干天天操 | 国产高清视频在线 | 久久久午夜精品理论片中文字幕 | 亚洲国产精品成人va在线观看 | 久久久网址 | 97视频人人免费看 | 黄色一级大片免费看 | 亚州精品成人 | 久久成人福利 | 日韩av片无码一区二区不卡电影 | 国产原创在线观看 | 91在线资源| 国产一级高清视频 | 99在线免费观看视频 | 最新日韩视频在线观看 | 亚洲aⅴ乱码精品成人区 | 久久a久久 | 久久久国产视频 | 97视频在线看| 亚洲www天堂com | 亚州免费视频 | 三级小视频在线观看 | 97视频在线免费 | 久久久久蜜桃 | av短片在线观看 | 在线观看完整版 | 中文字幕在线观看一区二区 | 色婷婷狠狠 | 在线一区观看 | 看黄色91 | 国产亚洲激情视频在线 | 制服丝袜一区二区 | 天天干夜夜爱 | 亚洲午夜久久久综合37日本 | 日韩免费在线观看视频 | 最新av在线播放 | 欧美狠狠操 | 国产高清无线码2021 | 天天操夜操 | 国产亚洲精品美女久久 | 亚洲精品视频免费在线 | 在线免费色视频 | 亚洲电影网站 | 国产成人a v电影 | 干干操操 | 97视频在线看 | 人人爽人人片 | 韩日三级在线 | 91在线播放综合 | 一区二区三区三区在线 | 日韩av黄| av福利网址导航 | 天天婷婷 | 天天天天色射综合 | 精品国产一区二区三区久久 | 久久精品电影 | 亚洲激情综合 | 97超碰站 | 亚洲成人午夜在线 | 婷婷av网站| 精品在线免费视频 | 草久在线观看视频 | 中文字幕频道 | 精品国产99 | 国产不卡在线 | 美女黄频免费 | 久久免费视频国产 | 97在线视频免费 | 精品一二三四五区 | 精品国内| 亚洲综合激情小说 | 亚洲国产精品500在线观看 | 久久久精品免费观看 | 丁香花在线视频观看免费 | 成年人视频在线 | 日韩欧美在线综合网 | 视频在线91| a色网站|