EP1057142A1 - Image processing method using a block overlap transformation procedure - Google Patents

Image processing method using a block overlap transformation procedure

Info

Publication number
EP1057142A1
EP1057142A1 EP99906861A EP99906861A EP1057142A1 EP 1057142 A1 EP1057142 A1 EP 1057142A1 EP 99906861 A EP99906861 A EP 99906861A EP 99906861 A EP99906861 A EP 99906861A EP 1057142 A1 EP1057142 A1 EP 1057142A1
Authority
EP
European Patent Office
Prior art keywords
block
blocks
window
signal
blending
Prior art date
Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
Withdrawn
Application number
EP99906861A
Other languages
German (de)
French (fr)
Inventor
Albert D. Edgar
Current Assignee (The listed assignees may be inaccurate. Google has not performed a legal analysis and makes no representation or warranty as to the accuracy of the list.)
Applied Science Fiction Inc
Original Assignee
Applied Science Fiction Inc
Priority date (The priority date is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the date listed.)
Filing date
Publication date
Application filed by Applied Science Fiction Inc filed Critical Applied Science Fiction Inc
Publication of EP1057142A1 publication Critical patent/EP1057142A1/en
Withdrawn legal-status Critical Current

Links

Classifications

    • GPHYSICS
    • G06COMPUTING; CALCULATING OR COUNTING
    • G06TIMAGE DATA PROCESSING OR GENERATION, IN GENERAL
    • G06T9/00Image coding
    • G06T9/007Transform coding, e.g. discrete cosine transform

