雙三次插值及優(yōu)化_第1頁(yè)
雙三次插值及優(yōu)化_第2頁(yè)
雙三次插值及優(yōu)化_第3頁(yè)
雙三次插值及優(yōu)化_第4頁(yè)
雙三次插值及優(yōu)化_第5頁(yè)
已閱讀5頁(yè),還剩7頁(yè)未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、數(shù)學(xué)模型對(duì)于一個(gè)目的像素,其坐標(biāo)通過反向變換得到的在原圖中的浮點(diǎn)坐標(biāo)為(i+u,j+v),其中i、j均為非負(fù)整數(shù),u、v為0,1)區(qū)間的浮點(diǎn)數(shù),雙三次插值考慮一個(gè)浮點(diǎn)坐標(biāo)(i+u,j+v)周圍的16個(gè)鄰點(diǎn),目的像素值f(i+u,j+v)可由如下插值公式得到:f(i+u,j+v)=A*B*CA=S(u+1)S(u+0)S(u-1)S(u-2)廠f(i-1,j-1)f(i-1,j+0)B=If(i+0,j-1)f(i+0,j+0)If(i+1,j-1)f(i+1,j+0)Lf(i+2,j-1)f(i+2,j+0)f(i-1,j+1)f(i-1,j+2)nf(i+0,j+1)f(i+0,j+2)If

2、(i+1,j+1)f(i+1,j+2)If(i+2,j+1)f(i+2,j+2)廠S(v+1)nC=IS(v+0)IIS(v-1)ILS(v-2)廠1-2*Abs(x)人2+Abs(x)人3,0v=Abs(x)v1S(x)=4-8*Abs(x)+5*Abs(x)A2-Abs(x)A3,1=Abs(x)=2S(x)是對(duì)Sin(x*Pi)/x的逼近(Pi是圓周率n),為插值核。計(jì)算流程獲取16個(gè)點(diǎn)的坐標(biāo)P1、P2P16由插值核計(jì)算公式S(x)分別計(jì)算出x、y方向的插值核向量Su、Sv進(jìn)行矩陣運(yùn)算,得到插值結(jié)果iTemp1=Su0*P1+Su1*P5+Su2*P9+Su3*P13iTemp2=Su0

3、*P2+Su1*P6+Su2*P10+Su3*P14iTemp3=Su0*P3+Su1*P7+Su2*P11+Su3*P15iTemp4=Su0*P4+Su1*P8+Su2*P12+Su3*P16iResult=Sv1*iTemp1+Sv2*iTemp2+Sv3*iTemp3+Sv4*iTemp4在得到插值結(jié)果圖后,我們發(fā)現(xiàn)圖像中有“毛刺”,因此對(duì)插值結(jié)果做了個(gè)后處理,即:設(shè)該點(diǎn)在原圖中的像素值為pSrc,若abs(iResult-pSrc)大于某閾值,我們認(rèn)為插值后的點(diǎn)可能污染原圖,因此用原像素值pSrc代替。3.算法優(yōu)化由于雙三次插值計(jì)算一個(gè)點(diǎn)的坐標(biāo)需要其周圍16個(gè)點(diǎn),更有多達(dá)20次的乘法

4、及15次的加法,計(jì)算量可以說是非常大,勢(shì)必要進(jìn)行優(yōu)化。我們選擇了Intel的SSE2優(yōu)化技術(shù),它只支持在P4及以上的機(jī)器。測(cè)試當(dāng)前CPU是否支持SSE2,可由CPUID指令得到,代碼為:BOOLg_bSSE2=FALSE;_asmmoveax,1;cpuid;testedx,0 x04000000;jzNotSupport;movg_bSSE2,1NotSupport:支持SSE2的CPU引入了8個(gè)128位的寄存器,這樣一個(gè)寄存器中就可以存放4個(gè)點(diǎn)(RGB),有利于并行計(jì)算。詳細(xì)代碼見Transform.cpp中函數(shù)Optimize_Bicubic。優(yōu)化中遇到的問題:圖像每個(gè)點(diǎn)由RGB通道組成

