下載本文檔
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、1.數(shù)學(xué)模型對于一個(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)f(i-1, j+1)f(i-1, j+2) B= f(i+0, j-1)f(i+0, j+0)f(i+0, j+1)f(i+0, j+2) f(i+1, j-1)f(i+1,
2、j+0)f(i+1, j+1)f(i+1, j+2) f(i+2, j-1)f(i+2, j+0)f(i+2, j+1)f(i+2, j+2) S(v + 1) C= S(v + 0) S(v - 1) S(v - 2) 1-2*Abs(x)2+Abs(x)3 , 0=Abs(x)1S(x)= 4-8*Abs(x)+5*Abs(x)2-Abs(x)3, 1=Abs(x)=2S(x)是對 Sin(x*Pi)/x 的逼近(Pi是圓周率),為插值核。2.計(jì)算流程1. 獲取16個(gè)點(diǎn)的坐標(biāo)P1、P2P162. 由插值核計(jì)算公式S(x) 分別計(jì)算出x、y方向的插值核向量Su、Sv3. 進(jìn)行矩陣運(yùn)算,得到插
3、值結(jié)果iTemp1 = Su0 * P1 + Su1 * P5 + Su2 * P9 + Su3 * P13iTemp2 = Su0 * 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 * iTemp44. 在得到插值結(jié)果圖后,我們發(fā)現(xiàn)圖像中有“毛
4、刺”,因此對插值結(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次的乘法及15次的加法,計(jì)算量可以說是非常大,勢必要進(jìn)行優(yōu)化。我們選擇了Intel的SSE2優(yōu)化技術(shù),它只支持在P4及以上的機(jī)器。測試當(dāng)前CPU是否支持SSE2,可由CPUID指令得到,代碼為: BOOL g_bSSE2 = FALSE; _asm mov eax, 1; cpuid; test edx, 0x04000000; jz
5、 NotSupport; mov g_bSSE2, 1 NotSupport: 支持SSE2的CPU引入了8個(gè)128位的寄存器,這樣一個(gè)寄存器中就可以存放4個(gè)點(diǎn)(RGB),有利于并行計(jì)算。詳細(xì)代碼見Transform.cpp中函數(shù)Optimize_Bicubic。優(yōu)化中遇到的問題:1. 圖像每個(gè)點(diǎn)由RGB通道組成,由于1個(gè)SSE2寄存器有16個(gè)字節(jié),這樣讀入4個(gè)像素點(diǎn)后,要浪費(fèi)4個(gè)字節(jié),同時(shí)要花費(fèi)時(shí)間將數(shù)據(jù)對齊,即由BRGB | RGBR | GBRG | BRGB對齊成 0RGB | 0RGB | 0RGB | 0RGB ;2. 讀16字節(jié)數(shù)據(jù)到寄存器時(shí),由于圖像地址不能保證是16字節(jié)對齊,
6、因此需用更多時(shí)鐘周期的MOVDQU指令(6個(gè)以上時(shí)鐘周期);如能使地址16字節(jié)對齊,則可用MOVDQA指令(1個(gè)時(shí)鐘周期) ;3. 為了消除除法及浮點(diǎn)運(yùn)算,對權(quán)值放大256倍,這樣在計(jì)算插值核時(shí),必須用2Bytes來表示1個(gè)系數(shù),而圖像數(shù)據(jù)都是1Byte,這樣在對齊做乘法時(shí),要浪費(fèi)一半的SSE2寄存器的空間,導(dǎo)致運(yùn)算時(shí)間變長;而若降低插值核的精度,使其在1Byte表示范圍內(nèi)時(shí),運(yùn)算的精度又大為下降 ;4. 對各指令的周期以及 若干行指令是否能夠并行流水缺乏經(jīng)驗(yàn)和認(rèn)識(shí)。附:SSE2指令整理算術(shù)(Arithmetic)指令:ADDPD-Packed Double-Precision Floatin
7、g-Point AddSSE2 2個(gè)double對應(yīng)相加ADDPD xmm0, xmm1/m128ADDPS-Packed Single-Precision Floating-Point AddSSE 4個(gè)float對應(yīng)相加ADDPS xmm0, xmm1/m128ADDSD-Scalar Double-Precision Floating-Point Add1個(gè)double(低端)對應(yīng)相加SSE2ADDSD xmm0, xmm1/m64ADDSS-Scalar Single-Precision Floating-Point AddSSE1個(gè)float(低端)對應(yīng)相加ADDSS xmm0, x
8、mm1/m32PADDB/PADDW/PADDD-Packed AddOpcodeInstructionDescription0F FC /rPADDB mm, mm/m64Add packed byte integers from mm/m64 and mm.66 0F FC /rPADDB xmm1,xmm2/m128Add packed byte integers from xmm2/m128 and xmm1.0F FD /rPADDW mm, mm/m64Add packed word integers from mm/m64 and mm.66 0F FD /rPADDW xmm1
9、, xmm2/m128Add packed word integers from xmm2/m128 and xmm1.0F FE /rPADDD mm, mm/m64Add packed doubleword integers from mm/m64 and mm.66 0F FE /rPADDD xmm1, xmm2/m128Add packed doubleword integers from xmm2/m128 and xmm1.PADDQ-Packed Quadword AddOpcodeInstructionDescription0F D4 /rPADDQ mm1,mm2/m64A
10、dd quadword integer mm2/m64 to mm166 0F D4 /rPADDQ xmm1,xmm2/m128Add packed quadword integers xmm2/m128 to xmm1PADDSB/PADDSW-Packed Add with SaturationOpcodeInstructionDescription0F EC /rPADDSB mm, mm/m64Add packed signed byte integers from mm/m64 and mm and saturate the results.66 0F EC /rPADDSB xm
11、m1,xmm2/m128Add packed signed byte integers from xmm2/m128 and xmm1 saturate the results.0F ED /rPADDSW mm, mm/m64Add packed signed word integers from mm/m64 and mm and saturate the results.66 0F ED /rPADDSW xmm1, xmm2/m128Add packed signed word integers from xmm2/m128 and xmm1 and saturate the resu
12、lts.PADDUSB/PADDUSW-Packed Add Unsigned with SaturationOpcodeInstructionDescription0F DC /rPADDUSB mm, mm/m64Add packed unsigned byte integers from mm/m64 and mm and saturate the results.66 0F DC /rPADDUSB xmm1, xmm2/m128Add packed unsigned byte integers from xmm2/m128 and xmm1 saturate the results.
13、0F DD /rPADDUSW mm, mm/m64Add packed unsigned word integers from mm/m64 and mm and saturate the results.66 0F DD /rPADDUSW xmm1, xmm2/m128Add packed unsigned word integers from xmm2/m128 to xmm1 and saturate the results.PMADDWD-Packed Multiply and AddOpcodeInstructionDescription0F F5 /rPMADDWD mm, m
14、m/m64Multiply the packed words in mm by the packed words in mm/m64. Add the 32-bit pairs of results and store in mm as doubleword66 0F F5 /rPMADDWD xmm1, xmm2/m128Multiply the packed word integers in xmm1 by the packed word integers in xmm2/m128, and add the adjacent doubleword results.PSADBW-Packed
15、 Sum of Absolute DifferencesOpcodeInstructionDescription0F F6 /rPSADBW mm1, mm2/m64Absolute difference of packed unsigned byte integers from mm2 /m64 and mm1; differences are then summed to produce an unsigned word integer result.66 0F F6 /rPSADBW xmm1, xmm2/m128Absolute difference of packed unsigne
16、d byte integers from xmm2 /m128 and xmm1; the 8 low differences and 8 high differences are then summed separately to produce two word integer results.PSUBB/PSUBW/PSUBD-Packed SubtractOpcodeInstructionDescription0F F8 /rPSUBB mm, mm/m64Subtract packed byte integers in mm/m64 from packed byte integers
17、 in mm.66 0F F8 /rPSUBB xmm1, xmm2/m128Subtract packed byte integers in xmm2/m128 from packed byte integers in xmm1.0F F9 /rPSUBW mm, mm/m64Subtract packed word integers in mm/m64 from packed word integers in mm.66 0F F9 /rPSUBW xmm1, xmm2/m128Subtract packed word integers in xmm2/m128 from packed w
18、ord integers in xmm1.0F FA /rPSUBD mm, mm/m64Subtract packed doubleword integers in mm/m64 from packed doubleword integers in mm.66 0F FA /rPSUBD xmm1, xmm2/m128Subtract packed doubleword integers in xmm2/mem128 from packed doubleword integers in xmm1.PSUBQ-Packed Subtract QuadwordOpcodeInstructionD
19、escription0F FB /rPSUBQ mm1, mm2/m64Subtract quadword integer in mm1 from mm2 /m64.66 0F FB /rPSUBQ xmm1, xmm2/m128Subtract packed quadword integers in xmm1 from xmm2 /m128.PSUBSB/PSUBSW-Packed Subtract with SaturationOpcodeInstructionDescription0F E8 /rPSUBSB mm, mm/m64Subtract signed packed bytes
20、in mm/m64 from signed packed bytes in mm and saturate results.66 0F E8 /rPSUBSB xmm1, xmm2/m128Subtract packed signed byte integers in xmm2/m128 from packed signed byte integers in xmm1 and saturate results.0F E9 /rPSUBSW mm, mm/m64Subtract signed packed words in mm/m64 from signed packed words in m
21、m and saturate results.66 0F E9 /rPSUBSW xmm1, xmm2/m128Subtract packed signed word integers in xmm2/m128 from packed signed word integers in xmm1 and saturate results.PSUBUSB/PSUBUSW-Packed Subtract Unsigned with SaturationOpcodeInstructionDescription0F D8 /rPSUBUSB mm, mm/m64Subtract unsigned pack
22、ed bytes in mm/m64 from unsigned packed bytes in mm and saturate result.66 0F D8 /rPSUBUSB xmm1, xmm2/m128Subtract packed unsigned byte integers in xmm2/m128 from packed unsigned byte integers in xmm1 and saturate result.0F D9 /rPSUBUSW mm, mm/m64Subtract unsigned packed words in mm/m64 from unsigne
23、d packed words in mm and saturate result.66 0F D9 /rPSUBUSW xmm1, xmm2/m128Subtract packed unsigned word integers in xmm2/m128 from packed unsigned word integers in xmm1 and saturate result.SUBPD-Packed Double-Precision Floating-Point SubtractOpcodeInstructionDescription66 0F 5C /rSUBPD xmm1, xmm2/m
24、128Subtract packed double-precision floating-point values in xmm2/m128 from xmm1.SUBPS-Packed Single-Precision Floating-Point SubtractOpcodeInstructionDescription0F 5C /rSUBPS xmm1 xmm2/m128Subtract packed single-precision floating-point values in xmm2/mem from xmm1.SUBSD-Scalar Double-Precision Flo
25、ating-Point SubtractOpcodeInstructionDescriptionF2 0F 5C /rSUBSD xmm1, xmm2/m64Subtracts the low double-precision floating-point numbers in xmm2/mem64 from xmm1.SUBSS-Scalar Single-FP SubtractOpcodeInstructionDescriptionF3 0F 5C /rSUBSS xmm1, xmm2/m32Subtract the lower single-precision floating-poin
26、t numbers in xmm2/m32 from xmm1.-PMULHUW-Packed Multiply High UnsignedOpcodeInstructionDescription0F E4 /rPMULHUW mm1, mm2/m64Multiply the packed unsigned word integers in mm1 register and mm2/m64, and store the high 16 bits of the results in mm1.66 0F E4 /rPMULHUW xmm1, xmm2/m128Multiply the packed
27、 unsigned word integers in xmm1 and xmm2/m128, and store the high 16 bits of the results in xmm1. PMULHW-Packed Multiply High SignedOpcodeInstructionDescription0F E5 /rPMULHW mm, mm/m64Multiply the packed signed word integers in mm1 register and mm2/m64, and store the high 16 bits of the results in
28、mm1.66 0F E5 /rPMULHW xmm1, xmm2/m128Multiply the packed signed word integers in xmm1 and xmm2/m128, and store the high 16 bits of the results in xmm1.PMULLW-Packed Multiply Low SignedOpcodeInstructionDescription0F D5 /rPMULLW mm, mm/m64Multiply the packed signed word integers in mm1 register and mm
29、2/m64, and store the low 16 bits of the results in mm1.66 0F D5 /rPMULLW xmm1, xmm2/m128Multiply the packed signed word integers in xmm1 and xmm2/m128, and store the low 16 bits of the results in xmm1.PMULUDQ-Multiply Doubleword UnsignedOpcodeInstructionDescription0F F4 /rPMULUDQ mm1, mm2/m64Multipl
30、y unsigned doubleword integer in mm1 by unsigned doubleword integer in mm2/m64, and store the quadword result in mm1.66 OF F4 /rPMULUDQ xmm1, xmm2/m128Multiply packed unsigned doubleword integers in xmm1 by packed unsigned doubleword integers in xmm2/m128, and store the quadword results in xmm1.PMUL
31、UDQ instruction with 64-Bit operands:DEST63-0 DEST31-0 * SRC31-0;PMULUDQ instruction with 128-Bit operands:DEST63-0 DEST31-0 * SRC31-0;DEST127-64 DEST95-64 * SRC95-64;MULPD-Packed Double-Precision Floating-Point MultiplyOpcodeInstructionDescription66 0F 59 /rMULPD xmm1, xmm2/m128Multiply packed doub
32、le-precision floating-point values in xmm2/m128 by xmm1.DEST63-0 DEST63-0 * SRC63-0;DEST127-64 DEST127-64 * SRC127-64;MULPS-Packed Single-Precision Floating-Point MultiplyOpcodeInstructionDescription0F 59 /rMULPS xmm1, xmm2/m128Multiply packed single-precision floating-point values in xmm2/mem by xm
33、m1.DEST31-0 DEST31-0 * SRC31-0;DEST63-32 DEST63-32 * SRC63-32;DEST95-64 DEST95-64 * SRC95-64;DEST127-96 DEST127-96 * SRC127-96;MULSD-Scalar Double-Precision Floating-Point MultiplyOpcodeInstructionDescriptionF2 0F 59 /rMULSD xmm1, xmm2/m64Multiply the low double-precision floating-point value in xmm
34、2/mem64 by low double-precision floating-point value in xmm1.DEST63-0 DEST63-0 * xmm2/m6463-0;* DEST127-64 remains unchanged *;MULSS-Scalar Single-FP MultiplyOpcodeInstructionDescriptionF3 0F 59 /rMULSS xmm1, xmm2/m32Multiply the low single-precision floating-point value in xmm2/mem by the low singl
35、e-precision floating-point value in xmm1.DEST31-0 DEST31-0 * SRC31-0;* DEST127-32 remains unchanged *;-DIVPD-Packed Double-Precision Floating-Point DivideDIVPDxmm0, xmm1/m128DEST63-0 DEST63-0 / (SRC63-0);DEST127-64 DEST127-64 / (SRC127-64);DIVPS-Packed Single-Precision Floating-Point DivideDIVPS xmm
36、0, xmm1/m128DEST31-0 DEST31-0 / (SRC31-0);DEST63-32 DEST63-32 / (SRC63-32);DEST95-64 DEST95-64 / (SRC95-64);DEST127-96 DEST127-96 / (SRC127-96);DIVSD-Scalar Double-Precision Floating-Point DivideDIVSDxmm0, xmm1/m64DEST63-0 DEST63-0 / SRC63-0;* DEST127-64 remains unchanged *;DIVSS-Scalar Single-Preci
37、sion Floating-Point DivideDIVSSxmm0, xmm1/m32DEST31-0 DEST31-0 / SRC31-0;* DEST127-32 remains unchanged *;-PAVGB/PAVGW-Packed AverageOpcodeInstructionDescription0F E0 /rPAVGB mm1, mm2/m64Average packed unsigned byte integers from mm2/m64 and mm1, with rounding.66 0F E0, /rPAVGB xmm1, xmm2/m128Averag
38、e packed unsigned byte integers from xmm2/m128 and xmm1, with rounding.0F E3 /rPAVGW mm1, mm2/m64Average packed unsigned word integers from mm2/m64 and mm1, with rounding.66 0F E3 /rPAVGW xmm1, xmm2/m128Average packed unsigned word integers from xmm2/m128 and xmm1, with rounding.-PMAXSW-Packed Signe
39、d Integer Word MaximumOpcodeInstructionDescription0F EE /rPMAXSW mm1, mm2/m64Compare signed word integers in mm2/m64 and mm1 for maximum values.66 0F EE /rPMAXSW xmm1, xmm2/m128Compare signed word integers in xmm2/m128 and xmm1 for maximum values.PMAXUB-Packed Unsigned Integer Byte MaximumOpcodeInst
40、ructionDescription0F DE /rPMAXUB mm1, mm2/m64Compare unsigned byte integers in mm2/m64 and mm1 for maximum values.66 0F DE /rPMAXUB xmm1, xmm2/m128Compare unsigned byte integers in xmm2/m128 and xmm1 for maximum values.PMINSW-Packed Signed Integer Word MinimumOpcodeInstructionDescription0F EA /rPMIN
41、SW mm1, mm2/m64Compare signed word integers in mm2/m64 and mm1 for minimum values.66 0F EA /rPMINSW xmm1, xmm2/m128Compare signed word integers in xmm2/m128 and xmm1 for minimum values.PMINUB-Packed Unsigned Integer Byte MinimumOpcodeInstructionDescription0F DA /rPMINUB mm1, mm2/m64Compare unsigned
42、byte integers in mm2/m64 and mm1 for minimum values.66 0F DA /rPMINUB xmm1, xmm2/m128Compare unsigned byte integers in xmm2/m128 and xmm1 for minimum values.-RCPPS-Packed Single-Precision Floating-Point ReciprocalOpcodeInstructionDescription0F 53 /rRCPPS xmm1, xmm2/m128Returns to xmm1 the packed app
43、roximations of the reciprocals of the packed single-precision floating-point values in xmm2/m128.DEST31-0 APPROXIMATE(1.0/(SRC31-0);DEST63-32 APPROXIMATE(1.0/(SRC63-32);DEST95-64 APPROXIMATE(1.0/(SRC95-64);DEST127-96 APPROXIMATE(1.0/(SRC127-96);RCPSS-Scalar Single-Precision Floating-Point Reciprocal
44、OpcodeInstructionDescriptionF3 0F 53 /rRCPSS xmm1, xmm2/m32Returns to xmm1 the packed approximation of the reciprocal of the low single-precision floating-point value in xmm2/m32.DEST31-0 APPROX (1.0/(SRC31-0);* DEST127-32 remains unchanged *;RSQRTPS-Packed Single-Precision Floating-Point Square Roo
45、t ReciprocalOpcodeInstructionDescription0F 52 /rRSQRTPS xmm1, xmm2/m128Returns to xmm1 the packed approximations of the reciprocals of the square roots of the packed single-precision floating-point values in xmm2/m128.DEST31-0 APPROXIMATE(1.0/SQRT(SRC31-0);DEST63-32 APPROXIMATE(1.0/SQRT(SRC63-32);DE
46、ST95-64 APPROXIMATE(1.0/SQRT(SRC95-64);DEST127-96 APPROXIMATE(1.0/SQRT(SRC127-96);RSQRTSS-Scalar Single-Precision Floating-Point Square Root ReciprocalOpcodeInstructionDescriptionF3 0F 52 /rRSQRTSS xmm1, xmm2/m32Returns to xmm1 an approximation of the reciprocal of the square root of the low single-
47、precision floating-point value in xmm2/m32.DEST31-0 APPROXIMATE(1.0/SQRT(SRC31-0);* DEST127-32 remains unchanged *;SQRTPD-Packed Double-Precision Floating-Point Square RootOpcodeInstructionDescription66 0F 51 /rSQRTPD xmm1, xmm2/m128Computes square roots of the packed double-precision floating-point
48、 values in xmm2/m128 and stores the results in xmm1.SQRTPS-Packed Single-Precision Floating-Point Square RootOpcodeInstructionDescription0F 51 /rSQRTPS xmm1, xmm2/m128Computes square roots of the packed single-precision floating-point values in xmm2/m128 and stores the results in xmm1.SQRTSD-Scalar
49、Double-Precision Floating-Point Square RootOpcodeInstructionDescriptionF2 0F 51 /rSQRTSD xmm1, xmm2/m64Computes square root of the low double-precision floating-point value in xmm2/m64 and stores the results in xmm1.SQRTSS-Scalar Single-Precision Floating-Point Square RootOpcodeInstructionDescriptio
50、nF3 0F 51 /rSQRTSS xmm1, xmm2/m32Computes square root of the low single-precision floating-point value in xmm2/m32 and stores the results in xmm1.移動(dòng)(Move)指令:MASKMOVDQU-Mask Move of Double Quadword UnalignedMASKMOVDQU xmm0, xmm1MASKMOVQ-Mask Move of QuadwordMASKMOVQ mm0, mm1MOVAPD-Move Aligned Packed
51、 Double-Precision Floating-Point ValuesMOVAPD xmm0, xmm1/m128MOVAPD xmm1/m128, xmm0MOVAPS-Move Aligned Packed Single-Precision Floating-Point ValuesMOVAPS xmm0, xmm1/m128MOVD-Move DoublewordInstructionDescriptionMOVD mm, r/m32Move doubleword from r/m32 to mm.MOVD r/m32, mmMove doubleword from mm to
52、r/m32.MOVD xmm, r/m32Move doubleword from r/m32 to xmm.MOVD r/m32, xmmMove doubleword from xmm register to r/m32.MOVDQ2Q - Move QuadwordInstructionDescriptionMOVDQ2Q mm, xmmMove low quadword from xmm to mmx register .MOVQ2DQ-Move QuadwordOpcodeInstructionDescriptionF3 0F D6MOVQ2DQ xmm, mmMove quadword from mmx to low quadword of xmm.DEST63-0 SRC63-0;DEST127-64 00000000000000000H;MOVDQA - Move Aligned Double QuadwordInstructionDe
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- GB/T 19054-2025燃油式火化機(jī)通用技術(shù)條件
- 2025年大學(xué)建筑歷史與理論(建筑歷史)試題及答案
- 2025年中職測繪工程技術(shù)(地形測量基礎(chǔ))試題及答案
- 2025年高職第一學(xué)年(大數(shù)據(jù)技術(shù))數(shù)據(jù)采集與預(yù)處理階段測試題及答案
- 2025年大學(xué)本科(服裝與服飾設(shè)計(jì))服裝色彩設(shè)計(jì)試題及答案
- 2025年大學(xué)水產(chǎn)養(yǎng)殖學(xué)(水產(chǎn)動(dòng)物育種)試題及答案
- 2025年大學(xué)哲學(xué)(倫理學(xué)原理)試題及答案
- 2026年禮品銷售(包裝服務(wù))試題及答案
- 2025年高職(經(jīng)濟(jì)林培育與利用)果樹種植階段測試題及答案
- 2025年高職視覺傳播設(shè)計(jì)與制作(視覺傳播設(shè)計(jì))試題及答案
- 醫(yī)療器械使用與維護(hù)常見問題匯編
- 中遠(yuǎn)海運(yùn)集團(tuán)筆試題庫2025
- 企業(yè)員工培訓(xùn)效果評估報(bào)告模板
- 江蘇省淮安市2024-2025學(xué)年七年級下學(xué)期期末歷史試題(含答案)
- 醫(yī)療器械胰島素泵市場可行性分析報(bào)告
- 地鐵施工現(xiàn)場防臺(tái)風(fēng)措施
- 種植業(yè)合作社賬務(wù)處理
- 【麗江玉龍旅游薪酬制度的創(chuàng)新研究6100字】
- 公司兩權(quán)分離管理制度
- 車輛叉車日常檢查記錄表
- 膠帶機(jī)硫化工藝.課件
評論
0/150
提交評論