2013-08-07 105 views
3

我定義了2個值的數組,並嘗試使用imgproc模塊的調整大小函數將其作爲插值方法使用線性插值重新調整爲10個元素。使用OpenCV插值1維陣列

cv::Mat input = cv::Mat(1, 2, CV_32F); 
input.at<float>(0, 0) = 0.f; 
input.at<float>(0, 1) = 1.f; 
cv::Mat output = cv::Mat(1, 11, CV_32F); 
cv::resize(input, output, output.size(), 0, 0, cv::INTER_LINEAR); 
for(int i=0; i<11; ++i) 
{ 
    std::cout<< output.at<float>(0, i) << " "; 
} 

我本來期望的輸出是:

0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0 

我所得到的卻是:

0 0 0 0.136364 0.318182 0.5 0.681818 0.863636 1 1 1 

顯然,我如何調整工作的理解是錯誤在最基本的層面。有人可以告訴我我做錯了什麼嗎?無可否認,OpenCV對於這種簡單的線性插值來說是一種矯枉過正,但請幫我解決這裏出現的問題。

回答

1

這很簡單。 OpenCV是一個圖像處理庫。所以你應該記住我們正在處理圖像。

看看輸出的時候,我們有目的地形象

0 0 0.125 0.375 0.625 0.875 11

只有8個象素如果你看看這個圖像是非常簡單易懂調整行爲

Example

正如你在這個link看到您使用的圖片轉換庫:「的功能在每本節形成二維圖像」的各種幾何變換

你想這導致

enter image description here

,但它不會正確插值原來的2個像素的圖像

+0

要麼你已經重申我的問題與圖像或儘管有你的解釋,恐怕我沒有發現直接理解的行爲。問題是:爲什麼不是結果(在你的情況下):[0 0.167 0.334 0.501 0.668 0.835 1]用於線性插值? – balajeerc

+0

因爲你必須考慮藍點作爲原始像素的中心。所以插值僅在兩個原始點之間起作用。新範圍只有一半將包含插值。你必須以像素來思考。 –

+0

我已經解釋了更多:) –