IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 人工智能 -> PCl:PointNet++讲解(三) -> 正文阅读

[人工智能]PCl:PointNet++讲解(三)


一、点云数据特征

  • 无序性:只是点而已,排列顺序不影响
  • 近密远疏的特性:扫描与视角不同导致
  • 非结构化数据,直接CNN有点难

二、PointNet

1. PointNet基本出发点

  • 由于点的无序性导致,需要模型具有置换不变性
    f ( x 1 , x 2 , . . . . . . , x n ) ≡ f ( x π 1 , x π 2 , . . . . . . , x π n ) , x i ∈ R D f(x_1,x_2,......,x_n) \equiv f(x_{\pi _1}, x_{\pi _2},......,x_{\pi _n}), x_i\in\mathbb{R}^D f(x1?,x2?,......,xn?)f(xπ1??,xπ2??,......,xπn??),xi?RD
  • 直接使用Max函数(简单粗暴)----- 损失太多特征 ----- 升维然后再做Max操作(其实就是神经网络的隐层)
    f ( x 1 , x 2 , . . . . . . , x n ) ≡ γ ° f ( h ( x 1 ) , h ( x 2 ) , . . . . . . , h ( x n ) ) , x i ∈ R D f(x_1,x_2,......,x_n) \equiv \gamma \circ f(h(x _1), h(x _2),......,h(x _n)), x_i\in\mathbb{R}^D f(x1?,x2?,......,xn?)γ°f(h(x1?),h(x2?),......,h(xn?)),xi?RD

2. 基本模型架构

  • 分别对每个点进行特征提取(卷积或者全连接),再MAX得到全局进行输出
    在这里插入图片描述

2. 整体网络架构

  • 分类就是得到整体特征再输出;分割就是各个点特征输出结果
    在这里插入图片描述

3. PointNet有哪些问题

  • 根当下主流网络不符,没有局部特征,要不自己,要么一个整体
  • 没有关系概念,局部样本点之间肯定存在关系的,没有考虑到
  • PointNet++版本要从局部入手,多利用局部特征
  • 注:pointNet ++整体思想不便,只不过再特征提取处使用类似图卷积的方式来整合特征

4. PointNet++

1. 基本出发点

  • 基于半径选择局部区域(类似得到很多个簇)
  • 针对得到的每个区域进行特征提取(卷积)
    在这里插入图片描述
  • 要解决的问题1:如何选择区域(簇中心点选择)
  • 要解决的问题2:簇半径大小如何定义,每个簇中选择多少个样本点

2. 步骤

  • 第一步先确定好每一个局部区域,接下来对局部区域执行pointnet
    在这里插入图片描述

1). 采样:最远采样点(farthest point sampling)

  • 先随机选择一个点A,计算所有点到点A的距离,选择到点A距离最远的一个点B
  • 计算所有点到A的距离 d A i d_{A_i} dAi??,计算所有点到B的距离 d B i d_{B_i} dBi??,取两者中小的 d i = m i n ( d A i , d B i ) d_i = min(d_{A_i},d_{B_i}) di?=min(dAi??dBi??),取距离最大的点C。
  • 其他采样点类似

在这里插入图片描述

2). 分组:gouping

  • 分组后每个组中的点的个数必须一致,少:取离簇中心最近的点进行复制多份,多:将里簇中心最远的多个点舍去。
  • 实际计算时是选择多种半径,多种样本点个数,得到的多个特征进行拼接,目的是特征更丰富。eg:半径 = (0.1, 0.2, 0.4);对应簇的样本个数(16, 32, 64)

3). 对各组进行特征提取

  • 先进性纬度变换 b ? n p o i n t s ? n s a m p l e ? f e a t u r e s b *npoints * nsample * features b?npoints?nsample?features ( 8 ? 128 ( 簇 个 数 ) ? 1 ( 每 个 簇 中 点 的 个 数 ) ? 6 ( 纬 度 ) ? > 8 ? 6 ? 16 ? 128 ( 顺 序 变 化 ) ) (8*128(簇个数)*1(每个簇中点的个数)*6(纬度) -> 8*6*16*128(顺序变化)) (8?128()?1()?6()?>8?6?16?128)
  • 进行卷积操作(eg:in=6,out=64),得到(86416*128)
  • 得到每个簇的特征,一个簇对应一个特征
  • 在对所有簇进行MAX,得到一个特征
  • 继续做多组采样,分组,卷积,将得到的特征进行拼接
  • 最终都得到batch中心点个数特征(但是特征个数可能不同)
  • 执行拼接操作

3. 分类整体网络架构

在这里插入图片描述

4. 分割整体网络架构

在这里插入图片描述

5. 遇到的问题

  • PointNet ++ 容易受样本点个数的影响
    在这里插入图片描述

6. 改进的设计

  • 多半经进行特征拼接或者跨层来提取不同分辨率特征

在这里插入图片描述

  人工智能 最新文章
2022吴恩达机器学习课程——第二课(神经网
第十五章 规则学习
FixMatch: Simplifying Semi-Supervised Le
数据挖掘Java——Kmeans算法的实现
大脑皮层的分割方法
【翻译】GPT-3是如何工作的
论文笔记:TEACHTEXT: CrossModal Generaliz
python从零学(六)
详解Python 3.x 导入(import)
【答读者问27】backtrader不支持最新版本的
上一篇文章      下一篇文章      查看所有文章
加:2022-05-14 09:57:29  更:2022-05-14 09:57:42 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/1 22:59:25-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码