python讀取圖像矩陣文件并轉(zhuǎn)換為向量實(shí)例
假設(shè)圖像矩陣大小為32×32,將其轉(zhuǎn)換為向量,首先創(chuàng)建1×1024的NumPy數(shù)組,然后打開給定的文件,循環(huán)讀出文件的前32行,并將每行的頭32個字符值存儲在NumPy數(shù)組中
import numpy as np def img2vector(filename): returnVect = np.zeros((1, 1024)) fr = open(filename) for i in range(32): lineStr = fr.readline() for j in range(32): returnVect[0, 32*i+j] = int(lineStr[j]) return returnVect
補(bǔ)充知識:旋轉(zhuǎn)向量和旋轉(zhuǎn)矩陣的互相轉(zhuǎn)換(python cv2.Rodrigues()函數(shù))
處理矩陣三維轉(zhuǎn)換時,通常采用旋轉(zhuǎn)矩陣,但是旋轉(zhuǎn)變換其實(shí)只有三個自由度,用旋轉(zhuǎn)向量表達(dá)時更為簡潔。因此,需要實(shí)現(xiàn)從旋轉(zhuǎn)向量和旋轉(zhuǎn)矩陣之間的互轉(zhuǎn)換。
旋轉(zhuǎn)向量和旋轉(zhuǎn)矩陣之間可以通過羅德里格斯公式進(jìn)行轉(zhuǎn)換:
代碼實(shí)現(xiàn):
可以直接采用opencv中的Rodrigues函數(shù)實(shí)現(xiàn),函數(shù)原型:
void Rodrigues( InputArray src, OutputArray dst, OutputArray jacobian = noArray() );
參數(shù):
輸入src:旋轉(zhuǎn)向量(3*1或者1*3)或者旋轉(zhuǎn)矩陣(3*3);
輸出dst:旋轉(zhuǎn)矩陣(3*3)或者旋轉(zhuǎn)向量(3*1或者1*3);
輸出jacobin:可選項(xiàng),輸出雅克比矩陣(3*9或者9*3),輸入數(shù)組對輸出數(shù)組的偏導(dǎo)數(shù)。
python代碼舉例:
# -*- coding: UTF-8 -*- import os import cv2 import numpy as np T = np.zeros((1,3), np.float32) a = (0.2,0.4,0.8) print (a) R = cv2.Rodrigues(a) print (R[0]) v3 = (R[0][2,1],R[0][0,2],R[0][1,0]) print (v3) c = cv2.Rodrigues(v3) print (c[0]) b = cv2.Rodrigues(R[0]) print (b[0]) p = (-2.100418,-2.167796,0.27330) print(cv2.Rodrigues(p)[0])
例子如下:
以上這篇python讀取圖像矩陣文件并轉(zhuǎn)換為向量實(shí)例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
解決安裝新版PyQt5、PyQT5-tool后打不開并Designer.exe提示no Qt platform plug
這篇文章主要介紹了解決安裝新版PyQt5、PyQT5-tool后打不開并Designer.exe提示no Qt platform plugin的問題,需要的朋友可以參考下2020-04-04pandas DataFrame索引行列的實(shí)現(xiàn)
這篇文章主要介紹了pandas DataFrame索引行列的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-06-06使用Python實(shí)現(xiàn)生成對角矩陣和對角塊矩陣
這篇文章主要為大家詳細(xì)介紹了如何使用Python實(shí)現(xiàn)生成對角矩陣和對角塊矩陣,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下2024-01-01Python+tkinter使用40行代碼實(shí)現(xiàn)計(jì)算器功能
這篇文章主要為大家詳細(xì)介紹了Python+tkinter使用40行代碼實(shí)現(xiàn)計(jì)算器功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-01-01Django Admin實(shí)現(xiàn)上傳圖片校驗(yàn)功能
這篇文章主要介紹了Django Admin實(shí)現(xiàn)上傳圖片校驗(yàn)功能的相關(guān)資料,需要的朋友可以參考下2016-03-03Python實(shí)現(xiàn)的基于優(yōu)先等級分配糖果問題算法示例
這篇文章主要介紹了Python實(shí)現(xiàn)的基于優(yōu)先等級分配糖果問題算法,涉及Python針對列表的遍歷、判斷、計(jì)算等相關(guān)操作技巧,需要的朋友可以參考下2018-04-04python把ipynb文件轉(zhuǎn)換成pdf文件過程詳解
這篇文章主要介紹了用python把ipynb文件轉(zhuǎn)換成pdf文件過程詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-07-07scrapy中的spider傳參實(shí)現(xiàn)增量的方法
有時候需要根據(jù)項(xiàng)目的實(shí)際需求向spider傳遞參數(shù)來控制spider的運(yùn)行方式,本文主要介紹了scrapy中的spider傳參實(shí)現(xiàn)增量的方法,具有一定的參考價值,感興趣的可以了解一下2022-06-06