Definitions

  • the present invention relates to image processing, and more particularly to image processing using tiles and reducing tile edge artifacts.
  • Modern computers deal with memory and processing demands of scanning and manipulating images in several ways. For a large image, only a part or block of the image is read from disk storage and transferred into active memory. These blocks of the image undergoing active processing are called tiles. When a tile has been processed, the tile is written back to disk storage, and the next tile is read from the disk. By processing an image in tiles, the entire image need not be stored in active memory at one time. Many modern computers, such as the Intel MMX system, operate on multiple data paths in parallel. To utilize parallel processing, different parts of the image must be processable in parallel.
  • the MPEG algorithms used in digital video processing are examples of tiled image processing. The tiles permit full use of parallel processing and minimal active memory, but such processing may produce edge artifacts between the tiles which are seen after the tiles are reassembled and are commonly known to MPEG and JPEG images.
  • Figure 1 illustrates the processing of an image 102 to produce a resultant image 104.
  • the image Prior to applying the processing algorithm 106, the image is sectioned into two-dimensional blocks 108, and the processing step 106 is applied individually to each block, such as block 110, to produce resultant blocks, such as block 112.
  • the processed blocks 114 are then reassembled like a jigsaw puzzle to form the resultant image 104.
  • Similar processing can be applied to a one-dimensional string of data, such as that from a processed signal, instead of a two-dimensional ordering of data.
  • the sectioned one-dimensional blocks are called frames.
  • the string is sectioned into frames, the processing applied to each frame, then the processed frames recombined to form a resultant string of processed signal data.
  • the input signal can be composed of discrete samples as in digital audio and image, or the signal can be a continuum such as that found in analog audio and film images or analog video. Block processing methods apply to both analog and digital signals.
  • the processing step 106 of Figure 1 can take many forms. For example, it may include transforming, compressing, and storing the data, as is common in JPEG and MPEG image compressions.
  • a class of processings is illustrated in Figure 2, wherein a data frame 202 undergoes a transformation step 204 to form a related frame 206 of numbers in a different transform space.
  • the input data frame 202 oscillates slowly as seen by the numbers inside the individual spatial elements.
  • the transformation step 204 is a frequency transform, so the related frame 206 is in frequency transform space. A higher number is found at the frequency element 208 corresponding to the frequency of the oscillation.
  • the frame 208 in transform space may undergo additional processing 210 such as a compression process step which compresses or limits high frequencies. Compression is but one example of an additional process which the data may undergo.
  • the frame 206 is processed by transformation step 212, the inverse of transformation step 204, to output the processed frame 214.
  • Block 302 is a single block from a segmented image, such as block 110 of image 102 shown in Figure 1. Based on the specific data shown, block 302 has a horizontal low frequency oscillation and a high frequency vertical oscillation. Transformation step 304 converts the numbers in block 302 into a frequency transform space 306, with specific frequency element 308 high due to the vertical high frequency oscillation, element 310 high due to horizontal low frequency oscillation, and element 312 high due to the "DC", or average.
  • processing step 314 is applied in the transform space to block 306 to produce block 316.
  • the processing step 314 is a low pass filter which erases to zero in block 316 all frequency terms exceeding a frequency denoted by dotted line 318, such as high frequency element 308.
  • transformation step 320 the inverse of transformation step 304, is applied to block 316 to produce block 322.
  • block 322 contains numbers similar to block 302 except that rapid changes with space, such as the high frequency oscillations, have been removed.
  • Input signal 410 will be processed using the prior art method described above.
  • Input signal 410 is represented in this case by a continuum. It is understood that input signal 410 could also be represented by a string of numbers as was used in Figure 2.
  • the difference between numbers and a continuum is the difference between numbers stored on a compact disk versus voltages fed to a speaker, or the difference between pixels scanned digitally versus light patterns received by the eye.
  • the translations between discrete numbers and a continuum are very well understood in the art, such that processes may be though of and explained interchangeably in either form.
  • Input signal 410 in Figure 4a is divided into four, discrete, nonoverlapping frames as shown in Figure 4b. These frames are selected to cover all of the signal without overlapping any portion of the signal.
  • step 412 the change from a low value to a higher value
  • step 416 occurs between frames 3 and 4, and thus appears to be "lost”.
  • each frame is then processed by a low pass filter to soften any edges. It is seen that step 412 has received the desired softening from the low pass filter to produce step 420. Note that the "lost" step 416 has received no softening because it occurred at the transition between frames 3 and 4, and so appears in no frame.
  • step 412 in Figure 4a appears as softened edge 424 as desired, but the step 416 that just happened to occur on the boundary between frame slices still appears as a hard step 426.
  • edge tolerant processing such as a discrete cosine transform (DCT)
  • DCT discrete cosine transform
  • the DCT assembles a wave with only cosine terms that have zero slope at transitions between frames, if any of the waves is removed by, for example, applying a low pass filter, the resultant function will not change slope between frames.
  • Other transforms are not so edge tolerant.
  • DFT discrete Fourier transform
  • a discrete Fourier transform has many desirable properties, but is not in common use for block processing because of its behavior at edges.
  • the present invention segments the image or signal being processed into overlapping blocks, separately processes each block, and reassembles the blocks following the processing.
  • the interstitial topology can be on a diagonal grid.
  • the blocks are windowed such that when they are reassembled by adding them together, the block windows mutually add to unity. Further, the windowing may be applied after processing, or divided before and after the processing step to facilitate edge sensitive processes. In addition, some attributes, such as the "DC" bias, can be separated from the block before processing, and windowed separately before recombining.
  • Figure 1 illustrates a prior art method of processing an image using blocks
  • Figure 2 illustrates a prior art method of processing a one-dimensional signal block in transform space
  • Figure 3 illustrates a prior art method of processing a two-dimensional image block in transform space
  • Figures 4a-4d illustrate prior art problems which arise during processing of non- overlapping one-dimensional blocks
  • FIGS 5a-5d illustrate prior art problems which arise during processing of non-overlapping one-dimensional blocks with an edge sensitive process
  • Figures 6a-6d illustrate the present invention applied to one-dimensional blocks
  • Figure 7 illustrates the present invention applied to two-dimensional image blocks
  • Figures 8a-8c illustrate a specific embodiment of the present invention processing two-dimensional blocks
  • Figures 9a-9e illustrate the present invention applied to one-dimensional blocks with an edge sensitive process
  • Figure 10 illustrates the present invention applied to two-dimensional image blocks with an edge sensitive process
  • Figures 1 la-1 lc illustrate a specific case of applying the present invention to two- dimensional blocks compatible with an edge sensitive process.
  • a continuous graph 602 is divided into multiple frames. As in the prior art processing, the graph is sectioned into frames 1 to 4 of Figure 6a; however, additional frames 1.5, 2.5, and 3.5 are selected such that they overlap a portion of the signal included in frames 1 to 4 of Figure 6a. All of these frames are individually displayed in Figure 6b.
  • edge 604 is represented in frame 2 as edge 606 as in the prior art.
  • edge 608 that was "lost" in the prior art method because of its position between frames 3 and 4 is now represented in one of the overlapping frames, frame 3.5, as edge 610.
  • a low pass filter is applied to every frame in Figure 6b to form the frames in Figure 6c.
  • edges 606 and 610 are softened to produce filtered edges 612 and 614.
  • overlapping frames of Figure 6c need to be reassembled into a complete graph. Because frames are overlapping, frames can not be simply concatenated like a jigsaw puzzle as was done in the prior art described in Figures 4 and 5. Rather, frames must be blended together with a gradual transition between edges taking into account the degree of overlap between blocks. This blending is accomplished by applying a blending window to each frame and then combining the windowed frames. "Applying a blending window" in this context means multiplying each element of a frame by the corresponding element of the window to produce a resulting element of the windowed frame.
  • a frame element can be a digital sample, such as a pixel, or a brief segment of time in an analog signal.
  • “Combining the windowed frames” means to first register the frames so that corresponding elements align, and then to add the values in each of the corresponding elements together to form the processed signal. If one is working in the logarithmic domain, the actual computer operation needed to form an effective multiplication or addition is different than if one is working in a linear domain, and hence the terms “apply” and “combine” encompass these operations and are used to prevent restriction to a specific domain.
  • blending windows are selected such that multiple copies will mutually add to unity when those copies of the window are laid over each signal block or frame. This insures that, wherever two or more signals overlap, the ultimate processed signal will have a value that is intermediate, or a weighted average, of the different overlapping signals.
  • blending windows are indicated as the dotted curves in Figures 6c and 6d.
  • time 640 and time 642 in Figure 6c and time 644 in Figure 6d are the same time registered to different frames. At time 640, assume that the value for frame 612 is 2.80 and the corresponding blending window is 0.25 (25% of unity).
  • windowed signal 648 (shown by the dotted curve) having a value of 0J0.
  • the value for frame 646 is 3.00 and the corresponding blending window is 0J5 (75% of unity).
  • a windowed signal 620 with a value of 2.25.
  • the value 2.95 is intermediate between the two frame signal values of 2.80 and 3.00. It is in fact an average of 25% of 2.80 and 75% of 3.00, where 25% plus 75% is unity.
  • the resulting processed signal would of course be ten times larger, and if desired, the entire processed signal could be divided by ten, or left amplified.
  • a gain of unity is used illustratively for simplicity, it should be understood that the wording of "unity" or “intermediate” further anticipates allowing the entire signal to be multiplied by a gain constant either before processing, within the window, post processing, or at any time, without departing from the
  • blending windows that possess the property of adding to unity.
  • One such window is the triangle response such as that shown at 620 and 622 for frame 2.5 and frame 3 in Figure 6c. These windows are also portrayed as they are designed to overlap in Figure 6d.
  • the triangle 622 starts with 0% gain at the left edge 626 of frame 3. This corresponds to the position at which the overlapping triangle 620 has 100%) gain, and so they mutually add to 100% unity.
  • the triangle 622 rises linearly to 100% at center position 630 in frame 3. At this position the overlapping triangles on each side have 0% gain, and so again they add to 100%).
  • triangle 622 is 50%, and the overlapping triangle 620 is 50%, so both add again to 100%.
  • the pedestal of 1/2 causes this function to vary from 0.0 at the left and right edges to 1.0 at the center position.
  • a windowed curve 632 is obtained. After windowing each frame of Figure 6c, and positioning and adding the windowed frames, the continuous function 634 of Figure 6d is obtained which is free of the artifacts seen in the prior art of Figure 4. In particular, both the rising edge 636 as well as the falling edge 638 have been smoothed by the method of the present invention.
  • Figure 7 is analogous to Figure 1 except for the division of the original image into intermediate overlapping blocks, such as block 702. Also needed to practice this version of the invention
  • -8- is the introduction of the blending window 704 to multiply by the unwindowed blocks, such as block 706, to produce windowed blocks, such as block 708. After windowing, the windowed blocks are aligned and added to produce the assembled output image 710.
  • Figure 8 gives a more detailed and specific example of applying the present invention in two dimensions.
  • Figure 8a shows a nonoverlapping set of blocks such as block 802, which may be considered analogous to block 712 of Figure 7.
  • Each of these blocks in this specific example contains an array of 8 by 8 pixels.
  • the centers of these first blocks are indicated by the numerals 1 in Figure 8b.
  • Interstitial with this first set of blocks is a second set of overlapping blocks of the same size, such as block 804, analogous to block 702 of Figure 7.
  • This second set of overlapping blocks are offset from the first set of nonoverlapping blocks in this specific example by 4 pixels both horizontally and vertically thereby producing centers indicated by the numerals 2 in Figure 8b.
  • the centers of the two sets of blocks lie on a diagonal grid. Together these two sets of blocks cause each pixel of an underlying image to lie in two blocks, one from the first set, and one from the second set.
  • Figure 8c shows a blending window useful for the diagonal grid arrangement of
  • FIG 8. This blending is analogous to blending window 704 of Figure 7.
  • the blending window will have 8 by 8 numerical values, such as shown in Figure 8c. Because in this example each pixel in the underlying image is covered by exactly two blocks, the blending
  • -9- window must contain gain value such that when the window is offset to the next tier (in the same way that dotted block 810 is offset relative to block 812), the sum of window values will mutually add to unity.
  • element 814 of window block 812 contains 1/8, which will overlay the equivalent of element 816 of window block 810, which contains 7/8. The sum of 1/8 and 7/8 is 1.
  • the invention may be further extended to work with an edge sensitive transform.
  • Any transform is useful to the extent it can segregate a wanted aspect of data from unwanted aspects, such as noise.
  • the DCT mentioned earlier is commonly used because it divides an image into various frequencies, with lower or stronger frequencies assumed to be more useful. However, the DCT is poor at distinguishing diagonal angles, hence the speckle around diagonal edges in images using the DCT algorithm.
  • the DFT is capable of distinguishing both frequency and angle, but as has been mentioned, is strongly sensitive to edge boundary conditions.
  • the present invention will allow the use of edge sensitive transforms, such as the DFT, without boundary problems as illustrated below.
  • Figure 9 uses the nomenclature of Figures 5 and 6, and it will be useful to view Figure 9 in this context.
  • a continuous signal 902 is received in Figure 9a, and as explained before, is divided into overlapping frames in Figure 9b.
  • Typical frames include frame 910 which is flat with a DC bias, or average value, of 1.0; frame 912 which includes a step and a DC bias of 2.0; and frame 914 which is again flat but with a higher DC bias of 3.0.
  • Figure 9b also portrays a blending window 916, normally the same for all frames, as illustrated.
  • Blending window 916 is shaped differently than the triangle 620 of Figure 6c.
  • window 916 portrays a curve wherein each point is the square root of a triangle window. As will be seen, this window will be applied twice, and so its double application, or mathematical square, will result in the triangle window such as 620 of Figure 6c that will sum to unity when the frames are reassembled.
  • the window applied before the process is called the preprocess blending window, and the
  • frame basis or block basis for the two-dimensional case
  • frame basis data are the DC, or average value, and the slope of the curve. In this example, only the DC value will be removed.
  • frame 910 the DC value of 1.0, term 920, is separated out, leaving a flat frame of zero value. This flat frame is then multiplied by blending window 916, resulting in the flat frame 926 in Figure 9c.
  • frame 912 has subtracted from it the DC term 922 of 2.0, leaving a frame that begins at -1.0 and ends at +1.0. This frame with DC removed is multiplied by window 916 to result in frame 928 of Figure 9c.
  • frame 914 has a higher DC bias term 924 of 3.0, but after removal gives a flat frame 930 identical to flat frame 926.
  • each frame of Figure 9b has the DC term removed, and the residue is then multiplied by window 916 to result in the continuous curve frames shown in Figure 9c, presented below each frame's associated removed DC term.
  • each of the continuous line frames of Figure 9c is processed to yield the dotted line frames shown in Figure 9c.
  • frame 928 may be transformed to frequency space, altered in frequency space, and transformed back to spatial domain, as was illustrated in Figure 2. If such processing involves a low pass filter, as was illustrated in Figure 2, this processing will yield low pass filtered frame 932 illustrated by a dotted line in Figure 9c.
  • Each of the dotted line processed frames of Figure 9c is next multiplied by the blending window 916 to produce the dotted line curves of Figure 9d, such as curve 940.
  • frame 912 of Figure 9b has been low pass filtered and multiplied by a triangle window as previously described in conjunction with Figure 6.
  • the critical difference in the process illustrated in Figure 9 is that the triangle window has been split into two "half triangle" windows 916 that when multiplied together, or applied twice, form the triangle window.
  • first half triangle window was applied to frame 912 before the low pass filter process to remove edge artifacts going into the processing
  • the second half triangle window was applied to the processed signal 932 to remove artifacts of the processing.
  • the first window can be the 2/3 power of a triangle and the second window a 1/3 power of that triangle, rather than both being the 1/2 power, or square root. This power imbalance would put more emphasis on removing edge artifacts going into the processing at the expense of less emphasis on removing edge artifacts of the processing.
  • the product curve also does not need to be a triangle, as will be demonstrated in a specific example to be described in relation to Figure 11.
  • each of the DC terms is also multiplied by both the pre and post processing windows, in this case that means multiplying by window 916 twice, or more simply, multiplying by the square of window 916 which is a triangle.
  • DC term 922 2.0 ( Figure 9c) is multiplied by a triangle window to yield curve 942 ( Figure 9d) which peaks at 2.0.
  • Curve 942 is registered with curve 950 in Figure 9e as curve 952.
  • DC term 920 ( Figure 9c) is multiplied by a triangle to give curve 944 in Figure 9d and registered curve 954 in Figure 9e.
  • the larger DC term 924 naturally results in taller triangle curve 946 and registered triangle curve 956.
  • Figure 9 has application to signals such as audio processing.
  • Figure 10 presents the same concept in two dimensions for applications such as image processing. The concept can also be used for higher dimensions, only the names
  • Figure 10 uses the nomenclature of Figure 7, and it will be useful to view Figure 10 in this context.
  • an image 1010 is separated into overlapping blocks 1012, such as the specific block 1014.
  • the bases are extracted to give a set of basis values 1016, such as specific basis value 1018 from block 1014, and a set of blocks 1020 with the bases removed, such as specific block 1022 containing the residue of block 1014 after removing the basis.
  • Each of the blocks of the set 1020 is multiplied by a blending window 1030 to yield a set of windowed blocks 1032.
  • block 1022 is multiplied by window 1030 to give the specific windowed block 1034. Multiplication in this sense means to multiply each pixel in block 1022 by the corresponding pixel in window 1030 to yield the corresponding pixel in the windowed block 1034.
  • process 1040 is applied to each of the windowed blocks 1032 to yield the set of processed windowed blocks 1042.
  • process 1040 may take a Fourier transform of block 1034, remove the high frequencies by zeroing terms in transform space, and then take the inverse transform to yield low pass filtered block 1044.
  • each of the processed blocks 1042 is multiplied by window 1050 to yield the set of completed blocks 1052.
  • windows 1030 and 1050 are selected such that when multiplied together, windows 1030 and 1050 form a window which, when a copy is positioned in register with each of the blocks in the set 1052, will sum to an identical value, typically unity, at all pixels.
  • specific processed block 1044 is multiplied by window 1050 to yield the specific finished block 1054.
  • the set of basis values 1016 is each multiplied by both windows 1060 and 1062 to yield windowed set 1064.
  • Multiplication in this sense means that the basis values are first reconstructed into a two-dimensional block. In the case where the only basis value is the DC term, every pixel in the reconstructed block is the same DC term. In the case where the basis values include a slope or higher order curve, the pixels in the reconstructed block will track that slope or higher order curve, using formulae well known in regression
  • each pixel in the reconstructed block derived from, for example, the specific basis values 1018 is scalarly multiplied by the corresponding pixel in window 1060 and again multiplied by the corresponding pixel in window 1062 to yield window blocks such as the specific windowed block 1066.
  • Window 1060 is a copy of window 1030, and window 1062 is a copy of window
  • Figure 11 illustrates a numerically specific implementation of the procedure just presented in Figure 10.
  • each pixel in a two-dimensional image will be covered by 8 blocks. This high positional redundancy will almost completely remove even subtle edge effects at the expense of computational speed. This would be used in a case where image quality matters over speed, such as, for example, in an image beauty enhancement or grain management program.
  • Figure 11a illustrates a single 16x16 pixel block 1102 centered at point 1104. This center point is shown by the solid dot 1106 in Figure l ib. Another single 16x16 pixel block 1110 is centered at point 1112, similarly shown in Figure l ib by the open dot 1114. Figure l ib shows the center points of all blocks in this specific implementation. The centers are seen to lie on a diagonal grid, and each pixel in the image will be overlaid by 8 blocks in differing positions.
  • the blocks could be 8x8 pixels with the upper right pixel missing so the blocks are not squares. These nonsquare 8x8 blocks could lie on a square grid with 7 pixel spacing between block centers. In such a case, the edge pixels would be overlaid twice, the corner pixels would be overlaid three times, and most pixels not overlaid at all, for an average 63/49 overlay redundancy. As seen by this later example, the other previously described specific examples of 2x and 8x redundancy, the specific examples using a diagonal pattern of block centers, or indeed the specific examples with square blocks should not be construed as limits.
  • Figure l ie illustrates a window operable with the block topology of Figures 11a and
  • Block 1120 is illustrated partially drawn around center point 1122.
  • the numeric values in each pixel are given by formula 1124 as follows:
  • this example uses a cosine blending window.

