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

视觉图像面积计算

在图像处理和计算机视觉中,计算对象面积的常见方法有两种:使用四邻域标记算法和使用轮廓计算。每种方法在不同情况下有各自的优缺点。

  1. 四邻域标记算法

    • 优点
      • 简单易实现。
      • 能够处理带有孔洞的复杂区域(只要孔洞不影响连通性判断)。
    • 缺点
      • 对于边缘不清晰或有噪声的图像,可能会导致面积计算误差。
      • 依赖于图像分辨率和阈值选择的精度。
  2. 轮廓计算

    • 优点
      • 通常更精确,因为它直接使用对象的边缘来计算面积。
      • 适合处理边界清晰的对象。
      • 可以在亚像素级别计算面积,提供更高精度。
    • 缺点
      • 计算复杂度相对较高,特别是在图像边缘检测和轮廓提取步骤。
      • 对于有噪声的图像,边缘检测可能会失败或产生错误的轮廓。

更准确的选择

通常情况下,使用轮廓计算面积更为准确,特别是在以下情况下:

  • 图像边缘清晰。
  • 需要高精度的面积计算。
  • 可以处理复杂形状和多种连通区域。

分别代码:

1 轮廓

# 获取连通域的边界和标签   # 查看各个轮廓contours, _ = cv2.findContours(gray_frame_seg, cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)# 筛选出面积较小的轮廓option_contours = [cnt for cnt in contours if cv2.contourArea(cnt) > area_threshold]logging.info(f'count: {len(contours)}, option contours: {len(option_contours)}')# 初始化要计算的参数num_contours = len(option_contours)areas = np.zeros(num_contours)

2 四邻域标记算法

    def calculate_perimeter():"""计算连通区域的周长"""contours, _ = cv2.findContours(region.astype(np.uint8), cv2.RETR_EXTERNAL, cv2.CHAIN_APPROX_SIMPLE)perimeter = 0for contour in contours:perimeter += cv2.arcLength(contour, True)return perimeter# 找到连通区域并计算每个区域的面积和周长labeled_array, num_features = label(gray_frame_seg)print(f'labeled_array, num_features:{labeled_array, num_features}')areas1 = []perimeters1 = []# 遍历每个连通区域for region_slice in find_objects(labeled_array):region = labeled_array[region_slice]area = np.sum(region > 0)perimeter = calculate_perimeter()areas1.append(area)perimeters1.append(perimeter)print(f'sort areas, len:{len(areas1)}:\n{sorted(areas1)}')return areas1, perimeters1

http://www.lryc.cn/news/394503.html

相关文章:

  • Vue笔记10-其它Composition API
  • AI集成工具平台一站式体验,零门槛使用国内外主流大模型
  • 北京交通大学学报
  • 【LinuxC语言】手撕Http之处理POST请求
  • 以软件定义推动智算中心建设
  • Apache Seata分布式事务原理解析探秘
  • MySQL-18-mysql source 执行 sql 文件时中文乱码
  • flutter环境安装(Mac+vscode)
  • 【题解】—— LeetCode一周小结27
  • C++后端开发--网络编程基础
  • 如何将资源前端通过 Docker 部署到远程服务器
  • @react-google-maps/api实现谷歌地图嵌入React项目中,并且做到点击地图任意一处,获得它的经纬度
  • 【MySQL】2.库的操作
  • 深入Laravel服务容器:构建灵活应用的秘诀
  • 3.js - 模板渲染 - 金属切面效果
  • 【测试】系统压力测试报告模板(Word原件)
  • 图片预加载和懒加载
  • Java中的数据可视化与图表库选择
  • STM32-TIM定时器
  • Python OpenCV与霍夫变换:检测符合特定斜率范围的直线
  • ubuntu22.04+pytorch2.3安装PyG图神经网络库
  • 新型开发语言的试用感受-仓颉语言发布之际
  • 基于字典学习的地震数据降噪(MATLAB R2021B)
  • 【Web】
  • kafka-3
  • MySQL性能优化 二、表结构设计优化
  • 用HttpURLConnection复现http响应码405
  • 2-27 基于matlab的一种混凝土骨料三维随机投放模型
  • ISA95-Part4-业务流程的解析与设计思路
  • 【Spring Cloud】一个例程快速了解网关Gateway的使用