百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

OpenCV 4.10更新发布,首次支持Windows ARM64、苹果VisionOS

nanshan 2024-10-08 05:30 27 浏览 0 评论

IT之家 6 月 4 日消息,OpenCV 是一款跨平台的计算机视觉和机器学习软件平台,在计算机视觉领域广泛使用,是目前人工智能应用中的重要基础平台。

OpenCV 4.10.0 版本更新于昨日发布(点此查看),对其深度神经网络(DNN) 模块进行了许多改进、实验性 NumPy 2.0 支持、Android 改进、NVIDIA CUDA 12.4+ 平台支持、RISC-V 和 ARM 改进、oneAPI 2024 支持、实验性 Windows ARM64 支持、实验性苹果 VisionOS 支持,以及 Linux 上的本机 Wayland 后端

IT之家附 OpenCV 4.10.0 更新内容如下:

Core Module:

  • 为 cv::Mat 添加了 CV_FP16 数据类型 #24892, #24918。弃用了 convertFp16 函数,添加了对 cv::Mat::convertTo 及其类似函数的 FP16 支持。

  • 修复了一些与 FP16 算术相关的未定义行为 #25598

  • 扩展了 HAL API,用于 minMaxIdx #25563, LUT #25554, meanStdDev #25483, moments 25490, normHamming #25491。为 transpose #25342 和一些算术函数 #25574, #25506 添加了 HAL 条目。

  • 持久性:将实数输出为用户友好的表达方式。#25351

  • 为并行框架添加了 cgroups v2 支持 #25285

  • 添加了对 cartToPolar 和 polarToCart 的就地支持 #24893

Imgproc Module:

  • 为 cv::remap 添加了相对位移场选项 #24621

  • 添加了新的 findContours 实现 #25146, #25680, #25385

  • 修复了 EMD 分配问题 #25583

  • 修复了大内核情况下 stackBlur 的错误 #25513

  • 扩展了 HAL 支持 projectPoints #25511, equalizeHist #25565, Otsu threshold #25509。为 gaussianBlur #25397, remap #25399, bilaterialFilter #25343 添加了新的 HAL 条目。

Calib3d Module:

  • 修复了手眼校准方法中的几个错误 #24897, #25423

  • 修复了 findHomography 实现中的几个错误 #25308, #25665

  • 在 findChessboardCorners 实现中进行了多项改进:#25365, 25195, 25177, 25182, 25145, 24779, 24710, 24833, 25090

  • 改进了对称圆点网格图案检测 #25258

  • 修复了 USAC 中可能的无限循环 #24987

  • 改变了鱼眼校准中焦距初步估计的方法 #25030

  • 添加了 Fisheye 相机模型的 solvePnP 实现 #25028

DNN Module:

  • 显著改进了 DNN 的内存消耗 #25181, 25163

  • 添加了 Net::dumpToPbtxt 方法,以使用 Netron 审查优化后的图 #25582

  • 添加了对多个 TFLite 层的支持:Global_Pool_2D #25613, Transpose #25297, HardSwishInt8 #24985, split, fully connected, SoftMax, Cast #25273。

  • 修复了多个 ONNX 层中的错误:Slice #25660, Range #25414, Clip #25319, ReduceMean #25120, Einsum #25100, Norm #24808, Concat 中负轴支持 #24865。

  • 添加了新的 ONNX 层:Mod #24765, GroupNorm 层 #24610。

  • 添加了更多与 OpenVINO 兼容的 DNN 层 #25524, #25291, 25518。

  • 优化了 RISC-V RVV 扩展的 fastDepthwiseConv #25361 和 int8 层 25230

  • 优化了 RISC-V P Packed SIMD Extension v0.5.2 的 fastDepthwiseConv #24556

  • 优化了 Attention #24476, #25271, #25238, #24613, 25076。

  • 为 scatter 和 scatterND 添加了并行版本 #24813

  • 在 CuDNN 后端中添加了广播支持(如果 a.rank() != b.rank())#24834

  • 调整了卷积的 Winograd 算法使用 #24709

  • 添加了 Raft 模型支持和示例 #24913

  • 为 DNN 模块中的 NaryEltwiseLayer 添加了 Vulkan 后端 #24768

  • 改进了现代 Yolo 检测器的支持。添加了示例和文档 #24898, #24611

  • 添加了 CuDNN 9+ 支持 #25412

  • 添加了 OpenVINO 2024 支持 #25199

