chinese直男口爆体育生外卖, 99久久er热在这里只有精品99, 又色又爽又黄18禁美女裸身无遮挡, gogogo高清免费观看日本电视,私密按摩师高清版在线,人妻视频毛茸茸,91论坛 兴趣闲谈,欧美 亚洲 精品 8区,国产精品久久久久精品免费

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

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

3天內(nèi)不再提示

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

福州市凌睿智捷電子有限公司 ? 2025-05-08 10:09 ? 次閱讀
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

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

1.基本知識講解

1.1 圖像的興趣區(qū)域(ROI)

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

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

1.2 顏色空間轉換

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

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

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

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

1.3 圖像統(tǒng)計信息

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

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


2.API文檔

2.1 頭文件

#include

2.2 提取興趣區(qū)域(ROI)

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

功能:

從圖像中提取一個矩形區(qū)域。

參數(shù):

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

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

(w, h):ROI的寬高。

返回值:

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

2.3 轉換為灰度圖

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

功能:

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

參數(shù):

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

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

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

返回值:

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


轉換方向轉換代碼描述
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);

功能:

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

參數(shù):

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

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

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

返回值:

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

2.5 計算最小值和最大值:

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

功能:

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

參數(shù):

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區(qū)域

// 定義 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 代碼實現(xiàn)

#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 編譯環(huán)境搭建

請確保你已經(jīng)按照開發(fā)環(huán)境搭建指南正確配置了開發(fā)環(huán)境。

同時以正確連接開發(fā)板。

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 容器并執(zhí)行以下命令來編譯項目

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

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


5. 例程運行示例

5.1 運行過程

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

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

5.2 運行效果

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

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

6. 總結

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

提取 ROI:使用 cv::Rect 提取感興趣區(qū)域。

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

計算統(tǒng)計信息:

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

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

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

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

    關注

    3

    文章

    110

    瀏覽量

    17300
  • AI視覺
    +關注

    關注

    0

    文章

    103

    瀏覽量

    4944
收藏 人收藏
加入交流群
微信小助手二維碼

掃碼添加小助手

加入工程師交流群

    評論

    相關推薦
    熱點推薦

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

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

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

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

    基于LockAI視覺識別模塊C++使用圖像統(tǒng)計信息

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

    基于LockAI視覺識別模塊C++二維碼識別

    二維碼識別視覺模塊經(jīng)常使用到的功能之一。我們將演示如何使用基于瑞芯微RV1106的LockAI視覺識別
    發(fā)表于 05-26 09:57

    基于LockAI視覺識別模塊C++條碼識別

    條碼識別視覺模塊經(jīng)常使用到的功能之一,經(jīng)常用于識別超市的貨物信息。本文我們將演示如何基于瑞芯微RV1106的
    發(fā)表于 05-27 10:26

    基于LockAI視覺識別模塊:手寫數(shù)字識別

    手寫數(shù)字識別是一種經(jīng)典的模式識別圖像處理問題,旨在通過計算機自動識別用戶手寫的數(shù)字。 本文將教會你如何使用基于RV1106的 LockAI
    發(fā)表于 06-30 16:45

    基于LockAI視覺識別模塊C++人臉識別

    本文基于RV1106做成的LockAI視覺識別模塊,采用 LZ-Picodet 模型訓練的人臉檢測模型 LZ-Face,以及ArcFace人臉識別
    發(fā)表于 07-01 12:01

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

    本文主要演示如何使用LockAI視覺識別模塊進行視頻流的讀取,同時使用Edit模塊進行圖像傳輸。
    的頭像 發(fā)表于 04-30 18:23 ?535次閱讀
    基于<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視覺識別
    的頭像 發(fā)表于 05-06 16:20 ?514次閱讀
    基于<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++尋找色塊

    在傳統(tǒng)計算機視覺場景中,顏色識別是目標檢測和分割的重要手段之一。通過識別特定顏色的色塊,可以在相對純凈的背景下快速定位目標區(qū)域。本實驗提供了一個簡單的色塊
    的頭像 發(fā)表于 05-12 14:27 ?477次閱讀
    # 基于<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>尋找色塊

    基于LockAI視覺識別模塊C++二維碼識別

    二維碼識別視覺模塊經(jīng)常使用到的功能之一。我們將演示如何使用基于瑞芯微RV1106的LockAI視覺識別
    的頭像 發(fā)表于 05-26 09:42 ?679次閱讀
    基于<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++條碼識別

    條碼識別視覺模塊經(jīng)常使用到的功能之一,經(jīng)常用于識別超市的貨物信息。本文我們將演示如何基于瑞芯微RV1106的
    的頭像 發(fā)表于 05-27 09:32 ?502次閱讀
    基于<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++目標檢測

    本文檔基于瑞芯微RV1106的LockAI凌智視覺識別模塊,通過C++語言做的目標檢測實驗。本文檔展示了如何使用lockzhiner_vis
    的頭像 發(fā)表于 06-06 13:56 ?592次閱讀
    基于<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>目標檢測

    基于LockAI視覺識別模塊:手寫數(shù)字識別

    手寫數(shù)字識別是一種經(jīng)典的模式識別圖像處理問題,旨在通過計算機自動識別用戶手寫的數(shù)字。本文將教會你如何使用基于RV1106的LockAI
    的頭像 發(fā)表于 06-30 15:44 ?840次閱讀
    基于<b class='flag-5'>LockAI</b><b class='flag-5'>視覺</b><b class='flag-5'>識別</b><b class='flag-5'>模塊</b>:手寫數(shù)字<b class='flag-5'>識別</b>

    基于LockAI視覺識別模塊C++人臉識別

    本文基于RV1106做成的LockAI視覺識別模塊,采用LZ-Picodet模型訓練的人臉檢測模型LZ-Face,以及ArcFace人臉識別
    的頭像 發(fā)表于 07-01 10:09 ?491次閱讀
    基于<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>