Landscapes

  • Physics & Mathematics (AREA)
  • General Physics & Mathematics (AREA)
  • Engineering & Computer Science (AREA)
  • Discrete Mathematics (AREA)
  • Multimedia (AREA)
  • Theoretical Computer Science (AREA)
  • Image Processing (AREA)
  • Compression Or Coding Systems Of Tv Signals (AREA)

Abstract

An image for digital image processing is often parsed into tiles, then the processing is applied to each tile separately. This segmentation reduces active memory and processing time compared to that needed to process the entire image as a whole. The image is parsed into a larger number of overlapping tiles. After image processing, the blocks are blended by multiplying each with a blending window chosen to be mutually constant, and the blocks are added together to form the product image free of transition artifacts. In one implementation the centers of the overlapping blocks are on a diagonal grid. In another implementation, a function of the complete window, typically the square root of each pixel of the window, is applied to the blocks prior to processing and the remainder applied after processing. This softens tile edges going into the image processing application to permit better results from edge sensitive functions, such as a Fourier transform.

Description

IMAGE PROCESSING METHOD USING A BLOCK OVERLAP TRANSFORMATION PROCEDURE
TECHNICAL FIELD OF THE INVENTION
The present invention relates to image processing, and more particularly to image processing using tiles and reducing tile edge artifacts.
BACKGROUND OF THE INVENTION
Modern computers deal with memory and processing demands of scanning and manipulating images in several ways. For a large image, only a part or block of the image is read from disk storage and transferred into active memory. These blocks of the image undergoing active processing are called tiles. When a tile has been processed, the tile is written back to disk storage, and the next tile is read from the disk. By processing an image in tiles, the entire image need not be stored in active memory at one time. Many modern computers, such as the Intel MMX system, operate on multiple data paths in parallel. To utilize parallel processing, different parts of the image must be processable in parallel. The MPEG algorithms used in digital video processing are examples of tiled image processing. The tiles permit full use of parallel processing and minimal active memory, but such processing may produce edge artifacts between the tiles which are seen after the tiles are reassembled and are commonly known to MPEG and JPEG images.
The context in which the present invention is practiced will be better understood in light of prior art practices. Figure 1 illustrates the processing of an image 102 to produce a resultant image 104. Prior to applying the processing algorithm 106, the image is sectioned into two-dimensional blocks 108, and the processing step 106 is applied individually to each block, such as block 110, to produce resultant blocks, such as block 112. The processed blocks 114 are then reassembled like a jigsaw puzzle to form the resultant image 104. Similar processing can be applied to a one-dimensional string of data, such as that from a processed signal, instead of a two-dimensional ordering of data. In the one- dimensional case, the sectioned one-dimensional blocks are called frames. The string is sectioned into frames, the processing applied to each frame, then the processed frames recombined to form a resultant string of processed signal data.
Further, the input signal can be composed of discrete samples as in digital audio and image, or the signal can be a continuum such as that found in analog audio and film images or analog video. Block processing methods apply to both analog and digital signals.
The processing step 106 of Figure 1 can take many forms. For example, it may include transforming, compressing, and storing the data, as is common in JPEG and MPEG image compressions. A class of processings is illustrated in Figure 2, wherein a data frame 202 undergoes a transformation step 204 to form a related frame 206 of numbers in a different transform space. In the case illustrated in Figure 2, the input data frame 202 oscillates slowly as seen by the numbers inside the individual spatial elements. The transformation step 204 is a frequency transform, so the related frame 206 is in frequency transform space. A higher number is found at the frequency element 208 corresponding to the frequency of the oscillation. The frame 208 in transform space may undergo additional processing 210 such as a compression process step which compresses or limits high frequencies. Compression is but one example of an additional process which the data may undergo. After any additional processing, the frame 206 is processed by transformation step 212, the inverse of transformation step 204, to output the processed frame 214.
Figure 3 illustrates application of the transform processing of Figure 2 to two dimensions. Block 302 is a single block from a segmented image, such as block 110 of image 102 shown in Figure 1. Based on the specific data shown, block 302 has a horizontal low frequency oscillation and a high frequency vertical oscillation. Transformation step 304 converts the numbers in block 302 into a frequency transform space 306, with specific frequency element 308 high due to the vertical high frequency oscillation, element 310 high due to horizontal low frequency oscillation, and element 312 high due to the "DC", or average.
-2- Processing step 314 is applied in the transform space to block 306 to produce block 316. In this example, the processing step 314 is a low pass filter which erases to zero in block 316 all frequency terms exceeding a frequency denoted by dotted line 318, such as high frequency element 308. Then, transformation step 320, the inverse of transformation step 304, is applied to block 316 to produce block 322. Note that block 322 contains numbers similar to block 302 except that rapid changes with space, such as the high frequency oscillations, have been removed.
The problems with prior art processing may be easily explained. Turning to Figure 4, an input signal 410 will be processed using the prior art method described above. Input signal 410 is represented in this case by a continuum. It is understood that input signal 410 could also be represented by a string of numbers as was used in Figure 2. The difference between numbers and a continuum is the difference between numbers stored on a compact disk versus voltages fed to a speaker, or the difference between pixels scanned digitally versus light patterns received by the eye. The translations between discrete numbers and a continuum are very well understood in the art, such that processes may be though of and explained interchangeably in either form.
Input signal 410 in Figure 4a is divided into four, discrete, nonoverlapping frames as shown in Figure 4b. These frames are selected to cover all of the signal without overlapping any portion of the signal. In the specific case of frame 2, step 412 (the change from a low value to a higher value) occurs in the middle of the frame, and so is well represented in the discrete segment 414. On the other hand, step 416 occurs between frames 3 and 4, and thus appears to be "lost". Continuing with Figure 4c, each frame is then processed by a low pass filter to soften any edges. It is seen that step 412 has received the desired softening from the low pass filter to produce step 420. Note that the "lost" step 416 has received no softening because it occurred at the transition between frames 3 and 4, and so appears in no frame.
After frames 1 through 4 are reassembled into a complete graph 422 in Figure 4d, the step 412 in Figure 4a appears as softened edge 424 as desired, but the step 416 that just happened to occur on the boundary between frame slices still appears as a hard step 426. The
-3- effect illustrated in Figure 4 wherein edges are treated differently depending on alignment with blocks or frames is a common problem in block processing methods such as JPEG and MPEG.
The process shown in Figure 4 was assumed to use edge tolerant processing, such as a discrete cosine transform (DCT), to derive the low pass filter. Because the DCT assembles a wave with only cosine terms that have zero slope at transitions between frames, if any of the waves is removed by, for example, applying a low pass filter, the resultant function will not change slope between frames. Other transforms are not so edge tolerant. For example, a discrete Fourier transform (DFT) has many desirable properties, but is not in common use for block processing because of its behavior at edges.
The processing illustrated in Figure 5 is equivalent to Figure 4 except that in Figure 5 a DFT-like function is used to accomplish the low pass filter process in place of the DCT-like function used in Figure 4. The signal 502 contained in frame 2 is seen by a DFT as a square wave repeating on a cycle equal to the length of frame 2. Thus when the high frequency harmonics are removed, there remains a full cycle sine wave 504 on a base value corresponding to the DC term for that frame. This is different from the DCT case resulting in a half cycle cosine wave, as shown by curve 420 of Figure 4. When the discrete frames are reassembled into a complete graph 510, the step 512 remains unfiltered as it did in Figure 4; however, new edge artifacts 514 and 516 appear at the transition between frames.
A need has thus arisen for an image processing method to reduce block edge artifacts associated with tiled image processing.
SUMMARY OF THE INVENTION
The present invention segments the image or signal being processed into overlapping blocks, separately processes each block, and reassembles the blocks following the processing. Typically there is one sequence of non-overlapping blocks, and in addition, at least one additional series of non-overlapping blocks with centers placed interstitially with the first
-4- series. The interstitial topology can be on a diagonal grid. The blocks are windowed such that when they are reassembled by adding them together, the block windows mutually add to unity. Further, the windowing may be applied after processing, or divided before and after the processing step to facilitate edge sensitive processes. In addition, some attributes, such as the "DC" bias, can be separated from the block before processing, and windowed separately before recombining.
BRIEF DESCRIPTION OF THE DRAWINGS
For a more complete understanding of the present invention and for further advantages thereof, reference is now made to the following Description of the Preferred Embodiments taken in conjunction with the accompanying Drawings in which:
Figure 1 illustrates a prior art method of processing an image using blocks; Figure 2 illustrates a prior art method of processing a one-dimensional signal block in transform space;
Figure 3 illustrates a prior art method of processing a two-dimensional image block in transform space;
Figures 4a-4d illustrate prior art problems which arise during processing of non- overlapping one-dimensional blocks;
Figures 5a-5d illustrate prior art problems which arise during processing of non-overlapping one-dimensional blocks with an edge sensitive process;
Figures 6a-6d illustrate the present invention applied to one-dimensional blocks; Figure 7 illustrates the present invention applied to two-dimensional image blocks; Figures 8a-8c illustrate a specific embodiment of the present invention processing two-dimensional blocks;
Figures 9a-9e illustrate the present invention applied to one-dimensional blocks with an edge sensitive process;
Figure 10 illustrates the present invention applied to two-dimensional image blocks with an edge sensitive process; and Figures 1 la-1 lc illustrate a specific case of applying the present invention to two- dimensional blocks compatible with an edge sensitive process.
DESCRIPTION OF THE PREFERRED EMBODIMENT
Turning now to Figure 6, a continuous graph 602 is divided into multiple frames. As in the prior art processing, the graph is sectioned into frames 1 to 4 of Figure 6a; however, additional frames 1.5, 2.5, and 3.5 are selected such that they overlap a portion of the signal included in frames 1 to 4 of Figure 6a. All of these frames are individually displayed in Figure 6b. It should be noted that edge 604 is represented in frame 2 as edge 606 as in the prior art. However, edge 608 that was "lost" in the prior art method because of its position between frames 3 and 4 is now represented in one of the overlapping frames, frame 3.5, as edge 610. Next, a low pass filter is applied to every frame in Figure 6b to form the frames in Figure 6c. In particular, edges 606 and 610 are softened to produce filtered edges 612 and 614.
Finally, the overlapping frames of Figure 6c need to be reassembled into a complete graph. Because frames are overlapping, frames can not be simply concatenated like a jigsaw puzzle as was done in the prior art described in Figures 4 and 5. Rather, frames must be blended together with a gradual transition between edges taking into account the degree of overlap between blocks. This blending is accomplished by applying a blending window to each frame and then combining the windowed frames. "Applying a blending window" in this context means multiplying each element of a frame by the corresponding element of the window to produce a resulting element of the windowed frame. A frame element can be a digital sample, such as a pixel, or a brief segment of time in an analog signal. "Combining the windowed frames" means to first register the frames so that corresponding elements align, and then to add the values in each of the corresponding elements together to form the processed signal. If one is working in the logarithmic domain, the actual computer operation needed to form an effective multiplication or addition is different than if one is working in a linear domain, and hence the terms "apply" and "combine" encompass these operations and are used to prevent restriction to a specific domain.
-6- According to the present invention, blending windows are selected such that multiple copies will mutually add to unity when those copies of the window are laid over each signal block or frame. This insures that, wherever two or more signals overlap, the ultimate processed signal will have a value that is intermediate, or a weighted average, of the different overlapping signals. By way of illustration, blending windows are indicated as the dotted curves in Figures 6c and 6d. For example, time 640 and time 642 in Figure 6c and time 644 in Figure 6d are the same time registered to different frames. At time 640, assume that the value for frame 612 is 2.80 and the corresponding blending window is 0.25 (25% of unity).
This results in a windowed signal 648 (shown by the dotted curve) having a value of 0J0. At the same time 642, the value for frame 646 is 3.00 and the corresponding blending window is 0J5 (75% of unity). This results in a windowed signal 620 with a value of 2.25.
Continuing with Figure 6d, at the same time 644, the windowed signal 648 is added to the windowed signal 620 to result in a value for the final processed signal 634 of 0.70+2.25=2.95 at time 644. The value 2.95 is intermediate between the two frame signal values of 2.80 and 3.00. It is in fact an average of 25% of 2.80 and 75% of 3.00, where 25% plus 75% is unity.
In this specific example (Figure 6), only two blending windows overlap at any single element. This is not a limitation, and a later example will present a case where more than two windows overlap at specific points. In the case of multiple window overlap, the blending window will still be chosen such that each element of the processed signal will have a value intermediate between the two most extreme values of the corresponding elements in all the overlapping blocks. Put another way, there will exist two of those blocks, which could be the greatest and least, for which the value of the processed signal is intermediate.
The explanation thus far has described blending windows that mutually add to unity.
If the blending windows all added instead to, for example, ten, then the resulting processed signal would of course be ten times larger, and if desired, the entire processed signal could be divided by ten, or left amplified. Although a gain of unity is used illustratively for simplicity, it should be understood that the wording of "unity" or "intermediate" further anticipates allowing the entire signal to be multiplied by a gain constant either before processing, within the window, post processing, or at any time, without departing from the
-7- intent of this invention. In fact, multiple gain constants could be applied throughout the described process.
There are a number of blending windows that possess the property of adding to unity. One such window is the triangle response such as that shown at 620 and 622 for frame 2.5 and frame 3 in Figure 6c. These windows are also portrayed as they are designed to overlap in Figure 6d. The triangle 622 starts with 0% gain at the left edge 626 of frame 3. This corresponds to the position at which the overlapping triangle 620 has 100%) gain, and so they mutually add to 100% unity. The triangle 622 rises linearly to 100% at center position 630 in frame 3. At this position the overlapping triangles on each side have 0% gain, and so again they add to 100%). At an intermediate position 628, triangle 622 is 50%, and the overlapping triangle 620 is 50%, so both add again to 100%.
Many other blending window shapes are possible. For example, the window could be a cosine wave on a base value, or pedestal, of 1/2 described by the formula l/2+cos(x)/2, where x = -π at left edge position 626 in frame 3, x = 0 at center position 630, and x = +π at the right edge. The pedestal of 1/2 causes this function to vary from 0.0 at the left and right edges to 1.0 at the center position. Although the present example illustrates a two-to-one window-to-frame overlap, different degrees of overlap are possible, resulting in different window functions. Later in this description an example will be given of a multiple level diagonal overlap in two dimensions.
By multiplying curve 614 of Figure 6c by a blending window such as 622, a windowed curve 632 is obtained. After windowing each frame of Figure 6c, and positioning and adding the windowed frames, the continuous function 634 of Figure 6d is obtained which is free of the artifacts seen in the prior art of Figure 4. In particular, both the rising edge 636 as well as the falling edge 638 have been smoothed by the method of the present invention.
The two-dimensional case of the present invention will be described next. Figure 7 is analogous to Figure 1 except for the division of the original image into intermediate overlapping blocks, such as block 702. Also needed to practice this version of the invention
-8- is the introduction of the blending window 704 to multiply by the unwindowed blocks, such as block 706, to produce windowed blocks, such as block 708. After windowing, the windowed blocks are aligned and added to produce the assembled output image 710.
Figure 8 gives a more detailed and specific example of applying the present invention in two dimensions. Figure 8a shows a nonoverlapping set of blocks such as block 802, which may be considered analogous to block 712 of Figure 7. Each of these blocks in this specific example contains an array of 8 by 8 pixels. The centers of these first blocks are indicated by the numerals 1 in Figure 8b. Interstitial with this first set of blocks is a second set of overlapping blocks of the same size, such as block 804, analogous to block 702 of Figure 7. This second set of overlapping blocks are offset from the first set of nonoverlapping blocks in this specific example by 4 pixels both horizontally and vertically thereby producing centers indicated by the numerals 2 in Figure 8b. Relative to each other, the centers of the two sets of blocks lie on a diagonal grid. Together these two sets of blocks cause each pixel of an underlying image to lie in two blocks, one from the first set, and one from the second set.
There are many other ways that blocks can be arranged in an overlapping fashion; however, the diagonal grid arrangement of Figure 8b has several advantages. First, it is efficient. If the blocks were made to overlap by keeping the same centers but doubling the size to 16 by 16 pixels, in direct analogy to the one-dimensional case just illustrated in Figure 6, the two-dimensional case would now include two squared, or four times the number of elements in overlapping blocks to compute. Second, a diagonal grid tends to diffuse artifacts caused by common horizontal and vertical lines in images. This diffusion results because if one tier aligns with the horizontal or vertical line, the alternate diagonal tier will disalign with it.
Figure 8c shows a blending window useful for the diagonal grid arrangement of
Figure 8. This blending is analogous to blending window 704 of Figure 7. Continuing with the specific example in which each block contains an array of 8 by 8 pixels, the blending window will have 8 by 8 numerical values, such as shown in Figure 8c. Because in this example each pixel in the underlying image is covered by exactly two blocks, the blending
-9- window must contain gain value such that when the window is offset to the next tier (in the same way that dotted block 810 is offset relative to block 812), the sum of window values will mutually add to unity. For example, element 814 of window block 812 contains 1/8, which will overlay the equivalent of element 816 of window block 810, which contains 7/8. The sum of 1/8 and 7/8 is 1.
The invention may be further extended to work with an edge sensitive transform. Any transform is useful to the extent it can segregate a wanted aspect of data from unwanted aspects, such as noise. The DCT mentioned earlier is commonly used because it divides an image into various frequencies, with lower or stronger frequencies assumed to be more useful. However, the DCT is poor at distinguishing diagonal angles, hence the speckle around diagonal edges in images using the DCT algorithm. The DFT is capable of distinguishing both frequency and angle, but as has been mentioned, is strongly sensitive to edge boundary conditions. The present invention will allow the use of edge sensitive transforms, such as the DFT, without boundary problems as illustrated below.
Figure 9 uses the nomenclature of Figures 5 and 6, and it will be useful to view Figure 9 in this context. First, a continuous signal 902 is received in Figure 9a, and as explained before, is divided into overlapping frames in Figure 9b. Typical frames include frame 910 which is flat with a DC bias, or average value, of 1.0; frame 912 which includes a step and a DC bias of 2.0; and frame 914 which is again flat but with a higher DC bias of 3.0. Figure 9b also portrays a blending window 916, normally the same for all frames, as illustrated. Blending window 916 is shaped differently than the triangle 620 of Figure 6c. In fact, window 916 portrays a curve wherein each point is the square root of a triangle window. As will be seen, this window will be applied twice, and so its double application, or mathematical square, will result in the triangle window such as 620 of Figure 6c that will sum to unity when the frames are reassembled.
Any two windows that multiply together to form a triangle, or form any other curve that allows the frames to mutually sum to unity, will satisfy the unity condition. In general, the window applied before the process is called the preprocess blending window, and the
-10- window applied after the process is called the postprocess blending window. The square root function presented above, used to derive preprocess and postprocess blending windows that are equal, is a simple expedient that meets the necessary requirements.
Continuing with Figure 9b, basic parameters of the frame, called the frame basis (or block basis for the two-dimensional case), are found and subtracted out of the frame. Examples of frame basis data are the DC, or average value, and the slope of the curve. In this example, only the DC value will be removed. In the specific case of frame 910, the DC value of 1.0, term 920, is separated out, leaving a flat frame of zero value. This flat frame is then multiplied by blending window 916, resulting in the flat frame 926 in Figure 9c. Continuing the example, frame 912 has subtracted from it the DC term 922 of 2.0, leaving a frame that begins at -1.0 and ends at +1.0. This frame with DC removed is multiplied by window 916 to result in frame 928 of Figure 9c. Continuing the process, frame 914 has a higher DC bias term 924 of 3.0, but after removal gives a flat frame 930 identical to flat frame 926. In general, each frame of Figure 9b has the DC term removed, and the residue is then multiplied by window 916 to result in the continuous curve frames shown in Figure 9c, presented below each frame's associated removed DC term.
Next, each of the continuous line frames of Figure 9c is processed to yield the dotted line frames shown in Figure 9c. As an example of this particular processing step, frame 928 may be transformed to frequency space, altered in frequency space, and transformed back to spatial domain, as was illustrated in Figure 2. If such processing involves a low pass filter, as was illustrated in Figure 2, this processing will yield low pass filtered frame 932 illustrated by a dotted line in Figure 9c.
Each of the dotted line processed frames of Figure 9c is next multiplied by the blending window 916 to produce the dotted line curves of Figure 9d, such as curve 940. In effect, frame 912 of Figure 9b has been low pass filtered and multiplied by a triangle window as previously described in conjunction with Figure 6. The critical difference in the process illustrated in Figure 9 is that the triangle window has been split into two "half triangle" windows 916 that when multiplied together, or applied twice, form the triangle window. The
-11- first half triangle window was applied to frame 912 before the low pass filter process to remove edge artifacts going into the processing, and the second half triangle window was applied to the processed signal 932 to remove artifacts of the processing. Although the current illustration has portrayed both "half triangle" windows as equal, the windows do not need to be. For example, the first window can be the 2/3 power of a triangle and the second window a 1/3 power of that triangle, rather than both being the 1/2 power, or square root. This power imbalance would put more emphasis on removing edge artifacts going into the processing at the expense of less emphasis on removing edge artifacts of the processing. As mentioned before, the product curve also does not need to be a triangle, as will be demonstrated in a specific example to be described in relation to Figure 11.
Continuing with Figure 9, the dotted frames of Figure 9d are assembled in register and added to produce Figure 9e. For example, frame 940 (Figure 9d) is seen in Figure 9e as curve 950. In addition, each of the DC terms is also multiplied by both the pre and post processing windows, in this case that means multiplying by window 916 twice, or more simply, multiplying by the square of window 916 which is a triangle. In the specific case of DC term 922, 2.0 (Figure 9c) is multiplied by a triangle window to yield curve 942 (Figure 9d) which peaks at 2.0. Curve 942 is registered with curve 950 in Figure 9e as curve 952. Similarly, DC term 920 (Figure 9c) is multiplied by a triangle to give curve 944 in Figure 9d and registered curve 954 in Figure 9e. The larger DC term 924 naturally results in taller triangle curve 946 and registered triangle curve 956.
Registering and adding all the curves together, both the dotted line curves and solid line curves of Figure 9e, gives the resultant bold line curve 958 of Figure 9e, which is seen to be a smooth low pass version of the original input curve 902, free of edge artifacts, as desired.
The one-dimensional case of Figure 9 has application to signals such as audio processing. Figure 10 presents the same concept in two dimensions for applications such as image processing. The concept can also be used for higher dimensions, only the names
-12- change to overlapping cubes. Figure 10 uses the nomenclature of Figure 7, and it will be useful to view Figure 10 in this context.
In Figure 10 an image 1010 is separated into overlapping blocks 1012, such as the specific block 1014. From each of these blocks, the bases are extracted to give a set of basis values 1016, such as specific basis value 1018 from block 1014, and a set of blocks 1020 with the bases removed, such as specific block 1022 containing the residue of block 1014 after removing the basis. Each of the blocks of the set 1020 is multiplied by a blending window 1030 to yield a set of windowed blocks 1032. For example, block 1022 is multiplied by window 1030 to give the specific windowed block 1034. Multiplication in this sense means to multiply each pixel in block 1022 by the corresponding pixel in window 1030 to yield the corresponding pixel in the windowed block 1034.
Next, process 1040 is applied to each of the windowed blocks 1032 to yield the set of processed windowed blocks 1042. For example, process 1040 may take a Fourier transform of block 1034, remove the high frequencies by zeroing terms in transform space, and then take the inverse transform to yield low pass filtered block 1044.
Next, each of the processed blocks 1042 is multiplied by window 1050 to yield the set of completed blocks 1052. As discussed before, windows 1030 and 1050 are selected such that when multiplied together, windows 1030 and 1050 form a window which, when a copy is positioned in register with each of the blocks in the set 1052, will sum to an identical value, typically unity, at all pixels. For example, specific processed block 1044 is multiplied by window 1050 to yield the specific finished block 1054.
On a parallel path, the set of basis values 1016 is each multiplied by both windows 1060 and 1062 to yield windowed set 1064. Multiplication in this sense means that the basis values are first reconstructed into a two-dimensional block. In the case where the only basis value is the DC term, every pixel in the reconstructed block is the same DC term. In the case where the basis values include a slope or higher order curve, the pixels in the reconstructed block will track that slope or higher order curve, using formulae well known in regression
-13- mathematics. Continuing with the multiplication, each pixel in the reconstructed block derived from, for example, the specific basis values 1018, is scalarly multiplied by the corresponding pixel in window 1060 and again multiplied by the corresponding pixel in window 1062 to yield window blocks such as the specific windowed block 1066.
Window 1060 is a copy of window 1030, and window 1062 is a copy of window
1050. The dual windows are presented to illustrate that the basis values are effectively multiplied by the same windows as the image blocks, but in practice one would merge 1060 and 1062 into a single window which was the multiplicative product of 1060 and 1062, rather than perform two multiplications each time.
Finally, all of the basis windowed blocks 1064 and the image windowed blocks 1052 are placed in register and added together to form the completed image 1072 that is substantially free of edge artifacts.
Figure 11 illustrates a numerically specific implementation of the procedure just presented in Figure 10. In this specific example, each pixel in a two-dimensional image will be covered by 8 blocks. This high positional redundancy will almost completely remove even subtle edge effects at the expense of computational speed. This would be used in a case where image quality matters over speed, such as, for example, in an image beauty enhancement or grain management program.
Figure 11a illustrates a single 16x16 pixel block 1102 centered at point 1104. This center point is shown by the solid dot 1106 in Figure l ib. Another single 16x16 pixel block 1110 is centered at point 1112, similarly shown in Figure l ib by the open dot 1114. Figure l ib shows the center points of all blocks in this specific implementation. The centers are seen to lie on a diagonal grid, and each pixel in the image will be overlaid by 8 blocks in differing positions.
The case of Figure 11 is different from previous examples in which each pixel was overlaid by only two blocks for a 2x redundancy. It should be noted that the number of
-14- overlays can be any value above one. For example, the blocks could be 8x8 pixels with the upper right pixel missing so the blocks are not squares. These nonsquare 8x8 blocks could lie on a square grid with 7 pixel spacing between block centers. In such a case, the edge pixels would be overlaid twice, the corner pixels would be overlaid three times, and most pixels not overlaid at all, for an average 63/49 overlay redundancy. As seen by this later example, the other previously described specific examples of 2x and 8x redundancy, the specific examples using a diagonal pattern of block centers, or indeed the specific examples with square blocks should not be construed as limits.
Figure l ie illustrates a window operable with the block topology of Figures 11a and
1 lb. Block 1120 is illustrated partially drawn around center point 1122. X values and y values are given for pixel columns and rows. Note that, because there are an even number of pixels, there is no pixel row or column centered at precisely x=0, y=0, and similarly there is no pixel row or column centered on precisely x=l or y=l at the edge. The numeric values in each pixel are given by formula 1124 as follows:
(1 + cos x) (1 + cos Tly)
Unlike previous examples using a triangle, this example uses a cosine blending window.
The property of this window to mutually add to unity when squared under the diagonal topology illustrated in Figure l ib is now explained. Consider the square grid sequence of centers of the solid dots in Figure l ib, and consider a window wherein the value at each pixel is (l+cos(πx)) (l+cos(πx)). Note that in the horizontal dimension, the cosine windows are positioned 180 degrees out of phase so they add horizontally to a constant. Along a vertical crest of y, this constant is 2x2=4. Now adding in the vertical direction, the crest value becomes the constant, again 4. Adding in the other sequence of centers of open dots in Figure 1 lb doubles the sum to 8, giving the 1/8 multiplicative constant in equation 1124 of Figure l ie. Further, as explained above, the window will be applied twice to each pixel, requiring the square root in equation 1124 for each "half window".
-15- Whereas the present invention has been described with respect to specific embodiments thereof, it will be understood that various changes and modifications will be suggested to one skilled in the art and it is intended to encompass such changes and modifications as fall within the scope of the appended claims.
-16-