G-API Module:

  • 将 G-API ONNXRT 后端移植到 V2 API #25662

  • 实现了并发执行器 #24845

  • 为 GMat 添加了快速值初始化支持 #25055

  • 修复了 OV 后端对非实数类型的均值 / 尺度预处理支持 #24704

Objdetect Module:

  • 修复了某些情况下 Charuco 棋盘生成的不准确问题 (.generateImage ()) #24873, #25673

  • 修复了 Aruco 检测器的线程安全问题 #24807,使 Aruco 检测器更加确定性 #24829

  • 添加了 QR 码结构化附加解码模式 #24548

  • 修复了 QR 码检测器和解码器中的多个错误 #25026

  • 修复了条形码 detectAndDecode #25035

  • 将剩余的 Aruco 和 Charuco 文档和示例移植到现代 API #23018

VideoIO:

  • 修复了 InternalFFMpegRegister 初始化中的竞争条件。#25419

  • Orbbec 相机支持 MacOS,Gemini2 和 Gemini2L 支持 Y16 格式 #24877

  • 为 V4L2 后端添加了 V4L2_PIX_FMT_SGRBG8 像素格式支持 #25249

  • 修复了当 CAP_PROP_FORMAT == -1 时,VideoCapture 返回的不正确时间戳 #24828

Python Bindings:

  • 实验性 NumPy 2.0 支持

  • 为 Rect2f 和 Point3i 添加了 Python 绑定 #24919

  • 将 MatLike 的 dtype 切换为数值类型,而不是通用类型 #25406

  • 在文件名预期的地方添加了路径对象支持 #24773:

  • 为 JavaCameraView 添加了任何屏幕方向支持 #24827,在安卓示例中添加了 avaCamera2View 和 NativeCameraView 支持 #24869。修复了 JavaCamera2View 中的双预览初始化错误 #24869。

  • 从构建脚本和教程中移除了 Android AIDL,因为自 4.9.0 起不再需要 #24843

  • 启用 Emscripten 文件系统 #24949

  • 为现代 Android Studio 更新了安卓示例。添加了从 Maven 支持 OpenCV 的功能。#24473

  • 向 AAR 添加了 kotlin 类 #24884

  • 为 ARM v8 和 v9 处理器添加了 KleidiCV 作为 HAL(CMake 选项 -DWITH_KLEIDICV=ON)#25443, #25618

平台支持:

    • CUDA 12.4+ 支持 #25658

    • Linux 的 Wayland 后端 #25551, #25510, #25502

    • MacOS 及其衍生产品的新 LAPACK 接口支持 #24804, #25625

    • 为带有 P 扩展的 RISC-V 处理器添加了初始 HAL 版本 #25167

    • 为 ARM v8 和 v9 处理器添加了 KleidiCV 作为 HAL(CMake 选项 -DWITH_KLEIDICV=ON)#25443, #25618

    • 添加了 zlib-ng 作为经典 zlib 的替代品(CMake 选项 -DWITH_ZLIB_NG=ON)#24782

    • OneAPI 2024 支持(IPP, TBB)

    • 实验性 Apple VisionOS 支持

    • 实验性 Windows ARM64 支持

相关推荐

0722-6.2.0-如何在RedHat7.2使用rpm安装CDH(无CM)

文档编写目的在前面的文档中,介绍了在有CM和无CM两种情况下使用rpm方式安装CDH5.10.0,本文档将介绍如何在无CM的情况下使用rpm方式安装CDH6.2.0,与之前安装C5进行对比。环境介绍:...