5、,由于1個(gè)SSE2寄存器有16個(gè)字節(jié),這樣讀入4個(gè)像素點(diǎn)后,要浪費(fèi)4個(gè)字節(jié),同時(shí)要花費(fèi)時(shí)間將數(shù)據(jù)對(duì)齊,即由BRGB|RGBR|GBRG|BRGB對(duì)齊成0RGB|0RGB|0RGB|0RGB;讀16字節(jié)數(shù)據(jù)到寄存器時(shí),由于圖像地址不能保證是16字節(jié)對(duì)齊,因此需用更多時(shí)鐘周期的MOVDQU指令(6個(gè)以上時(shí)鐘周期);如能使地址16字節(jié)對(duì)齊,則可用MOVDQA指令(1個(gè)時(shí)鐘周期);為了消除除法及浮點(diǎn)運(yùn)算,對(duì)權(quán)值放大256倍,這樣在計(jì)算插值核時(shí),必須用2Bytes來表示1個(gè)系數(shù),而圖像數(shù)據(jù)都是lByte,這樣在對(duì)齊做乘法時(shí),要浪費(fèi)一半的SSE2寄存器的空間,導(dǎo)致運(yùn)算時(shí)間變長(zhǎng);而若降低插值核的精度,使其在

6、1Byte表示范圍內(nèi)時(shí),運(yùn)算的精度又大為下降;對(duì)各指令的周期以及若干行指令是否能夠并行流水缺乏經(jīng)驗(yàn)和認(rèn)識(shí)。附:SSE2指令整理算術(shù)(Arithmetic)指令:ADDPD-PackedDouble-PrecisionFloating-PointAddSSE22個(gè)double對(duì)應(yīng)相加ADDPDxmm0,xmm1/m128SSEADDPS-PackedSingle-PrecisionFloating-PointAdd4個(gè)float對(duì)應(yīng)相加ADDPSxmm0,xmm1/m128ADDSD-ScalarDouble-PrecisionFloating-PointAdd1個(gè)double(低端)對(duì)應(yīng)相加S

7、SE2ADDSDxmm0,xmm1/m64ADDSS-ScalarSingle-PrecisionFloating-PointAddSSE1個(gè)float(低端)對(duì)應(yīng)相加ADDSSxmm0,xmm1/m32PADDB/PADDW/PADDD-PackedAddOpcodeInstructionDescriptionOFFC/rPADDBmm,mm/m64Addpackedbyteintegersfrommm/m64andmm.660FFC/rPADDBxmm1,xmm2/m128Addpackedbyteintegersfromxmm2/m128andxmm1.0FFD/rPADDWmm,mm/

8、m64Addpackedwordintegersfrommm/m64andmm.660FFD/rPADDWxmml,xmm2/ml28Addpackedwordintegersfromxmm2/m128andxmm1.0FFE/rPADDDmm,mm/m64Addpackeddoublewordintegersfrommm/m64andmm.660FFE/rPADDDxmm1,xmm2/m128Addpackeddoublewordintegersfromxmm2/m128andxmm1.PADDQ-PackedQuadwordAddOpcodeInstructionDescriptionOF

9、D4/rPADDQmml,mm2/m64Addquadwordintegermm2/m64tomm166OFD4hrPADDQxmm1,xmm2/m128Addpackedquadwordintegersxmm2/m128toxmm1PADDSB/PADDSW-PackedAddwithSaturationOpcodeInstructionDescription0FEC/rPADDSBmm,mm/m64Addpackedsignedbyteintegersfrommm/m64andmmandsaturatetheresults.660FEC/rPADDSBxmm1,xmm2/m128Addpa

