在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

基于LockAI視覺識別模塊:C++使用圖像的統計信息

福州市凌睿智捷電子有限公司 ? 2025-05-08 10:09 ? 次閱讀

在圖像處理中,統計信息可以幫助我們了解圖像的特性,例如區域內的像素分布、顏色轉換以及特定區域的分析。本文將介紹基于LockAI視覺識別模塊如何提取興趣區域(ROI)、轉換顏色通道、計算均值和標準差,以及查找最小值和最大值,并通過一個綜合示例展示其實際應用。

1.基本知識講解

1.1 圖像的興趣區域(ROI)

ROI(Region of Interest):指圖像中感興趣的區域,通常用于局部分析或處理。

提取 ROI 的目的是減少數據量并專注于特定區域,從而提高處理效率。

1.2 顏色空間轉換

不同的顏色空間適用于不同的任務。例如:

灰度圖:簡化圖像處理,常用于邊緣檢測等任務。

HSV:用于顏色分割任務,分離色調、飽和度和亮度。

LAB:更接近人類視覺感知,適合顏色校正。

1.3 圖像統計信息

均值和標準差:反映圖像整體亮度及亮度變化情況。

最小值和最大值:幫助識別圖像中的極端像素值及其位置。


2.API文檔

2.1 頭文件

#include

2.2 提取興趣區域(ROI)

cv::Matroi=image(cv::Rect(x,y,w,h));

功能:

從圖像中提取一個矩形區域。

參數:

image:輸入圖像(cv::Mat類型)。

(x, y):ROI左上角的坐標。

(w, h):ROI的寬高。

返回值:

提取出的ROI圖像(cv::Mat類型)。

2.3 轉換為灰度圖

cv::cvtColor(image,grayImage,cv::COLOR_BGR2GRAY);

功能:

將彩色圖像轉換為灰度圖像。

參數:

image:輸入圖像(cv::Mat類型)。

grayImage:輸出灰度圖像(cv::Mat類型)。

COLOR_BGR2GRAY:將BGR圖像轉換為灰度圖像。

返回值:

無。最后結果儲存在grayImage中。注意:其中根據不同的轉換要求可以使用不同的轉換代碼,具體如下所示。


轉換方向轉換代碼描述
BGR Grayscalecv::COLOR_BGR2GRAY將 BGR 圖像轉換為灰度圖像
cv::COLOR_GRAY2BGR將灰度圖像轉換為 BGR 圖像
BGR RGBcv::COLOR_BGR2RGB將 BGR 圖像轉換為 RGB 圖像
cv::COLOR_RGB2BGR將 RGB 圖像轉換為 BGR 圖像
BGR HSVcv::COLOR_BGR2HSV將 BGR 圖像轉換為 HSV 圖像
cv::COLOR_HSV2BGR將 HSV 圖像轉換為 BGR 圖像
BGR LABcv::COLOR_BGR2LAB將 BGR 圖像轉換為 LAB 圖像
cv::COLOR_Lab2BGR將 LAB 圖像轉換為 BGR 圖像
BGR YUVcv::COLOR_BGR2YUV將 BGR 圖像轉換為 YUV 圖像
cv::COLOR_YUV2BGR將 YUV 圖像轉換為 BGR 圖像
BGR XYZcv::COLOR_BGR2XYZ將 BGR 圖像轉換為 CIE XYZ 圖像
cv::COLOR_XYZ2BGR將 CIE XYZ 圖像轉換為 BGR 圖像
BGR YCrCbcv::COLOR_BGR2YCrCb將 BGR 圖像轉換為 YCrCb 圖像
cv::COLOR_YCrCb2BGR將 YCrCb 圖像轉換為 BGR 圖像
BGR HLScv::COLOR_BGR2HLS將 BGR 圖像轉換為 HLS 圖像
cv::COLOR_HLS2BGR將 HLS 圖像轉換為 BGR 圖像
BGR Luvcv::COLOR_BGR2Luv將 BGR 圖像轉換為 Luv 圖像
cv::COLOR_Luv2BGR將 Luv 圖像轉換為 BGR 圖像
BGR Bayercv::COLOR_BayerBG2BGR將 Bayer 格式圖像轉換為 BGR 圖像
BGR RGBAcv::COLOR_BGR2RGBA將 BGR 圖像轉換為 RGBA 圖像(添加 Alpha 通道)
cv::COLOR_RGBA2BGR將 RGBA 圖像轉換為 BGR 圖像

