欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

OpenCV reshape函數(shù)實現(xiàn)矩陣元素序列化

 更新時間:2021年12月03日 14:47:09   作者:徐其華  
reshape函數(shù)是OpenCV中一個很有用的函數(shù),不僅可以改變矩陣的通道數(shù),還可以對矩陣元素進(jìn)行序列化。本文將主要介紹如何通過reshape實現(xiàn)矩陣元素序列化,需要的小伙伴可以參考一下

在opencv中,reshape函數(shù)比較有意思,它既可以改變矩陣的通道數(shù),又可以對矩陣元素進(jìn)行序列化,非常有用的一個函數(shù)。

函數(shù)原型:

C++: Mat Mat::reshape(int cn, int rows=0) const

參數(shù)比較少,但設(shè)置的時候卻要千萬小心。

cn: 表示通道數(shù)(channels), 如果設(shè)為0,則表示保持通道數(shù)不變,否則則變?yōu)樵O(shè)置的通道數(shù)。

rows: 表示矩陣行數(shù)。 如果設(shè)為0,則表示保持原有的行數(shù)不變,否則則變?yōu)樵O(shè)置的行數(shù)。

首先設(shè)置一個初始矩陣:一個20行30列1通道的一個矩陣

int main()
{
    Mat data = Mat(20, 30, CV_32F);  //設(shè)置一個20行30列1通道的一個矩陣
    cout << "行數(shù): " << data.rows << endl;
    cout << "列數(shù): " << data.cols << endl;
    cout << "通道: " << data.channels() << endl;
    system("pause");
    return 1;
}

輸出:

第一次變化:通道數(shù)不變,將矩陣序列化1行N列的行向量。

int main()
{
    Mat data = Mat(20, 30, CV_32F);  //設(shè)置一個20行30列1通道的一個矩陣
    cout << "行數(shù): " << data.rows << endl;
    cout << "列數(shù): " << data.cols << endl;
    cout << "通道: " << data.channels() << endl;
    cout << endl;
    Mat dst = data.reshape(0, 1);
    cout << "行數(shù): " << dst.rows << endl;
    cout << "列數(shù): " << dst.cols << endl;
    cout << "通道: " << dst.channels() << endl;
    system("pause");
    return 1;
}

第二次變化:通道數(shù)不變,將矩陣序列化N行1列的列向量。

int main()
{
    Mat data = Mat(20, 30, CV_32F);  //設(shè)置一個20行30列1通道的一個矩陣
    cout << "行數(shù): " << data.rows << endl;
    cout << "列數(shù): " << data.cols << endl;
    cout << "通道: " << data.channels() << endl;
    cout << endl;
    Mat dst = data.reshape(0, data.rows*data.cols);
    cout << "行數(shù): " << dst.rows << endl;
    cout << "列數(shù): " << dst.cols << endl;
    cout << "通道: " << dst.channels() << endl;
    system("pause");
    return 1;
}

可見,序列成列向量比行向量要麻煩一些,還得去計算出需要多少行。但我們可以先序列成行向量,再轉(zhuǎn)置

Mat dst = data.reshape(0, 1);      //序列成行向量
Mat dst = data.reshape(0, 1).t();  //序列成列向量

第三次變化:通道數(shù)由1變?yōu)?,行數(shù)不變。

int main()
{
    Mat data = Mat(20, 30, CV_32F);  //設(shè)置一個20行30列1通道的一個矩陣
    cout << "行數(shù): " << data.rows << endl;
    cout << "列數(shù): " << data.cols << endl;
    cout << "通道: " << data.channels() << endl;
    cout << endl;
    Mat dst = data.reshape(2, 0);
    cout << "行數(shù): " << dst.rows << endl;
    cout << "列數(shù): " << dst.cols << endl;
    cout << "通道: " << dst.channels() << endl;
    system("pause");
    return 1;
}

從結(jié)果可以看出,列數(shù)被分出一半,放在第二個通道里去了。

同理,如果通道數(shù)由1變?yōu)?,行數(shù)不變。則每通道的列數(shù)變?yōu)樵瓉淼娜种弧?/p>

需要注意的是,如果行保持不變,改變的通道數(shù)一定要能被列數(shù)整除,否則會出錯。

第四次變化:通道數(shù)由1變?yōu)?,行數(shù)變?yōu)樵瓉淼奈宸种弧?/span>

int main()
{
    Mat data = Mat(20, 30, CV_32F);  //設(shè)置一個20行30列1通道的一個矩陣
    cout << "行數(shù): " << data.rows << endl;
    cout << "列數(shù): " << data.cols << endl;
    cout << "通道: " << data.channels() << endl;
    cout << endl;
    Mat dst = data.reshape(2, data.rows/5);
    cout << "行數(shù): " << dst.rows << endl;
    cout << "列數(shù): " << dst.cols << endl;
    cout << "通道: " << dst.channels() << endl;
    system("pause");
    return 1;
}

