日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python双线性插值函数_双线性插值法原理 python实现

發布時間:2025/3/11 python 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python双线性插值函数_双线性插值法原理 python实现 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

碼字不易,如果此文對你有所幫助,請幫忙點贊,感謝!

一. 雙線性插值法原理:

① 何為線性插值?

插值就是在兩個數之間插入一個數,線性插值原理圖如下:

在位置 x 進行線性插值,插入的值為f(x) ↑

② 各種插值法:

插值法的第一步都是相同的,計算目標圖(dstImage)的坐標點對應原圖(srcImage)中哪個坐標點來填充,計算公式為:

srcX = dstX * (srcWidth/dstWidth)

srcY = dstY * (srcHeight/dstHeight)

(dstX,dstY)表示目標圖像的某個坐標點,(srcX,srcY)表示與之對應的原圖像的坐標點。srcWidth/dstWidth 和 srcHeight/dstHeight 分別表示寬和高的放縮比。

那么問題來了,通過這個公式算出來的 srcX, scrY 有可能是小數,但是原圖像坐標點是不存在小數的,都是整數,得想辦法把它轉換成整數才行。

不同插值法的區別就體現在 srcX, scrY 是小數時,怎么將其變成整數去取原圖像中的像素值。

最近鄰插值(Nearest-neighborInterpolation):看名字就很直白,四舍五入選取最接近的整數。這樣的做法會導致像素變化不連續,在目標圖像中產生鋸齒邊緣。

雙線性插值(Bilinear Interpolation):雙線性就是利用與坐標軸平行的兩條直線去把小數坐標分解到相鄰的四個整數坐標點。權重與距離成反比。

雙三次插值(Bicubic Interpolation):與雙線性插值類似,只不過用了相鄰的16個點。但是需要注意的是,前面兩種方法能保證兩個方向的坐標權重和為1,但是雙三次插值不能保證這點,所以可能出現像素值越界的情況,需要截斷。

③ 雙線性插值算法原理

雙線性插值算法原理圖,將P的小數坐標變成 Q11、Q12、Q21、Q22 4個整數坐標內容的加權和 ↑

假如我們想得到未知函數 f 在點 P = (x, y) 的值,假設我們已知函數 f 在 Q11 = (x1, y1)、Q12 = (x1, y2), Q21 = (x2, y1) 以及 Q22 = (x2, y2) 四個點的值。最常見的情況,f就是一個像素點的像素值。首先在 x 方向進行線性插值,然后再在 y 方向上進行線性插值,最終得到雙線性插值的結果。

x 方向上線性插值算法 ↑

y 方向上線性插值算法 ↑

雙線性插值算法 ↑

④ 舉例說明

如果選擇一個坐標系統使得 f 的四個已知點坐標分別為 (0, 0)、(0, 1)、(1, 0) 和 (1, 1),那么雙線性插值公式就可以化簡為上式 ↑

矩陣表示為 ↑

可以看到,與這種插值方法名稱不同的是,這種插值方法的結果通常不是線性的,它的形式是? ↑

二. python實現灰度圖像雙線性插值算法:

灰度圖像雙線性插值放大縮小

import numpy as np

import math

import cv2

def double_linear(input_signal, zoom_multiples):

'''

雙線性插值

:param input_signal: 輸入圖像

:param zoom_multiples: 放大倍數

:return: 雙線性插值后的圖像

'''

input_signal_cp = np.copy(input_signal)? # 輸入圖像的副本

input_row, input_col = input_signal_cp.shape # 輸入圖像的尺寸(行、列)

# 輸出圖像的尺寸

output_row = int(input_row * zoom_multiples)

output_col = int(input_col * zoom_multiples)

output_signal = np.zeros((output_row, output_col)) # 輸出圖片

for i in range(output_row):

for j in range(output_col):

# 輸出圖片中坐標 (i,j)對應至輸入圖片中的最近的四個點點(x1,y1)(x2, y2),(x3, y3),(x4,y4)的均值

temp_x = i / output_row * input_row

temp_y = j / output_col * input_col

x1 = int(temp_x)

y1 = int(temp_y)

x2 = x1

y2 = y1 + 1

x3 = x1 + 1

y3 = y1

x4 = x1 + 1

y4 = y1 + 1

u = temp_x - x1

v = temp_y - y1

# 防止越界

if x4 >= input_row:

x4 = input_row - 1

x2 = x4

x1 = x4 - 1

x3 = x4 - 1

if y4 >= input_col:

y4 = input_col - 1

y3 = y4

y1 = y4 - 1

y2 = y4 - 1

# 插值

output_signal[i, j] = (1-u)*(1-v)*int(input_signal_cp[x1, y1]) + (1-u)*v*int(input_signal_cp[x2, y2]) + u*(1-v)*int(input_signal_cp[x3, y3]) + u*v*int(input_signal_cp[x4, y4])

return output_signal

# Read image

img = cv2.imread("../paojie_g.jpg",0).astype(np.float)

out = double_linear(img,2).astype(np.uint8)

# Save result

cv2.imshow("result", out)

cv2.imwrite("out.jpg", out)

cv2.waitKey(0)

cv2.destroyAllWindows()

三. 灰度圖像雙線性插值實驗結果:

原圖 ↑

放大2倍后圖像 ↑

四. 彩色圖像雙線性插值python實現

def BiLinear_interpolation(img,dstH,dstW):

scrH,scrW,_=img.shape

img=np.pad(img,((0,1),(0,1),(0,0)),'constant')

retimg=np.zeros((dstH,dstW,3),dtype=np.uint8)

for i in range(dstH-1):

for j in range(dstW-1):

scrx=(i+1)*(scrH/dstH)

scry=(j+1)*(scrW/dstW)

x=math.floor(scrx)

y=math.floor(scry)

u=scrx-x

v=scry-y

retimg[i,j]=(1-u)*(1-v)*img[x,y]+u*(1-v)*img[x+1,y]+(1-u)*v*img[x,y+1]+u*v*img[x+1,y+1]

return retimg

im_path='../paojie.jpg'

image=np.array(Image.open(im_path))

image2=BiLinear_interpolation(image,image.shape[0]*2,image.shape[1]*2)

image2=Image.fromarray(image2.astype('uint8')).convert('RGB')

image2.save('3.png')

五. 彩色圖像雙線性插值實驗結果:

原圖 ↑

RGB圖像雙線性插值放大2倍后圖像 ↑

六. 最近鄰插值算法和雙三次插值算法可參考:

七. 參考內容:

總結

以上是生活随笔為你收集整理的python双线性插值函数_双线性插值法原理 python实现的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。