首页 / 专利库 / 电脑零配件 / 多核处理器 / LARGE KERNEL FILTERING USING A FIXED-SIZE BLOCK PROCESSOR

LARGE KERNEL FILTERING USING A FIXED-SIZE BLOCK PROCESSOR

阅读:750发布:2022-08-24

专利汇可以提供LARGE KERNEL FILTERING USING A FIXED-SIZE BLOCK PROCESSOR专利检索,专利查询,专利分析的服务。并且A method and system for filtering a digital image with a filter larger than the hardware capabilities of the imaging system is workable by subdividing the large filter into a number of small filters which can each be individually processed by the system. The method includes the steps of: segmenting the digital image into data blocks of a predetermined size; overlapping adjacent data blocks by a predetermined number of pixels; providing a preselected filter kernel; generating small filters by processing a preselected group of components of the filter kernal; applying each of the small filters to each overlapped data block to produce component data blocks; and merging and saving the component data blocks into filtered data blocks according to a predetermined specific criteria, whereby the filtered data blocks represent the filtered digital image.,下面是LARGE KERNEL FILTERING USING A FIXED-SIZE BLOCK PROCESSOR专利的具体信息内容。

WHAT IS CLAIMED IS:
1. A method for filtering a digital image, comprising the steps of: segmenting said image into data blocks of a predetermined size; overlapping adjacent said data blocks by a predetermined number of pixels; providing a preselected filter kernel; generating small filters by processing a preselected group of components of said filter kernel; applying each said small filter to each said overlapped data block to produce component data blocks; merging and saving said component data blocks into filtered said data blocks according to a predetermined specific criteria, said filtered data blocks representing the filtered digital image.
2. A method for filtering a digital image, comprising the steps of: segmenting said image into data blocks of a predetermined size; overlapping adjacent said data blocks by a predetermined number of pixels; generating DCT blocks by performing a discrete cosine transform (DCT) on each said overlapped data block; providing a preselected filter kernel; generating small filters by processing a preselected group of components of said filter kernel; generating DOCT filters by performing a discrete odd cosine transformation (DOCT) on each said small filter; generating mask multiplied blocks by mask multiplying each DCT block times each DOCT filter; generating IDCT blocks by performing an inverse discrete cosine transform (IDCT) on each said mask multiplied block; and merging and saving said IDCT blocks into filtered data blocks according to a predetermined specific criteria, said filtered data blocks representing the filtered digital image. AMENDED CLAIMS
[received by the International Bureau on 7 August 1997 (07.08.97); new claims 3-7 added; remaining claims unchanged (2 pages)]
3. A method for filtering a digital image, comprising the steps of segmenting said image into data blocks of a prede etmined size; overlapping adjacent said data blocks by a predetermined number of pixels to generate overlapped blocks; providing a large filter having predetermined large filter coefficients, said large filter represented by a large filter kernel having predetermined degrees of freedom; generating a number of small filters, having small filter coefficients, to emulate said large filter by establishing a mathematical relationship between said large filter coefficients and said small fitter coefficients; producing component data blocks by point-by-point filtering of said overlapped blocks with said small filters; and emulating filtering of the image with said large filter by combining said component data blocks,
4. The method of claim 3, wherein the step of generating small filters comprises: deteπnining one filtered pixel value, represented in terms of said large filter coefficients, by point-by-point filtering of the image with said large filter; selecting said small filters to emulate said large filter by accounting for said predetermined degrees of freedom; applying said small filters to portions of the image via point-by-point filtering to obtain values represented in terms of said email filter coefficients; end determining said small filter coefficients by equating said one filtered pixel value with said values, then substituting said large kernel coefficients into said equation.
5. The method of claim 3, further comprising the steps of: generating DCT blocks by performing a discrete cosine transform (DCT) on each said overlapped data block; generating DOCT filters by performing a discrete odd. cosine transformation (DOCT) on each said small filter: generating mask multiplied blocks by mask multiplying said DCT blocks times said DOCT filters; generating IDCT blocks by performing an inverse discrete cosine transform (IDCT) on each said mask multiplied block; and merging and saving said IDCT blocks into filtered data according to said predetermined criteria, said filtered data representing the filtered digital image.
6. The method of claim 5, wherein said merging and saving step comprises selecting a number of IDCT blocks equal to or greater than the number of small filters.
7. The method of claim 6 wherein the merging and saving step further comprises obtaining said filtered data by combining one preselected pixel value from each one of the selected IDCT blocks.
说明书全文

