opencv RGB圖像轉灰度圖

這段代碼的作用是將一個?3通道的 RGB 圖像(CV_8UC3)轉換為灰度圖像(CV_8UC1,并使用 OpenCV 的?parallel_for_?對圖像處理進行并行加速。


🔍 一、函數功能總結

if (CV_8UC3 == img.type()) {// 創建灰度圖 dst// 使用并行方式將 RGB 圖像轉為灰度圖return dst;
}
  • 判斷輸入圖像是否是?3通道 8 位無符號整型的 RGB 圖像
  • 如果是,則創建一個?單通道灰度圖?dst
  • 使用并行循環對每一行像素進行?RGB 轉 Gray 操作
  • 返回灰度圖像?dst

🧠 二、詳細解釋

? 條件判斷:if (CV_8UC3 == img.type())

  • img.type()?是 OpenCV 中用于獲取圖像類型的函數。
  • CV_8UC3?表示:
    • 8U: 每個像素值是 8 位無符號整數(0~255)
    • C3: 有三個通道(Red, Green, Blue)

所以這句的意思是:“如果輸入圖像是一張標準的 RGB 彩色圖像”。


📷 創建灰度圖像:

dst.create(img.rows, img.cols, CV_8UC1);
  • 創建一個新的圖像?dst
  • 大小與原圖一致 (img.rows x img.cols)
  • 類型是?CV_8UC1:即單通道灰度圖

?? 并行處理圖像:

cv::parallel_for_(cv::Range(0, img.rows), [&](const cv::Range &range) {for (int row = range.start; row < range.end; ++row) {...}
});
  • 使用 OpenCV 的并行機制?parallel_for_?對圖像的每一行進行遍歷
  • 這里是按行并行化處理,適用于多核 CPU 加速大圖像處理

🖼 像素級 RGB 轉 Gray 計算:

const uchar* row_src = img.ptr<uchar>(row); // 獲取當前行指針
uchar* row_dst = dst.ptr<uchar>(row);       // 獲取目標行指針for (int col = 0; col < img.cols; ++col) {uchar red   = row_src[col * 3];uchar green = row_src[col * 3 + 1];uchar blue  = row_src[col * 3 + 2];row_dst[col] = static_cast<uchar>(0.114 * blue + 0.587 * green + 0.299 * red);
}
🎯 每個像素的操作:
  • 取出當前像素的 R、G、B 值
  • 使用加權平均公式將 RGB 轉換為灰度值:

$$ Gray = 0.299 \times Red + 0.587 \times Green + 0.114 \times Blue $$

這是 ITU-R BT.601 標準推薦的亮度計算公式。


📌 三、為什么要這樣寫?性能優化!

? 為什么不用?cvtColor

雖然你可以簡單地寫:

cv::cvtColor(img, dst, COLOR_RGB2GRAY);

但這段代碼可能出于以下目的而選擇手動實現:

目的說明
性能優化在特定平臺上或特定圖像尺寸下,手動并行化可能比內置函數更快
控制精度明確指定顏色權重公式,避免不同庫版本差異
教學/調試用途展示底層實現邏輯

🧪 四、輸出結果舉例

假設你有一張 RGB 圖像,某個像素的顏色是:

red = 255, green = 128, blue = 0

那么灰度值為:

$$ Gray = 0.299 \times 255 + 0.587 \times 128 + 0.114 \times 0 ≈ 150 $$

所以這個像素在灰度圖中會顯示為一個偏暗的灰色。


? 五、完整流程圖

輸入 RGB 圖像 (CV_8UC3)↓
判斷是否為 RGB 圖像↓
創建灰度圖 (CV_8UC1)↓
[并行處理]↓
取出每個像素的 R/G/B 分量↓
應用加權公式轉換為灰度值↓
保存到灰度圖 dst↓
返回灰度圖

🧰 六、擴展建議

🔄 替換為其他灰度公式(可選):

  • 平均法
    Gray = (red + green + blue) / 3;
  • 最大值法
    Gray = max(red, max(green, blue));

🧵 單線程版(用于調試):

for (int row = 0; row < img.rows; ++row) {const uchar* row_src = img.ptr<uchar>(row);uchar* row_dst = dst.ptr<uchar>(row);for (int col = 0; col < img.cols; ++col) {row_dst[col] = static_cast<uchar>(0.114 * row_src[col * 3 + 2] +0.587 * row_src[col * 3 + 1] +0.299 * row_src[col * 3]);}
}

? 七、應用場景

