毕业设计(论文)基于六角像素的图像双三次插值算法.doc
基于六角像素的图像双三次插值算法摘 要与传统的方形网格相比,基于六角网格的数字图像处理方法有它独特的优点,因此,基于六角像素的图像处理技术的研究越来越受到人们的关注。然而,由于没有成熟的硬件来支持基于六角网格下图像的获取和显示,人们的研究工作往往在模拟六角网格进行。 在四角像素中,双三次插值算法是一种插值效果较好的方法。本文的主要任务就是研究在六角像素下的双三次插值算法的使用和使用效果。试图证明:在六角像素下双三次插值算法也同样具有更好的插值效果。 本文采用一种Pseudo六角像素模拟方法中关于虚拟六角像素的SA算法,在虚拟六角像素定址的基础上实现虚拟六角网格中的插值实验。具体步骤:1. 首先将一个正方形像素细分为7×7的49个小像素,用双线性插值算法求每个小像素的灰度,并表示图像。2. 在虚拟的六角结构下运用双线性插值算法对灰度图像进行灰度重建,再采用双三次插值算法,对相同的灰度图像进行灰度重建。本文采用三次卷积公式进行双三次插值。3. 返回到四角结构下显示重建图像,比较两个重建灰度图的重建效果。4. 通过计算原始图像信号噪音功率比和最终图像的信号噪音功率比,对实验结果进行分析比较,我们可以得到这样的结论:在六角形象素下的图像双三次插值算法同样具有更好的插值效果。关键词: 六角网格,灰度值,双三次插值Image Bicubic Interpolation Algorithm Base on Hexagonal GridAbstractCompared to the traditional square grid,The way of image processing based on the hexangular grid has its special advantage.Therefore,people pay more and more attention to the study of image processing techlnique.However,Because there is no mature hardware supporting for the capture and display of hexagonal-based image,the study work of researchers is done based on hexangular grid imitation.Bicubic interpolation is a way in square grid which has better effect of image interpolation.The main job of this paper. is studying how to use Bicubic interpolation on the hexangular pixel and the effect of using.Try to prove that Bicubic interpolation also has better effect of image interpolation on hexangular pixel.This paper uses SA algorithm about virtual hexangular pixel which is a part of Pseudo hexangular pixel imitation,it uses the SA algorithm to implement the virtual hexangular grid based on ascertaining the address in imitating the hexangular pixel. Concrete step:1. First,each one pixel is divided delicately to 49 small pixel. Then, we adopt the Blinear interpolation to calculate the grey and figure the image.2. We adopt the improved Blinear interpolation based on hexangular grid imitation to reconstruct the grey image. We do it again using the improved Bicubic interpolation instead and reconstruct the same grey image. This paper adopts Bicubic interpolation in the use of cubic convolution formula.3. We compare the rebuilding effect of two grey images after displaying the reconstructed image on square grid.4. After computing signal to noise between original and final image and analysing,comparing the result, we can make the conclusion that the image Bicubic interpolation based on hexangular grid has better effect in interpolation Key Words: hexagonal grid, grey value,bicubic-interpolation目 录摘 要IAbstractII第一章 绪论11.1 研究背景11.2 研究的主要内容11.3 研究的目的意义2第二章 虚拟六角结构分析32.1四角网格32.2六角网格32.3六角网格的特点42.3.1四角网格与六角网格的进一步比较42.3.2六角网格的优点42.4 模拟六角网格52.3.1四角像素错位模拟六角像素52.3.2另一种方法的模拟六角结构62.3.3 Pseudo六角像素72.3.4虚拟六角结构下的图像处理8第三章 插值实验设计93.1 灰度插值算法93.1.1 最近邻插值算法(近邻取样法)93.1.2 双线性插值法93.1.3 双三次插值法103.2 实验的软硬件条件113.2.1 实验的硬件要求113.2.2 实验的软件要求113.3 定址方法113.4基于六角网格的双线性插值实验133.5基于六角网格的双三次插值实验163.5.1传统的双三次插值算法163.5.2 改进后的基于六角网格的双三次插值算法163.5.3 实现基于六角网格的双三次插值法17第四章 实验结果及分析194.1 实验结果194.2 结果分析20结论22谢辞23参考文献24第一章 绪论1.1 研究背景插值算法是计算机图形学和图像处理的基本算法,它广泛地应用在图像缩放和旋转、动画中间帧的生成等图形学和图像处理问题的研究之中。由于通常的显示设备大多数是将像素点以四角网格形式排列的,因此,早期的图像处理的研究基本上是基于四角网格进行的,有关插值算法的研究也基本上是在四角网格上实现的。然而,早在60年代初,数学家就对如何分布平面上的取样问题进行了深入的研究,其中Rogers指出,平面上的最佳分布是按六角网格形式分布的1。1991年Wuthrlch和Stuki 证明了方型网格和六角网格在几何意义上是相似的,并且提出了两个在六角网格上绘制直线和圆的算法2。在一个模拟的六角网格显示屏上显示表明,六角网格的确有很好的绘图特性。六角网格的优势越来越明显,但是由于硬件条件的限制,人们都是在虚拟六角网格上进行研究并得出结论。虚拟六角网格的定义有多种多样,其中Pseudo六角像素模拟法是一种比较常用的以四角网格模拟实现六角网格的方法。其中的SA算法对于六角像素的定址有着积极的意义。本文就是在这种背景下提出了在六角网格上进行双三次插值算法的实现,从而得到更好的目标图像。三次插值的算法有很多种,常见的有Hermite三次插值,三次样条插值,双三次插值(三次卷积)等。本文采用的是三次卷积公式。1.2 研究的主要内容本论文主要研究基于六角像素图像的插值算法,重点研究双三次插值算法及其意义。具体内容包括以下几个方面:1. 确定原图的像素灰度值。创建一个虚拟的六角网格系统,建立四角像素和六角像素的关系。2. 分别利用双线性插值算法和双三次插值算法求虚拟的六角结构中每个六角像素的灰度。3. 基于四角结构重建图像,并绘制显示图像。4. 计算原始图像信号和最终图像的信号噪音功率比5. 分析比较实验结果数据,得出有效的结论。1.3 研究的目的意义目前,使用六角网格的优势被充分认识。一个良好的模拟六角网格的算法,无论是对图像显示或处理的研究,还是硬件的开发都有着积极的影响。在四角结构和六角结构的转换过程中,如果有一个优秀的插值算法,那么得到的图像不仅不会失真而且清晰度方面还会有提高的可能,对以后硬件的发展也有着积极的推动作用。因此,本文对插值算法的实验研究意义在于可以建立四角结构图像与六角结构图像的关系,使得在虚拟的六角结构中进行图像处理成为可能并且方便,促进了基于六角像素的图像处理研究的进一步深入和发展。第二章 虚拟六角结构分析2.1四角网格在分析六角网格之前,先看看四角网格的特点。四角网格,即四角像素,也成方形网格。四角网格以其排列整齐,像素点读取方便迅速成为当前显示设备、图像处理软件的普遍图像信息表示法。一幅图假设大小为N×M,可将该图视为由N行,M列的矩阵构成,每一个四角像素占有图的某行和某列。从图2-1我们看到,四角网格排列整齐,容易定出像素点坐标,方便读取。图2-1 四角网格2.2六角网格六角网格是指平面上的点按照六角网格形式分布,这种分布使每个像素对应着一个正六边形,而将六边形的中心点作为网格点如图2-2所示3。图2-2 四角网格与六角网格在四角网格中,正四边形覆盖图像,六角网格改变原来正四边形覆盖图像的原理,采用正六边形覆盖图像。如2-3所示,正六边形具有等距性的特点,显得更加匀称。除此之外,六角像素还具有一致的连接性和对称性,六角像素形状为正六边形,与真实的像素点更为接近。图2-3 六角网格具有等距性2.3六角网格的特点2.3.1四角网格与六角网格的进一步比较尽管四角网格与六角网格都可以用来表征图像,但是它们表现的方法却不尽相同,四角网格虽然容易读取,排列整齐,但是在某些图像特性上有明显的不足,比如四角网格只有两个方向的对称轴,这种对称特征使图像处理不够精确。基于四角网格的图像进行旋转的时候,可能会丢失较多的图像信息。六角网络与四角网格相比,形状类似于光点,六角网络具有的一致连接性,等距性,对称性,这些良好的特性让它在表现图像信息方面显得尤其出色,表示出来的图像边缘清晰,线条也更加光滑。2.3.2六角网格的优点总的来说,与方形网格相比,六角网格具有以下优点1:(1) 所显示的直线(或曲线)看起来更加连贯。在方形网格上绘制直线(或曲线)时,屏幕上显示的线条好像是由一段段断开的水平或垂直小线段所组成,中间有很明显的断点,当直线或曲线中有一对点相邻的像素时,就会出现一个“断点”,而在六角网格上,每个像素的6个相邻像素都是边相邻的,所以在直线或曲线中的每一对相邻像素之间都有一公共边,因而不会有“断开”的现象(2) 像素点的分布更加合理和紧凑正六边形与四边形相比更加相似于光点的形状设小圆点的直径长度(或像素的长度)为1,则对于一个面积为m×n的显示屏,如果采用方形网格分布可以容纳m×n个点;若采用六角网格分布,m×n个点只占用该显示屏的2空间,即86.6 的空间因为这时点的行间距离是0866而不是1这样,整个显示屏就可容纳(约为1.155m×n)个点,即点数增加了15.5 ,这表明点的密度增加了,因而可更好地表示图形与图像的细节(3)由于每个像素与其所有相邻像素之间只有一种相邻关系,这就为许多图像处理算法提供了简便的实现途径,并且提高了算法的效率。传统的方形网格中的每个像素到其相邻像素的距离不等,因此其相邻像素有4邻接和8邻接两种定义。而对于六角网格,只有一种6邻接定义,所以,所有诸如区域在某一点是否连续或两点间的距离等几何性质的定义及双线性插值算法都是惟一确定的。2.4 模拟六角网格虽然六角网格有如此多的优点,但是六角网格并不能被广泛地应用于图像处理。主要的原因是,获取和显示基于六角网格的图像时,并没有相应的基于六角网格的硬件设备支持,这是更深入地进行六角网格方面的研究是个很大的障碍,所以怎么在现有的四角显示设备上显示六角样本数字图像成为一个重要的问题,幸运地是,现在我们已经有一些方法利用现有的四角网格来模拟六角网格,这些方法的使用,能够发挥基于六角网格的计算机视觉和计算机图像的优势4。2.3.1四角像素错位模拟六角像素该方法主要是通过四角像素在水平方向的错位来模拟六角像素结构。如图2-4所示。在这个模拟方案中,像素的形状是方形的。总而言之,垂直方向和水平方向的取样间隔是一致的。这个方案通过设置垂直方向和水平方向一致的取样间隔使得硬件的设计简单化。然而六角像素中的等距的优点却没能在这个模型中体现,图2-4表明,如果我们标记任意两个垂直方向相邻或任意两个水平方向的相邻点的距离为1个单位,那么任意两个斜对角方向相邻的像素的距离却为25图2-4 使用半像素偏移四角像素模拟六角像素为了弥补这个方案的缺点,Staunton等人进行了改进。如图2-5所示,这个结构的优点是所有的取样点与它们相邻的最邻近像素点的距离相等,两个邻近像素点之间的夹角为60o ,水平取样点相距2。像素大小为1×2,而这样图像素比例变为2:15。图2-5 使用半像素偏移四角像素模拟六角像素2.3.2另一种方法的模拟六角结构一个这样的六角像素由四个传统的四角像素组成,而灰度值则由这四个像素的灰度平均而成,参见图2-6。这个模拟方案保存了六角结构的一个特征,那就是每个像素都有六个相邻像素,然而,这个模拟六角像素的灰度值是由四个像素的灰度平均取得的,所以影响了图像的分辨率,再者,六角结构的一个重要特征是,中心像素和六领域的距离是相等的,而在这个模拟的六角结构中,这个优点没有得到保持5。图2-6 四个传统四角像素末模拟六角结构2.3.3 Pseudo六角像素为了评估四角像素和六角像素的视觉效果,人们提出了Pesudo六角像素。其主要思想是:基于四角像素和六角像素分别建立可比较的网格系统。一个六角像素称为一个超像素,用四角像素集模拟构造,并且模拟使得四角像素网格与六角像素网格的密度具有可比较性5。参见图2-7。图2-7模拟超像素基于了Pesudo六角像素的思想,最常用、最有效的构造方法是:首先,一个四角像素分成7×7后的小像素,称为子像素。每个子像素的灰度为原四角像素的灰度。每个虚拟六角像素由如图2-8所示的56个子像素组成,灰度值由这56个子像素灰度值取平均获得6。每个虚拟六角像素比四角像素大12.5%,因此,表示一个图像时,虚拟六角像素比四角像素少用了12.5%的像素6,但已被证明这并不影响图像的分辨率。如果将每一个像素都这样进行处理,得到一个虚拟的六角结构。在这个虚拟的六角网格中,垂直方向距离为8,斜方向上距离为8.06,近似为8,这样等距性在这里得到了很好的保持,而且几乎不会产生图像扭曲。图2-8 一个六角像素的构成2.3.4虚拟六角结构下的图像处理虚拟的六角结构仅仅存在于图像处理过程,虚拟六角像素存在于计算机的内存空间中。那么,运算处理是在虚拟的空间中进行。最后将结果映射到四角结构中显示6。参见图2-9。方形网格上的原始图像虚拟六角网格上的图像在方形网格上 处理图像在六角网格上处理图像映射逆映射MAM 图2-9 虚拟六角结构图像处理过程第三章 插值实验设计3.1 灰度插值算法3.1.1 最近邻插值算法(近邻取样法)最简单的灰度插值算法是最近邻插值,也叫零阶插值。最近邻插值首先将就是将经空间变换映射为。如果是非整数坐标,则寻找的最近邻,并将最近邻的灰度值赋给校正图像处的像素7。可见,最近邻插值简单直观,但是得到的图像质量不高,通常不是一个较好的插值方法。3.1.2 双线性插值法对于通常的图像处理,双线性插值很实用。它利用点的四个最近邻的灰度值来确定的灰度值。见图3-1。设的四个最近邻为A,B,C,D;它们的坐标分别为,、;其灰度值分别为,。首先计算E和F这两点的灰度值,7: (公式3-1) (公式3-2)则点的灰度值为 (公式3-3)即对于一个目标像素,可以设置浮点坐标为,其中均为非负整数,为0,1区间的浮点数,则这个像素灰度值可由原图像中坐标为,、所对应的四个像素的值决定,即: (公式3-4)CDABAYX图3-1双线性插值示意图双线性插值算法容易实现,能够产生区域效果。从滤波的角度看,双线性插值对图像的低频有较好的相应能力,可以看着是一个低通滤波器8。双线性插值是图像处理中比较常用的方法。3.1.3 双三次插值法双三次插值(也称协调板元),二元双三次插值公式共有(31)216个系数,其一般形式可写成9: (公式3-5)双三次插值方法能够克服双线性插值和最邻近插值算法的缺点。计算精度比较高,插值效果较最近邻插值法和双线性插值法好,但是计算量大。该方法考虑一个浮点坐标(i+u,j+v)周围的16个邻点,目标像素值f(i+u,j+v)可由如下插值公式得到:其中 (公式3-6)3.2 实验的软硬件条件3.2.1 实验的硬件要求一台PC机,CPU为PII300以上或更高,内存256M以上,4.0G以上硬盘空间。由于本实验涉及的图像处理需要处理一定量的数据内容,所以适当提高硬件设备有利于实验的顺利进行,提高实验的速度。3.2.2 实验的软件要求(1) 操作系统平台为WinNT/Win2000/WinXP。(2) 编程环境为MATLAB7.0。MATLAB是有MathWorks公司于1984年推出的一套科学计算软件。它具有强大的矩阵计算和数据可视化能力,一方面可以实现数据分析、优化统计、偏微分方程数值解,自动控制、信号处理等若干邻域的数学计算,另一方面可以实现二维、三维图形绘制,三维场景创建和渲染、科学计算可视化、图像处理、虚拟现实和地图制作等图形图像方面的处理10。3.3 定址方法在实验中,首先要模拟六角像素,找出四角像素和六角像素之间的关系。无论用哪种方法模拟六角像素,六角像素的定址是非常重要的,因为任何基于六角网格的图像操作,都要对准确地对每个六角像素进行定位,才能对图像中像素的灰度值进行处理。在这个实验中,我们采用的是SA定址方法5。为了定位一个虚拟的六角像素,我们可以定位标记为a×10i (i=1,2, ; a=1,2,3,6)的像素。首先,用矢量0,0标记地址为0的位置,矢量j,k(j,k是整数)标记一个离源0,0横向距离为j, 纵向距离为j的像素的位置,其中向右右,向下为正。 用L(a)来表示地址为a的坐标位置,这样,L(0)=0,0,从图上可以得到,L(1)=0,8, L(2)=-7,4, L(3)=-7,-4, L(4)=0,-8, L(5)=7,-4, L(6)=7,4。 图3-2 六角像素螺旋定址注意到,六角像素中标记地址为10的位置,它可以由L(1)和L(2)决定,在这里的计算就是简单的矢量运算,根据矢量关系,L(10)=L(1)+2L(2);同理: L(20)=L(2)+2L(3);L(30)=L(3)+2L(4);L(40)=L(4)+2L(5);L(50)=L(5)+2L(6);L(60)=L(6)+2L(1);根据这个规律,可能容易推得:L(a×10i)= L(a×10i-1)+2 L(a+1)×10i-1)L(6×10i)= L(6×10i-1)+2 L(10i-1)i=1,2, A=1,2,5 (公式3-7) 具体计算时L(anana1)= (公式3-8)举个例子:L(316)= L(300)+ L(10)+ L(6)= L(30)+2 L(40)+ L(10)+ L(6)= L(3)+2 L(4)+2(L(4)+2 L(5)+ L(1)+2 L(2)+ L(6)=14,-323.4基于六角网格的双线性插值实验图像的双线性插值算法在四角网格系统的运用已经成熟了,而对于基于六角结构下的插值,如果我们采用Pesudo六角像素,将每个四角像素细分为7×7的子像素,那么在六角结构下,采用SA算法来定址,对于任意一个六角结构下坐标为的坐标并一定能够找到四角坐标下的一个像素点与之对于。也就是说,假设六角像素坐标为,转化为细分前的四角像素坐标,不一定取整数。因此,这样的坐标不一定存在。于是我们就可运用双线性插值和双三次插算法进行处理。对于一张四角像素组成的灰度图,可以转换为模拟六角像素并进行双线性插值,具体实现步骤如下:(1) 在四角结构下,将一个四角像素细分为7×7的小像素,中心小像素的灰度值为原四角像素的灰度值。(2) 利用通常意义的双线性插值算法求出其余小像素的灰度值。代码编写的关键部分:I=imread('beauty.bmp');%读取图像数据nrows,ncols=size(I);%获取图像大小。I=double(I)width = 7 * nrows; height = 7 * ncols;widthScale = 1/7; heightScale = 1/7;for x = 4:width-4 for y = 4:height-4xx = (x+3) * widthScale; yy = (y+3) * heightScale; a=floor(x+3)/7);b=floor(y+3)/7); x11 =I(a,b); x12 =I(a,b+1); x21 =I(a+1,b); x22 =I(a+1,b+1); J(x,y) = uint8( (b+1-yy) * (xx-a)*x21 + (a+1-xx)*x11) + (yy-b) * (xx-a)*x22 +(a+1-xx) * x12) ); endend具体代码参见本论文配套光盘中的bilinearel.m文件(3) 通过SA算法定址,确定六角网格的坐标,找出六角像素与四角像素之间的关系,从而得到六角像素中心子像素的灰度值。六角像素的中心点是这样定义的,假定图像在四角结构下为2M行和2N列,M和N是正整数。每个像素细分为7×7个子像素,为14M行和14N列。将由56个子像素构成的第一个虚拟六角像素的中心定位在7M与7M1的中间和7N的位置上11。也就是说,如图3-3所示的一个六角像素,其中心位置在P点。为了运算方便,在实验中我们取中心位置为图中第4行第5列的像素点。图3-3六角像素的中心位置(4) 在六角结构下,每个六角像素由56个子像素构成。以(3)中求出的中心子像素点为插值基点,通过双线性插值算法再求出六角结构像素中的其它小像素的灰度值。对于每一个六角像素,我们可以通过(公式3-4)求出六角像素中心子像素的坐标12。设X是任意给定的六角像素点,那么在原图像空间,存在四个四角像素A,B,C和D,如图3-3 所示。定义A,B,C和D的坐标分别为,。设 , ,得到12设为图像的灰度函数,定义像素的灰度值,那么通过下列的双线性插值计算的灰度值:代码编写的关键部分:%六角像素中心小像素坐标(m,n)%计算六角小像素的灰度 if (floor(m)<=0)|(floor(n)<=0) Y(x,y)=J(1,1);elseif (floor(m)=m)&&(floor(n)=n) Y(x,y)=J(floor(m),floor(n);elseif(floor(m)<nrows/7-1) && (floor(n)<ncols/7-1)x11=double(J(floor(m),floor(n);x12=double(J(floor(m),ceil(n);x21=double(J(ceil(m),floor(n);x22=double(J(ceil(m),ceil(n); Wx1=double(1-(m-floor(m);Wx2=double(m-floor(m);Wy1=double(1-(n-floor(n);Wy2=double(n-floor(n); Y(x,y)=uint8(Wx1*Wy1*x11+Wx2*Wy1*x21+Wx1*Wy2*x12+Wx2*Wy2*x22); elseY(x,y)=J(floor(m),floor(n)end 具体代码参见本论文配套光盘中的bilinearw.m文件(5) 四角结构下重建图像,并显示。本文采取将49个小像素的平均值作为四角像素的灰度值。也可以用中心小像素的灰度值作为四角像素的灰度值。两者效果相当。代码编写的关键部分:for x = 1:nrows/7 for y = 1:ncols/7 k=x-1; t=y-1; J(x,y)=uint8(1/49)*(sum(I(7*k+1:7*k+7,7*t+1)+sum(I(7*k+1:7*k+7,7*t+2)+sum(I(7*k+1:7*k+7,7*t+3)+sum(I(7*k+1:7*k+7,7*t+4)+sum(I(7*k+1:7*k+7,7*t+5)+sum(I(7*k+1:7*k+7,7*t+6)+sum(I(7*k+1:7*k+7,7*t+7); endendend 显示缩小后的效果3.5基于六角网格的双三次插值实验3.5.1传统的双三次插值算法双三次插值是一种更加复杂的插值方式,它能创造出比双线性插值更平滑的图像边缘。通过双三次插值创造一个像素,而这个像素的灰度值是由它附近的4 x 4邻近像素值推算出来的,因此精确度较高。双三次插值方法通常运用在一部分图像处理软件、打印机驱动程序和数码相机中,对原图像或原图像的某些区域进行放大。本文采用双三次的卷积公式。双三次插值算法重建的图像边缘更清晰,画质更高,但也有不足之处就是计算量大,在计算机上运行耗时长,效率较低。3.5.2 改进后的基于六角网格的双三次插值算法基于方形网格上的双三次插值算法,虽然能取得令人满意的效果,与双线性插值类似,如果要用在基于六角网格的图像上,需要对此双三次插值方法进行改进。因为在方形网格中,对图像进行双三次插值时,对图像的每个像素灰度的读取是按每行每列顺序进行的,而我们所要做的工作是希望是在SA定址算法的基础上来重新计算像素的灰度值,以达到重建的目的。对于六角结构下的小像素的灰度值的计算采用双三次插值法,具体的对于每个六角像素,在进行SA算法定址后,对其六角网格坐标分别除以7对应于原图,即六角像素的坐标为,除以7之后对应于原图的坐标为,由于六角像素的坐标不同与四角像素的坐标,除以7之后,会出现浮点的情况,这样于是,可以通过双三次插值来处理。具体地,对的坐标取整,得到坐标,取原图中它周围的15个点的灰度值:, ,。上述共16个插值基点,通过双三次插值计算出小六角像素的灰度值。以此类推,得到所有小六角像素的灰度值。3.5.3 实现基于六角网格的双三次插值法对于一张四角像素的灰度图,转换为基于六角像素的灰度图并进行双三次插值,其中的步骤与双线性插值算法处理六角像素相似。不同之处在于后者使用双三次插值算法对中心六角像素的六角网格坐标进行双三次插值。对于一张四角像素组成的灰度图,可以转换为模拟六角像素并进行双线性插值,具体实现步骤如下:(1) 在四角结构下,将一个四角像素细分为7×7的小像素,中心小像素的灰度值为原四角像素的灰度值。(2) 通过双线性插值求出小像素的灰度值。(3) 通过SA算法定址,确定六角网格的坐标,找出六角像素与四角像素之间的关系,从而得到六角像素中心子像素的灰度值。(4) 通过六角网格中心小像素对应的六角网格坐标以及小像素在原图中对应像素的周围16个邻点像素的灰度值进行双三次插值算法,从而算出小六角像素的灰度值。双三次插值代码编写的关键部分:%计算六角小像素的灰度方法:双三次插值 if (floor(m)<=1)|(floor(n)<=1) Y(x,y)=J(1,1);elseif (floor(m)=m)&&(floor(n)=n) Y(x,y)=J(floor(m),floor(n);elseif (floor(m)<nrows/7-1) && (floor(n)<ncols/7-1) I22=double(J(floor(m),floor(n); I12=double(J(floor(m)-1,floor(n); I11=double(J(floor(m)-1,floor(n)-1); I21=double(J(floor(m),floor(n)-1); I31=double(J(ceil(m),floor(n)-1); I41=double(J(ceil(m)+1,floor(n)-1); I42=double(J(ceil(m)+1,floor(n); I32=double(J(ceil(m),floor(n); I33=double(J(ceil(m),ceil(n); I23=double(J(floor(m),ceil(n); I13=double(J(floor(m)-1,ceil(n); I14=double(J(floor(m)-1,ceil(n)+1); I24=double(J(floor(m),ceil(n)+1); I34=double(J(ceil(m),ceil(n)+1); I44=double(J(ceil(m)+1,ceil(n)+1); I43=double(J(ceil(m)+1,ceil(n); S=double(zeros(8); u=m-floor(m); S(1)=u+1;S(2)=u;S(3)=u-1;S(4)=u-2; v=n-floor(n); S(5)=v+1;S(6)=v;S(7)=v-1;S(8)=v-2; for i=1:8 if (abs(S(i)<1) && (abs(S(i)>=0) S(i)=1-2*power(abs(S(i),2)+power(abs(S(i),3); elseif (abs(S(i)<2) && (abs(S(i)>=1) S(i)=4-8*abs(S(i)+5*power(abs(S(i),2)-power(abs(S(i),3); else S(i)=0; end endY(x,y)=uint8(S(1) S(2) S(3) S(4)*I11 I12 I13 I14;I21 I22 I23 I24;I31 I32 I33 I34;I41 I42 I43 I44*S(5);S(6);S(7);S(8);elseY(x,y)=J(floor(m),floor(n); end 具体代码参见本论文配套光盘中的bicubic.m文件 (5) 四角结构下重建图像,并显示。第四章 实验结果及分析4.1 实验结果按照第3章插值实验设计的方法,我们选用了两张人物灰度图像lena_new.bmp和beauty.bmp分别进行实验,将实验结果输出的图像与原图像进行分析比较得到以下结果:图4-1(a)是基于方形网格的lena_new.bmp原图,图(b)是经过双线性插值重建后的效果图,图(C)是经过双三次插值重建后的效果图。 (a)lena_new.bmp原图 (b) 双线性插值重建后 (c) 双三次插值重建后图4-1 lena_