我跟他有同樣的問題:Scaling a matrix in OpenCV實施mat2gray OpenCV中與Python
我和他有同樣的問題,我有一個彩色的畫面,我用MATLAB讀取圖片:Input = imread('input1.jpg');
,和格式的圖像是612x612x3 UINT8,我打印5x5x1像素在畫面如下:Input(1:5,1:5,1)
201 201 201 201 201
201 201 201 201 201
202 202 202 202 202
203 203 203 203 203
204 204 204 204 204
通過使用mat2gray功能:rgb_out = mat2gray(Input);
,這些像素可以被轉化到這一點,他們都在範圍在0和1之間:rgb_out(1:5,1:5,1)
0.9684 0.9455 0.9266 0.9099 0.9047
0.9657 0.9542 0.9432 0.9354 0.9299
0.9642 0.9571 0.9502 0.9495 0.9456
0.9621 0.9609 0.9562 0.9532 0.9516
0.9673 0.9633 0.9597 0.9580 0.9575
所以,問題是我怎麼能在OpenCV中使用Python實現這一點,我想爲下面的代碼:
print(Input)
rgb_out = np.zeros(Input.shape, np.uint8)
cv2.normalize(Input,rgb_out,1,0,cv2.NORM_MINMAX)
print(rgb_out)
但第一次印刷是:
[[[205 207 201]
[205 207 201]
[205 207 201]
...,
[232 254 242]
[232 254 242]
[231 253 241]]...
和元素在rgb_out中不超過1或0.請幫忙,謝謝。
感謝了很多,它確實幫助我 – Chris
這是不正確的。你需要除以255,而不是標準化。規範化在這種情況下起作用的事實只是運氣,因爲原始圖像具有0和255的值。 – Miki
@Miki他希望模擬'mat2gray'在MATLAB中的行爲。 'mat2gray'不會被255分頻,而是會縮放輸入中的所有值,以使它們跨越0到1,而不管輸入的最大值如何。 – Suever