這種圖像預處理常用于以下任務:

應用場景說明
ARUCO/AprilTag 檢測灰度圖是檢測算法的標準輸入格式
圖像識別/匹配減少數據維度,提高效率
邊緣檢測Canny、Sobel 等算法通常基于灰度圖
OCR 字符識別如 Tesseract 需要灰度圖作為輸入

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/diannao/86592.shtml
繁體地址,請注明出處:http://hk.pswp.cn/diannao/86592.shtml
英文地址,請注明出處:http://en.pswp.cn/diannao/86592.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

React Hooks 的原理、常用函數及用途詳解

1. ??Hooks 是什么&#xff1f;?? Hooks 是 React 16.8 引入的函數式組件特性&#xff0c;允許在不編寫 class 的情況下使用 state 和其他 React 特性&#xff08;如生命周期、副作用等&#xff09;。??本質是一類特殊函數??&#xff0c;它們掛載到 React 的調度系統中…

學習路之PHP--webman協程學習

學習路之PHP--webman協程學習 一、準備二、配置三、啟動四、使用 協程是一種比線程更輕量級的用戶級并發機制&#xff0c;能夠在進程中實現多任務調度。它通過手動控制掛起和恢復來實現協程間的切換&#xff0c;避免了進程上下文切換的開銷 一、準備 PHP > 8.1 Workerman &g…

linux libusb使用libusb_claim_interface失敗(-6,Resource busy)解決方案

linux libusb使用libusb_claim_interface失敗&#xff08;-6&#xff0c;Resource busy&#xff09;解決方案 ? 問題原因&#x1f6e0;? 解決方案&#x1f538; 方法一&#xff1a;分離內核驅動 libusb_detach_kernel_driver()&#x1f538; 方法二&#xff1a;使用 usb-devi…

使用mpu6500/6050, PID,互補濾波實現一個簡單的飛行自穩控制系統

首先&#xff0c;參考ai給出的客機飛機的比較平穩的最大仰府&#xff0c;偏轉&#xff0c;和防滾角度&#xff0c;如下&#xff1a; 客機的最大平穩仰俯&#xff08;Pitch&#xff09;、偏轉&#xff08;Yaw&#xff09;和防滾&#xff08;Roll&#xff09;角度&#xff0c;通…

深度解析AD7685ARMZRL7:16位精密ADC在低功耗系統中的設計價值

產品概述 AD7685ARMZRL7是16位逐次逼近型&#xff08;SAR&#xff09;ADC&#xff0c;采用MSOP-10緊湊封裝。其核心架構基于電荷再分配技術&#xff0c;支持2.3V至5.5V單電源供電&#xff0c;集成低噪聲采樣保持電路與內部轉換時鐘。器件采用偽差分輸入結構&#xff08;IN/-&a…

EXCEL 實現“點擊跳轉到指定 Sheet”的方法

&#x1f4cc; WPS 表格技巧&#xff1a;如何實現點擊單元格跳轉到指定 Sheet 在使用 WPS 表格&#xff08;或 Excel&#xff09;時&#xff0c;我們經常會希望通過點擊一個單元格&#xff0c;直接跳轉到工作簿中的另一個工作表&#xff08;Sheet&#xff09;。這在制作目錄頁…

Python格式化:讓數據輸出更優雅

Python格式化&#xff1a;讓數據輸出更優雅 Python的格式化功能能讓數據輸出瞬間變得優雅又規范。不管是對齊文本、控制數字精度&#xff0c;還是動態填充內容&#xff0c;它都能輕松搞定。 一、基礎格式化&#xff1a;從簡單拼接開始 1. 百分號&#xff08;%&#xff09;格式…

2025年滲透測試面試題總結-小鵬[實習]安全工程師(題目+回答)

安全領域各種資源&#xff0c;學習文檔&#xff0c;以及工具分享、前沿信息分享、POC、EXP分享。不定期分享各種好玩的項目及好用的工具&#xff0c;歡迎關注。 目錄 小鵬[實習]安全工程師 1. 自我介紹 2. 有沒有挖過src&#xff1f; 3. 平時web滲透怎么學的&#xff0c;有…

VSCode科技風主題設計詳細指南

1. 科技風設計的核心特點 科技風設計是一種強調未來感、現代感和高科技感的設計風格,在VSCode主題設計中,可以通過以下幾個核心特點來體現: 1.1 色彩特點 冷色調為主:藍色、紫色、青色等冷色調是科技風設計的主要色彩高對比度:深色背景配合明亮的霓虹色,形成強烈的視覺…

