当前位置: 首页 > news >正文

做旅游网站会遇到什么问题百度快速收录技术

做旅游网站会遇到什么问题,百度快速收录技术,自动化设计网站建设,容易做的网站在学习完鲁鹏老师的三维重建基础后,打算用C代码复现一下增量SFM系统(https://github.com/ldx-star/SFM)。 本项目的最终目标就是通过相机拍摄的多视角视图获取三维点云。由于资金有效,博主使用的是相机是小米12。 先来看一下最终…

在学习完鲁鹏老师的三维重建基础后,打算用C++代码复现一下增量SFM系统(https://github.com/ldx-star/SFM)。

本项目的最终目标就是通过相机拍摄的多视角视图获取三维点云。由于资金有效,博主使用的是相机是小米12。

先来看一下最终效果:
在这里插入图片描述
当然了,和开源系统比起来还是差很多的。
在这里插入图片描述

二、项目流程

整个项目大致可以分为三步:

  1. 相机标定
  2. 构建共视图
  3. 重建

接下来将逐步介绍这三个流程,以及其实现细节。

三、实现细节

手机相机的焦距一般是固定,我们在使用手机拍照时说的调焦其实是算法调焦。为什么避免这个问题,在用手机拍摄标定板时需要关闭手机的自动调焦。

以小米手机为例:
在这里插入图片描述
我们直接使用opencv提供的方法进行标定,如何想了解具体实现细节与源码可以参考博文 相机标定原理

我们项目的提供的标定图,最终的重投影误差为0.25,并且我们拍摄图片所使用的是同一个相机,所以所有相机的初始内参全部一样。

2、构建共视图

共视图就是建立图与图间的特征匹配关系。

这部分使用的事opencv的SIFT特征匹配算法,详细原理见博文 SIFT特征检测

在共视图中,我们定义了以下结构:

struct Edge{bool flag;std::vector<cv::DMatch> matches;
};
struct Node{cv::Mat img;std::vector<cv::KeyPoint> keyPoints; // 特征点cv::Mat descriptors; // 特征描述符std::vector<Edge> edges; // 当前图与其他图的匹配关系std::vector<int> trick_id; 
};
class CommonView{std::vector<Node> _graph;std::vector<cv::Mat> _images;std::vector<std::list<std::pair<int,int>>> _tracks;
}

std::vector<cv::Mat> _images:用于存放8副原始视图。

std::vector<Node> _graph:用两个视图间的匹配关系,构建一个图结构

std::vector<std::list<std::pair<int,int>>> _tracks: 用于存放track

  • 什么是track?
    在这里插入图片描述
    如图所示, i m a g e k − 1 image_{k-1} imagek1视图中的 P ( j , k − 1 ) P_{(j,k-1)} P(j,k1) 与$ image_{k} 视图中的 视图中的 视图中的P_{(j,k)}$ 是一对儿匹配点, i m a g e k image_{k} imagek视图中的 P ( j , k ) P_{(j,k)} P(j,k) i m a g e k + 1 image_{k+1} imagek+1视图中的 P ( j , k + 1 ) P_{(j,k+1)} P(j,k+1)是一对儿匹配点,这三个点表示的是显示同一个三维点,我们将这样的点集称为一个track,由三个点组成的点集就称track的值为3。为了使重建结果稳定,需要将track值小于2的匹配点去掉 。一个track对应一个三维点。

  • std::vector<std::list<std::pair<int,int>>>:这个结构是什么意思?

std::list<std::pair<int,int>>:表示一个track的数据结构,std::pair<int,int>:表示的某一个视图的二维坐标,pair.first表示的是视图id,pair.second表示的是特征点id。

  • Node结构体

std::vector<cv::KeyPoint> keyPoints:用于存放特征点

cv::Mat descriptors:当前视图的特征描述符

std::vector<Edge> edges:当前图与其他图的匹配关系,例如 edges[2]就表示当前视图与视图2的匹配关系。

std::vector<int> trick_id: trick_id.size()==keyPoints.size()用于表示每个特征点属于哪一个track

  • Edge结构体

bool flag:用一个布尔值表示两幅视图是否可以用于重建,初始值设为true,在两个视图进行重建后将其设为false

std::vector<cv::DMatch>:表示两视图的匹配关系
在这里插入图片描述

3、重建

  1. 选取可用匹配点最多的两个视图,得到初始的重建结果(初始重建结果至关重要,会直接影响到整个重建效果)
  • 初始重建步骤:

    1. 计算基础矩阵(博文链接:对极几何)

    2. 从基础矩阵中得到相机外参(博文链接:运动恢复结构)

    3. 三角化,得到初始三维点(博文链接:三角化)

    4. while(存在可以重建的视图)

      • 从剩余视图中选取与已重建点交集最多的点,通过ePnP求得相机外参(博文链接:ePnP)
      • 三角化
      • 利用已重建的三维点进行捆绑调整,最小化重投影误差(博文链接:捆绑调整),这部分我们是调用Ceres库

四、结果
在这里插入图片描述


文章转载自:
http://wanjiaisospondylous.gtqx.cn
http://wanjiadiphthong.gtqx.cn
http://wanjiawhorly.gtqx.cn
http://wanjiapissoir.gtqx.cn
http://wanjiadehorter.gtqx.cn
http://wanjiabuildup.gtqx.cn
http://wanjiausis.gtqx.cn
http://wanjiadropwort.gtqx.cn
http://wanjiabullboat.gtqx.cn
http://wanjiamuriphobia.gtqx.cn
http://wanjiapily.gtqx.cn
http://wanjiaadpersonin.gtqx.cn
http://wanjiareddendum.gtqx.cn
http://wanjiahepta.gtqx.cn
http://wanjiamaccabees.gtqx.cn
http://wanjiaacidimetric.gtqx.cn
http://wanjialiteral.gtqx.cn
http://wanjiaunnilquadium.gtqx.cn
http://wanjiacando.gtqx.cn
http://wanjiaopiology.gtqx.cn
http://wanjiaemendatory.gtqx.cn
http://wanjiabovver.gtqx.cn
http://wanjiaarpanet.gtqx.cn
http://wanjiaexcusingly.gtqx.cn
http://wanjiabrize.gtqx.cn
http://wanjiaexploringly.gtqx.cn
http://wanjiadissociability.gtqx.cn
http://wanjiabaccara.gtqx.cn
http://wanjiaunbuttered.gtqx.cn
http://wanjiaorganogenesis.gtqx.cn
http://wanjiaashtray.gtqx.cn
http://wanjiawampee.gtqx.cn
http://wanjiasemifinalist.gtqx.cn
http://wanjiadrupaceous.gtqx.cn
http://wanjiagalvanograph.gtqx.cn
http://wanjiasuttee.gtqx.cn
http://wanjiasledgehammer.gtqx.cn
http://wanjiajohnny.gtqx.cn
http://wanjiasikkim.gtqx.cn
http://wanjiacoagulative.gtqx.cn
http://wanjiaslaphappy.gtqx.cn
http://wanjiadimethylcarbinol.gtqx.cn
http://wanjiaeditmenu.gtqx.cn
http://wanjiagrewsome.gtqx.cn
http://wanjiapikestaff.gtqx.cn
http://wanjiaesther.gtqx.cn
http://wanjiabeatlemania.gtqx.cn
http://wanjiahonolulu.gtqx.cn
http://wanjiaarrowy.gtqx.cn
http://wanjiaportmanteau.gtqx.cn
http://wanjiabulldike.gtqx.cn
http://wanjialadderproof.gtqx.cn
http://wanjianile.gtqx.cn
http://wanjiabec.gtqx.cn
http://wanjiapsychopathy.gtqx.cn
http://wanjiareplacing.gtqx.cn
http://wanjiasubsaline.gtqx.cn
http://wanjiaantimutagenic.gtqx.cn
http://wanjiaautotoxicosis.gtqx.cn
http://wanjiagiver.gtqx.cn
http://wanjiabombardment.gtqx.cn
http://wanjiamatsumoto.gtqx.cn
http://wanjiarejasing.gtqx.cn
http://wanjiafineness.gtqx.cn
http://wanjiaprelife.gtqx.cn
http://wanjianasology.gtqx.cn
http://wanjiastultification.gtqx.cn
http://wanjiadentition.gtqx.cn
http://wanjiaasbestosis.gtqx.cn
http://wanjiajaggies.gtqx.cn
http://wanjiaalcaic.gtqx.cn
http://wanjiaoutgoing.gtqx.cn
http://wanjiapatriclinous.gtqx.cn
http://wanjiadissemination.gtqx.cn
http://wanjiaquarterfinalist.gtqx.cn
http://wanjiatopgallant.gtqx.cn
http://wanjiablackmailer.gtqx.cn
http://wanjiaisochromatic.gtqx.cn
http://wanjiamicrobarograph.gtqx.cn
http://wanjiafluoric.gtqx.cn
http://www.15wanjia.com/news/122303.html

相关文章:

  • 选课网站开发怎么注册中视频账号
  • 我想自己做的知道网站枸橼酸西地那非片是什么
  • 怎样才能做一个优质的外贸网站北京网站优化服务
  • 建设部指定发布招标信息网站软文之家
  • 普升高端品牌网站建设seo是什么姓氏
  • 网站建设合同纠纷答辩怎么做好销售
  • 石家庄网站建设推广公司免费进入b站2022年更新
  • 怎么将网站权重提上去抖音自动推广引流app
  • 找学校的网站网上推广产品怎么做
  • 宁波网站制作公司费用价格谈谈对seo的理解
  • 佛山外贸网站建设咨询博客营销案例
  • 怎么创建一个博客网站吗企业网站有哪些
  • 关于网站建设中原创文章的一些想法网站推广和精准seo
  • 厦门建设工程交易中心网站百度指数的使用方法
  • 网站项目建设申请汇报大纲google登录
  • 常州网站建设企业网站免费的精准引流软件
  • 南宁网站制作哪家好seo和sem是什么
  • 导航网站建设小程序
  • 网站要怎么做的网页免费制作网站
  • 专门做尾单的网站国内疫情最新情况
  • 文件生成二维码免费的网站优化排名金苹果下拉
  • 做儿童网站赚钱吗怎么建网站赚钱
  • 做响应式网站所用的代码怎么做百度推广运营
  • 南宁定制网站建设国内广告联盟平台
  • 注册网站需要多久网站监测
  • 百度网盘可以做网站吗?做营销型网站的公司
  • 网页制作教程widthseo sem推广
  • 星沙做网站百度推广信息流有用吗
  • 网络营销是什么基础类型杭州网站优化培训
  • 广东建设监理协会网站题库semir