Claims

1. A method of signal processing comprising: receiving a signal and sectioning the signal into a plurality of blocks; selecting a first block from the signal; selecting a second block from the signal which overlaps a portion of the signal included in the first block; operating on the first block with a signal processing function to produce a first processed block; operating on the second block with the signal processing function to produce a second processed block; selecting a blending window; applying the blending window to the first processed block to produce a first windowed block; applying the blending window to the second processed block to produce a second windowed block which overlaps the first windowed block; and combining the first and second windowed blocks to produce a processed signal.
2. The method of claim 1 wherein the signal is received as a continuum.
3. The method of claim 1 wherein the signal is received as discrete samples.
4. The method of claim 3 wherein the signal is a one-dimensional line of samples and wherein the blocks are one-dimensional frames.
5. The method of claim 3 wherein the signal is a two-dimensional array of samples and wherein the blocks are two-dimensional blocks.
6. The method of claim 5 wherein the first and second blocks are members of an array of blocks whose centers are arranged on a grid.
-17-
7. The method of claim 6 wherein the grid is a square grid.
8. The method of claim 6 wherein the grid is a diagonal grid.
9. The method of claim 6 wherein the grid is an hexagonal grid.
10. The method of claim 5 wherein the blocks are square in shape.
11. The method of claim 10 wherein at least one corner of the square is deleted.
12. The method of claim 1 wherein the blending window is selected such that the processed signal will have a value intermediate between the value of the signal in the first and second blocks where the first and second blocks overlap.
13. The method of claim 12 wherein the blending window is selected to have a maximum value at the center of the blending window and drops linearly to the edges of the blending window.
14. The method of claim 12 wherein the blending window function is described by a cosine wave added to a constant base value so that the function reaches a maximum at the center of the blending window and a minimum at the edges of the blending window.
15. A method of signal processing comprising : receiving a signal and sectioning the signal into a plurality of blocks, selecting a first block from the signal; selecting a second block from the signal which overlaps a portion of the signal included in the first block; selecting a preprocess blending window; applying the preprocess blending window to the first block to produce a first preprocess windowed block;
-18- applying the preprocess blending window to the second block to produce a second preprocess windowed block; operating on the first preprocess windowed block with a signal processing function to produce a first processed block; operating on the second preprocess windowed block with the signal processing function to produce a second processed block; selecting a postprocess blending window; applying the postprocess blending window to the first processed block to produce a first windowed block; applying the postprocess blending window to the second processed block to produce a second windowed block which overlaps the first windowed block; and combining the first and second windowed blocks to produce a processed signal.
16. The method of claim 15 wherein the preprocess and postprocess blending windows are selected such that the processed signal will have a value intermediate between the value of the signal in the first and second blocks where the first and second blocks overlap.
17. The method of claim 16 wherein the preprocess and postprocess blending windows are substantially equal.
18. The method of claim 16 wherein the product of the preprocess and postprocess blending windows is selected to have a maximum value at the center of the window and drops linearly to the edges of the blending window.
19. The method of claim 16 wherein the product of the preprocess and postprocess blending windows is a function described by a cosine wave added to a constant base value so that the function reaches a maximum at the center of the blending window and a minimum at the edges of the blending window.
-19-
EP99906861A 1998-02-23 1999-02-10 Image processing method using a block overlap transformation procedure Withdrawn EP1057142A1 (en)