android知識總結

Activity啟動模式 standard (標準模式) 每次啟動該 Activity&#xff08;例如&#xff0c;通過 startActivity()&#xff09;&#xff0c;系統總會創建一個新的實例&#xff0c;并將其放入調用者&#xff08;啟動它的那個 Activity&#xff09;所在的任務棧中。 singleTop (棧…

第3章 MySQL數據類型

MySQL數據類型 1、數字數據類型1.1 整數類型1.2 定點類型1.3 浮點類型1.4位值類型1.5 超出范圍和溢出處理1.5.1 超出范圍處理1.5.2 溢出處理 2、日期和時間數據類型3、字符串數據類型3.1 char和varchar類型3.2 binary和varbinary類型3.3 blob 和 text類型3.4 enum類型3.4.1 創建…

label-studio的使用教程(導入本地路徑)

文章目錄 1. 準備環境2. 腳本啟動2.1 Windows2.2 Linux 3. 安裝label-studio機器學習后端3.1 pip安裝(推薦)3.2 GitHub倉庫安裝 4. 后端配置4.1 yolo環境4.2 引入后端模型4.3 修改腳本4.4 啟動后端 5. 標注工程5.1 創建工程5.2 配置圖片路徑5.3 配置工程類型標簽5.4 配置模型5.…

mysql為什么一個表中不能同時存在兩個字段自增

背景。設置sort自增。會引發錯誤 通常自增字段都是用于表示數據的唯一性。數據庫限制。需要自定義排序字段大小。

牛客round95D

原題鏈接&#xff1a;D-小紅的區間修改&#xff08;一&#xff09;_牛客周賽 Round 95 題目背景&#xff1a; 初始擁有一個長度10^100元素全為0的數組&#xff0c;進行q查詢&#xff0c;每次查詢如果區間內的元素都為0就將區間變為首項為 1、公差為 1 的等差數列&#xff1b;否…

visual studio 2022更改主題為深色

visual studio 2022更改主題為深色 點擊visual studio 上方的 工具-> 選項 在選項窗口中&#xff0c;選擇 環境 -> 常規 &#xff0c;將其中的顏色主題改成深色 點擊確定&#xff0c;更改完成

實踐篇:利用ragas在自己RAG上實現LLM評估②

文章目錄 使用ragas做評估在自己的數據集上評估完整代碼代碼講解1. RAG系統構建核心組件初始化文檔處理流程 2. 評估數據集構建3. RAGAS評估實現1. 評估數據集創建2. 評估器配置3. 執行評估 本系列閱讀&#xff1a; 理論篇&#xff1a;RAG評估指標&#xff0c;檢索指標與生成指…

微軟PowerBI考試 PL300-在 Power BI 中清理、轉換和加載數據

微軟PowerBI考試 PL300-在 Power BI 中清理、轉換和加載數據 Power Query 具有大量專門幫助您清理和準備數據以供分析的功能。 您將了解如何簡化復雜模型、更改數據類型、重命名對象和透視數據。 您還將了解如何分析列&#xff0c;以便知曉哪些列包含有價值的數據&#xff0c;…

PostgreSQL 安裝與配置全指南(適用于 Windows、macOS 與主流 Linux 發行版)

PostgreSQL 是一個功能強大、開源、穩定的對象關系數據庫系統&#xff0c;廣泛用于后端開發、數據處理與分布式架構中。本指南將手把手教你如何在 Windows、macOS 以及主流 Linux 發行版 上安裝 PostgreSQL&#xff0c;并附上安裝驗證命令與基礎配置方法。 一、Windows 安裝與配…

WordPress博客文章SEO的優化技巧

在數字時代&#xff0c;博客不僅用于表達觀點&#xff0c;也能提升品牌影響力并吸引潛在客戶。許多服務器提供商&#xff08;如 Hostease&#xff09;支持 WordPress 一鍵安裝功能&#xff0c;方便新手快速完成安裝&#xff0c;專注于內容創作和 SEO 優化。然而&#xff0c;寫出…

Python:操作 Excel 折疊

??親愛的技術愛好者們,熱烈歡迎來到 Kant2048 的博客!我是 Thomas Kant,很開心能在CSDN上與你們相遇~?? 本博客的精華專欄: 【自動化測試】 【測試經驗】 【人工智能】 【Python】 Python 操作 Excel 系列 讀取單元格數據按行寫入設置行高和列寬自動調整行高和列寬水平…