三维重建的几何评价指标

1.三维重建的几何评价指标

1.1 Chamfer Distance

Geometry quality
(1) Chamfer Distance(CD)
CD衡量两组点云之间的几何差异,距离越小越好。
CD是一种用于衡量两个点云之间相似度的常用几何评价指标。它计算一个点云中每个点到另一个点云的最近点的距离,并且反过来也计算另一点云到第一个点云最近点的距离。这种距离用于评估重建模型的几何准确性。

计算CD指标代码: ThibaultGROUEIX/ChamferDistancePytorch

1.2 F-Score

F-Score 综合表面重建精度和召回率,用于评估模型点云与参考点云之间的匹配度,值越大越好。
Precision(精度):在重建模型中,有多少点是正确的,即这些点在参考模型中能够找到最近邻。
Recall(召回率):在参考模型中,有多少点在重建模型中得到了正确的匹配。
F-Score:精度和召回率的综合衡量指标,通过调和平均得到。


计算F-Score指标代码:ThibaultGROUEIX/ChamferDistancePytorch/fscore.py

1.3 Normal Consistency

NC评估模型表面法向量与参考模型的一致性,值越接近1越好。
通过比较两个点云中点的法向量相似性,来评估它们之间的表面一致性。这个指标特别适用于评估表面质量、几何细节的保真度,尤其是用于重建模型与参考模型之间的比较。


gpt生成关于NC指标计算的代码

import numpy as np
from scipy.spatial import KDTreedef calculate_normals(points):"""计算点云的法向量(简单估计):param points: Numpy 数组,形状为 (N, 3):return: 法向量的 Numpy 数组,形状为 (N, 3)"""normals = []for i in range(1, len(points) - 1):p1 = points[i - 1]p2 = points[i]p3 = points[i + 1]v1 = p2 - p1v2 = p3 - p1normal = np.cross(v1, v2)normals.append(normal / np.linalg.norm(normal))return np.array(normals)def normal_consistency(P, Q, normals_P, normals_Q):"""计算点云 P 和 Q 之间的法向一致性:param P: 点云 P,形状为 (N, 3):param Q: 点云 Q,形状为 (M, 3):param normals_P: 点云 P 的法向量,形状为 (N, 3):param normals_Q: 点云 Q 的法向量,形状为 (M, 3):return: 法向一致性评分 NC"""# 创建 Q 的 KDTree 以加速最近邻查找tree = KDTree(Q)nc_sum = 0.0count = 0# 对于点云 P 中的每个点 pfor i, p in enumerate(P):# 找到点 p 在点云 Q 中的最近邻点 q_, idx = tree.query(p)q = Q[idx]# 计算法向量的点积n_p = normals_P[i]n_q = normals_Q[idx]dot_product = np.clip(np.dot(n_p, n_q), -1.0, 1.0)# 累加点积nc_sum += dot_productcount += 1# 返回平均法向一致性NC = nc_sum / count if count > 0 else 0.0return NC# 示例使用
np.random.seed(0)  # 为了可重现性
points_P = np.random.rand(100, 3)
points_Q = np.random.rand(100, 3)# 计算法向量
normals_P = calculate_normals(points_P)
normals_Q = calculate_normals(points_Q)# 计算法向一致性
nc_score = normal_consistency(points_P, points_Q, normals_P, normals_Q)
print(f"Normal Consistency (NC) score: {nc_score}")

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/431993.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

seL4 Threads(四)

官网链接: Threads Threads 这篇教程主要是使用seL4中的threads。 TCB Thread Control Blocks seL4提供了线程代表执行的上下文以及管理处理器时间。seL4中的线程是通过线程控制块对象(TCB)实现的,每个内核线程都有一个线程控制块。 线程…

Web3技术在元宇宙中的应用:从区块链到智能合约

随着元宇宙的兴起,Web3技术正逐渐成为其基础,推动着数字空间的重塑。元宇宙不仅是一个虚拟世界,它还代表着一个由去中心化技术驱动的新生态系统。在这个系统中,区块链和智能合约发挥着至关重要的作用,为用户提供安全、…

Vue | watch监听

Vue | watch监听 在Vue.js的世界里,watch监听器是一个强大且灵活的工具,它允许我们在数据变化时执行特定的逻辑。本文将深入探讨watch的出现背景、使用方法、应用场景、源码原理以及扩展技巧,旨在帮助读者全面掌握这一重要特性。 文章目录 Vu…

TMStarget学习——T1 Segmentation数据处理及解bug

最新学习季公俊老师的神器 TMStarget 的第一个模块基于结构像的靶区计算T1 segmentation。下面上步骤: (1)在github 上下载 TMStarget https://github.com/jigongjun/Neuroimaging-and-Neuromodulation (2)按照要求下载依赖工具软件AFQ、vistasoft、SPM12 &#…

笔试编程-百战成神——Day02

1.简写单词 题目来源: 简写单词——牛客网 测试用例 算法原理 本题的主要难点就是如何识别每一个单词并且返回其首字母大写,最终组成一个新的字符串后输出,这里我们使用while(cin>>str)就可以解决,直接忽略每一个空格直接…

20240926 每日AI必读资讯

一个开源的自托管 AI 入门工具包 - 此工具包利用Docker Compose模板,包含多种本地AI工具并提供AI工作流模板和网络配置,简化了本地AI工具的安装和使用。 安装它将拥有: • 一个拥有 400 多个 AI 组件和集成的低代码平台 • Ollama&#xf…

基于stm32物联网身体健康检测系统