10、ckedsignedbyteintegersfromxmm2/m128andxmm1saturatetheresults.0FED/rPADDSWmm,mm/m64Addpackedsignedwordintegersfrommm/m64andmmandsaturatetheresults.660FED/rPADDSWxmm1,xmm2/m128Addpackedsignedwordintegersfromxmm2/m128andxmm1andsaturatetheresults.PADDUSB/PADDUSW-PackedAddUnsignedwithSaturationOpcodeInst

11、ructionDescription0FDC/rPADDUSBmm,mm/m64Addpackedunsignedbyteintegersfrommm/m64andmmandsaturatetheresults.660FDC/rPADDUSBxmm1,xmm2/m128Addpackedunsignedbyteintegersfromxmm2/m128andxmm1saturatetheresults.0FDD/rPADDUSWmm,mm/m64Addpackedunsignedwordintegersfrommm/m64andmmandsaturatetheresults.660FDD/rP

12、ADDUSWxmm1,xmm2/m128Addpackedunsignedwordintegersfromxmm2/m128toxmm1andsaturatetheresults.PMADDWD-PackedMultiplyandAddOpcodeInstructionDescription0FF5/rPMADDWDmm,mm/m64Multiplythepackedwordsinmmbythepackedwordsinmm/m64.Addthe32-bitpairsofresultsandstoreinmmasdoublewordX7X6X5x+xjX2X1xoY7Y6Y5Y4Y3Y2Y1Y

13、OABX7-Y7|AB9:X1-Y1iABXO-YO)OOHOOHOOHOOHOOHOOHSUMfTBWP7.TBWP0)PSADBW-PackedSumofAbsoluteDifferencesOpcodeInstructionDescriptionOFF6/rPSADBWmm1,mm2/m64Absolutedifferenceofpackedunsignedbyteintegersfrommm2/m64andmm1;differencesarethensummedtoproduceanunsignedwordintegerresult.66OFF6/rPSADBWxmml,xmm2/ml

14、28Absolutedifferenceofpackedunsignedbyteintegersfromxmm2/m128andxmm1;the8lowdifferencesand8highdifferencesarethensummedseparatelytoproducetwowordintegerresults.PSUBB/PSUBW/PSUBD-PackedSubtractOpcodeInstructionDescription0FF8/rPSUBBmm,mm/m64Subtractpackedbyteintegersinmm/m64frompackedbyteintegersinmm

15、.660FF8/rPSUBBxmm1,xmm2/m128Subtractpackedbyteintegersinxmm2/m128frompackedbyteintegersinxmm1.0FF9/rPSUBWmm,Subtractpackedwordintegersinmm/m64frommm/m64packedwordintegersinmm.66OFF9hrPSUBWxmml,xmm2/ml28Subtractpackedwordintegersinxmm2/m128frompackedwordintegersinxmm1.OFFA/rPSUBDmm,mm/m64Subtractpack

16、eddoublewordintegersinmm/m64frompackeddoublewordintegersinmm.66OFFAhrPSUBDxmml,xmm2/m128Subtractpackeddoublewordintegersinxmm2/mem128frompackeddoublewordintegersinxmm1.PSUBQ-PackedSubtractQuadwordOpcodeInstructionDescription0FFB/rPSUBQmm1,mm2/m64Subtractquadwordintegerinmm1frommm2/m64.660FFB/rPSUBQx

17、mm1,xmm2/m128Subtractpackedquadwordintegersinxmm1fromxmm2/m128.PSUBSB/PSUBSW-PackedSubtractwithSaturationOpcodeInstructionDescription0FE8/rPSUBSBmm,mm/m64Subtractsignedpackedbytesinmm/m64fromsignedpackedbytesinmmandsaturateresults.660FE8/rPSUBSBxmm1,xmm2/m128Subtractpackedsignedbyteintegersinxmm2/m1

18、28frompackedsignedbyteintegersinxmm1andsaturateresults.0FE9/rPSUBSWmm,mm/m64Subtractsignedpackedwordsinmm/m64fromsignedpackedwordsinmmandsaturateresults.660FE9/rPSUBSWxmm1,xmm2/m128Subtractpackedsignedwordintegersinxmm2/m128frompackedsignedwordintegersinxmm1andsaturateresults.PSUBUSB/PSUBUSW-PackedS