2.4 計算均值和標準差:

cv::meanStdDev(src,mean,stddev);

功能:

計算圖像或矩陣元素的平均值和標準偏差。

參數:

src:輸入圖像或矩陣(cv::Mat類型)。

mean:輸出平均值(cv::Scalar類型)。

stddev:輸出標準偏差(cv::Scalar類型)。

返回值:

無。最后結果儲存在mean和stddev中。

2.5 計算最小值和最大值:

cv::minMaxLoc(src,&minVal,&maxVal,&minLoc,&maxLoc);

功能:

在輸入圖像或矩陣中找到最小值和最大值。

參數:

src:輸入圖像或矩陣(cv::Mat類型)。

minVal:輸出最小值(double類型)。

maxVal:輸出最大值(double類型)。

minLoc:輸出最小值對應的位置(cv::Point類型)。

maxLoc:輸出最大值對應的位置(cv::Point類型)。

返回值:

無。最后結果儲存在minVal、maxVal、minLoc和maxLoc中。


3.綜合代碼解析

3.1 流程圖

7052a870-2bb1-11f0-9434-92fbcf53809c.png

3.2 代碼解釋

讀取圖像文件

cv::Matimage=cv::imread("2.jpg");
if(image.empty()) {
std::cerr<<"Error: Could not open image!"<<std::endl;
return-1;
}

設定ROI區域

// 定義 ROI 并提取
cv::RectroiRect(50,50,200,200);
cv::Matroi=image(roiRect);

轉換為灰度圖

cv::MatgrayRoi;
cv::cvtColor(roi,grayRoi,cv::COLOR_BGR2GRAY);

均值和標準差計算

// 計算均值和標準差
cv::Scalarmean,stddev;
cv::meanStdDev(grayRoi,mean,stddev);

3.3 代碼實現

#include
#include

intmain()
{
// 讀取圖像
cv::Matimage=cv::imread("example.jpg");
if(image.empty())
{
std::cerr<<"Error: Could not open image!"<<std::endl;
return-1;
}

// 定義 ROI 并提取
cv::RectroiRect(50,50,200,200);
cv::Matroi=image(roiRect);

// 轉換為灰度圖
cv::MatgrayRoi;
cv::cvtColor(roi,grayRoi,cv::COLOR_BGR2GRAY);

// 計算均值和標準差
cv::Scalarmean,stddev;
cv::meanStdDev(grayRoi,mean,stddev);

// 計算最小值和最大值
doubleminVal,maxVal;
cv::PointminLoc,maxLoc;
cv::minMaxLoc(grayRoi,&minVal,&maxVal,&minLoc,&maxLoc);

// 輸出結果
std::cout<<"Mean: "<<mean[0]<<std::endl;
std::cout<<"Standard Deviation: "<<stddev[0]<<std::endl;
std::cout<<"Min Value: "<<minVal<<" at "<<minLoc<<std::endl;
std::cout<<"Max Value: "<<maxVal<<" at "<<maxLoc<<std::endl;

return0;
}


4.編譯過程

4.1 編譯環境搭建

請確保你已經按照開發環境搭建指南正確配置了開發環境。

同時以正確連接開發板。

4.2 Cmake介紹

# CMake最低版本要求
cmake_minimum_required(VERSION3.10)

project(test-Image-information-statistics)

set(CMAKE_CXX_STANDARD17)
set(CMAKE_CXX_STANDARD_REQUIRED ON)

# 定義項目根目錄路徑
set(PROJECT_ROOT_PATH"${CMAKE_CURRENT_SOURCE_DIR}/../..")
message("PROJECT_ROOT_PATH = "${PROJECT_ROOT_PATH})

include("${PROJECT_ROOT_PATH}/toolchains/arm-rockchip830-linux-uclibcgnueabihf.toolchain.cmake")

# 定義 OpenCV SDK 路徑
set(OpenCV_ROOT_PATH"${PROJECT_ROOT_PATH}/third_party/opencv-mobile-4.10.0-lockzhiner-vision-module")
set(OpenCV_DIR"${OpenCV_ROOT_PATH}/lib/cmake/opencv4")
find_package(OpenCV REQUIRED)
set(OPENCV_LIBRARIES"${OpenCV_LIBS}")
# 定義 LockzhinerVisionModule SDK 路徑
set(LockzhinerVisionModule_ROOT_PATH"${PROJECT_ROOT_PATH}/third_party/lockzhiner_vision_module_sdk")
set(LockzhinerVisionModule_DIR"${LockzhinerVisionModule_ROOT_PATH}/lib/cmake/lockzhiner_vision_module")
find_package(LockzhinerVisionModule REQUIRED)