Applications Claiming Priority (3)

Application Number Priority Date Filing Date Title
US7566498P 1998-02-23 1998-02-23
US75664P 1998-02-23
PCT/US1999/002828 WO1999042954A1 (en) 1998-02-23 1999-02-10 Image processing method using a block overlap transformation procedure

Publications (1)

Publication Number Publication Date
EP1057142A1 true EP1057142A1 (en) 2000-12-06

Family

ID=22127225

Family Applications (1)

Application Number Title Priority Date Filing Date
EP99906861A Withdrawn EP1057142A1 (en) 1998-02-23 1999-02-10 Image processing method using a block overlap transformation procedure

Country Status (4)

Country Link
EP (1) EP1057142A1 (en)
AU (1) AU2667799A (en)
TW (1) TW410316B (en)
WO (1) WO1999042954A1 (en)

Families Citing this family (5)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
AUPP444898A0 (en) 1998-07-02 1998-07-23 Canon Kabushiki Kaisha A method and apparatus for boundary filtering a digital image
US6781724B1 (en) 2000-06-13 2004-08-24 Eastman Kodak Company Image processing and manipulation system
US6369873B1 (en) 2000-06-13 2002-04-09 Eastman Kodak Company Thermal processing system and method including a kiosk
US6950608B2 (en) 2003-12-23 2005-09-27 Eastman Kodak Company Capture of multiple interlaced images on a single film frame using micro-lenses and method of providing multiple images to customers
CN109934778B (en) * 2019-01-30 2024-02-23 长视科技股份有限公司 Blind deblurring method for household monitoring video screenshot