19、ubtractUnsignedwithSaturationOpcodeInstructionDescription0FD8/rPSUBUSBmm,mm/m64Subtractunsignedpackedbytesinmm/m64fromunsignedpackedbytesinmmandsaturateresult.660FPSUBUSBxmm1,SubtractpackedunsignedbyteintegersinD8/rxmm2/ml28xmm2/m128frompackedunsignedbyteintegersinxmmlandsaturateresult.OFD9/rPSUBUSW

20、mm,mm/m64Subtractunsignedpackedwordsinmm/m64fromunsignedpackedwordsinmmandsaturateresult.66OFD9/rPSUBUSWxmml,xmm2/m128Subtractpackedunsignedwordintegersinxmm2/m128frompackedunsignedwordintegersinxmm1andsaturateresult.SUBPD-PackedDouble-PrecisionFloating-PointSubtractOpcodeInstructionDescription660F5

21、C/rSUBPDxmm1,xmm2/m128Subtractpackeddouble-precisionfloating-pointvaluesinxmm2/m128fromxmm1.SUBPS-PackedSingle-PrecisionFloating-PointSubtractOpcodeInstructionDescription0F5C/rSUBPSxmm1xmm2/m128Subtractpackedsingle-precisionfloating-pointvaluesinxmm2/memfromxmm1.SUBSD-ScalarDouble-PrecisionFloating-

22、PointSubtractOpcodeInstructionDescriptionF20F5C/rSUBSDxmm1,xmm2/m64Subtractsthelowdouble-precisionfloating-pointnumbersinxmm2/mem64fromxmm1.SUBSS-ScalarSingle-FPSubtractOpcodeInstructionDescriptionF0F5CSUBSSxmm1,xmm2/m32Subtractthelowersingle-precisionfloating-pointnumbersinxmm2/m32fromxmm1.PMULHUW-

23、PackedMultiplyHighUnsignedOpcodeInstructionDescription0FE4/rPMULHUWmm1,Multiplythepackedunsignedwordintegersinmm1mm2/m64registerandmm2/m64,andstorethehigh16bitsoftheresultsinmm1.66OFE4/rPMULHUWxmml,xmm2/ml28Multiplythepackedunsignedwordintegersinxmm1andxmm2/m128,andstorethehigh16bitsoftheresultsinxm

24、m1.SRCX3X2X1XODESTY3Y2Y1YO73nY3Z2=X2tY2Z1=X1*Y1ZO=XO*YODEST23(31陰Zq3l-1GZl31-16Zq31-16PMULHW-PackedMultiplyHighSignedOpcodeInstructionDescription0FE5/rPMULHWmm,mm/m64Multiplythepackedsignedwordintegersinmm1registerandmm2/m64,andstorethehigh16bitsoftheresultsinmm1.660FE5/rPMULHWxmm1,xmm2/m128Multiply

25、thepackedsignedwordintegersinxmm1andxmm2/m128,andstorethehigh16bitsoftheresultsinxmm1.PMULLW-PackedMultiplyLowSignedOpcode0FD5/rInstructionDescriptionPMULLWmm,mm/m64Multiplythepackedsignedwordintegersinmm1registerandmm2/m64,andstorethelow16bitsoftheresultsinmm1.660FD5/rPMULLWxmm1,xmm2/m128Multiplythepackedsignedwordintegersinxmm1andxmm2/m128,andstorethelow16bitsoftheresultsinxmm1.PMULUDQ-MultiplyDoublewordUnsignedOpcodeInstructionDescription0FF4/rPMULUDQmm1,Multiplyunsigneddoublewordintegerinmm1bymm2/m64unsigneddoublewordintegerinmm2/m64,andstorethequadwordresultinmm1.66OFF4/

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論