在当今社会,由于经济的发展带来了人们生活水平不断提高,但是人们的健康问题却越来越突出了,各种各样的亚健康随处可在,失眠、抑郁、焦虑症,高血压、高血糖等等侵袭着人们的健康,人们对健康的关注达到了一个…

单细胞Scanpy流程学习和整理(单样本10X数据读取/过滤/降维/聚类)

打算仔细学习一下基于python的单细胞相关分析框架hhh 新手上路写的很繁琐,多多包涵,本次用的IDE是Visual studio code。 流程来自Scanpy官网(Preprocessing and clustering 3k PBMCs (legacy workflow)): https://scanpy.readthedocs.io/e…

01【MATLAB】最小二乘系统辨识

目录 1.系统辨识的定义及其分类 1.1 系统辨识的定义 1.2 系统辨识的分类 2.参数模型 3.系统辨识的步骤 一、最小二乘法(Least Squares Method)一般步骤 二、LSM原理及应用 三、LSM在控制系统建模中的应用 1.系统辨识的定义及其分类 1.1 系统辨识的…

力扣P1706全排列问题 很好的引入暴力 递归 回溯 dfs

代码思路是受一个洛谷题解里面大佬的启发。应该算是一个dfs和回溯的入门题目&#xff0c;很好的入门题目了下面我会先给我原题解思路我想可以很快了解这个思路。下面是我自己根据力扣大佬写的。 我会进行详细讲解并配上图辅助理解大家请往下看 #include<iostream> #inc…

【机器学习】Flux.jl 生态

官方API https://fluxml.ai/Flux.jl/stable/ecosystem/ 官网给出了 Flux’s model-zoo&#xff0c; 是一个庞大的案例库&#xff0c; 可以提供直观的参考&#xff0c; 并且还列举了基于 Flux.jl 开发的第三方库。 机器视觉 ObjectDetector.jl YOLO 抓取的“预备跑” 图像Met…

使用vite+react+ts+Ant Design开发后台管理项目(一)

前言 本文将引导开发者从零基础开始&#xff0c;运用vite、react、react-router、react-redux、Ant Design、less、tailwindcss、axios等前沿技术栈&#xff0c;构建一个高效、响应式的后台管理系统。通过详细的步骤和实践指导&#xff0c;文章旨在为开发者揭示如何利用这些技…

SpringCloud Alibaba之Seata处理分布式事务

&#xff08;学习笔记&#xff0c;必用必考&#xff09; 问题&#xff1a;Transactional 的9种失效场景&#xff1f; 1、介绍 1.1、简介 官网地址&#xff1a;Apache Seata 源码地址&#xff1a;Releases apache/incubator-seata GitHub Seata是一款开源的分布式事务解决…

Thinkphp5x远程命令执行 靶场攻略

环境配置 靶场&#xff1a;vulhub/thinkphp/5-rce docker-compose up -d #启动环境 漏洞复现 1.访问靶场&#xff1a;http://172.16.1.198:8080/ 2.远程命令执⾏ POC&#xff1a; ?sindex/think\app/invokefunction&functioncall_user_func_array&vars[0]system…

【VUE_ruoyi-vue】基于ruoyi-vue框架实现简单的系统通用文件模块

基于ruoyi-vue框架&#xff0c;新增一个简单的系统通用文件模块&#xff0c;服务与各个模块涉及到文件上传信息的记录和相关展示 运行sql,创建数据库表 DROP TABLE IF EXISTS sys_file_info; CREATE TABLE sys_file_info (id int(11) NOT NULL AUTO_INCREMENT COMMENT id,lin…

在虚幻引擎中实时显示帧率

引擎自带了显示帧率的功能 但是只能在编辑器中显示 , 在游戏发布后就没有了 , 所以我们要自己做一个 创建一个控件蓝图 创建画布和文本 , 修改文本 文本绑定函数 , 点击创建绑定 添加一个名为 FPS 的变量 格式化文本 用大括号把变量包起来 {FPS Int} FPS 然后转到事件图表…

机器学习算法与Python实战 | 三万字详解!GPT-5:你需要知道的一切(下)建议收藏!

本文来源公众号“机器学习算法与Python实战”&#xff0c;仅用于学术分享&#xff0c;侵权删&#xff0c;干货满满。 原文链接&#xff1a;三万字详解&#xff01;GPT-5&#xff1a;你需要知道的一切 作者&#xff1a;Alberto Romero &#xff08;青稞AI整理&#xff09; 原…

Go语言基础学习01-Liunx下Go开发环境配置;源码组织方式;go build/install/get详解

目录 Linux环境下配置安装VScode并配置Go语言开发环境Go语言源码的组织方式Go语言源码安装后的结果Go程序构建和安装的过程go build扩展go get 命令详解 之前学习过Go语言&#xff0c;学习的时候没有记录笔记&#xff0c;最近找了个极客时间的Go语言36讲&#xff0c;打算时间学…

第 1 章:Vue 核心

1. Vue 简介 1.1. 官网 英文官网: https://vuejs.org/中文官网: https://cn.vuejs.org/&#xff1a;中文官网里面【教程】和【API】是比较重要的。用到api就去查询&#xff0c;实践当中记忆更牢靠。 风格指南&#xff1a;官方推荐写的一个代码风格cookbook&#xff1a;编写v…

QT窗口无法激活弹出问题排查记录

问题背景 问题环境 操作系统: 银河麒麟V10SP1qt版本 : 5.12.12 碰见了一个问题应用最小化,然后激活程序窗口无法弹出 这里描述一下代码的逻辑,使用QLocalServer实现一个单例进程,具体的功能就是在已存在一个程序A进程时,再启动这个程序A,新的程序A进程会被杀死,然后激活已存…