Family Cites Families (6)

* Cited by examiner, † Cited by third party
Publication number Priority date Publication date Assignee Title
US4442454A (en) * 1982-11-15 1984-04-10 Eastman Kodak Company Image processing method using a block overlap transformation procedure
EP0527097A3 (en) * 1991-08-06 1995-03-01 Eastman Kodak Co Apparatus and method for collectively performing tile-based image rotation, scaling and digital halftone screening
JP2549479B2 (en) * 1991-12-06 1996-10-30 日本電信電話株式会社 Motion compensation inter-frame band division coding processing method
GB2283633B (en) * 1993-11-05 1997-10-29 Sony Uk Ltd Anti-alias filter control for a split picture
WO1995015530A1 (en) * 1993-11-30 1995-06-08 Polaroid Corporation Image coding by use of discrete cosine transforms
US5764805A (en) * 1995-10-25 1998-06-09 David Sarnoff Research Center, Inc. Low bit rate video encoder using overlapping block motion compensation and zerotree wavelet coding

Non-Patent Citations (1)

* Cited by examiner, † Cited by third party
Title
See references of WO9942954A1 *

Also Published As

Publication number Publication date
WO1999042954A1 (en) 1999-08-26
AU2667799A (en) 1999-09-06
TW410316B (en) 2000-11-01

