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

[具身智能-234]:OpenCV - 图像通常是三维的(高 H × 宽 W × 通道 C,例如 RGB 三通道),而 Mask 通常是二维的(高 H × 宽 W,单通道黑白),为什么?

图像通常是三维的高 H × 宽 W × 通道 C例如 RGB 三通道而Mask通常是二维的高 H × 宽 W单通道黑白。它们之间的“映射”并不是数学上的维度变换而是一种基于广播机制的逻辑索引。简单来说Mask 是“印章”它同时盖在图像的三个颜色通道上。下面我为你拆解这个“降维打击”的过程1. 核心原理广播与“逻辑与”虽然 Mask 是二维的单通道但在 OpenCV 和 NumPy 的逻辑中当你把一个二维 Mask 应用到一个三维图像上时系统会自动执行广播。图像Image[y, x, channel](3层数据)MaskMask[y, x](1层数据)映射规则Mask 在空间位置(y, x)上的值会同时作用于图像在该位置的所有颜色通道R、G、B。如果Mask[y, x] 255白保留Image[y, x, 0](R)保留 Image[y, x, 1] (G)保留Image[y, x, 2](B)结果该像素显示原色。如果Mask[y, x] 0黑Image[y, x, :]全部变为 0。结果该像素变为黑色。2. 代码实现三种“映射”方式在实际编程中这种映射主要通过以下三种方式实现方式一cv2.bitwise_and最常用符合直觉这是 OpenCV 提供的专用函数它内部自动处理了维度的对齐。pythonimport cv2 import numpy as np # img 是三维 (H, W, 3) # mask 是二维 (H, W) # 注意mask 必须是 uint8 类型0 或 255 result cv2.bitwise_and(img, img, maskmask)原理它把img和img自己做“与运算”但受mask控制。Mask 为 1 的地方img img img保留Mask 为 0 的地方结果强制为 0变黑。方式二NumPy 布尔索引最 Pythonic效率最高利用 NumPy 的高级索引功能直接“提取”或“修改”被 Mask 选中的像素。python# 1. 将 mask 转换为布尔值 (True/False) # 此时 mask 变成了一个二维的 True/False 矩阵 bool_mask mask 0 # 2. 直接映射索引 # 这行代码的意思是取出 img 中所有对应 mask 为 True 的像素点包含所有通道 pixels img[bool_mask] # 3. 或者原地修改例如把选中区域变红 img[bool_mask] [0, 0, 255]原理NumPy 会自动识别img是多维数组当传入二维布尔数组时它会自动沿着通道维度进行广播匹配提取出所有符合条件的像素点集合。方式三cv2.copyToC 风格语义清晰这个函数的语义是“把源图拷贝到目标图但只拷贝 Mask 选中的地方”。python# 创建一个全黑的背景图作为目标 target np.zeros_like(img) # 将 img 的内容根据 mask 的指示拷贝到 target 中 cv2.copyTo(img, mask, target)原理这就像是“镂空喷漆”。target是墙面img是油漆mask是模板。只有模板镂空白色的地方油漆才会喷上去。3. 为什么不需要把 Mask 变成三维你可能会问为什么不手动把 Mask 复制三份变成(H, W, 3)再运算内存效率Mask 只需要存储一次空间信息哪里是物体哪里是背景。如果复制成三维会浪费 3 倍内存且没有任何信息量的增加。计算优化OpenCV 和 NumPy 的底层SIMD 指令集针对这种“单通道控制多通道”的操作做了极致优化。它们会在 CPU 指令层面并行处理 R、G、B 三个通道而不需要你手动去写循环。 总结Mask 到彩色图的映射本质上是“空间维度的控制”。Mask (2D)决定了“哪里”Where。Image (3D)决定了“什么”What。映射结果在 Mask 指定的“哪里”显示出 Image 对应的“什么”颜色。这种机制使得我们可以用一个简单的黑白剪影轻松控制复杂的彩色世界。

