The present invention relates an image processing device.
It is conventionally known that an image is blurred upon taking a picture with a camera and the like. A blur of an image is mainly due to hand-jiggling upon taking a picture, various aberrations in optics, lens distortion and the like.
In order to stabilize an image, there are two methods, moving lens and electronic processing. As a method of moving a lens, for example, the patent document 1 discloses a method of stabilizing an image by detecting hand-jiggling and moving a predetermined lens in response to jiggling.
As a method of electronic processing, the document 2 discloses a method of producing a restored image by detecting displacement of a camera's optical axis with an angular velocity sensor, gaining a transfer function that shows a blurry state upon taking a picture from detected angular velocity, and inversely transforming the gained transfer function about a shot image.
A camera, equipped with a method of stabilizing an image shown in the patent document 1, becomes a large size because of necessity of a space for mounting hardware for driving a lens such as motor and the like. Further, installing such hardware and a driving circuit for driving the hardware needs to increase a cost.
Further, a method of stabilizing an image shown in the patent document 2 includes following issues, although the method does not have the above mentioned problem. Namely, following two issues cause difficulty of producing a restored image in actual; though inversed transformation of a gained transfer function theoretically produces a restored image.
First, the gained transfer function is extremely weak in handling noises and information errors about a blur and slight variation of them greatly affects the values of the function. This variation results in a disadvantage in that a restored image produced by the inversed transformation is far from a stabilized image without hand-jiggling and out of use in actual. Second, the inverse transformation factoring noises sometime needs a method of estimating solutions by using singular value decomposition about solutions in simultaneous equations. But calculated values for such estimation run into astronomical numbers, actually yielding a high risk of remaining unsolved.
The advantage of the invention is to provide an image processing device realizing a practical image processing of restoring image data as well as preventing the device from becoming a large size.
In order to solve the above mentioned issues, the image processing device of the present invention produces restored data by repeating processes without using the inversed transfer function.
The aspect of the invention produces restored data approaching to an original image by only producing predetermined data through using data of fluctuation factor information that triggers image fluctuation. This processing does not need an increase of additional hardware, not making a device a large size. Further the processes of producing comparison data from restored data and comparing the comparison data with the original image data as an object to be processed are repeated, obtaining the restored data that gradually approaches to an image before fluctuation which is a base for an original image. These processes realize practical restoring operations. Hence, these processes can provide an image processing device that includes a system of circuitry for processing in order to restore an image.
According to other aspect of the invention, an image processing device repeats the processes of reduced data as an object to be processed, and then produces restored data by using a transfer function obtained from restored data which is a reduced image.
According to this aspect of the invention, the repetition of the processes in order to obtain reduced and restored data approaching to the initial image before fluctuation, which is a base for the original image, is combined with deconvolution processing using a transfer function. This combined processing prevents a device from being a large size, realizes more practical restoring operation and enhances high speed processing.
Further, a reduced data of the original image is produced by thinning the original image data. A processing unit may attain a new transfer function by reversely multiplying the transfer function with the reduce ratio of reduced original image data to the original image and interpolating a enlarged space, and then produce the restored data approaching to the initial image by using the new transfer function. These processes can attain the transfer function corresponding to an entire image.
Further, the reduced data of an original image may be produced by directly retrieving a part of region from original image data. This process can attain a transfer function corresponding to a part of a region and being applied to an entire image.
Further, according to other aspect of the invention, an image processing device produces superimposed-restored data by superimposing image data to be processed on data for superimposing and repeating the processes by using image attained by such superimposing. Then, a superimposed portion is removed.
According to this aspect of the invention, the data for superimposing based on already-known image data is superimposed on the original image data as an object to be processed. Such superimposing shortens processing time while changing image quality even if it takes long time to produce the restored image. Further, it provides an image processing device including a method of practical circuit processing while preventing the device from become a large size.
Further, the already-known image data may favorably be image data which shows less contrast comparing to the original image before fluctuation. By using the image data, data which is an object to be processed for producing a superimposed restored image data, becomes image data having further less contrast, and reduces time for processing.
Further, according to other aspect of the invention, an image processing device produces restored data, approaching to an original image before fluctuation, by calculating error component data within the restored data attained through repetition of processing in some degrees, and removing the error component data from the restored data.
The aspect of the invention can attain the error component data, and calculate the restored data, approaching to the original image, by removing the error component data included in the restored data from the restored data attained with repetition of processing in some degrees. Such calculation can shorten processing time. Further, it provides an image processing device including a method of practical circuit processing while preventing the device from being a large size.
Further, the above calculation of the error component data may comprise: producing fluctuated image data of first restored data from the first restored data by using data of fluctuation factor information; adding the fluctuated image data to original image data as an object to be processed; producing second restored data by restoring the added data; obtaining error component data by using the second restored data and the first restored data. The above processes can simplify a processing structure since the second restored data is produced by a process that is the same of producing the first restored data.
The processing unit may preferably halt the repetition of the processes if the difference data become equal to or less or smaller than a predetermined value. This halt can avoid long time processing since the processes are halted before “zero” difference. Further, setting the difference data equal to or less than a predetermined value can further approximate the restored data to an image before fluctuation(before blurring) as base of an original image. Further, even upon yielding noises may bring a situation of “zero” difference, which is not actually happened, the above halt can avoid unlimited repetition.
Further, the processing unit may favorably halt the repetition of the processes if the number of the repetition becomes a predetermined number. This halt can avoid long time processing since the processes are halted in spite that the difference becomes “zero” or does not. Further, the processes are repeated by the predetermined numbers. This repetition can further approximate the restored data to the image data before fluctuating, which will be a base for an original image. Further, even when yielding noises may bring a situation of none “zero”□difference, which is actually happened, the above halt can avoid unlimited repetition since the repetition is completed by the predetermined number.
Further, in case of the repetition of the processes, the processing unit may halt the repetition if the difference data at the time when the numbers of repetition reaches the predetermine number, is equal to or less or smaller than the a predetermined number, and may continue the repetition by the predetermined number if the difference data is equal to or more or larger than the predetermined number. In this aspect of the invention, combining the number of process repetition with the difference value can attain favorite balance between image quality and short processing time compared to a case of simply limiting the number of the repetition or limiting the difference value.
The advantage of the invention is to provide an image processing device that realizes practical image processing of restoring image data as well as preventing the device from becoming a large size.
1: image processing device
4: processing unit,
5: recording unit,
Io: data of an initial image (data of an arbitrary image)
Io′: comparison data,
G: data of fluctuation-factor information (data of information about blurring factors)
Img′: data of an original image (a shot image)
σ:difference data,
k: allocation ratio
Io+n: restored data (restored image data)
Img: data of an intrinsic correct image without blurring
ISmg′: reduced original image data
GS: reduced data of fluctuation factor information
ISmg: reduced initial image
ISo+n: approximated, reduced, and restored data
B: already-known image data
B′: image data for superimposing
C′: superimposed image data
D: image data of restoring an original image
Img1: first restored data
v: error component data
Img2′: added data
Img3: second restored data
A first embodiment of the invention will be explained with referring to
The image processing device 1 comprises an imaging unit 2 for shooting an image such as a figure, a controller 3 for driving the imaging unit 2 and a processing unit 4 for processing an image (signal data) shot by the imaging unit 2. The image processing device 1 further comprises a recording unit 5 for recording an image processed by the processing unit 4, an angular speed sensor, a detector 6 for detecting fluctuation factor information, which is a main factor for an image blur, and a fluctuation-factor information storing unit 7.
The imaging unit 2 is a unit provided with an imaging optics having lens and an imaging element converting a light image passed through lens into electrical signals such as a charged coupled device (CCD) and a complementary metal oxide semiconductor (CMOS). The controller 3 controls any units of the image processing device 1 such as the imaging unit 2, the processing unit 4, the recording unit 5, the detector 6 and the factor information storing unit 7.
The processing unit 4 includes an image processing processor composed of hardware such as application specific integrated circuit (ASIC). The processing unit 4 may store an image which becomes a base for generating comparison data described later. The processing unit 4 may comprise software instead of hardware like ASIC. The recording unit 5 includes a semiconductor memory, but may include a magnetic recording means like a hard disk drive or an optical recording means like digital versatile disk (DVD).
The detector 6 is provided with two angular speed sensors, detecting the angular speed along X axis and Y axis perpendicular to Z axis, which is the, optical axis of the image processing device 1 as shown in
The factor-information storing unit 7 is a recoding unit which records information regarding fluctuation factors such as already-known blur factors like aberration of optics and others. In the embodiment, the factor information storing unit 7 stores information of aberration of optics and lens distortion. But such information is not used for restoring a blurred image due to hand-jiggling described later.
Next, a processing method performed by the processing unit 4 in the image processing device 1 will be explained with referring to
In
“σ” is difference data between the original image data Img′ and the comparison data Io′. “k” is an allocation ratio based on fluctuation-factor information. “Io+n” is restored image data (restored data), newly produced by allocating the difference data σ to the initial image data Io based on the data of fluctuation-factor information. “Img” is intrinsic-correct image data without a blur, which is a base of the original image data “Img′”, a blurred image when it was shot. Here the relationship between Img and Img′ is assumed to be expressed as the following formula (1)
Img′=Img×G (1)
Where, “x” is an operator for superimposing integration. Here, the difference “δ” is generally varied by the data G of fluctuation-factor information and expressed as the following formula (2), though the data may be a simple difference of a corresponding pixel.
σ=f(Img′, Img, G) (2)
With respect to a routine processed by the processing unit 4, first, arbitrarily image data Io is prepared (step S101). The initial image data Io may be the shot blurred image data Img′ or may be any image data having solid black, solid white, solid gray, check and the like. Step S102 obtains the comparison data Io′ as the blurred image by inputting the arbitrary image data Io, which becomes the initial image, to the formula (1) instead of Img. Next, the difference data σ is calculated by comparing the original image data Img′ as the shot and blurred image with the comparison data Io′(step S103).
Step S104 judges the difference data σ whether it is equal to or more than a predetermined value or not. Then, step S105 produces newly restored image data (restored data) if the difference data σ is equal to or more than a predetermined value. Namely, newly restored data Io+n is produced by allocating the difference data CY to the arbitrary image data Io based on the data G of fluctuation-factor information. Steps S102, S103 and S104 are repeated thereafter.
If step S104 judges the difference data σ as being smaller than the predetermined value, the processes are halted (step S106). Then, the restored data Io+n at the time of halting the processes are assumed to be a correct image, namely an image data Img without a blur. Then this correct data is recorded to the recording unit 5. Here, the recording unit 5 may record the initial image data Io and the data G of fluctuation-factor information and send them to the processing unit 4 if they are necessary.
The above processing method will be summarized as the followings. Namely, this method does not gain solutions as solving inverse issues, but gain solutions as optimizing issues to seek rational solutions. As disclosed in the patent document 2, solving inverse issues is theoretically possible, but faces difficulty in actual site.
Gaining solutions as optimizing issues needs the following premises:
In other words, as shown in
Here, in the embodiment, the angular velocity sensor detects an angular velocity every 5 μsec. The value for judging the difference data σ is “6” in the embodiment when each data is expressed as 8 bits (0 to 255). Namely, when the difference data is smaller than 6, equal to or less than 5, the processes are halted. Row data of fluctuation detected by the angular velocity sensor is not coincided with actual fluctuation if correcting the sensor is insufficient. Therefore, it is necessary to compensate the detected raw data such as multiplying it with a predetermined magnification in order to fit the actual fluctuation when the sensor is not corrected.
Next, the details of the processes shown in
[Restoring Algorism on Hand-Jiggling]
Upon no hand-jiggling, optical energy corresponding to a predetermined pixel concentrates on the pixel during exposure. But upon hand-jiggling, optical energy disperses to pixels blurred during exposure. Further, if the degree of hand-jiggling during exposure is recognized, the way of making optical energy dispersion during exposure is also recognized. Therefore, it is possible for the recognition to produce a non blurred image from a blurred image.
Details will be explained as a horizontal one dimension for simplicity. Pixels are defined as n−1,n, n+1.n+2,n+3 from a left side and a pixel “n” is paid to attention. When no hand-jiggling, energy during exposure concentrates to the pixel, making the energy concentration become “1.0”. This energy concentration is shown in
Upon hand-jiggling during exposure, an image is supposed to be blurred to the nth pixel during 50% of exposure time, the (n+1) pixel during 30% of it and the (n+2)th pixel during 20% of it. The way of making energy dispersion is shown in the table of
A blur is uniform on all pixels. If there is no upper blur (vertical blur), the status of a blur is shown in the table of
In this explanation, the shot-original image data Img′ is used as the arbitrary image data Io shown in step S101, though any kinds of data can be applied to such data. Namely, Io is defined to be equal to Img′ at the beginning. “Input” shown in the table of
Then the size of the difference data σ is judged in Step S104. More specifically, if the absolute values of all the difference data σ become equal to or less than 5, the processes are halted. But, the difference data σ shown in
The difference data σ is allocated by the following. The data “30” at the “n−3” pixel, for example, is allocated to the “n−3” pixel by “15” which is obtained through multiplying “30” with “0.5”, the allocation ratio at the “n−3” pixel itself. The data “15” at the “n−2” pixel is allocated to the “n−2” pixel by “4.5” which is obtained through multiplying “15” with “0.3”, the allocation ratio at the “n−2” pixel. The data “9.2” at the “n−1” pixel is allocated to the “n−1” pixel by “1.84” which is obtained through multiplying “9.2” with “0.2”, the allocation ratio at the “n−1” pixel. The total amount allocated to “n−3” pixel becomes “21.34”. The restored data Io+1 is produced by adding this value to the initial image data Io (the shot-original image data Img′ here).
As shown in
The image processing device 1 is able to fix either the numbers of processing or a reference value for judging the difference data σ in advance or both of them during step S104. Repeating numbers for processing can be fixed to be arbitrary such as 20 or 50 for example. Further, the value of difference data σ is set to be “5” among 8 bits (0 to 255) for halting the processes. If the data becomes equal to or less than 5, the processes can be completed. Otherwise, if the value is set to be “0.5” and the data becomes equal to or less than “0.5”, the processes can be completed. The value can be arbitrarily fixed. Upon inputting both the numbers of repeating processing and the reference value for judging, the processes are halted if either one of them is satisfied. Here, if setting both is possible, the reference value for judging may be prioritized and the predetermined numbers of repeating the processes can be further repeated if the difference data does not become within the range of the reference value for judging by repeating predetermined numbers.
In the embodiment, information stored in the factor information storing unit 7 is not used. But, already-known and blur-factor data such as optical aberration and lens distortion may be used. In this case, in the processes shown in
In the second embodiment, an image processing device has the same structure of the image processing device 1 in the first embodiment. But, a processing method performed by the processing unit 4 is different. But, the basic concept of the repetition of the processes in the second embodiment is the same in the first embodiment. Hence, major differences will be explained.
In order to speed up the restoring process during repetition of the processes, there is a method of combining the repetition with an inverse issue. Namely, the processes are repeated with reduced data and a transfer function is calculated from the reduced original image to transfer reduced-restored data. Then the calculated- transfer function is enlarged and interpolated. The restored data of the original image is obtained by using the enlarged and interpolated transfer function. This processing method is effective for processing a large image.
The basic concept of speed up processing, which is effective for restoring a large image, will be explained hereafter.
Only repetition of the processes needs long time for convergence. This disadvantage particularly emerges in a large image. On the other hand, deconvolution in frequency space is very attractive because of high speed calculation using Fast Fourier Transform (FFT). Here, optical deconvolution means that an initial image without a blur and the like is restored by removing fluctuation factors such as distortion, a blur and the like from a blurred image.
An ideal state of an image is expressed as the following output of convolution integration, where input is in(x), output: ou(x), transfer function: g(x) and output: ou(x).
ou(x)=∫in(t)g(x−t)dt (3)
Here, “∫” is an integration mark. The formula (3) becomes the following in a frequency space:
O(u)=I(u)G(u) (4)
Deconvolution is a method of obtaining unknown input in(x) from the already-known output ou(x) and the transfer function g(x). In order to do that, if I(u)=O(u)/G(u) can be obtained in a frequency space, then, returning the result of I(u) to a real space attains the unknown input In(x).
The formula (3) becomes “ou(x)+α(x)=∫in(t)g(x−t)dt+α(x)” in actual due to a noise and the like. Here, “ou(x)+α(x)” is already known, but ou(x) and α(x) are unknown. Even if the above formula is approximately solved as an inverse issue, it is difficult to obtain a sufficient solution in actual. Therefore, the process flow, shown in
ou(x)+α(x)=∫in(t)g(x−t)dt+α(x)□∫jn(t)g(x−t)dt.
Here, if “α(x)□ou(x)”, the relationship of jn(x)□in(x) is satisfied.
The above method obtains a sufficient solution because of repeating and making the calculation converge within an entire data region. But, it has a disadvantage of taking long time if it handles many numbers of data. On the other hand, under an ideal state without a noise, a solution can be attained with high speed by calculating deconvolution in a frequency space. Accordingly, a combination of these two methods can attain a sufficient solution with high speed.
Two methods are substantial ways of this processing. First, thinning data obtains the reduced data. This thinning method will be explained as a second method using the method shown in
Namely, the original image data Img′ and the data G of fluctuation information are thinned, producing the thinned and reduced original image data ISmg′ and reduced data GS of fluctuation factor information. Then, the processes as shown in
The reduced, approximated, and restored data ISo+n is assumed to be the reduced-initial image ISmg before it fluctuates to the reduced-original image ISmg′, namely the reduced and correct image Img. Then, the reduced-original image data ISmg′ is considered to be a convolution-integration of the reduced and stored data ISo+n with the transfer function g(x). Then, the transfer function g1(x) is obtained from the reduced and stored data ISo+n and the reduced-original image data ISmg′.
The reduced and stored data ISo+n is sufficiently enough data, but still approximated data. Therefore, the transfer function g(x) of the restored data Io+n and the original image data Img′ is not the transfer function g1(x), obtained by repeating the processes of reduced data. Hence, the transfer function g1(x) is calculated from the reduced and stored data ISo+n and the original image data Img′. Then the transfer function g1(x) is enlarged and a space between enlarged portions is interpolated. This enlarged and interpolated function is a modified new transfer function g2(x), which is defined as the transfer function g(x) for the original image data Img′ as initial data. The new transfer function g2(x) is obtained through multiplying the obtained transfer function g1(x) by inversed-multiple numbers of reduction ratio of reduced original image data, and then interpolating a value between enlarged spaces by a linear interpolation or a spline interpolation or the like. For example, upon thinning pixels along vertical and horizontal directions to a half as shown in
Then, by using the modified new transfer function g2(x)(=g(x)), deconvolutuion (removing blur portions from a blurred image group by calculation) is calculated in a frequency space, attaining the perfect restored data Io+n of an entire image, assuming it to be the intrinsic-correct image Img (an initial image) without a blur.
Step S201 reduces the original image data Img′ and the data G of fluctuation-factor information to 1/M. In the example shown in
The transfer function g1(x), which transforms the reduced-original image data ISmg′ to the reduced-restored data ISo+n, is calculated from the obtained, reduced-restored data ISo+n and the already-known, and reduced-original image data ISmg′ (step S203). Then, step S204 enlarges the transfer function g1(x) by M times (four times in
Next, deconvolution is performed using the new transfer function g2(x) and the original image data Img′, obtaining the restored data Io+n. The restored data Io+n is defined as the initial image (step S205). Accordingly, high speed processing can be attained by combining a) repetition of the processes with b) obtaining the transfer functions g1(x) and g2(x) and using the transfer functions g2(x) for the processes.
Here, in this second processing, the attained and correct image and the assumed and restored data Io+n may be used as the initial image data Io shown in
Other method of using a reduced image is to retrieve a part of the original image data Img′ and define it as the reduced original image data ISmg′. This method will be explained as a third method using the method shown in
The details of the third processing method will be explained referring to the flow chart in
In the third method, first, step S301 obtains the reduced-original image data ISmg′, described above. Next, steps S102 to S105 as shown in
The transfer function g1′(x), which transforms the reduced-restored data ISo+n to the reduced-original image data ISmg′, is calculated from the obtained and reduced-restored data ISo+n and the already-known and reduced-original image data ISmg′ (step S303). Next, the calculated-transfer function g1′(x) is defined as the transfer function g′(x) corresponding to the initial image Img. Then, the initial image Img is obtained by inverse-calculation using the transfer function g1′(x)(=g′(x)) and the already-known original image data Img′. Here, the calculated result becomes data of an image approaching to the initial image Img.
Accordingly, high speed processing can be attained by combining a) repetition of the process with b) obtaining and using the transfer function g′1(x) for the process. Here, the obtained-transfer function g1′(x) may be modified using the data G of fluctuation-factor information instead that the transfer function g1′(x) is defined as the entire transfer function g′(x).
Accordingly, the above third method as a high speed process does not restore the entire regions of an image by repeating the processes, but repeats the processes of a part of regions to attain a favorite restored image instead. By using the result of the repetition, the transfer function g1′(x) corresponding to the part is obtained. Finally an entire image is restored by using such transfer function g1′(x) itself or the modified (enlarged) it. Here, the above-retrieved region must be sufficiently larger than the fluctuated regions. In the example shown in
In case of retrieving the reduced region as shown in
[Third embodiment] In the third embodiment, an image processing device has the same structure of the image processing device 1 in the first and the second embodiments. But, a processing method performed by the processing unit 4 is different. But, the basic concept of the repetition of the processes in the first and second embodiments is the same in the first embodiment. Hence, major differences will be explained.
Further, upon processing an image that has a sharp change of a contrast with basic operations from
In case when an object to be processed has a sharp contrast change, repetition numbers are increased in order to obtain an image approaching to an initial image by using the repetition of restoring the image with a method shown in
Details of this fourth method will be explained referring to
First, blurred image data B′ as image data for superimposing is produced by using the data G of fluctuation-factor information from image data B as already-known image data of which contents are known (step S401). Namely, this blurred image data B′ is generated by applying a blur to image data B with fluctuation factor information. Then, an image data C′=Img′+B′ is produced by the original image data Img′ with the B′ (step S402). The data Img′ is a shot-original image (a blurred image), an object to be processed. Accordingly, steps S401 and S402 produce superimposed image data C′.
Next, the arbitrary image data Io is prepared (step S403). The image data Io may be the shot and blurred image data Img′ or may be any image data having solid black, solid white, solid gray, check and the like. Then step S404 obtains the comparison data Io′ as the blurred image by inputting the arbitrary image data Io to the formula (1) instead of the data Img. Namely, steps S403 and S404 produce the comparison data.
Next, step S405 compares the comparison data Io′ with the superimposed image data C′ to calculate the difference data σ. Further, step S406 judges whether the difference data σ is equal to or more than a predetermined value or not. Then, step S407 produces newly restored image data (restored data), if the difference data σ is equal to or more than a predetermined value. Namely, the newly restored data Io+n is produced by allocating the difference data σ to the arbitrary image data Io based on the data G of fluctuation factor information. Steps S404, S405 and S406 are repeated thereafter.
Step S406 estimates the restored data Io+n as superimposed image data in which an image that approaches to the intrinsic and correct image without a blur is superimposed on the already-known image data B. Accordingly, steps S403 to S407 produce the superimposed and restored image data.
Steps S403 to S407 producing superimposed and restored image data are similar to the above mentioned process of producing the restored data shown in
Next, the already-known image data B is removed from the superimposed-restored image data. Step S408 produces the restored data D approaching to an original data before fluctuation. The restored data D produced by step S408 is assumed to be an image data approaching the image data Img without a blur and stored in the recording unit 5.
Even if the intrinsic and correct data Img includes a sharp contrast change, the above method reduces the sharp contrast change and numbers of repeating the restoring process by adding the already-known image data B. The already-known image data is data having less contrast comparing to the intrinsic and correct data Img, or data of no contrast or the shot-image data Img′. In particular, the superimposed image data efficiently becomes image data having low contrast by using data having less contrast comparing to the intrinsic and correct data Img or data of no contrast. Further, the numbers of repetitions of the processes are efficiently reduced.
[Fourth embodiment] Further, a fifth method of the processes shown in
The details of this method will be explained as the fourth embodiment thereafter.
First, if a desired and correct image is defined as A, a shot and original image is A′ and an error component is ν, image data restored from the shot and original image A′ becomes A+ν and data for comparison with a blur produced by the restored data becomes A′+ν.′ Then, “A′” is added to “A′+ν′” and these added data become “A+ν+A+ν+ν” through restoring process. These data are “2A+3ν” or “2(A+ν)+ν”. “A+ν” is already obtained by the previous process. Therefore, “ν” can be obtained by calculating “2(A+ν)+ν−2(A+ν)”. Hence, “ν” is removed from the restored image data “A+ν”, obtaining the desired and correct image A.
Details of the fifth method will be explained referring to
First, the arbitrary image data Io is prepared (step S501). The initial image data Io may be the shot and blurred image data Img′ or may be any image data having solid black, solid white, solid gray, check and the like. Step S502 obtains the comparison data Io′ as the blurred image by inputting the arbitrary image data Io, which becomes the initial image, to the formula (1) instead of the data Img. Next, the difference data σ is calculated by comparing the original image data Img′ as the shot and blurred image A′ with the comparison data Io′(step S503).
Next, step S504 judge whether the difference data σ is equal to or more than a predetermined value or not. Then, step S505 produces newly restored image data (restored data) if the difference data σ is equal to or more than a predetermined value. Namely, the newly restored data Io+n is produced by allocating the difference data σ to the arbitrary image data Io based on the data G of fluctuation factor information. Steps S502, S503 and S504 are repeated thereafter.
Step S504 halts data-restoring processes of S501 to S504 if the difference data σ becomes smaller than the predetermined value. At this point, the restored data Io+n is defined as a first restored data Img1(step S506). Then, the first restored data Img1 is assumed to be image data including the image data Img of the desired image A and the error component data ν, namely data Img+ν.
In the first embodiment referring to
Next, the error component data is calculated. First, step S507 inputs the first restored data Img1 instead of the data Img of the formula (1) and obtains image data Img1′, produced in a manner that the first restored data Img1 (=Img+ν) is blurred by the data G of fluctuation-factor information. The image data Img1′ is the comparison data A′+ν′ as the blurred image and the data Img′+ν′.
Then, an added data Img2′ is obtained by adding the image data Img′ of the original image A′ as a shot and blurred image to the image data Img′+ν′ blurred from the image data Img1 (step S508). Then, the added data Img2′ is treated as the shot-blurred image and restored (steps S509 to S513). Steps S509 to S513 are a similar restoring processes of steps S501 to S505 except a process in which the shot and blurred image Img′ is added to the added data Img2′.
First, the arbitrary image data Io is prepared (step S509). Then, the comparison data Io′ as the blurred image is obtained by inputting the arbitrary image data Io to the formula (1) instead of Img as step S510. Next, the added data Img2′ is compared with the comparison data Io′ to calculate the difference data σ (step S511).
Further, step S512 judges whether the difference data σ is equal to or more than a predetermined value or not. Then, step S513 produces newly restored image data (restored data) if the difference data σ is equal to or more than a predetermined value. Namely, the newly restored data Io+n is produced by allocating the difference data σ to the arbitrary image data Io based on the data G of fluctuation factor information. Steps S510, S511 and S512 are repeated thereafter.
Restoring processes of steps S510 to S513 are completed if the difference data σ becomes smaller than a predetermined value in step S512.
The restored data Io+n at the time of completing steps S510 to S513 is defined as a second restored data Img3 (step S514). The contents of the second restored data Img3 are “A+ν+A+ν+ν”, namely “Img+ν+Img+ν+ν”, or “2(Img+ν)+ν”. Accordingly, the contents of added data Img2′ are “Img′+Img′+ν′”. Hence, the restoring steps from S509 to S513 restore “Img′” and “ν′” as “Img+ν” and “ν” respectively.
Then, the error component data ν is obtained (step S515) if the second restored data Img3(=2(Img+ν)+ν) is subtracted by the data 2Img1(=2(Img+ν)), since step S506 already obtained “Img+ν” as the first restored data Img1. Namely, steps S507 to S515 calculate the error component data.
Then, step 516 subtracts the error component data ν from the first restored data Img1 to obtain the original restored data as the original image Img before fluctuation. Further, the restored data Img obtained by step S516 is stored in the recording unit 5 Here, the recording unit 5 may store the initial image data Io and the data G of fluctuation factors information and send them to the processing unit 4 if they are necessary.
[Other embodiment] The image processing device 1 with respect to various embodiments of the invention has been explained. But, it is possible to modify it within the spirit of the invention. For example, the processing unit 4 performs processes with software. But, hardware comprising parts sharing their workload together may be used for processing.
Further, as the original image, an object to be processed, some processed data may also be used such that shot image data may be color-compensated or Fourier-transformed. Further, as the comparison data, some processed data except the data G of fluctuation-factor information may also be used such that the data G may be color-compensated or Fourier-transformed. Further, the data of fluctuation factor information may include not only data of blur factors, but information simply varying an image or improving image quality.
Further, if the numbers of repetition are automatically set or fixed by the image processing device 1, such numbers may be changed depending on the data G of fluctuation-factor information. When data of one pixel is dispersed to many other pixels by blurring, the numbers of repetition may be increased for example. But when the dispersion is small, the numbers of repetition may be decreased.
Further, when the difference data σ becomes dispersed during repetition of the processes, namely increased, the processes may be halted. Regarding judging the dispersion about the difference data σ, if it is observed that the average value of the difference data σ becomes larger than a previous value for example, the difference data σ may be judged to be dispersed. Further, if the dispersion occurs once, the processes may be halted. Otherwise, if the dispersion is continuously occurred twice or predetermined numbers, the processes may be halted.
When an input is changed to be an abnormal value during repeating the processes, the processes may be halted. When the input is 8 bits and a value to be changed exceeds 255, the processes may be halted. When an input as new data is changed to be an abnormal value during repeating the processes, a normal value may be used instead of such abnormal value. For example, when a value, surpassing 255 among 0 to 255 of 8 bits, is input, the processes may be executed under a condition when the input data is a maximum value as 255. Namely, if the restored data include an abnormal value (a value surpassing 255 in the above example) more than a permitted value (a value of 0 to 255 in the above example), the processes may be halted. Otherwise, if the restored data includes an abnormal value more than a permitted value, the abnormal value may be replaced with the permitted value and, then the processes may be continued.
Further, when the restored data is produced as an output image, data may go out of the region specified as an image to be restored depending on the data G of fluctuation-factor information. In such case, data going out of the region should be input to an opposing side. Further, if data come from the outside of the region, the data may be brought into an opposing side. If image data, allocated to pixels located lower than the most bottom position of the region where pixels XN1 (the Nth row and the first column) is located, is generated for example, the location will be out of the region. In such case, the data will be allocated to the pixels X1 (the first row and the first column) at the most top position directly above the pixel XN1. The data at the pixel XN2 (the Nth row and the second column) will also be allocated to the pixels X12(the first row and the second column adjacent to the pixel X11) at the most top position directly above the pixel XN2 (the Nth row and the second column) adjacent to the pixel XN1 through a similar manner. Accordingly, in a case of producing the restored data, when data occurs out of the region to be restored, the data is rearranged at the positions opposing to the position where the data occurs toward one of the vertical, horizontal or oblique directions within the region to be restored. Such rearrangement is able to certainly restore the data in the region to be restored.
In case of producing the restored data Io+n, the barycenter of fluctuation factors such as a blur and the like may be calculated. Then, the difference of only the barycenter or the variable powers of the difference may be added to the previous restored data Io+n−1. This approach as a method of using the barycenter of fluctuation factors is explained as a sixth method using the method shown in
As shown in
In this blurring due to the move of the pixel 33, if the pixel stays at the position of the pixel 43 for the most longest time, the barycenter of blurs, namely fluctuation factors, of the original image data Img′ comes to the position of the pixel 43 with respect to the pixel 33 in the corrected image data Img. By this movement, as shown in
In the previous example, among three barycenters “0.5”, 0.3” and “0.2”, the highest value is “0.5”, which will be a self center. Hence, without considering allocation of “0.3” and “0.2”, only “0.5” or the variable power of “0.5” is allocated to the self position. Such processing is preferable when energy of a blur concentrates.
Further, in a case of producing the restored data Io+n, the allocation ratio k may not be used. Instead, the difference data σ corresponding to a pixel to be treated may be directly added to the pixel in the previous restored data Io+n−1. Otherwise, the difference data σ may be variably powered and, then added to the pixel. Further, the data kσ (the value as “a renewing amount” in
The summaries of the above-mentioned various methods are;
Further, any pluralities of these methods (1) to (7) may be stored in the processing unit 4 and any of them may be automatically selected depending on user's selection or kinds of images. Further, any pluralities of these seven methods may be selected and alternately used every one routine or in series. Otherwise, one method may be used during initial several times and other methods may be used thereafter. The image processing device 1 may use methods which are different from one of or any of the above-mentioned seven methods.
Further, the above methods may be programmed. Such programmed contents may be stored in a memory such as compact disc (CD) DVD, universal serial bus (USB) and read by a computer. In this case, the image processing device 1 may include a means for reading the program stored in the medium. Further, programmed contents may be input to a server out of the image processing device, down-loaded and used if they are necessary. In such case, the image processing device 1 may include a communication means down-loading the program stored in a medium.
Number | Date | Country | Kind |
---|---|---|---|
2005-180336 | Jun 2005 | JP | national |
2005-216388 | Jul 2005 | JP | national |
2005-227094 | Aug 2005 | JP | national |
Filing Document | Filing Date | Country | Kind | 371c Date |
---|---|---|---|---|
PCT/JP2006/311946 | 6/14/2006 | WO | 00 | 12/18/2007 |