Similar Documents

Publication Publication Date Title
US4553165A (en) Transform processing method for reducing noise in an image
US7864867B2 (en) Video coder employing pixel transposition
US6370279B1 (en) Block-based image processing method and apparatus therefor
EP0731957B1 (en) Method for scaling and filtering images using discrete cosine transforms
JP4771803B2 (en) Reversible two-dimensional pre / post filtering for superimposed bi-orthogonal transformation
US6360024B1 (en) Method and apparatus for removing noise in still and moving pictures
DE69632622T2 (en) Universal MPEG decoder with scalable image size
US6018596A (en) Method and apparatus for processing an input image
US6151420A (en) Minimizing blocking artifacts in a filtered image
DE69609842T2 (en) JPEG COMPRESSION CIRCUIT WITH FILTERING
Linderhed Compression by image empirical mode decomposition
JPH05507600A (en) Video signal compression
EP1053534A1 (en) Post-processing decompressed images
US6141456A (en) Methods and apparatus for combining downsampling and inverse discrete cosine transform operations
US5748792A (en) Large kernel filtering using a fixed-size block processor
US5887084A (en) Structuring a digital image into a DCT pyramid image representation
US6768817B1 (en) Fast and efficient computation of cubic-spline interpolation for data compression
EP1057142A1 (en) Image processing method using a block overlap transformation procedure
US6738523B1 (en) Parallel inverse discrete wavelet transform
EP0686940B1 (en) Image processing systems and methods
US6111989A (en) 1/4 size real time decoding of digital video
US20090214131A1 (en) System and method for multi-scale sigma filtering using quadrature mirror filters
Merhav et al. A fast algorithm for DCT domain filtering
US20040247194A1 (en) Video coder employing pixel transposition
JPH04245865A (en) Picture processor

Legal Events

Date Code Title Description
PUAI Public reference made under article 153(3) epc to a published international application that has entered the european phase

Free format text: ORIGINAL CODE: 0009012

AK Designated contracting states

Kind code of ref document: A1

Designated state(s): AT BE CH CY DE DK ES FI FR GB GR IE IT LI LU MC NL PT SE

17P Request for examination filed

Effective date: 20001007

17Q First examination report despatched

Effective date: 20010420

GRAH Despatch of communication of intention to grant a patent

Free format text: ORIGINAL CODE: EPIDOS IGRA

STAA Information on the status of an ep patent application or granted ep patent

Free format text: STATUS: THE APPLICATION IS DEEMED TO BE WITHDRAWN

18D Application deemed to be withdrawn

Effective date: 20020903