LARGE KERNEL FILTERING USING A FIXED-SIZE BLOCK PROCESSOR

BACKGROUND OF THE INVENTION

1. Field of the Invention

The invention relates generally to an improved method and apparatus for digital image processing. More particularly, the invention relates to a novel method and apparatus for filtering a digital image in the frequency domain using a filter kernel which is conventionally considered to be too large to be used with the resident block processing hardware.

2. Description of the Prior Art

A digital image can be electronically filtered in a number of ways, including filtering in the frequency domain such as the discrete fourier transform (DFT) or the discrete even cosine transform (DCT) domain. Typically, filtering the image in the DCT domain will provide the same results as a mathematical convolution in the spatial domain.

Convolution of an image, as understood by those skilled in the art, is a process of filtering in the spatial domain by multiplying two discrete signals point-by-point, then summing the products over appropriate limits. Convolution generally results in filtering by sharpening or smoothing an image. Sharpening enhances blurry images, particularly by enhancing high frequency components representing edges in an image, whereas smoothing softens the edges of the image.

The steps required for filtering a digital image in the DCT domain in a manner which is mathematically equivalent to a convolution in the spatial domain are detailed in U.S. Patent Application No. 08/159,795 filed November 30, 1993 by Munib A. Wober and Michael L. Reisch. The steps generally proceed as follows.

The digital image is first segmented into MxN blocks of pixels, where M and N are preselected integers. This is done to provide compatibility of the block sizes with the processing limitations of commercially available chips. For instance, 8x8 block processing chips conform to international compression standards set by JPEG (Joint Photographic Experts Group) and MPEG (Motion Picture Experts Group). Adjacent blocks of pixels are typically overlapped in the spatial domain. The amount of overlap is variable, depending on the size of the filter and the size of the DCT. The overlapped blocks are then transformed to DCT matrices or blocks in the frequency domain by taking a DCT of each overlapped block.

An odd, symmetrical filter is chosen and represented by a filter kernel defined as the signal values of the filter used for performing a specific filtering operation such as sharpening or smoothing. A discrete odd cosine transformation (DOCT) of the filter kernel is taken to generate a DOCT matrix of DOCT coefficients. Then a mask multiplied matrix is generated by mask multiplying (i.e. point-by-point multiplication) each DCT matrix times the DOCT matrix. Finally, an inverse discrete cosine transformation (IDCT) is taken of the mask multiplied matrix to generate a reconstructed filtered block of pixels in the spatial domain. These IDCT coefficients represent the filtered image.

Only certain points of the filtered block are saved. The other points within the filtered block are discarded. Specifically, the number of saved points for each block is given by

G = N - (K -1) (1) where G is the number of points to be saved in each block after filtering, N is the size of the block, K is the length of the filter (which is alternatively referred to as the kernel, or the filter kernel), and (K-1V2 is the amount of overlap between adjacent blocks. Note also that, due to symmetry, the number of independent coefficients (i.e. the degrees of freedom) in the filter equals {K - (K-1V2}. For example if N=8 and K=5, then the number of saved points, G, is equal to 4. In other words, using a block size of 8 with a 5 point filter provides 4 saved filtered points from each filtered block. From equation (1) it is clear that N must be greater than or equal to K to generate any saved points G, i.e. the length of the filter can be no longer than the length of the pixel block. The above principles, of course, extend to multi-dimensional filtering.

One shortcoming to conventional image filtering occurs when the available processor has a processing capability which is smaller than the chosen filter length. This hardware limitation is present whether the filtering occurs in either the spatial or frequency domain. When filtering high quality images, such as those used in graphical arts and medical imaging, a large size filter (e.g. 9 point or 13 point) is often desirable, although the available processor may be limited to processing, for instance, 8x8 blocks of image data.

Consequently, it is a primary object of the present invention to provide a method and apparatus for filtering a digital image in either the spatial or frequency domain using a filter which is larger in size than the processing capability of the associated chip. This and other objects will become apparent from the following detailed description and drawings.

SUMMARY OF THE INVENTION

A method and system for filtering a digital image with a filter larger than the hardware capabilities of the imaging system is workable by subdividing the large filter into a number of small filters which can each be individually processed by the system. The method includes the steps of: segmenting the digital image into data blocks of a predetermined size; overlapping adjacent data blocks by a predetermined number of pixels; providing a preselected filter kernel; generating small filters by processing a preselected group of components of the filter kernel; applying each of the small filters to each overlapped data block to produce component data blocks; and merging and saving the component data blocks into filtered data blocks according to a predetermined specific criteria, whereby the filtered data blocks represent the filtered digital image.

BRIEF DESCRIPTION OF THE DRAWINGS

The aforementioned aspects and other features of the invention are described in detail in conjunction with the accompanying drawings in which the same reference numerals are used throughout for denoting corresponding elements and wherein:

Figure 1 A is a block diagram of the inventive method;

Figure IB is a block diagram of a preferred embodiment of the inventive method of Figure 1;

Figures 2-19D are all directed towards the preferred embodiment of Figure IB;

Figure 2 is a diagram depicting nine separate 8x8 pixel blocks in an area of an image where 0 < i < 15 and O < j < 15;

Figures 3A, 3B and 3C are diagrams depicting horizontal overlapping of the pixel blocks of Figure 2;

Figures 4A, 4B and 4C are diagrams depicting vertical overlapping of the pixel blocks of Figure 2;

Figure 5 is a diagram depicting both vertical and horizontal overlapping of the adjacent pixel blocks of Figure 2;

Figure 6 is a diagrammatic representation of a filtered 8x8 pixel block;

Figure 7 is a diagram showing nine 8x8 pixel blocks before and after DCT processing;

Figures 8-12 are diagrammatic representations of a 5x5 point large filter kernel and the small filter coefficients generated therefrom;

Figure 13 is a matrix representation of the small filter kernel SMALL 1;

Figure 14 is a matrix representation of the small filter kernel SMALL2;

Figure 15 is a matrix representation of the small filter kernel SMALL3;

Figure 16 is a diagram showing nine 8x8 DCT blocks multiplied by each of three small filters to generate three sets of filtered DCT blocks;

Figure 17 is a diagram depicting the transformation of the three filtered 8x8 DCT blocks of Figure 16 to the spatial domain via an IDCT;

Figure 18 is a representation of the saved region of an 8x8 filtered pixel block; Figure 19A is a diagrammatic representation of the derivation of α values for the upper left portion of the saved region of Figure 18;

Figure 19B is a diagrammatic representation of the derivation of β values for the lower left portion of the saved region of Figure 18;

Figure 19C is a diagrammatic representation of the derivation of γ values for the upper right portion of the saved region of Figure 18; and

Figure 19D is a diagrammatic representation of the derivation of μ values for the lower right portion of the saved region of Figure 18.

DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS

The primary example detailed in this disclosure relates to a preferred embodiment of the invention using DCT transforms, although the inventive process is not limited to DCT processing.

1. DCT Mathematics

This section sets forth certain fundamental concepts relating to forward and inverse discrete cosine transforms.

An image is typically made up of a two-dimensional PxQ array of descriptors called pixels or image data points, where P is the number of rows and Q is the number of columns representing the image. The image can be represented by either image data points in the spatial domain, or by corresponding DCT coefficients in the frequency domain. A forward DCT generates the DCT coefficients by taking a discrete even cosine transformation (DECT abbreviated as DCT) of the image data points. Conversely, an inverse discrete even cosine transformation (IDECT abbreviated as IDCT) generates the IDCT coefficients (i.e. reconstructed image data points) by taking an inverse discrete cosine transformation of the DCT coefficients.

A DCT transformation can occur in any number of dimensions as understood by those skilled in the art. In the following one-dimensional example, a row (more generically referred to as a segment) of N image data points s(j) can be transformed from the spatial domain to corresponding DCT coefficients S(v) in the frequency domain in accordance with equation (2).

where: j is an integer, v is an integer;

0 < v < (N -l); s(j) represents the matrix of image data points in the segment; S(v) represents the corresponding matrix of DCT coefficients; N represents the number of image data points in the segment;

Cv =*■=* for v = 0; and V2

Cv = 1 for \≠ 0.

The DCT coefficients S(v) are determined from equation (2) where the normalized cosine basis terms are derived for a segment having N image data points. The value for S(0) is determined for v = 0 by summing each of the image data points s(j) for 0 < j < (N-l) times the cosine terms of the basis function. The value for S(l) is determined as the summation of image data points s(j) times the cosine terms for v = 1. This procedure, which indexes first on v and then on j, is repeated for derivation of DCT coefficients S(0) through S(N-1).

The corresponding one-dimensional IDCT equation is written as:

for 0 < j < 7, where s'(j) represents the reconstructed image data points.

A one dimensional discrete odd cosine transform (DOCT) matrix H(u) is shown in equation (4) where h(i) is an odd symmetrical filter kernel. (v) = 2∑ dj h(j) cos^- (4)

for 0 ≤ v ≤ (N-l); where N represents the size of the DCT block used; h(j) = 0 for |j | > (k-l)/2;

d

j = l for i=l, 2 ... (N -l); j, u and N are integers; and k is the kernel size.

2. The Method

One-Dimensional Processing

A block diagram of a preferred embodiment of the inventive filtering method for filtering an image using a filter larger than the processing capability of the available processor is illustrated in Figure 1. The processor is a standard 8x8 DCT chip (e.g. an MPEG or JPEG chip) which can be used to process one or two dimensional blocks of image data points. A digital image is acquired in block 10 as from a digital camera, a scanner, or a memory.

The image is segmented in block 12 into 8 point pixel blocks where a four pixel overlap is provided between adjacent pixel blocks in block 14. For instance, a first 8 point block can be represented as {s0, s-, s , s3, s4, s5, s6, s7}, a second overlapping 8 point block can be represented as {s4, s5, s6, s , s8, s , sio, sπ}, etc. A DCT is performed on each 8 point block of pixels in block 16. The large filter (i.e. larger than the hardware processing capability - in this case, a 9 point symmetrical filter) is selected in block 22. Typically the large filter values will be predetermined for the particular imaging system and application of interest, and they will be stored in long term memory for easy retrieval. However for the general case, any size filter can be selected which is larger than any size processor.

The selected 9 point symmetrical filter can be represented as the set

LARGE = {£,, f3, f2, fi, fo, f., f2, f3, £.} (5)

A 9 point pixel block can be represented as the set IMAGE = {s.2, s.ι, so, st, s2, s3, s , s5, s6}, (6) and point-by-point filtering of IMAGE by LARGE for determining a filtered center pixel element s2 yields

S2 = {f»S.2 + f3S.] + f2S0 + fiSi +f0S2 + f]S3 + f2s4 + f3s5 + f s6} (7) where s2 represents the filtered center element s .

It is well known in the art that a symmetrical 9 point filter can be represented as a 5 point filter kernel {f0, f*, f2, f , f4} having five degrees of freedom. Hence, in keeping with the objective of the inventive method for converting the 9 point filter into a number of smaller filters which can readily be processed by the available hardware, the small filters selected must account for five degrees of freedom in order to properly emulate the 9 point filter.

One of the small filters, SMALL1, is selected as a five point filter that can be implemented using a standard 8x8 block processor.

SMALL1 = {po2, po1, p0°, Po\ Po2} (8)

SMALL 1 can be represented by a filter kernel having three degrees of freedom {po°, Po', Po2}. Point-by-point filtering of IMAGE by SMALL1 for determining a center pixel element, CENTER, yields

CENTER = {po2 s0 + po1 s, + p0° s2 + po1 s3 + p0 2 s4} . (9)

According to the method, two more degrees of freedom are required for a total of five degrees of freedom for any combination of small filters to emulate the large filter. For instance, a second 5 point small filter

SMALL2 = {p,2, p1 l, p1 0, p1 1, p,2} (10) provides two degrees of freedom when the center element p*° is set to zero. To retain symmetry, SMALL2 should be applied to both the left and right sides of IMAGE. Note that since the processing is equivalent to 9 point filtering, the nine points of IMAGE are each considered for their effect at s2. Hence, the left side of IMAGE which is point-by- point filtered by SMALL2 is represented as,

LEFT -^ p^ + p- 's-i + pΛo + p i + p ;.} (11) where pι° = 0, and the right side of IMAGE which is point-by-point filtered by SMALL2 is represented as,

RIGHT = {p,2s2 + pi 's3 + pι°s4 + pι's5 + pι2s6} (12) where p*° *■*= 0. None of the small filters processes a group of pixels which is larger than the 8 point processing capability of the system.

The effects of the processing by the two small filters SMALL 1 and SMALL2 can be combined to emulate the 9 point filtering of s2 so that, s2 = CENTER + LEFT + RIGHT (13)

= {po2so + Po'si + po°s2 + po's*? + ρ0 2s4}

+ { Pι s-2 + p s-i + pι°so + pi'si + pι2s2} + {pι2S2 + Pi 's3 + pι°s + pi 's5 + pι s6} . (14)

Solving equation (14) yields the following relationships between the LARGE filter kernel coefficients {f0 , fi, f2, f3, f4} and both the SMALL 1 and SMALL2 filter kernel coefficients {po°, po', Po2} and {p p-2}, respectively: fo = Pι ; f. = Po ; f3 = p1 1; f« = pι ; po = fo - 2£*;

Po = f2i

Pι' = f3; and

P.2 = f - Since the large filter coefficients are known values, the small filter coefficients are easily solved.

Once the small filters are generated, a DOCT is taken of each small filter SMALL1, SMALL2 ...SMALLN in block 26 of Figure 1 to yield DOCT filters Hl(v), H2(v)... HN(v), respectively. Block 18 provides for each DCT block XI, X2, X3, X4, X5, X6, X7 and X8 to be mask multiplied times each one of the DOCT filters HI, H2 ... HN to yield mask multiplied blocks Xj, X2 ... Xg . At this point, an IDCT is performed in block 20 on each mask multiplied block X*, X2 ... Xg to yield corresponding spatial domain blocks s'(j) of reconstructed image data points. The DCT domain blocks are designated by upper case letters and the spatial domain blocks are designated by lower case letters. Each original pixel block in the present example is now represented by three separate 8 point filtered blocks which are the results of the mask multiplication of each DCT block times the DOCT filters HI and H2. The three filtered blocks corresponding to each original 8 point block must now be merged together into a single 8 point filtered block as shown in Figure 1 at block 28.

The above procedure is followed for each 8 point block of the image until all pixels have been filtered and saved. The pixels at the left and right edges of the image can, of course, be dealt with conventionally - such as by extrapolating information from neighboring pixels or merely duplicating neighboring pixel values.

Two-Dimensional Processing

The above one-dimensional mathematics is readily expandable to multi- dimensions as understood by those skilled in the art. Furthermore, the choice (and number) of small filters is variable in keeping with the condition of equating the sum of the degrees of freedom of the small filter kernels with the total degrees of freedom of the large filter kernel.

The block diagram of Figure 1 is equally applicable for illustrating the method in multiple dimensions. The standard 8x8 DCT chip is capable of processing two dimensional blocks of image data points. First, a digital image is acquired in block 10 as from a digital camera, a scanner, or from a memory. The image is segmented in block 12 into 8x8 pixel blocks. Thereafter, adjacent pixel blocks are overlapped in block 14 by four pixels in each dimension. The overlapping procedure is illustrated in Figures 2 through 5. An original portion of an image where 0 < i ≤ 15 and 0 < j < 15 can be broken into nine 8x8 overlapped pixel blocks (blocks xO, xl, x2, x3, x4, x5, x6, x7 and x8) shown in Figure 2 where block xO contains values for 0 < i < 7, 0 < j < 7; block xl contains values for 4 < i < 11 , 0 < j < 7; etc. Figure 3A shows the 4 point horizontal overlap of block xl with blocks xO and x2; Figure 3B shows the 4 point horizontal overlap of block x4 with blocks x3 and x5; and Figure 3C shows the 4 point horizontal overlap of block x7 with blocks x6 and x8. Figure 4 A shows the 4 point vertical overlap of block x3 with blocks xO and x6; Figure 4B shows the 4 point vertical overlap of block x4 with blocks xl and x7; and Figure 4C shows the 4 point vertical overlap of block x5 with blocks x2 and x8. Figure 5 shows the result of both horizontal and vertical 4 point overlap of the nine blocks of Figure 2.

The nine 8x8 overlapped pixel blocks xO, xl, x2, x3, x4, x5, x6, x7 and x8 shown in Figure 2 are each subjected to a discrete cosine transformation in block 16 of Figure 1 to generate nine corresponding 8x8 DCT blocks XO, XI, X2, X3, X4, X5, X6, X7 and X8, respectively, as shown in Figure 7. Prior to performing mask multiplication in block 18, a filter must be selected and processed.

A large filter (i.e. a filter larger than the available hardware processing capability) is selected in block 22. For this example, a 9x9 point odd symmetrical filter is selected for processing with the standard JPEG 8x8 point processor.

The selected large filter is broken into a subset of small filters in block 24. Utilizing the minimum number of small filters necessary to process the image will result in maximum efficiency although in some cases, additional small filters can be used if desired. The process of generating appropriate small filters, which together emulate the large filter, is set out below for two dimensional processing. Those skilled in the art can readily expand the two-dimensional processing set out below to higher-dimensional processing as desired.

Figures 8-15 are helpful in understanding how small filter coefficients are determined for two-dimensional filtering of an 8x8 block of image data points using a 9x9 filter. Figure 13 shows a 3x3 filter kernel corresponding to a first small filter SMALL1; Figure 14 shows a 3x3 filter kernel corresponding to a second small filter SMALL2; and Figure 15 shows a 3x3 filter kernel corresponding to a third small filter SMALL3. The various coefficients of the small filters are derived from the known large filter coefficients. Each figure 8-12 depicts a filter kernel of the selected 9x9 large filter. Mathematical processing including solving simultaneous equations as described above yields the small filter coefficients {a, b, c, d, e, g, k, 1, m, n, p, w, x, y, z} in terms of the known large filter coefficients.

Once the small filters are generated, a discrete odd cosine transform (DOCT) is taken of each small filter SMALL1, SMALL2 ...SMALLN in block 26 of Figure 1 to yield DOCT filters Hl(v,u), H2(v,u) ... HN(v,u). The method for generating a DOCT of a two-dimensional image block is well known in the art as described, for instance, in previously cited U.S. Patent Application No. 08/159,795. To facilitate multiplication of the small filters with the 8x8 pixel blocks, the small filters are padded with zeroes. Then a two-dimensional DOCT is performed on each small filter such that,

N-l M-l wπ ιvπ

H(v,u) = ∑ ∑ d, dj hi- Q,i) cos cos- — ( 15 ) i-O j-0 N M

for 0 < u < (N-l) and 0 < v < (N-l), where hp(j,i) is the two dimensional padded small filter;

N is the number of elements of hp(j,i) in the first dimension;

M is the number of elements of hp(j,i) in the second dimension;

d, = 1 for i = 1, 2, ... (N-l); d

j = V

2 forj = 0; d

j = 1 forj = 1, 2, ...(M-l); i, j, u, v, N, M are integers; and

kPG,i) = 0 for | i | or |j | > -^ .

For the present example, hp(j,i) represents a padded small filter SMALLN (N being an integer) where H(v,u) is calculated for Hl(v,u), H2(v,u) ... HN(v,u).

Block 18 of Figure 1 provides for each DCT matrix XO, XI, X2, X3, X4, X5, X6, X7 and X8 to be mask multiplied times each one of the DOCT matrices H(v,u), yielding the mask multiplied blocks (Xoo, Xio, -X82) that are shown in Figure 16. At this point, an IDCT is performed in block 20 on each mask multiplied block (Xoo, Xio, ...Xg2) to yield corresponding spatial domain blocks (xoo, xio- — X82) as shown in Figure 17. Note that DCT domain blocks are designated by upper case letters and spatial domain blocks are designated by lower case letters. Each original pixel block is now represented by three separate 8x8 filtered blocks which are the results of the mask multiplication of each DCT block times the three DOCT filters H(v,u). The three filtered blocks corresponding to each original 8x8 block must now be merged together into a single 8x8 filtered block as shown in Figure 1 at block 28. The result of the complete processing of each 8x8 pixel block is a 4x4 filtered and saved region as depicted in Figure 18. The saved region is subdivided into an upper left hand corner having four α values, an upper right hand corner having four γ values, a lower left hand corner having four β values and a lower right hand corner having four μ values. Each subdivision of the saved region is separately calculated as follows.

The four α values are determined by evaluating each of the blocks shown in Figure 19A at i = {3,4} and j = {3,4}. Each of the nine blocks x-*o, xπ, Xι2, X41, x42, X 1, x 2, x3ι and x02 is taken from the results of the IDCT of block 20 (see Figure 1) as shown in Figure 8. Specifically for i=3 and j=3, α(0,0) equals the sum of x40(3,3), xπ(3,5), xι2(5,5), x ι(5,3), x42(5,5), x4ι(3,5), x32(5,5), x3ι(5,3) and xo2(5,5). For i=3 and j=4, α(0,l) equals the sum of x o(3,4), xn(3,6), xι2(5,6), x4ι(5,4), x 2(5,6), X4i(3,6), x32(5,6), x3ι(5,4) and xo2(5,6). For i=4 and j=3, α(l,0) equals the sum of x40(4,3), xn(4,5), xι2(6,5), x ι(6,3), x 2(6,5), x4ι(4,5), x32(6,5), x3ι(6,3) and x02(6,5). For i=4 and j=4, α(l,l) equals the sum of x40(4,4), xn(4,6), xi2(6,6), x4ι(6,4), x 2(6,6), x4ι(4,6), x32(6,6), x3ι(6,4) and x02(6,6).

The four β values are determined by evaluating each of the blocks shown in

Figure 19B at i = {3,4} and j = {5,6}. Each block X40, x ι, X-t2, x-u, X72, X71, 62, 31 and x32 is taken from the results of the IDCT of block 20 (see Figure 1) as shown in Figure 8. Specifically for i=3 and j=5, β (0,0) equals the sum of x4o(3,5), x4ι(3,3), x42(5,3), x ι(5,5), x72(5,3), x7ι(3,3), x62(5,3), x3ι(5,5) and x32(5,3). For i=3 and j=6, β(0,l) equals the sum of x40(3,6), x4ι(3,5), x42(5,4), x4](5,6), x72(5,4), x7ι(3,4), x62(5,4), x3 t(5,6) and X32(5,4). For i=4 and j=5, β(l,0) equals the sum of x40(4,5), x4ι(4,3), x42(6,3),

x

72(6,3), x

7ι(4,3), x

62(6,3), x

3ι(6,5) and x

32(6,3). For i=4 and j=6, β (1,1) equals the sum of x

40(4,6), x ι(4,4), x

2(6,4), x

4ι(6,6), x

72(6,4), x

7*(4,4), x

62(6,4), x

3ι(6,6) and x

32(6,4).

The four γ values are determined by evaluating each of the blocks shown in Figure 19C at i = {5,6} and j = {3,4}. Each of the nine blocks X40, x4ι, x-j2, X41, x52, X51, x22, xi 1 and x*2 is taken from the results of the IDCT of block 20 (see Figure 1) as shown in Figure 8. Specifically for i=5 and j=3, 7(0,0) equals the sum of X40(5,3), x4ι(3,3), x42(3,5), x 1(5,5), x52(3,5), x5ι(3,3), x 2(3,5), xn(5,5) and x12(3,5). For i=5 and j=4, γ(0,l) equals the sum of x40(5,4), x4ι(3,4), x^^ό), x4ι(5,6), x52(3,6), x5ι(3,4), x22(3,6), xn(5,6) and xι2(3,6). For i=6 and j=3, 7(1,0) equals the sum of x 0(6,3), x4|(4,3), x 2(4,5), X4i(6,5), x52(4,5), x5ι(4,3), x22(4,5), xn(6,5) and x12(4,5). For i=6 and j=4, 7(1,1) equals the sum of x40(6,4), x ι(4,4), x42(4,6), x !(6,6), x52(4,6), x5ι(4,6), x22(4,6), xι,(6,6) and xι2(4,6).

