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

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

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

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

基于LockAI視覺識別模塊:C++圖像的基本運(yùn)算

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

掃碼添加小助手

加入工程師交流群

在圖像處理中,理解圖像的基本操作是掌握計算機(jī)視覺技術(shù)的關(guān)鍵。本文章將介紹 基于LockAI視覺識別模塊下OpenCV 中圖像的基本運(yùn)算方法,包括像素操作、邏輯運(yùn)算和差值運(yùn)算,并通過一個綜合示例展示其實(shí)際應(yīng)用。

1. 基本知識講解

1.1 圖像坐標(biāo)系

在圖像處理中,坐標(biāo)是一個非常重要的概念:

原點(diǎn):圖像的左上角為原點(diǎn) (0, 0)。

x 軸:從左到右遞增。

y 軸:從上到下遞增。

1.2 圖像的基本屬性

每張圖像都有以下基本屬性:

寬度(Width):圖像的列數(shù)。

高度(Height):圖像的行數(shù)。

通道數(shù)(Channels):

灰度圖:1 個通道。

彩色圖:通常為 3 個通道(BGR)。

1.3 圖像的基本操作

圖像的基本操作包括:

獲取和設(shè)置像素值:訪問和修改圖像中的像素值。

邏輯運(yùn)算:如按位與、或、異或等。

差值運(yùn)算:計算兩張圖像之間的差異。


2.API文檔

2.1 頭文件

#include

2.2 獲取設(shè)置像素點(diǎn)

ucharcv::at<uchar>(introw,intcol)const;// 灰度圖
cv::Vec3bcv::at<cv::Vec3b>(introw,intcol)const;// 彩色圖

參數(shù):

row:行索引(y坐標(biāo))

col:列索引(x坐標(biāo))

返回值:

對于灰度圖,返回單通道值(unchar)

對于彩色圖,返回三通道值(cv::Vec3b)

2.3 設(shè)置像素點(diǎn):

voidcv::at<uchar>(introw,intcol)=value;// 灰度圖
voidcv::at<cv::Vec3b>(introw,intcol)=value;// 彩色圖

參數(shù):

row:行索引(y坐標(biāo))

col:列索引(x坐標(biāo))

value:要設(shè)置的像素值(uchar或cv::Vec3b)

2.4 獲取圖像的寬度和高度

2.4.1 獲取寬度

intcv::cols;

返回值

返回圖像的寬度(列數(shù))

2.4.2 獲取高度

intcv::rows;

返回值

返回圖像的高度(行數(shù))

2.5 獲取圖像的格式和大小

2.5.1 判斷是否為灰度圖

intcv::channels();

返回值

1表示灰度圖

3表示彩色圖

2.5.2 獲取圖像大?。ㄗ止?jié)數(shù))

size_tcv::total();// 總像素數(shù)
size_tcv::elemSize();// 每個像素的字節(jié)數(shù)
size_ttotalBytes=img.total()*img.elemSize();//計算公式

返回值

返回圖像的總字節(jié)數(shù)

2.6 圖像取反

voidcv::bitwise_not(InputArraysrc,OutputArraydst);

參數(shù):

src:輸入圖像(cv::Mat)

dst:輸出圖像(cv::Mat)

返回值:

結(jié)果儲存在dst中

2.7 圖像邏輯運(yùn)算

2.7.1 按位與(AND)

voidcv::bitwise_and(InputArraysrc1,InputArraysrc2,OutputArraydst);

-參數(shù):

src1:輸入圖像1(cv::Mat)

src2:輸入圖像2(cv::Mat)

dst:輸出圖像(cv::Mat)

返回值:

結(jié)果儲存在dst中

2.7.2 按位或(OR)

voidcv::bitwise_or(InputArraysrc1,InputArraysrc2,OutputArraydst);

參數(shù):

src1:輸入圖像1(cv::Mat)

src2:輸入圖像2(cv::Mat)

dst:輸出圖像(cv::Mat)

返回值:

結(jié)果儲存在dst中

2.7.3 按位異或(XOR)

voidcv::bitwise_xor(InputArraysrc1,InputArraysrc2,OutputArraydst);

參數(shù):

src1:輸入圖像1(cv::Mat)

src2:輸入圖像2(cv::Mat)

dst:輸出圖像(cv::Mat)

返回值:

結(jié)果儲存在dst中

2.7.4 按位取反(NOT)

voidcv::bitwise_not(InputArraysrc,OutputArraydst);

參數(shù):

src:輸入圖像(cv::Mat)

dst:輸出圖像(cv::Mat)

返回值:

結(jié)果儲存在dst中

2.7.5 復(fù)雜的圖像邏輯運(yùn)算

如果需要實(shí)現(xiàn)復(fù)雜的邏輯運(yùn)算(如NAND、NOR、NXOR等),可以通過組合上述基本函數(shù)來完成。例如:**NAND 與非運(yùn)算

cv::MatnandResult;
cv::bitwise_and(img1,img2,nandResult);// 計算 AND
cv::bitwise_not(nandResult,nandResult);// 取反得到 NAND

通過這樣的組合我們就可以實(shí)現(xiàn)更為復(fù)雜的邏輯運(yùn)算了。

2.8 絕對差值

voidcv::absdiff(InputArraysrc1,InputArraysrc2,OutputArraydst);

參數(shù):

src1:輸入圖像1(cv::Mat)

src2:輸入圖像2(cv::Mat)

dst:輸出圖像(cv::Mat)

返回值:

結(jié)果儲存在dst中


3.綜合代碼解析

3.1 流程圖

063be050-2a53-11f0-9434-92fbcf53809c.png

3.2 代碼解析

像素操作

// 從(10,10)開始,寬40,高40,設(shè)置為藍(lán)色
cv::Rectroi(10,10,40,40);
image1(roi).setTo(cv::Scalar(255,0,0));

圖像變換

// 圖像取反
cv::MatinvertedImage;
cv::bitwise_not(image1,invertedImage);
// 圖像差分
cv::MatdiffImage;
cv::absdiff(image1,image2,diffImage);

顯示結(jié)果

// 顯示結(jié)果
cv::imshow("Original Image",image1);
cv::imshow("Inverted Image",invertedImage);
cv::imshow("Difference Image",diffImage);

3.3 代碼實(shí)現(xiàn)

#include
#include
#include

intmain(intargc,char*argv[])
{
// 檢查命令行參數(shù)數(shù)量是否正確
if(argc!=3)
{
std::cerr<<"Usage: "<<argv[0]<<" "<<std::endl;
return-1;
}

// 從命令行參數(shù)中讀取圖像路徑
std::stringimage1Path=argv[1];
std::stringimage2Path=argv[2];

// 加載圖像
cv::Matimage1=cv::imread(image1Path);
cv::Matimage2=cv::imread(image2Path);

// 檢查圖像是否加載成功
if(image1.empty()||image2.empty())
{
std::cerr<<"Error: Could not load images!"<<std::endl;
return-1;
}

// 獲取圖像尺寸
intwidth=image1.cols;
intheight=image1.rows;
std::cout<<"Image size: "<<width<<"x"<<height<<std::endl;

// 從(10,10)開始,寬40,高40,設(shè)置為藍(lán)色
cv::Rectroi(10,10,40,40);
image1(roi).setTo(cv::Scalar(255,0,0));

// 圖像取反
cv::MatinvertedImage;
cv::bitwise_not(image1,invertedImage);

// 圖像差分
cv::MatdiffImage;
cv::absdiff(image1,image2,diffImage);

// 顯示結(jié)果
cv::imshow("Original Image",image1);
cv::imshow("Inverted Image",invertedImage);
cv::imshow("Difference Image",diffImage);

cv::waitKey(0);
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-basic-method)

set(CMAKE_CXX_STANDARD17)
set(CMAKE_CXX_STANDARD_REQUIRED ON)