ARM64 平台基于 openEuler + iSula 环境部署 Kubernetes

为什么要在arm64平台上部署Kubernetes,而且还是鲲鹏920的架构。说来话长。。。此处省略5000字。介绍下系统信息;o架构:鲲鹏920(Kunpeng920)oOS:ope...

生产环境starrocks 3.1存算一体集群部署

集群规划FE:节点主要负责元数据管理、客户端连接管理、查询计划和查询调度。>3节点。BE:节点负责数据存储和SQL执行。>3节点。CN:无存储功能能的BE。环境准备CPU检查JDK...

在CentOS上添加swap虚拟内存并设置优先级

现如今很多云服务器都会自己配置好虚拟内存,当然也有很多没有配置虚拟内存的,虚拟内存可以让我们的低配服务器使用更多的内存,可以减少很多硬件成本,比如我们运行很多服务的时候,内存常常会满,当配置了虚拟内存...

国产深度(deepin)操作系统优化指南

1.升级内核随着deepin版本的更新,会自动升级系统内核,但是我们依旧可以通过命令行手动升级内核,以获取更好的性能和更多的硬件支持。具体操作:-添加PPAs使用以下命令添加PPAs:```...

postgresql-15.4 多节点主从(读写分离)

1、下载软件[root@TX-CN-PostgreSQL01-252software]#wgethttps://ftp.postgresql.org/pub/source/v15.4/postg...

Docker 容器 Java 服务内存与 GC 优化实施方案

一、设置Docker容器内存限制(生产环境建议)1.查看宿主机可用内存bashfree-h#示例输出(假设宿主机剩余16GB可用内存)#Mem:64G...

虚拟内存设置、解决linux内存不够问题

虚拟内存设置(解决linux内存不够情况)背景介绍  Memory指机器物理内存,读写速度低于CPU一个量级,但是高于磁盘不止一个量级。所以,程序和数据如果在内存的话,会有非常快的读写速度。但是,内存...

Elasticsearch性能调优(5):服务器配置选择

在选择elasticsearch服务器时,要尽可能地选择与当前业务量相匹配的服务器。如果服务器配置太低,则意味着需要更多的节点来满足需求,一个集群的节点太多时会增加集群管理的成本。如果服务器配置太高,...

Es如何落地

一、配置准备节点类型CPU内存硬盘网络机器数操作系统data节点16C64G2000G本地SSD所有es同一可用区3(ecs)Centos7master节点2C8G200G云SSD所有es同一可用区...

针对Linux内存管理知识学习总结

现在的服务器大部分都是运行在Linux上面的,所以,作为一个程序员有必要简单地了解一下系统是如何运行的。对于内存部分需要知道:地址映射内存管理的方式缺页异常先来看一些基本的知识,在进程看来,内存分为内...

MySQL进阶之性能优化

概述MySQL的性能优化,包括了服务器硬件优化、操作系统的优化、MySQL数据库配置优化、数据库表设计的优化、SQL语句优化等5个方面的优化。在进行优化之前,需要先掌握性能分析的思路和方法,找出问题,...

Linux Cgroups(Control Groups)原理

LinuxCgroups(ControlGroups)是内核提供的资源分配、限制和监控机制,通过层级化进程分组实现资源的精细化控制。以下从核心原理、操作示例和版本演进三方面详细分析:一、核心原理与...

linux 常用性能优化参数及理解

1.优化内核相关参数配置文件/etc/sysctl.conf配置方法直接将参数添加进文件每条一行.sysctl-a可以查看默认配置sysctl-p执行并检测是否有错误例如设置错了参数:[roo...

如何在 Linux 中使用 Sysctl 命令?

sysctl是一个用于配置和查询Linux内核参数的命令行工具。它通过与/proc/sys虚拟文件系统交互,允许用户在运行时动态修改内核参数。这些参数控制着系统的各种行为,包括网络设置、文件...

取消回复欢迎 发表评论: