GB2304015A - Method and apparatus for uniformly scaling a digital image - Google Patents
Method and apparatus for uniformly scaling a digital image Download PDFInfo
- Publication number
- GB2304015A GB2304015A GB9611306A GB9611306A GB2304015A GB 2304015 A GB2304015 A GB 2304015A GB 9611306 A GB9611306 A GB 9611306A GB 9611306 A GB9611306 A GB 9611306A GB 2304015 A GB2304015 A GB 2304015A
- Authority
- GB
- United Kingdom
- Prior art keywords
- sum
- data
- original
- image data
- pixel data
- 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.)
- Granted
Links
- 238000000034 method Methods 0.000 title claims description 31
- 230000003213 activating effect Effects 0.000 claims description 10
- 238000010586 diagram Methods 0.000 description 12
- 238000005303 weighing Methods 0.000 description 3
- 230000000717 retained effect Effects 0.000 description 2
- 238000013341 scale-up Methods 0.000 description 2
- RYGMFSIKBFXOCR-UHFFFAOYSA-N Copper Chemical compound [Cu] RYGMFSIKBFXOCR-UHFFFAOYSA-N 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 238000003780 insertion Methods 0.000 description 1
- 230000037431 insertion Effects 0.000 description 1
- 238000007781 pre-processing Methods 0.000 description 1
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06T—IMAGE DATA PROCESSING OR GENERATION, IN GENERAL
- G06T3/00—Geometric image transformations in the plane of the image
- G06T3/40—Scaling of whole images or parts thereof, e.g. expanding or contracting
- G06T3/4007—Scaling of whole images or parts thereof, e.g. expanding or contracting based on interpolation, e.g. bilinear interpolation
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04N—PICTORIAL COMMUNICATION, e.g. TELEVISION
- H04N5/00—Details of television systems
- H04N5/222—Studio circuitry; Studio devices; Studio equipment
- H04N5/262—Studio circuits, e.g. for mixing, switching-over, change of character of image, other special effects ; Cameras specially adapted for the electronic generation of special effects
- H04N5/2628—Alteration of picture size, shape, position or orientation, e.g. zooming, rotation, rolling, perspective, translation
Landscapes
- Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Multimedia (AREA)
- Signal Processing (AREA)
- Image Processing (AREA)
- Editing Of Facsimile Originals (AREA)
Description
A M 1 - 2304015 METHOD AND APPARATUS FOR UNIFORMLY SCALING A DIGITAL IMAGE
The invention relates to an image processing.method and apparatus, more particularly to a method and apparatus for uniformly scaling a digital image.
The ability to combine digital images is of utmost importance in computer multi-media applications. Usually, a digital image is preprocessed bef ore it can be combined with another digital image. Preprocessing is normally accomplished by increasing the size of the digital image (hereinafter referred to as scaling-up), reducing the size of the digital image (hereinafter referred to as scaling-down), cutting a selected portion of the digital image, shifting the selected portion of the digital image to another location, etc.
Scaling-up and scaling-down of digital images are usually accomplished by a specially-programmed computer. Scaling-up is achieved by performing linear interpolation of every two scan lines of the digital image to obtain at least one interpolated scan line that is inserted therebetween, and by performing linear interpolation of every two pixel data of each scan line to obtain at least one interpolated pixel data that is inserted therebetween. Scaling-down is achieved by deleting some of.the scan lines of the digital image, and by deleting some of the pixel data of each of the retained scan lines.
2 - In the scaling-up of digital images, linear interpolation of original image data by the computer is relatively slow. Thus, various dedicated hardware devices, such as those disclosed in European Patent Publication No. 0079542 A2 and British Patent Publication No. GB2226471 A,have been developed to permit real-time scaling-up of digital images.
One of the drawbacks of these dedicated hardware devices is that they are only capable of scaling-up digital images to a limited extent. When scaling-up a digital image with (N) scan lines, the total number of scan lines to be interpolated must be a multiple of (N1) so as to permit insertion of an equal number of interpolated scan lines between every two of the original scan lines of the original digital image in order to maintain uniformity. The same is true when scaling-up a scan line with (NI) pixel data. Thus, the conventional scaling-up apparatus is incapable of uniformly scaling a digital image with (N) scan lines (or (NI) pixel data per scan line) if the total number of interpolated scan lines (or interpolated pixel data per scan line) is not a multiple of (N-1) (or (NI1)). In addition, the conventional scaling-up apparatus is only capable of scaling-up a digital image in both the horizontal and vertical directions, and is incapable of scaling-down a digital image in one of the horizontal and vertical directions.
Therefore, the object of the present invention is to provide a method and apparatus for uniformly scaling a digital image.
More specifically, one object of the present invention is to provide a method and apparatus which is capable of uniformly scaling-down a digital image in one of the horizontal and vertical directions.
According to one aspect of the present invention, there is provided a method for processing an original digital image to obtain a uniformly scaled desired digital image, in which the original digital image has a number (N) of successive original image data and the desired digital image has a number (M) of successive desired image data, and in which the number (M) is less than the number (N), comprising the steps of:
i) storing the original image data in a7 memory unit; ii) controlling the memory unit to output a first one of the original image data; iii) storing a number (U), which is a remainder that results from division of the number (N) by the number (M), in a data register; iv) adding the number (U) and the number stored in the data register to obtain a sum; v) comparing the sum with the number (M); vi) activating the address generator to control the memory unit to output another one of the original image data offset from an immediately preceding original image data outputted by the memory unit by a number (V) equal to a quotient that results f rom the division of the number (N) by the number (M) when the sum is less than the number (M), and by a number (V+1) when the sum is at least equal to the number (M); vii) when the sum is at least equal to the number (M), subtracting the number (M) from the sum and storing thexesulting difference in the data register; and when the sum is less than the number (M), storing the sum in the data register; and viii) repeating steps iv) to vii) until (M) original image data have been outputted by the memory unit.
According to a further aspect of the present invention, there is provided an apparatus for processing an original digital image to obtain a uniformly scaled desired digital image, in which the original digital image has a number (N) of successive original image data and the desired digital image has a number (M) of successive desired image data, and in which the number (M) is less than the number (N), said apparatus comprising: a memory unit for storing the original image data therein; an address generator, connected to the memory unit, for controlling the memory unit to output a first one of the original image data; generating means for generating a number (U), which a remainder that results from division of the number (N) by the number (M); a data register; adder means, connected to the generating means and the data register, for adding the number (U) apd the number stored in the data register to obtain a sum; and computing means, connected to the adder means, the address generator and the data register, for comparing the sum with the number (M) and for activating the address generator to control the memory unit to output another one of the original image data which is offset from an immediately preceding original image data outputted by the memory unit by a number (V) equal to a quotient that results from the division of the number 6 - (N) by the number (M) when the sum is less than the number (M), and by a number (V+1) when the sum is at least equal to the number (M); the computing means storing the difference from the nuniber (M) and the sum in thedata register when the sum is at least equal to the number (M), and storing the sum in the data register when the sum is less than the number (M).
Other features and advantages of the present invention will become apparent in the following detailed description of the preferred erbodiment, given by way of example only, with reference to the accarpanying drawings, of which:
Figure 1 is a schematic circuit block diagram of the preferred embodiment of a scaling apparatus according to the present invention; Figure 2 is a schematic circuit block diagram of a bilinear adder of the preferred embodiment; Figure 3 is a schematic circuit block diagram of a scaling controller of the preferred embodiment; " Figure 4 is a schematic circuit block diagram of a residue distributor of the scaling controller; Figure 5 is a schematic circuit block diagram of an alpha series generator of the scaling controller; Figure 6 is a schematic circuit block diagram of an address generator of the scaling controller; # 1 - 7 Figure 7 is a timing diagram illustrating the scaling-up operation of the preferred embodiment when N=5 and AN=2; Figure 8 is a timing diagram illustrating the scaling-up operation of the preferred embodiment when N=5 and AN=6; and Figure 9 is a timing diagram illustrating the scaling-down operation of the preferred embodiment when N=5 and AN=2.
Referring to Figure 1, the preferred embodiment of an apparatus for uniformly scaling a digital image in accordance with the present invention is shown to comprise a vertical scaling unit and a horizontal scaling unit. The vertical scaling unit is capable of scaling-up and scaling-down a digital image in a vertical direction and includes a line memory 3, a line buffer 4, a bilinear adder 5 and a vertical scaling controller 6. The horizontal scaling unit is capable of scaling-UP and scaling-down_a digital image in a' horizontal direction and includes a dot register 7, a dot buffer 8, a bilinear adder 9 and a horizontal scaling controller 10.
In use, a digital image to be processed with the use of the apparatus of the preferred embodiment is initially stored.in a frame memory 2. The digital image may be from an image decoder or an image capturing system. The vertical scaling controller 6 controls the - 8 frame memory 2 to provide a selected scan line of the digital image to the line memory 3. The vertical scaling controller 6 further controls the line buffer 4 to store a previous scan line from the line memory 3 therein. The bilinear adder 5 receives scan line. data from the line memory 3 and the line buffer 4, and performs bilinear interpolation according to a pair of weighing coeffici6nts a, 1-a from the vertical scaling controller 6.
Figure 2 is a schematic circuit block diagram of the bilinear adder 5. As shown, scan line data from the line buffer 4, which corresponds to an (n)th scan line of the digital image in the frame memory 2, is multiplied by the coefficient 1-a, while scan line data from the line memory 3, which corresponds to an (n+l)th scan line of the digital image in the frame memory 2, is multiplied by the coefficient a. The resulting products are then added to obtain an interpolated scan line when the coefficient a is a fraction, i.e. not equal to 0 or- 1. The operation of the bilinear adder 5 will be described in greater.detail in the succeeding paragraphs.
Referring to Figure 3, the vertical scaling controller 6 is shown to comprise a programmable register set 30 %hich includes a first register 30a for storing the number (N) of original scan lines of the digital image in the frame memory 2, a second register 1 9 30b for storing the number (AN) of scan lines to be interpolated or deleted, and a third register 30c for storing an INC/DEC flag 38 that is used to indicate whether scaling-up or scaling-down of the digital image in a vertical direction is to be performed. The vertical scaling controller 6 further includes first, second and third computing circuits 31, 32, 33 which read the contents of the first, second and third registers 30a, 30b, 30c. The first computing circuit 31 outputs a quotient T resulting from division of (AN) by (N-1), while the second computing circuit 32 outputs a remainder S resulting from the division of (AN) by (N1). The quotient T corresponds to the minimum number of interpolated scan lines to be inserted between every two original scan lines of the digital image stored in the frame memory 2, and the remainder S corresponds to the total number of residual interpolated scan lines to be distributed uniformly among the original scan lines of the digital image stored in the frame memory-2 when the digital image is scaled-up. The third computing circuit 33 outputs a remainder U resulting from division of (N) by (N-AN). The remainder U corresponds to the total number of residual scan lines to be deleted from the digital image stored in the frame memory 2 when the.digital image is scaled-down.
A two-input selector 34 has a first input which receives the remainder U from the third computing circuit 33 and a second input which receives the remainder S from the second computing circuit 32. The selector 34 further has a control input which receives the INC/DEC flag 38 from the third register 30c. The output 42 of the selector 34 is received by a residue distributor 35. The residue distributor 35 further receives the quotient T from the first computing circuit 31, and has a control input which receives the INC/DEC flag 38 from the third register 30c, and a control output 39 which is connected to an alpha series generator 36 and an address generator 37. The residue distributor 35 determines when a residual interpolation step is to be performed during scaling-up of the digital image and when a residual scan line is to be deleted during scaling-down of the digital image. The alpha series generator 36 receives the quotient T from the first computing circuit 31 and the INC/DEC flag 38 from the third register 30c, and generates the coefficients a, 1-a for the bilinear adder 5 and a store command signal for the line buffer 4 (see Figure 1). The address generator 37 also receives the quotient T from the first computing circuit 31 and the INC/DEC flag 38 from the third register 30c, and provides line address data to the frame memory 2.
Referring to.Figure 4, the residue distributor 35 comprises a computing circuit 40 which outputs the difference of (N) and (AN), and a two-input selector 41 is which has a first input that receives the output of the computing circuit 40, a second input that receives the number (N) from the first register 30a, and a control input that receives the INC/DEC flag 38 from the third register 30c. A medial data register 56 receives the output 42 of the selector 34 (see Figure 3) and has an output connected to one of the inputs of a two-input adder 43. The other input of the adder 43 receives the output 42 of the selector 34. The output of the adder 43 and the output of the selector 41 serve as inputs to a computing circuit 44 which deducts the latter from the former and which generates an enable signal at a control output 39 thereof when the output of the adder 43 is larger than or equal to the output of the selector 41. A two-ifiput selector 45 has a first input that receives the output of the adder 43, a second input that receives the difference of the outputs of the adder 43 and the selector 41 from the computing circuit 44, a control input that is connected-to the control output 39 of the computing circuit 44, and an output that is connected to the medial data register 56.
A clock modifying circuit 46 receives the original input line clock and modifies the latter in accordance with the signal at the control output 39 and the quotient T from the first computing circuit 31. When the control output 39 is in a logic high state, the clock modifying circuit 46 outputs a divide-by-(T+2) clock that has a duration of (T+2) times of the original input line clock, and when the control. output 39 is in a logic low state, the clock modifying circuit 46 outputs a divide-by-(T+1) clock that has a duration of (T+1) times of the original input line clock. The output of the clock modifying circuit 46 and the original input line clock serve as inputs to a selector 47. The INC/DEC flag 38 from the third register 30c serves as the control input of the selector 47. The medial data register 56 has a load pin LD that receives a clock signal mClockl from the selector 47.
Referring to Figure 5, the alpha series generator 36 includes a coefficient generator 363 which is connected to the control output 39 of the computing circuit 44 and which receives the original input line clock and the quotient T from the first computing circuit 31. When the control output 39 is in a logic high- state, the coefficient generator 363 generates consecutive 1, 1/(T+2), 21(T+2), ---- (T+1)/(T+2) alpha coefficients respectively in consecutive (T+2) line clock periods, and when the control output 39 is in a logic low state, the coefficient generator 363 generates consecutive 1, 1/(T+1), 2/(T+1),.... (T)/(T+1) alpha coefficients respectively in consecutive (T+1) line clock periods. A selector 364 has a first input fixed to 1, a second input that receives the output of the coefficient generator 363, and a control input that receives the INC/DEC flag 38. The output of the selector 364.is the coefficient a and serves as one of the inputs to a subtracting circuit 365. The other input of the subtracting circuit 365 is fixed to 1. one of the outputs of the subtracting circuit 365 is the coefficient 1-a. The other output of the subtracting circuit 365 is the store command signal for the line buffer 4 (see Figure 1). The subtracting circuit 365 generates the store command signal when the coefficient 1-a is equal to zero, i.e. a = 1.
Referring to Figure 6, the address generator 37 includes a computing circuit 371 which outputs a quotient v resulting from the division of (N) by (NAN). The quotient V corresponds to an offset number between two selected scan lines of the digital image in the frame memory 2 when the digital image is scaleddown. The quotient V and the control output 39 serve as inputs to an adder 372. The output of the adder 372 serves as one of the inputs to a selector 373. The other input of the selector 373 is fixed to 1. The INC/DEC flag 38 serves as a control input of the selector 373. The selector 373 generates an offset number which is provided to an adder 374. The output of the adder 374 is c6nnected to an address register 375. The output of the address register 375 is the line address data and, in turn, is received by the adder 374. The address register 375 has a Start input to preset a line address of the first one of the original scan lines stored in the f rame memory 2. The address register 375 further has a load pin LD for controlling the storing of a next address therein.
A latch circuit 376 samples and holds the signal at the control output 39 according to the original input line clock. A clock modifying circuit 377 receives the original input line clock and modifies the latter in accordance with the output of the latch circuit 376 and the quotient T from the first computing circuit 31. When the output of the latch circuit 376 is in a logic high state, the clock modifying circuit 377 outputs a divide-by-(T+2) clock that has a duration of (T+2) times of the original input line clock, and when the output of the latch circuit 376 is in a logic low state, the clock modifying circuit 377 outputs a divide-by-(T+ 1) clock that has a duration of (T+1) times of the original input line clock. A selector 378 receives the original input line clock and the output of the clock modifying circuit 377, and is controlled by the INC/DEC flag 38 to output one of the inputs thereto as a clock input raClock2 that is received by the address register 375 at the load pin LD.
The operation of the vertical scaling unit is now described as follows:
1 - is - A. In order to facilitate explanation of the scaling-up operation of the preferred embodiment, an example in which an original digital image with five original scan lines is scaled-up so as to obtain a desired digital image with seven desired scan lines is provided.
Referring to Figure 3, the programmable register set 30 is initially programmed by storing the number 11511 in the first register 30a, the number 11211 in the second register 30b, and a logic 11111 in the third register 30c. The number 11511 corresponds to the number (N) of original sca n lines of the original digital image in the frame memory 2. The number 11211 corresponds to the total number (AN) of scan lines to be interpolated. The logic 11111 in the third register 30c indicates that scaling-up of the original digital image is to be performed.
The first computing circuit 31 outputs the quotient T resulting from the division of (AN) by (N-1). Since (AN) is less than (N-1), the quotient T is 0. The second computing circuit 32 outputs the remainder S resulting from the division of (AN) by (N-1) In this example, the remainder S is equal to 2. The output of the third computing circuit 33 is irrelevant since the selector 34 provides the output of the second computing circuit 32 to the residue distributor 35 during the scale-up operation.
1 - 16 is Referring to Figure 1 and to Figures 3 to 7, the address register 375 of the address generator 37 initially sets the line address of a first one. of the original scan lines stored in the frame memory 2 and controls the frame memory 2 to provide the first one of the original scan lines to the line memory 3 during a starting line clock. At the same time, the remainder S is stored in the medial data register 56, and the adder 43 then adds the remainder S and the contents of the medial data register 56. Since the output of the adder 43, which is equal to 4 at this time, is less than the number (N), which is equal to 5, the control output 39 of the computing circuit 44 is at a low logic state. The selector 45 provides the output of the adder 43 to the medial data register 56, and the clock input mClockl provided to the medial data register 56 is the divideby-(T+1) clock, which is exactly the same as the original input line clock since the quotient T is equal to 0.
Because the control output 39 is at a low logic state., and since the quotient T is equal to 0, the coefficient generator 363 provides the number 11111 to the selector 364. Since the INC/DEC flag 38 is at a logic 11111, the selector 364 chooses the output of the coefficient genepator 363 as the weighing coefficient a. Since the coefficient a is equal to 1, the coefficient 1-a is equal to 0, and the store command is 17 - signal is generated so as to control the line buffer 4 to store the first one of the original scan lines from the line memory 3 therein. The output of the bilinear adder 5 at this stage is the first one of the original scan lines.
The selector 373 provides an offset number, which is equal to 1, to the adder 374. The adder 374 thus increments the output of the address register 375 by one unit when the next clock pulse mClock2 arrives, thereby controlling the frame memory 2 to provide a second one of the original scan lines to the line memory 3.
Upon arrival of the next clock pulse mClocki, the medial data register 56 stores the previous output of the adder 43, which is the number 114,11 therein. At this time, the output of the adder 43, which is now equal to 6, is larger than the number (N), which is equal to 5, such that the control output 39 of the computing circuit 44 is at a high logic state. The selector 45 provides the difference of the outputs of the adder 43 and the selector 41 to the medial data register 56, and the clock input mClocki to the medial data register 56 is now the divide-by-(T+2) clock, the duration of which is twice the duration of the original input line clock.
Now that the control output 39 is at a high logic state, the coefficient generator 363 generates successively two outputs, 1 and h, within one mClockl - 18 pulse, that is, two consecutive original input line clocks. Within the first original input line clock, the bilinear adder 5 outputs the second one of the original scan lines and, at the same time, the latter is stored in the line buffer 4 since the coefficient a is equal to 1. Within the second original input line clock, the contents of the address register 375 are incremented by one unit upon reception of the next mClock2 pulse to control the frame memory 2 to provide a third one of the original scan lines to the line memory 3. At this time, the output of the coefficient generator 363 is equal to k, the coefficient a is equal to k, the coefficient 1-a is equal to k, and no store command signal is generated. Thus, the second one of the original scan lines remains in the line buffer 4. The output of the bilinear adder 5 at this stage is the bilinear interpolation of the second and third ones of the original scan lines.
The contents of the medial data register -56 are updated so as to become 1, which is the difference of the output of the adder 43 and the number (N), when the next mClockl pulse arrives. The output of the adder 43 is 3, which is less than the number (N), such that the control output 39 is at a low logic state. The selector 45 provides the putput of the adder 43 to the medial data register 56, the clock input mClockl provided to the medial data register 56 is the divide-by-(T+1) 19 - is clock, and the coefficient a from the alpha series generator 36 is equal to 1. The output of the bilinear adder 5 is the third one of the original scan lines and, because the coefficient a is equal to 1, the third one of the original scan lines is stored in the- line buffer 4.
The succeeding steps are similar to the foregoing until the fifth one of the original scan lines has been outputted by the bilinear adder 5.
Figure 7 is a timing diagram which illustrates the scaling-up operation of the preferred embodiment for this example, that is N=5 and AN=2.
It has thus been shown that the vertical scaling controller 6 controls the bilinear adder 5 to perform bilinear interpolation of an (n)th one of the original scan lines, which is stored in the line buffer 4, and an (n+ l)th one of the original scan lines, which is stored in the line memory 3, so as to produce a residual interpolated scan line that is inserted between the (n)th and'(n+l)th ones of the-original scan lines when division of (AN) by (N-1) results in a remainder (S), and when (n) is a minimum number that meets the condition (n+l) (S) t (s) (N), wherein (s) ranges from 1 to (S).
In the preceding example, the quotient (T) resulting from the division of (AN) by (N-1) is 0. If the quotient T is not zero, that is, (AN) is greater than or equal to (N-1), the vertical scaling controller 6 controls the bilinear adder 5 to perform bilinear interpolation of the (n)th and (n+l)th ones.of the original scan lines so as to produce an additional number T of successive interpolated scan lines that are inserted between the (n)th and (n+l)th ones of the original scan lines. Figure 8 illustrates a timing diagram of a sample scaling-up operation performed by the preferred embodiment when N=5 and AN=6. In this example, the quotient T is equal to 1, and the remainder S is equal to 2. Obviously, there is an additional interpolated scan line inserted between every interval of the (n)th and (n+l)th ones of the original scan lines.
B. In order to facilitate explanation of the scaling-down operation of the preferred embodiment, an example in which an original digital image with five original scan lines is scaled-down so as to obtain a desired digital image with three desired scan lines is provided.
Referring to Figure 3, the programmable register set is initially programmed by storing the number 11511 in the first register 30a, the number 11211 in the second register 30b, and a logic 11011 in the third register 30c. The number.11511 corresponds to the number (N) of original scan lines of the original digital image in the frame memory 2. The number 11211 corresponds to the - 21 total number (AN) of scan lines to be deleted. The logic 11011 in the third register 30c indicates that scaling-down of the original digital image is to be performed.
The outputs of the f irst and second computing circuits 31, 32 are irrelevant during the scale-down operation. The third computing circuit 33 outputs the remainder U resulting from the division of (N) by (NAN), (N-AN) being the number of original scan lines to be retained. In this example, the remainder U is equal to 2. The selector 34 provides the output of the third computing circuit 33 to the residue distributor 35.
Referring to Figure 1, Figures 3 to 6, and to Figure 9, the address register 375 of the address generator 37 initially sets the line address of a first one of the original scan lines stored in the frame memory 2 and controls the frame memory 2 to provide the first one of the original scan lines to the line memory 3 during a starting line clock. At the same time, the remainder U is stored in the medial data register 56, and the adder 43 then adds the remainder U and the contents of the The computing circuit 44 from the selector medial data register 56. subtracts the number (N-AN) the output of the adder 43. Since the output adder 43, which is equal to 4 at this time, is than the number (N-AN), which is equal to control output 39 of the computing circuit 44 41 from of the greater 3, the is in a - 22 high logic state. The selector 45 provides the difference of the outputs of the adder 43 and the selector 41 to the medial data register 56. The original line clock is supplied to the medial data register 56 via the selector 47.
Referring to Figures 3 and 5, because a logic 11011 is stored in the third register 30c, the selector 364 maintains the coefficient a at 1. The coefficient 1-a is thus equal to 0, and the store command signal is always generated so as to activate the line buffer 4 to store continuously anoriginal scan line from the line memory 3 therein. In addition, the output of the bilinear adder 5 is always the output of the line memory 3.
Referring to Figure 6, the computing circuit 371 outputs the quotient V resulting from the division of (N) by (N-AN). In this example, the quotient V is equal to 1. The adder 372 generates the sum of the quotient V and the logic state of the control output 39, which is currently at a high logic state. The selector 373 chooses the output of the adder 372, which is equal to 2, and provides the same to the adder 374. Thus, the output of the address register 375 is incremented by two units when the next mClock2 pulse arrives, thereby controlling the frame memory 2 to provide the third one of the original scan lines to the line memory 3.
is Referring again to Figure 4, upon arrival of the next line clock pulse, the medial data register 56 stores the number 111,11 which is the previous difference computed by the computing circuit 44, therein. At this time, the output of the adder 43, which is equalto 3, is equal to the output of the selector 41. The control output 39 of the computing circuit 44 is at a high logic state, and the selector 45 provides the difference of the outputs of the adder 43 and the selector 41 to the medial data register 56.
Referring again to Figure 6, the adder 372 once more generates the sum of the quotient V and the current logic state of the control output 39. The output of the adder 372, which is equal to 2, is provided to the adder 374 via the selector 373. Thus, the output of the address register 375 is again incremented by two units when the next mClock2 pulse arrives, controlling the frame memory 2 to provide the of the original scan lines to the line memory 9 is a timing diagram-which illustrates the down operation of the preferred embodiment example, that is N=5 and AN=2.
From the foregoing, it has been shown that the address generator 37 controls the frame memory 2 to output only chosen ones of the original scan lines. The original scan lines which were not outputted by the frame memory 2 are, in effect, discarded. It is noted thereby fifth one 3.Figure scalingfor this - 24 that the original scan line to be outputted by the frame memory 2 is offset from an immediately preceding original scan line that was outputted by the latter by the number V when the output of the adder 43 is less than the difference (N-AN), and by the number,(V+1) when the output of the adder 43 is at least equal to the difference (N-AN).
The structure and operation of the horizontal scaling unit will now be described as follows:
The output of the bilinear adder 5 is received by the dot register 7. The horizontal scaling controller 10 controls the dot buffer 8 to store a previous pixel data from the dot register 7 therein. The bilinear adder 9 receives pixel data from the dot register 7 and the dot buffer 8, and performs bilinear interpolation according to a pair of weighing coefficients q, 1-a from the horizontal scaling controller 10. The structure of the bilinear adder 9 is similar to that of the bilinear adder 5 shown in Figure 2. In the bilinear adder 9, howeVer, pixel data from the dot buffer 8, which corresponds to an (nl)th pixel data of the scan line data from the bilinear adder 5, is multiplied by the coefficient I-a, while pixel data from the dot register 7, which corresponds to an (nl+l)th pixel data of the scan line data from the bilinear adder 5, is multiplied by the coefficient a. Thus, the dot register 7 is equivalent to the line memory 3 of the vertical - scaling unit, while the dot buffer 8 is equivalent to the line buffer 4 of the vertical scaling unit.
The structure of the horizontal scaling controller 10 is substantially similar to that of the vertical scaling controller 6 shown in Figures 3 to 6.-Minor differences between the two controllers 6, 10 exist. For example, in the horizontal scaling controller 10, the first register of the programmable register set is used to store the number (NI) of pixel data per original scan line of the digital image in the frame memory 2, and the second register is used to store the number (AN') of pixel data to be interpolated or deleted per scan line. The third register stores an INC/DEC flag that is used to indicate whether scalingup or scaling-down of the digital image in a horizontal direction is to be performed. The clock input to the address generator, the alpha series generator and the residue distributor is the original pixel clock. The address output of the address register of the horizontal scaling controller 10 is a dot address that is used to control the line memory 3 and the line buffer 4. Thus, during scaling-up in a horizontal direction, all of the pixel data of (n)th and (n+l)th ones of the original scan lines and the interpolated scan lines therebetween, if any, pass through the bilinear adder S. When scaling-down in both vertical and horizontal directions, only selected ones of the 26 - pixel data of the chosen ones of the original scan lines pass through the bilinear adder S.
Since the apparatus of the present invention is a dedicated hardware device, real-time scaling-up of digital images is possible. In addition, uniform scaling of a digital image with (N) scan lines (or (NI) pixel data per scan line) is possible even if the total number of interpolated scan lines (or interpolated pixel data per scan line) is not a multiple of (N-1) (or (NI-1)). Furthermore, the scaling apparatus of the present invention can be used to scale-UP and scale-down a digital image selectively in any of the horizontal and vertical directions. The objectives of the present invention are thus met.
The present application is divided from U.K. Patent Application No. 9515266.6.
1
Claims (17)
- Claims is 1. A method for processing an original digital image to obtain auniformly scaled desired digital image, the original digital image having a number (N) of successive original image data, the desired digital image having a number (M) of successive desired image data, the number (M) being less than the number (N), said method comprising the steps of:a) storing the original image data in a memory unit; b) providing an address generator which controls said memory unit to output a first one of the original image data; c) storing a number (U), which is a remainder that results from division of the number (N) by the number (M), in a data register; d) adding the number (U) and the number stored in said data register to obtain a sum; - e) comparing the sum with the number (M); f) activating said address generator to control said memory unit to output another one of the original image data, said another one of the original image data being offset from an immediately preceding original image data outputted by said memory unit by a number (V) equal to a quotient that results from the division of the number (N) by the number (M) when the sum is less than the number (M), and by a number (V+1) when the sum is at least equal 1 le ts to the number (M); g) when the sum is at least equal to the number (M) subtracting the number (M) from the sum and storing the resulting difference in said data register; and when the sum is less than the number (M), storing the sum in said data register; and h) repeating steps d) to g) until (M) original image data have been outputted by said memory unit.
- 2. The method as claimed in claim 1, wherein the original image data is scan line data.
- 3. The method as claimed in Claim 1 or 2 wherein each of the original image data has a number (NI) of successive original pixel data and each of the desired image data has a number (M') of successive desired pixel data, the number (M') being greater than the number (NI), said method further comprising the steps of:providing a first linear interpolator; and controlling said first linear interpolator to perform a linear interpolation of (nl)th and (nl+l)th one& of the original pixel data of each of the original image data to produce a residual interpolated pixel data inserted therebetween when division of (M'-NI) by (NI-1) results in a remainder (S') and when (nl) is a minimum number which meets a condition (nl+l)(S1) 2! (s')(N1), wherein the number (sl) ranges from 1 to (V).
- 4. The method as claimed in Claim 3, further comprising the step of controlling said first linear interpolator to perform a linear interpolation of the (nl)th and (nl+l)th ones of the original pixel data of each of the original image data to produce an additional number (T1) of successive interpolated pixel data inserted therebetween when (M'-NI) is larger than (NI-1), the number (T1) being equal to a quotient resulting from the division of (M'-NI) by (NO-1).
- 5. The method as claimed in any preceding Claim, wherein said first linear interpolator is a bilinear adder.
- 6. The method as claimed in Claim 3 or 4, wherein said controlling step comprises the steps of:bi) storing the number (S') in a data register; bii) adding the number (S') and the number stored in said data register to obtain a sum; biii) comparing the sum in step bii) with the number (NI); biv) when the sum in step bii) is at least equal to the number (NI), controlling said linear interpolator to produce the residual interpolated pixel data inserted between the (nl)th and (nl+l)th ones of the original pixel data, subtracting the number (NI) from the sum in step bii), and storing the resulting difference in said data register; and when the sum in step bii) is less than the number (NI), storing said sum in said data register; bv) repeating steps bii) to biv) by incrementing (nl) by 1 until (nl) equals (NI).
- 7. The method as claimed in any preceding claim, wherein each of the original image data has a number (NI) of successive original pixel data and each of the desired 9 A image data has a number (M') of successive desired pixel data, the number (M') being less than the number (NI), said method further comprising the steps of:ci) storing one of the original image data in a memory unit; cii) providing an address generator which controls said memory unit to output a f irst one of the original pixel data; ciii) storing a number (U'), which is a remainder that results from division of the number (NI) by the number (M'), in a data register; civ) adding the number (U') and the number stored in said data register to obtain a sum; CV) comparing the sum in step civ) with the number W); cvi) activating said address generator to control said memory unit to output another one of the original pixel data, said another- one of the original pixel data being offset from an immediately preceding original pixel data outputted by said memory unit by a number (V') equal to a quotient that results from the division of the number (NI) by the number (M') when the sum in step civ) is less than the number (M'), and by a number (V1+1) when the sum in step civ) is at least equal to the number (M'); cvii) when the sum in step civ) is at least equal to the number (M'), subtracting the number (M') from the sum in step civ) and storing the resulting difference in said data register; and when the sum in step civ) is less than the number (M'), storing said sum in said data register; and cviii) repeating steps civ) to cvii) until (MI) original pixel data have been outputted by said memory unit.
- 8. The method as claimed in any preceding claim, wherein the original image data is original pixel data of one scan line.
- 9. An apparatus for processing an original digital image to obtain a uniformly scaled desired digital image, the original digital image having a number (N) of successive original image data, the desired digital image having a number (M) of successive desired image data, the number (M) being less than the number (N), said apparatus comprising:a first memory unit for storing the original image data therein; a first address generator, connected to said first memory unit, for controlling said first memory unit to output a first one of the original image data; first generating means for generating a number (U), which is a remainder that results from division of the number (N) by the number (M); a first data register; F - 32 first adder means, connected to said first generating means and said first data register, for adding the number (U) and the number stored in said first data register to obtain a sum; and first computing means, connected to said first adder means, said f irst address generator and said f irst data register, f or comparing the sum with the number (M) and for activating said f irst address generator to control said first memory unit to output another one of the original image data, said another one of the original image data being offset from an immediately preceding original image data outputted by said first memory unit by a number (V) equal to a quotient that results from the division of the number (N) by the number (M) when the sum is less than the number (M), and by a number (V+1) when the sum is at least equal to the number (M); said first computing means storing the difference of the number (M) and the sum in said f irst data register when the sum is at least equal to the number (M), and storing the sum in said first data register when the sum is less than the number (M).
- 10. The apparatus as claimed in any of Claim. 9, wherein the original image data is scan line data.
- 11. The apparatus as claimed in claim 10, wherein each of the original image data has a number (NI) of successive original pixel data and each of the desired image data has a number (M') of successive desired pixel data, the number (M') being greater than the number (NI), said apparatus further comprising:a linear interpolator; and controller means, connected to said linear interpolator, for controlling said linear interpolator to perform a linear interpolation of (nl)th and (nl+l)th ones of the original pixel data of each of the original image data to produce a residual interpolated pixel data inserted therebetween when division of (M'-NI) by (NI-1) results in a remainder (S') and when (nl) is a minimum number which meets a condition (nl+l)(S1) 2t (s')(N1), wherein the number (sl) ranges from 1 to (S').
- 12. The apparatus as claimed in Claim 11, wherein said controller means further controls said linear interpolator to perform a linear interpolation of the (nl)th and (nl+l)th ones of the original pixel data of each of the original image data to produce an additional number (T1) of successive interpolated image data inserted therebetween when (M'-NI) is larger than (NI-1), the number (T1) being equal to a quotient resulting from the division of (M'- NI) by (NI-1).
- 13. The apparatus as claimed in Claim 12, wherein said linear interpolator is a bilinear adder.
- 14. The apparatus as claimed in any of Claims9 to13, wherein each of the original image data has a number (NI) of successive original pixel data and each of the desired image data has a number (M') of successive desired pixel data, the number (M') being less than the number (NO), said apparatus further comprising:t second memory unit for storing one of the original image data therein; second address generator, connected to said second memory unit, f or controlling said second memory unit to output a first one of the original pixel data; second generating means for generating a number (U'), which is a remainder that results f rom division of the number (NO) by the number (M'); a second data register; second adder means, connected to said second generating means and said second data register, f or adding the number (U') and the number stored in said second data register to obtain a sum; and second computing means, connected to said second adder means, said second address generator and said second data register, for comparing the sum with the number (M') and for activating said second address generator to control said second memory unit to output another one of the original pixel data, said another one of the original pixel data being offset from an immediately preceding original pixel data outputted by said second memory unit by a number (V') equal to a quotient that results from the division of the number (NI) by the number (M') when the sum is less than the number (M'), and by a number (V1+1) when the sum is at least equal to the number (M'); said second computing means storing the difference of the number (M') and the sum in said second data register when the sum is at least equal to the number (M'), and 0 % storing the sum in said second data register when the sum is less than the number (M').
- 15. The apparatus as claimed in any of Claims 9 to 14, wherein the original image data is original pixel data of one scan line.
- 16. The method for processing an original digital image to obtain a uniformly scaled desired digital image substantially as hereinbefore described with reference to and as illustrated in the accompanying drawings.
- 17. The apparatus for processing an original digital image to obtain a uniformly scaled desired digital image substantially as hereinbefore described with reference to and as illustrated in the accompanying drawings.17. The apparatus for processing an original digital image to obtain a uniformly scaled desired digital image substantially as hereinbefore described with reference to and as illustrated in the accompanying drawings.1311 Amendments to the claims have been filed as follows 1. A method for processing an original digital image to obtain a uniformly scaled desired digital image, the original digital image having a number (N) of successive original image data, the desired digital image having a number (M) of successive desired image data, the number (M) being less than the number (N), said method comprising the steps of:a) storing the original image data in a memory unit; b) providing an address generator which controls said memory unit to output a first one of the original image data; c) storing a number (U), which is a remainder that results from division of the number (N) by the number (M), in a data register; d) adding the number (U) and the number stored in said data register to obtain a sum; - e) comparing the sum with the number (M); f) activating said address generator to control said memory unit to output another one of the original image data, said another one of the original image data being offset from an immediately preceding original image data outputted by said memory unit by a number (V) equal to a quotient that results from the division of the number (N) by the number (M) when the sum is less than the number (M), and by a number (V+1) when the sum is at least equal 1 to the number (M); g) when the sum is at least equal to the number (M), subtracting the number (M) from the sum and storing the resulting difference in said data register; and when the sum is less than the number (M), storing the sum in said data register; and h) repeating steps d) to g) until (M) original image data have been outputted by said memory unit. 2. The method as claimed in claim 1, wherein the original image data is scan line data. 3. The method as claimed in claim 1 or 2 wherein each of the original image data has a number (NI) of successive original pixel data and each of the desired image data has a number (M') of successive desired pixel data, the number is (M') being greater than the number (NI), said method further comprising the steps of:providing a first linear interpolator; and controlling said first linear interpolator to perform a linear interpolation of (nl)th and (nl+l)th one@ of the original pixel data of each of the original image data to produce a residual interpolated pixel data inserted therebetween when division of (M'-NI) by (NI-1) results in a remainder (S') and when (nl) is a minimum number which meets a condition (nl+l)(S9) k (s')(N1), wherein the number (sl) ranges from 1 to (S').4. The method as claimed in Claim 3, further comprising the step of controlling said first linear interpolator to perform a linear interpolation of the (nl)th and (nl+l)th r t_ - A ones of the original pixel data of each of the original image data to produce an additional number (T1) of successive interpolated pixel data inserted therebetween when (M'-NI) is larger than (NI-1), the number (T1) being equal to a quotient resulting from the division of by (NI-1).5. The method as claimed in any preceding Claim, wherein said first linear interpolator is a bilinear adder.6. The method as claimed in Claim 3 or 4, wherein said controlling step comprises the steps of:bi) storing the number (S') in a data register; bii) adding the number (V) and the number stored in said data register to obtain a sum; biii) comparing the sum in step bii) with the number (NI); biv) when the sum in step bii) is at least equal to the number (NI), controlling said linear interpolator to produce the residual interpolated pixel data inserted between the (nl)th and (nl+l)th ones of the original pixel data, subtracting the number (NI) from the sum in step bii), and storing the resulting difference in said data register; and when the sum in step bii) is less than the number (NI), storing said sum in said data register; bv) repeating steps bii) to biv) by incrementing (nl) by 1 until (nl) equals (NI). 7. The method as claimed in any preceding claim, wherein each of the original image data has a number (NI) of successive original pixel data and each of the desired 1 h is - 3q - image data has a number (M') of successive desired pixel data, the number (M) being less than the number (NI), said method further comprising the steps of:ci) storing one of the original image data in a memory unit; cii) providing an address generator which controls said memory unit to output a f irst one of the original pixel data; ciii) storing a number (U'), which is a remainder that results from division of the number (NI) by the number (M'), in a data register; civ) adding the number (U') and the number stored in said data register to obtain a sum; CV) comparing the sum in step civ) with the number W); cvi) activating said address generator to control said memory unit to output another one of the original pixel data, said another- one of the original pixel data being offset from an immediately preceding original pixel data outputted by said memory unit by a number (V') equal to a quotient that results from the division of the number (NI) by the number (M') when the sum in step civ) is less than the number (M'), and by a number (V1+1) when the sum in step civ) is at least equal to the number (M'); cvii) when the sum in step civ) is at least equal to the number (M'), subtracting the number (M') from the sum in step civ) and storing the resulting difference in said data register; and when the sum in step civ) is less than - 46 the number (M'), storing said sum in said data register; and cviii) repeating steps civ) to cvii) until (M') original pixel data have been outputted by said memory unit. 8. The method as claimed in any preceding Claim, wherein the original image data is original pixel data of one scan line. 9. An apparatus for processing an original digital image to obtain a uniformly scaled desired digital image, the original digital image having a number (N) of successive original image data, the desired digital image having a number (M) of successive desired image data, the number (M) being less than the number (N), said apparatus comprising:a first memory unit for storing the original image data therein; a first address generator, connected to said first memory unit, for controlling said first memory unit to output a first one of the original image data; first generating means for generating a number (U), which is a remainder that results from division of the number (N) by the number (M); a first data register for storing the number (U) generated by said first generating means; t - 4 f irst adder means, connected to said f irst generating means and said first data register, for adding the number (U) and the number stored in said first data register to obtain a sum; and first computing means, connected to said first adder means, said f irst address generator and said f irst data register, f or comparing the sum with the number (M) and f or activating said f irst address generator to control said first memory unit to output another one of the original image data, said another one of the original image data being offset from an immediately preceding original image data outputted by said first memory unit by a number (V) equal to a quotient that results from the division of the number (N) by the number (M) when the sum is less than the number (M), and by a number (V+I) when the sum is at least equal to the number (M); said first computing means storing the difference of the number (M) and the sum in said f irst data register when the sum is at least equal to the number (M), and storing the sum in said first data register when the sum is less than the number (M).10. The apparatus as claimed in any of Claim, 9, wherein the original image data is scan line data. 11. The apparatus as claimed in claim 10, wherein each of the original image data has a number (NI) of successive original pixel data and each of the desired image data has a number (M') of successive desired pixel data, the number (M') being greater than the number (NI), said apparatus r further comprising:a linear interpolator; and controller means, connected to said. linear interpolator, for controlling said linear interpolator to perform a linear interpolation of (nl)th and (nl+l)th ones of the original pixel data of each of the original image data to produce a residual interpolated pixel data inserted therebetween when division of (M'-NI) by (NI-1) results in a remainder (S') and when (nl) is a minimum number which meets a condition (nl+l)(S1) k (si)(NO), wherein the number (sl) ranges from 1 to (S').12. The apparatus as claimed in claim 11, wherein said controller means further controls said linear interpolator to perform a linear interpolation of the (nl)th and (nl+l)th ones of the original pixel data of each of the original image data to produce an additional number (T9) of successive interpolated image data inserted therebetween when (M'-NI) is larger than (NI-1), the number (TO) being equal to a quotient resulting from the division of (M'-NI) by (NI-1).13. The apparatus as claimed in Claim 12, wherein said linear interpolator is a bilinear adder.14. The apparatus as claimed in any of Claims9 to13, wherein each of the original image data has a number (NI) of successive original pixel data and each of the desired image data has a number (M') of successive desired pixel data, the number (M') being less than the number (NI), said apparatus further comprising:- It3> - second memory unit for storing one of the original image data therein; second address generator, connected to said second memory unit, f or controlling said second memory unit to output a first one of the original pixel data; second generating means for generating a number (U I), which is a remainder that results f rom division of the number (NI) by the number (M'); a second data register; second adder means, connected to said second generating means and said second data register, f or adding the number (U') and the number stored in said second data register to obtain a sum; and second computing means, connected to said second adder means, said second address generator and said second data register, for comparing the sum with the number (M') and for activating said second address generator to control said second memory unit to output another one of the original pixel data, said another one of the original pixel data being offset from an immediately preceding original pixel data outputted by said second memory unit by a number (V') equal to a quotient that results from the division of the number (NI) by the number (M') when the sum is less than the number (M'), and by a number (V1+1) when the sum is at least equal to the number (M'); said second computing means storing the difference of the number (M') and the sum in said second data register when the sum is at least equal to the number (M'), and 0 & - Ltt, storing the sum in said second data register when the sum is less than the number (M1).15. The apparatus as claimed in any of Claims 9 to 14, wherein the original image data is original pixel data of one scan line.16. The method for processing an original digital image to obtain a uniformly scaled desired digital image substantially as hereinbefore described with reference to and as illustrated in the accompanying drawings.
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
GB9515266A GB2304014B (en) | 1995-07-25 | 1995-07-25 | Method and apparatus for uniformly scaling a digital image |
Publications (3)
Publication Number | Publication Date |
---|---|
GB9611306D0 GB9611306D0 (en) | 1996-07-31 |
GB2304015A true GB2304015A (en) | 1997-03-05 |
GB2304015B GB2304015B (en) | 1997-06-04 |
Family
ID=10778237
Family Applications (3)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
GB9611306A Expired - Fee Related GB2304015B (en) | 1995-07-25 | 1995-07-25 | Method and apparatus for uniformly scaling a digital image |
GB9515266A Expired - Fee Related GB2304014B (en) | 1995-07-25 | 1995-07-25 | Method and apparatus for uniformly scaling a digital image |
GB9615557A Expired - Lifetime GB2303758B (en) | 1995-07-25 | 1996-07-24 | Method and apparatus for uniformly scaling a digital image |
Family Applications After (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
GB9515266A Expired - Fee Related GB2304014B (en) | 1995-07-25 | 1995-07-25 | Method and apparatus for uniformly scaling a digital image |
GB9615557A Expired - Lifetime GB2303758B (en) | 1995-07-25 | 1996-07-24 | Method and apparatus for uniformly scaling a digital image |
Country Status (1)
Country | Link |
---|---|
GB (3) | GB2304015B (en) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
GB2354130A (en) * | 1999-09-09 | 2001-03-14 | Inventec Electronics | Method for enlarging/reducing digital images |
Families Citing this family (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5847714A (en) * | 1996-05-31 | 1998-12-08 | Hewlett Packard Company | Interpolation method and apparatus for fast image magnification |
US6097434A (en) * | 1998-03-25 | 2000-08-01 | Intel Corporation | System and method for correcting pixel data in an electronic device |
Family Cites Families (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4282546A (en) * | 1979-11-28 | 1981-08-04 | Rca Corporation | Television image size altering apparatus |
US4558347A (en) * | 1983-08-26 | 1985-12-10 | Rca Corporation | Progressive scan television system employing vertical detail enhancement |
JP2767933B2 (en) * | 1989-11-14 | 1998-06-25 | ソニー株式会社 | Pixel number conversion circuit |
JP2913797B2 (en) * | 1990-08-10 | 1999-06-28 | ソニー株式会社 | Image scaling processing method |
-
1995
- 1995-07-25 GB GB9611306A patent/GB2304015B/en not_active Expired - Fee Related
- 1995-07-25 GB GB9515266A patent/GB2304014B/en not_active Expired - Fee Related
-
1996
- 1996-07-24 GB GB9615557A patent/GB2303758B/en not_active Expired - Lifetime
Cited By (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
GB2354130A (en) * | 1999-09-09 | 2001-03-14 | Inventec Electronics | Method for enlarging/reducing digital images |
GB2354130B (en) * | 1999-09-09 | 2002-05-15 | Inventec Electronics | Method for enlarging/reducing digital images |
Also Published As
Publication number | Publication date |
---|---|
GB9515266D0 (en) | 1995-09-20 |
GB2304015B (en) | 1997-06-04 |
GB9611306D0 (en) | 1996-07-31 |
GB2303758B (en) | 1997-08-06 |
GB2304014B (en) | 1997-08-20 |
GB2303758A (en) | 1997-02-26 |
GB2304014A (en) | 1997-03-05 |
GB9615557D0 (en) | 1996-09-04 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US4402012A (en) | Two-dimensional digital linear interpolation system | |
EP0462565B1 (en) | Multiwindow display control method and apparatus | |
US5008752A (en) | Digital image interpolator with multiple interpolation algorithms | |
JPH04503141A (en) | Fast interpolation filter for television standard conversion | |
US5825367A (en) | Apparatus for real time two-dimensional scaling of a digital image | |
US5621870A (en) | Method and apparatus for uniformly scaling a digital image | |
EP0723688B1 (en) | Digital image resizing apparatus and method of using the same | |
JP3216907B2 (en) | Electronic zoom device and imaging device | |
GB2304015A (en) | Method and apparatus for uniformly scaling a digital image | |
EP0316956B1 (en) | Image processing system | |
EP0497494A1 (en) | Image scaling apparatus for a multimedia system | |
US6304679B1 (en) | Method and apparatus for implementing two-dimensional digital filters | |
US5177698A (en) | Selectable power of two coefficient signal combining circuit | |
EP1153507B1 (en) | Interpolation method for a video signal, and display device with function of interpolation for a video signal | |
US5905539A (en) | Method and apparatus for generating a wipe solid | |
EP0145181B1 (en) | Halo generation for crt display symbols | |
JPH0771189B2 (en) | Image data scaling processor | |
WO1992001260A1 (en) | Selectable power of two coefficient signal combining circuits | |
KR100208389B1 (en) | Method and apparatus for uniformly scaling adigital image | |
US5493521A (en) | Vector calculation apparatus capable of rapidly carrying out vector calculation of two input vectors | |
JP3025437B2 (en) | Method and apparatus for processing original digital images | |
JP3726971B2 (en) | Parallel processor device | |
US6859205B1 (en) | Apparatus and method for drawing lines | |
JPH02135880A (en) | Image pickup device | |
KR960005208B1 (en) | Method and apparatus for filtering induced boundary error compensation |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
PCNP | Patent ceased through non-payment of renewal fee |
Effective date: 20080725 |