# 圖像信息處理
add_executable(Test-Image-information-statistics Image_information_statistics.cc)
target_include_directories(Test-Image-information-statistics PRIVATE${LOCKZHINER_VISION_MODULE_INCLUDE_DIRS})
target_link_libraries(Test-Image-information-statistics PRIVATE${OPENCV_LIBRARIES}${LOCKZHINER_VISION_MODULE_LIBRARIES})

install(
TARGETS Test-Image-information-statistics
RUNTIME DESTINATION .
)

4.3 編譯項目

使用 Docker Destop 打開 LockzhinerVisionModule 容器并執行以下命令來編譯項目

# 進入Demo所在目錄
cd/LockzhinerVisionModuleWorkSpace/LockzhinerVisionModule/Cpp_example/B02_Image_information_statistics
# 創建編譯目錄
rm-rfbuild &&mkdirbuild &&cdbuild
# 配置交叉編譯工具鏈
exportTOOLCHAIN_ROOT_PATH="/LockzhinerVisionModuleWorkSpace/arm-rockchip830-linux-uclibcgnueabihf"
# 使用cmake配置項目
cmake ..
# 執行編譯項目
make-j8&&makeinstall

在執行完上述命令后,會在build目錄下生成可執行文件。


5. 例程運行示例

5.1 運行過程

在凌智視覺模塊中輸入以下命令:

chmod777Test-Image-information-statistics
./Test-Image-information-statistics

5.2 運行效果

在運行上述代碼時,會輸出以下結果:

7066c08a-2bb1-11f0-9434-92fbcf53809c.png

6. 總結

通過上述內容,我們介紹了如何使用 OpenCV 提取圖像的 ROI、轉換顏色空間、計算統計信息等操作。按照以下步驟,您可以輕松地進行圖像的統計分析:

提取 ROI:使用 cv::Rect 提取感興趣區域。

顏色轉換:使用 cv::cvtColor 轉換顏色空間。

計算統計信息:

使用 cv::meanStdDev 計算均值和標準差。

使用 cv::minMaxLoc 查找最小值和最大值及其位置。

綜合應用:結合上述方法對圖像進行局部分析和全局統計。

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 視覺識別
    +關注

    關注

    3

    文章

    94

    瀏覽量

    16946
  • AI視覺
    +關注

    關注

    0

    文章

    77

    瀏覽量

    4681