相关文章:

[具身智能-234]:OpenCV - 图像通常是三维的(高 H × 宽 W × 通道 C,例如 RGB 三通道),而 Mask 通常是二维的(高 H × 宽 W,单通道黑白),为什么?

图像通常是三维的(高 H 宽 W 通道 C,例如 RGB 三通道),而 Mask 通常是二维的(高 H 宽 W,单通道黑白)。它们之间的“映射”并不是数学上的维度变换,而是一种基于广播机制的逻辑索引…...

别再傻傻分不清!一张图看懂PMOS、NMOS和CMOS在电路设计中的真实区别

从物理特性到电路设计:PMOS、NMOS与CMOS的实战解析 在电子工程领域,MOSFET晶体管就像乐高积木一样构成了现代集成电路的基础模块。但面对PMOS、NMOS这对"双胞胎"时,许多初学者常常陷入困惑——为什么数字电路总爱用CMOS结构&#x…...

Harness 中的事务边界定义:微事务与补偿

Harness 中的事务边界定义:微事务与补偿 引言 核心概念铺垫 在开始本文的核心内容——Harness 中的事务边界定义与微事务/补偿实践体系——之前,我们需要先锚定一组贯穿全文的、与 CI/CD 交付流水线强绑定的专属术语与业务通用术语的融合定义: 交付事务(Delivery Transac…...

VLAN配置避坑指南:为什么你的Trunk接口加了PVID还是不通?

VLAN配置避坑指南:为什么你的Trunk接口加了PVID还是不通? 刚接触企业网络的新手工程师们,是否经常遇到这样的困惑:明明按照文档配置了Trunk接口的PVID,设备间的VLAN通信却依然无法建立?这背后往往隐藏着对P…...

Kubernetes集群的监控告警最佳实践

Kubernetes集群的监控告警最佳实践 🔥 硬核开场 各位技术老铁,今天咱们聊聊Kubernetes集群的监控告警最佳实践。别跟我扯那些理论,直接上干货!在云原生时代,监控告警是系统可靠性的关键,它能帮助我们及时发…...

告别迷茫!S32K312 MCU的LIN通信实战:从EB Tresos配置到代码调试全流程避坑

S32K312 MCU的LIN通信实战:从配置到调试的完整避坑指南 第一次在S32K312上实现LIN通信时,我盯着EB Tresos里密密麻麻的MCAL配置选项发呆了半小时。作为从STM32转战NXP平台的工程师,本以为LIN这种低速总线会很简单,直到实际项目中遇…...

云原生环境中的配置中心实践

云原生环境中的配置中心实践 🔥 硬核开场 各位技术老铁,今天咱们聊聊云原生环境中的配置中心实践。别跟我扯那些理论,直接上干货!在云原生时代,配置管理是系统可靠性和可维护性的关键。不搞配置中心?那你…...

Kubernetes与多集群服务网格实践

Kubernetes与多集群服务网格实践 🔥 硬核开场 各位技术老铁,今天咱们聊聊Kubernetes与多集群服务网格实践。别跟我扯那些理论,直接上干货!在云原生时代,多集群部署已经成为常态,而服务网格是实现多集群服务…...

云原生应用的性能测试与优化

云原生应用的性能测试与优化 🔥 硬核开场 各位技术老铁,今天咱们聊聊云原生应用的性能测试与优化。别跟我扯那些理论,直接上干货!在云原生时代,性能是用户体验的关键,也是系统可靠性的保障。不搞性能测试与…...

Harness Engineering入门基础教程(非常详细),从人类写码到Agent开发,看这篇就够了!

读完 OpenAI 关于 Harness Engineering 的文章后,我做了一份核心总结,并结合自己的项目写下了这些启发。 最近在团队里,我尝试借鉴 OpenAI 提出的 Harness Engineer 概念,探索一种新的开发模式。它的核心问题是:如果人…...

WPF MES 产线执行系统:AGV与立库协同控制的核心实现

ERP MES 两套系统源代码 WPF AGV C# WPF开发。 A,WPF MES 上位机产线执行系统。 1, 完整纯源代码; 2, AGV自动调度; 3, SQLSERVER数据库。 带附加文件。 4, WPF各种技术应用。 5, 数…...

COMSOL超声相控阵仿真模型 模型介绍:本链接有两个模型,分别使用压力声学与固体力学对超声相...

COMSOL超声相控阵仿真模型 模型介绍:本链接有两个模型,分别使用压力声学与固体力学对超声相控阵无损检测进行仿真,负有模型说明。 使用者可自定义阵元数、激发频率、激发间隔等参数,可激发出聚焦、平面等波形,可以一次…...

分享稳定可靠的TMC5160、TMC5130高性能步进电机驱动代码,支持级联,简单易用,附送原理图

TMC5160、TMC5130高性能步进电机驱动代码 代码都已长时间验证,稳定可靠运行! 图里资料就是到手资料 简介: 德国TMC步进电机驱动代码 送你OrCAD或者AD版本原理图 自己整个重新写的代码,注释详细 支持多个TMC5160级联 调用很简单&a…...

BilibiliDown高效视频下载指南:全面掌握B站视频离线解决方案

BilibiliDown高效视频下载指南:全面掌握B站视频离线解决方案 【免费下载链接】BilibiliDown (GUI-多平台支持) B站 哔哩哔哩 视频下载器。支持稍后再看、收藏夹、UP主视频批量下载|Bilibili Video Downloader 😳 项目地址: https://gitcode.com/gh_mir…...

Vue3 使用 Store 的注意事项:官方推荐的方式始终是在 setup 或 composable 函数内部调用 useStore()

在 hook 中错误使用 Store:useStore() 在函数外部调用import { useUserList } from "/hooks"; import { useDepartmentStore } from "/stores"; import type { Department } from "/types"; import { onMounted, ref } from "vu…...

设计键盘键帽个性替换件,精准适配,输出,客制化键盘低成本平替。

如何低成本获得独一无二的键帽。项目方案:基于Python的键盘键帽激光雕刻参数化生成系统一、 实际应用场景描述想象一下,你是一个 VIM 党,或者是一个重度使用 Figma 的设计师。你对键盘有着极致的追求:你想把 "ESC" 键换…...

编写程序实现钓鱼浮标刻度雕刻,防水不褪色,输出钓友精准看口,实用刚需。

应用到广大钓友最关心的“眼睛”——钓鱼浮标(浮漂)上。我们要解决的是户外垂钓中一个既专业又恼人的问题:浮标刻度的防水与清晰度。项目方案:基于Python的钓鱼浮标激光刻度精密雕刻系统一、 实际应用场景描述想象一下&#xff0c…...

饲草打包机的设计及其三维造型【农业机械】(论文+5张cad图纸+solidworks三维+动画+答辩】

饲草打包机作为农业机械化作业的关键设备,其设计需兼顾效率、可靠性与操作便捷性。传统饲草处理依赖人工捆扎,不仅劳动强度大,且打包质量参差不齐,易受天气影响导致饲草霉变。针对这一痛点,新型饲草打包机通过优化机械…...

AtCoder Beginner Contest 433

AtCoder Beginner Contest 433 ABCD https://www.bilibili.com/video/BV1srUTBEEfa/ AtCoder Beginner Contest 433 https://www.bilibili.com/video/BV14xUWBYELd/ https://blog.csdn.net/2503_93669452/article/details/155140717 【实况】AtCoder Beginner Contest 433&…...

seo中文网站如何应对算法更新

SEO中文网站如何应对算法更新 在互联网的迅速发展中,搜索引擎的算法更新频繁,这对SEO中文网站提出了更高的要求。面对这一挑战,我们需要深入分析问题,理解原因,并采取有效的应对策略。本文将详细探讨如何应对搜索引擎…...

魔兽争霸III优化终极指南:WarcraftHelper插件完整使用教程

魔兽争霸III优化终极指南:WarcraftHelper插件完整使用教程 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper 还在为魔兽争霸III在现代电脑上…...

NCM音乐格式转换完全指南:从加密困境到自由播放的解决方案

NCM音乐格式转换完全指南:从加密困境到自由播放的解决方案 【免费下载链接】ncmdump 项目地址: https://gitcode.com/gh_mirrors/ncmd/ncmdump 一、问题解析:NCM格式的技术困境与用户痛点 当你下载了喜爱的音乐却发现只能在特定应用中播放&…...

虚拟机检测工具VMDE深度解析与实战指南

虚拟机检测工具VMDE深度解析与实战指南 【免费下载链接】VMDE Source from VMDE paper, adapted to 2015 项目地址: https://gitcode.com/gh_mirrors/vm/VMDE 揭示VMDE的核心价值 在虚拟化技术广泛应用的今天,准确识别系统运行环境的真实性变得至关重要。虚…...

QMK Toolbox:如何用这款开源工具轻松刷写机械键盘固件?

QMK Toolbox:如何用这款开源工具轻松刷写机械键盘固件? 【免费下载链接】qmk_toolbox A Toolbox companion for QMK Firmware 项目地址: https://gitcode.com/gh_mirrors/qm/qmk_toolbox QMK Toolbox 是一款专为机械键盘爱好者设计的开源固件刷写…...

番茄小说下载器:终极开源工具,让数字阅读更简单高效

番茄小说下载器:终极开源工具,让数字阅读更简单高效 【免费下载链接】Tomato-Novel-Downloader 番茄小说下载器不精简版 项目地址: https://gitcode.com/gh_mirrors/to/Tomato-Novel-Downloader 你是否曾经遇到过这样的困境:正在追更的…...

MATLAB代码:基于主从博弈的电热综合能源系统DE算法优化动态定价与能量管理

MATLAB代码:基于主从博弈的电热综合能源系统动态定价与能量管理 关键词:主从博弈 电热综合能源 动态定价 能量管理 仿真平台:MATLAB 平台 优势:代码具有一定的深度和创新性,注释清晰,非烂大街的代码&…...

游戏开发者必备免费源码网,一键搭建

一、全场景覆盖:从休闲小游戏到商业级项目 源码分享网的源码资源库堪称“游戏开发的全家桶”,覆盖了从前端交互到后端逻辑、从移动端到网页端的完整技术栈。无论是想要快速验证创意的休闲小游戏,还是需要搭建商业级游戏平台,这里…...

小程序开发首选免费源码网:全开源生态下的创新加速器

一、全开源免费源码:破解开发难题的“钥匙”1. 降低技术门槛,加速产品落地对于初创团队或个人开发者而言,全开源免费源码的价值在于其“开箱即用”的特性。以GitHub和码云(Gitee)为例,这两个全球最大的开源…...

市电转低压直流这事儿玩过的人都知道,反激式拓扑是性价比首选。最近手头刚做完两个工业电源项目,正好拿6W和12W两个方案来唠唠实战细节

220V转12V成熟设计,做过相关认证。 两种电路。 1)6W,包含原理图和pcb,附芯片手册,包含变压器设计. 2) 12W,包含原理图和pcb,附 BOM,变压器参数,芯片手册。 备注:方案一芯片比方案二芯片价格偏低…...

订单状态机实战:代码校验 + SQL 幂等一次讲清

这篇不是“先写 SQL 再补代码”,而是从设计层面把代码层状态机和SQL 幂等更新绑定在一起。状态流转(业务真实模型) UNPAID -> PAID -> SHIPPED -> COMPLETED UNPAID -> CANCELED PAID -> REFUNDING -> REFUNDED SHIPPED-…...