可見,不管怎么變,都遵循這樣一個等式:

變化之前的? rows*cols*channels = 變化之后的 rows*cols*channels

我們只能改變通道數(shù)和行數(shù),列數(shù)不能改變,它是自動變化的。

但是要注意的是,在變化的時候,要考慮到是否整除的情況。如果改變的數(shù)值出現(xiàn)不能整除,就會報錯。

最后,我們再驗證一下:opencv在序列化的時候是行序列化還是列序列化呢?

我們知道,在matlab里面,是列序列化, 即取值為從上到下,從左到右,opencv又是怎么樣的呢

int main()
{
    Mat data = (Mat_<int>(2, 3) << 1, 2, 3, 10, 20, 30);  //2行3列的矩陣
    cout << data << endl;
    Mat dst1 = data.reshape(0, 6);   //通道不變,序列成列向量
    cout <<endl<< dst1 << endl;
    Mat dst2 = data.reshape(0, 1);   //通道不變,序列成行向量
    cout << endl << dst2 << endl;
    system("pause");
    return 1;
}

從結(jié)果看出,不管是變化成行向量還是列向量,opencv都是行序列化,即從左到右,從上到下,與matlab是不一樣的。

簡單的一個函數(shù),功能卻很強大!你會用了嗎?

到此這篇關(guān)于OpenCV reshape函數(shù)實現(xiàn)矩陣元素序列化的文章就介紹到這了,更多相關(guān)OpenCV reshape的內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • c語言中十六進(jìn)制轉(zhuǎn)二進(jìn)制顯示的實現(xiàn)方法

    c語言中十六進(jìn)制轉(zhuǎn)二進(jìn)制顯示的實現(xiàn)方法

    本篇文章對c語言中十六進(jìn)制轉(zhuǎn)二進(jìn)制顯示的實現(xiàn)方法進(jìn)行了詳細(xì)的分析介紹,需要的朋友參考下
    2013-05-05
  • C++中std::deque的使用

    C++中std::deque的使用

    std::deque是C++標(biāo)準(zhǔn)庫中的一個雙端隊列容器,本文主要介紹了C++中std::deque的使用,具有一定的參考價值,感興趣的可以了解一下
    2024-03-03
  • 常用的STL查找算法

    常用的STL查找算法

    這篇文章主要介紹了常用的STL查找算法的相關(guān)資料,十分的詳細(xì),需要的朋友可以參考下
    2015-07-07
  • c++標(biāo)準(zhǔn)輸入輸出流關(guān)系的前世今生

    c++標(biāo)準(zhǔn)輸入輸出流關(guān)系的前世今生

    這篇文章主要給大家介紹了關(guān)于c++標(biāo)準(zhǔn)輸入輸出流關(guān)系的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-04-04
  • 使用c語言判斷100以內(nèi)素數(shù)的示例(c語言求素數(shù))

    使用c語言判斷100以內(nèi)素數(shù)的示例(c語言求素數(shù))

    這篇文章主要介紹了使用c語言判斷100以內(nèi)素數(shù)的示例(c語言求素數(shù)),需要的朋友可以參考下
    2014-03-03
  • c++查詢最短路徑示例

    c++查詢最短路徑示例

    這篇文章主要介紹了c++查詢最短路徑示例,需要的朋友可以參考下
    2014-05-05
  • C語言之實現(xiàn)輾轉(zhuǎn)相除法的兩種方式

    C語言之實現(xiàn)輾轉(zhuǎn)相除法的兩種方式

    這篇文章主要介紹了C語言之實現(xiàn)輾轉(zhuǎn)相除法的兩種方式,具有很好的參考價值,希望對大家有所幫助,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-08-08
  • C++游戲教程基本技巧之隨機化詳解

    C++游戲教程基本技巧之隨機化詳解

    在小游戲的制作中時常常會要用到隨機數(shù),這篇文章就來和大家談?wù)凜++中這個所謂的“隨機”。文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下
    2022-11-11
  • 最新C語言自定義類型詳解

    最新C語言自定義類型詳解

    生活當(dāng)中有很多物品是不能簡單的用整型、浮點型、字符型來區(qū)分,它們常常是復(fù)雜的集合,比如人,一個人擁有年齡,身高、體重、學(xué)歷......等信息,我們可以用結(jié)構(gòu)體來實現(xiàn)準(zhǔn)確描述人這種復(fù)雜集合,這篇文章主要介紹了C語言?自定義類型,需要的朋友可以參考下
    2023-01-01
  • C++執(zhí)行Linux Bash命令的方法

    C++執(zhí)行Linux Bash命令的方法

    今天小編就為大家分享一篇C++執(zhí)行Linux Bash命令的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07

最新評論