收藏 人收藏

    評論

    相關推薦
    熱點推薦

    匯編語言模塊調用C++函數實例

    現在編寫一個簡單的應用程序,提示用戶輸入整數,通過移位的方式將其與 2 的幕 (21?2?) 相乘,并用填充前導空格的形式再次顯示每個乘積。輸入-輸出使用 C++。匯編模塊將調用 3 個 C++ 編寫的函數。程序將由
    發表于 10-11 09:52 ?1078次閱讀

    基于LockAI視覺識別模塊C++圖像采集例程

    本文主要演示如何使用LockAI視覺識別模塊進行視頻流的讀取,同時使用Edit模塊進行圖像傳輸。
    發表于 04-30 10:52

    基于LockAI視覺識別模塊C++圖像的基本運算

    圖像處理中,理解圖像的基本操作是掌握計算機視覺技術的關鍵。本文章將介紹 基于LockAI視覺識別
    發表于 05-06 16:56

    基于LockAI視覺識別模塊C++使用圖像統計信息

    圖像處理中,統計信息可以幫助我們了解圖像的特性,例如區域內的像素分布、顏色轉換以及特定區域的分析。本文將介紹基于LockAI
    發表于 05-08 10:31

    [數字圖像處理與機器視覺:Visual C++與Matlab實現].張錚.

    ` 本帖最后由 explorer126 于 2014-8-10 23:03 編輯 三部分已經全部上傳完畢。下載的同學們可以完整下載了。數字圖像處理與機器視覺:Visual C++與Matlab實現].張錚.高清版本。已經全部
    發表于 08-08 16:50

    【工程源碼】基于FPGA的數字識別的實現

    `基于FPGA的數字識別的實現1基于數字特征算法實現數字識別我們采用基于數字特征的算法進行數字的識別,通過圖像采集模塊采集到
    發表于 02-17 18:39

    數字圖像處理與機器視覺:Visual C++與Matlab實現

    數字圖像處理與機器視覺:Visual C++與Matlab實現
    發表于 04-01 13:58

    人臉識別C/C++源代碼

    人臉識別C/C++源代碼 將生物特征識別應用于人臉,實際上是包含兩個方面:第一,從圖像或視頻幀中檢測人臉,即所謂的“人臉檢測”(face
    發表于 02-09 16:05 ?184次下載

    Visual C++數字圖像模式識別技術及工程實踐

    Visual C++數字圖像模式識別技術及工程實踐。
    發表于 11-06 10:08 ?3次下載

    基于線性CCD視覺信息的道路交通標志識別系統

    基于線性CCD視覺信息的道路交通標志識別系統,適用于圖像識別類。
    發表于 04-28 09:49 ?6次下載

    關于彩色圖像高斯反向投影基于OpenCV的C++代碼

    圖像反向投影的最終目的是獲取ROI然后實現對ROI區域的標注、識別、測量等圖像處理與分析,是計算機視覺與人工智能的常見方法之一。圖像反向投影
    的頭像 發表于 05-31 10:31 ?1133次閱讀

    機器視覺圖像目標識別方法綜述

    文章來源:MEMS引言從20世紀80年代開始,機器視覺技術的發展速度不斷加快,已經走進了人們的日常生活與工作之中。機器視覺圖像目標識別系統的自動化程度較高,應用范圍廣,尤其在危險場所
    的頭像 發表于 02-23 08:26 ?911次閱讀
    機器<b class='flag-5'>視覺</b>的<b class='flag-5'>圖像</b>目標<b class='flag-5'>識別</b>方法綜述

    OpenCV圖像識別C++代碼

    的頭文件 在您的C++代碼中,包含以下必要的頭文件: # include # include # include # include # include # include # include 讀取圖像
    的頭像 發表于 07-16 10:42 ?3545次閱讀

    基于LockAI視覺識別模塊C++圖像采集例程

    本文主要演示如何使用LockAI視覺識別模塊進行視頻流的讀取,同時使用Edit模塊進行圖像傳輸。
    的頭像 發表于 04-30 18:23 ?55次閱讀
    基于<b class='flag-5'>LockAI</b><b class='flag-5'>視覺</b><b class='flag-5'>識別</b><b class='flag-5'>模塊</b>:<b class='flag-5'>C++</b><b class='flag-5'>圖像</b>采集例程

    基于LockAI視覺識別模塊C++圖像的基本運算

    圖像處理中,理解圖像的基本操作是掌握計算機視覺技術的關鍵。本文章將介紹基于LockAI視覺識別
    的頭像 發表于 05-06 16:20 ?46次閱讀
    基于<b class='flag-5'>LockAI</b><b class='flag-5'>視覺</b><b class='flag-5'>識別</b><b class='flag-5'>模塊</b>:<b class='flag-5'>C++</b><b class='flag-5'>圖像</b>的基本運算
    主站蜘蛛池模板: 欧美人成绝费网站色www吃脚 | 秋霞一级特黄真人毛片 | 日日噜噜夜夜狠狠久久aⅴ 日日噜噜夜夜狠狠久久丁香 | 字幕网中文aⅴ资源站 | 四虎影视最新地址 | 99视频精品全国免费 | 亚洲综合色婷婷 | 欧美性猛交xxxx免费 | 国产高清在线免费 | 久久福利青草精品资源 | 4438x成人全国最大 | 性做久久久久 | 久久99热久久精品动漫 | 亚洲欧美人成网站综合在线 | jinv在线视频 | 97天天摸天天碰天天爽 | 色无五月 | 羞羞漫画喷水漫画yy漫画 | 女同性进行性行为视频 | 亚洲伊人成人网 | freesex性woman欧美 | 国产高清免费午夜在线视频 | 日本免费黄色小视频 | 四虎在线免费播放 | 亚洲video| 色噜噜噜噜 | 三级视频在线播放线观看 | 色综合久久中文字幕网 | 黄字幕网 | 欧美69xx性欧美 | 亚洲人成电影在线播放 | 日韩欧美在线中文字幕 | 成人免费看黄网站无遮挡 | 免费大片黄日本在线观看 | 白嫩美女一级高清毛片免费看 | 色噜噜狠狠网站 | 中文天堂在线www | zsvdy午夜片 爱爱456高清国语在线456 | 国产三级在线观看视频 | 免费国产一区 | 88影视在线观看污污 |