The four μ values are determined by evaluating each of the blocks shown in Figure 19D at i = {5,6} and j = {5,6}. Each of the nine blocks x 0, x^, x72, x7ι, x82, x51, x5 , x4| and x42 is taken from the results of the IDCT of block 20 (see Figure 1) as shown in Figure 8. Specifically for i=5 and j=5, μ(0,0) equals the sum of x4o(5,5), x4ι(3,5), x72(3,3), x7ι(5,3), xs2(3,3), x5ι(3,5), x52(3,3), x ι(5,3) and X 2(3,3). For i=5 and j=6, μ(0,l) equals the sum of x40(5,6), x 1(3,6), x72(3,4), x7ι(5,4), x82(3,4), x5i(3,6), x52(3,4), x ι(5,4) and X42(3,4). For i=6 and j=5, μ(l,0) equals the sum of x 0(6,5), x4ι(4,5), x72(4,3), x7ι(6,3), xg2(4,3), x5ι(4,5), x52(4,3), x4ι(6,3) and x 2(4,5). For i=6 and j=6, μ(l,l) equals the sum of x40(6,6), x4ι(4,6), x7 (4,4), x7ι(6,4), x82(4,4), x5*(4,6), x52(4,4), x4](6,4) and x42(4,4).

The above procedure is followed for each 8x8 block of the image until all pixels in the image have been filtered and saved. The pixels around the perimeter of the image can, of course, be dealt with conventionally - such as by extrapolating information from neighboring pixels or merely duplicating neighboring pixel values.

It is to be understood that the above described embodiments are merely illustrative of the present invention and represent a limited number of the possible specific embodiments that can provide applications of the principles of the invention. Numerous and varied other arrangements may be readily devised in accordance with these principles by those skilled in the art without departing from the spirit and scope of the invention as claimed.

高效检索全球专利

专利汇是专利免费检索,专利查询,专利分析-国家发明专利查询检索分析平台,是提供专利分析,专利查询,专利检索等数据服务功能的知识产权数据服务商。

我们的产品包含105个国家的1.26亿组数据,免费查、免费专利分析。

申请试用

分析报告

专利汇分析报告产品可以对行业情报数据进行梳理分析,涉及维度包括行业专利基本状况分析、地域分析、技术分析、发明人分析、申请人分析、专利权人分析、失效分析、核心专利分析、法律分析、研发重点分析、企业专利处境分析、技术处境分析、专利寿命分析、企业定位分析、引证分析等超过60个分析角度,系统通过AI智能系统对图表进行解读,只需1分钟,一键生成行业专利分析报告。

申请试用

QQ群二维码
意见反馈