# 定義項(xiàng)目根目錄路徑
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-basic-method basic_method.cc)
target_include_directories(Test-basic-method PRIVATE${LOCKZHINER_VISION_MODULE_INCLUDE_DIRS})
target_link_libraries(Test-basic-method PRIVATE${OPENCV_LIBRARIES}${LOCKZHINER_VISION_MODULE_LIBRARIES})

install(
TARGETS Test-basic-method
RUNTIME DESTINATION .
)

4.3 編譯項(xiàng)目

使用 Docker Destop 打開 LockzhinerVisionModule 容器并執(zhí)行以下命令來編譯項(xiàng)目

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

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


5. 例程運(yùn)行示例

5.1 運(yùn)行過程

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

chmod777Test-basic-method
# 需要輸入兩張大小一樣的圖片
./Test-basic-method image1_path image2_path

5.2 運(yùn)行結(jié)果

原始圖像左上角加上一個40*40的矩形藍(lán)像素點(diǎn)

圖像差分結(jié)果:

0702f17c-2a53-11f0-9434-92fbcf53809c.png


6.總結(jié)

通過上述內(nèi)容,我們介紹了圖像的基本操作及其對應(yīng)的 OpenCV API。按照以下步驟,您可以輕松地進(jìn)行圖像的基本運(yùn)算:

獲取和設(shè)置像素值:使用 cv::at 方法訪問和修改像素。

邏輯運(yùn)算:使用 cv::bitwise_and、cv::bitwise_or 等函數(shù)實(shí)現(xiàn)邏輯運(yùn)算。

差值運(yùn)算:使用 cv::absdiff 計算圖像之間的差異。

復(fù)雜運(yùn)算:通過組合基本函數(shù)實(shí)現(xiàn)更復(fù)雜的邏輯運(yùn)算。

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

    關(guān)注

    3

    文章

    110

    瀏覽量

    17300
  • AI視覺
    +關(guān)注

    關(guān)注

    0

    文章

    103

    瀏覽量

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

掃碼添加小助手

加入工程師交流群

    評論

    相關(guān)推薦
    熱點(diǎn)推薦

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

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

    基于LockAI視覺識別模塊C++圖像的基本運(yùn)算

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

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

    圖像處理中,統(tǒng)計信息可以幫助我們了解圖像的特性,例如區(qū)域內(nèi)的像素分布、顏色轉(zhuǎn)換以及特定區(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的LockAI
    發(fā)表于 05-27 10:26

    基于LockAI視覺識別模塊C++目標(biāo)檢測

    本文檔基于瑞芯微RV1106的LockAI凌智視覺識別模塊,通過C++語言做的目標(biāo)檢測實(shí)驗(yàn)。 本文檔展示了如何使用 lockzhiner_v
    發(fā)表于 06-06 14:43

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

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

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

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

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

    本文主要演示如何使用LockAI視覺識別模塊進(jìn)行視頻流的讀取,同時使用Edit模塊進(jìn)行圖像傳輸。
    的頭像 發(fā)表于 04-30 18:23 ?534次閱讀
    基于<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)計信息

    圖像處理中,統(tǒng)計信息可以幫助我們了解圖像的特性,例如區(qū)域內(nèi)的像素分布、顏色轉(zhuǎn)換以及特定區(qū)域的分析。本文將介紹基于LockAI視覺識別
    的頭像 發(fā)表于 05-08 10:09 ?536次閱讀
    基于<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>的統(tǒng)計信息

    基于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的LockAI
    的頭像 發(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++目標(biāo)檢測

    本文檔基于瑞芯微RV1106的LockAI凌智視覺識別模塊,通過C++語言做的目標(biāo)檢測實(shí)驗(yàn)。本文檔展示了如何使用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>目標(biāo)檢測

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

    手寫數(shù)字識別是一種經(jīng)典的模式識別圖像處理問題,旨在通過計算機(jī)自動識別用戶手寫的數(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模型訓(xùn)練的人臉檢測模型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>