Login| Sign Up| Help| Contact|

Patent Searching and Data


Title:
PREVENTING MOTION ARTIFACTS BY INTELLIGENTLY DISABLING VIDEO STABILIZATION
Document Type and Number:
WIPO Patent Application WO/2014/046867
Kind Code:
A1
Abstract:
Digital video stabilization is selectively turned off in circumstances where it could actually decrease the quality of a captured video. A video camera (100) includes a device (110) for directly detecting physical motion of the camera (100). Motion data from the motion detector (110) are analyzed (206) to see if video stabilization is appropriate. If the motion data indicate that the video camera (100) is stable, for example, then video stabilization is not applied to the video, thus preventing the possibility of introducing "motion artifacts" into the captured video. In another example, motion as detected (404) by the motion detector (110) can be compared with motion as detected (406) by the video-stabilization engine (108). If the two motions disagree significantly (408), then the video-stabilization engine (108) is probably responding more to motion in the captured video rather than to motion of the camera (100) itself, and video stabilization should probably not be applied to the video.

Inventors:
PETRESCU DOINA I (US)
RYAN BILL (US)
Application Number:
PCT/US2013/057903
Publication Date:
March 27, 2014
Filing Date:
September 04, 2013
Export Citation:
Click for automatic bibliography generation   Help
Assignee:
MOTOROLA MOBILITY LLC (US)
International Classes:
H04N5/232
Foreign References:
US6734902B12004-05-11
US20110234825A12011-09-29
US6734901B12004-05-11
Attorney, Agent or Firm:
BRETSCHER, John T. et al. (Libertyville, Illinois, US)
Download PDF:
Claims:
CLAIMS

We claim:

1. On a personal electronics device (100) comprising a camera (102), a digital video stabilizer (108), and a motion detector (110), a method comprising:

producing (400), by the camera (102), a series of images (104);

calculating (402), by the digital video stabilizer (108), a stabilization- compensation value associated with the series of images (104);

producing (404), by the motion detector (110), motion data; analyzing (406) the motion data and the stabilization-compensation value; and

only if (408) the analyzing reveals that motion detected by the motion detector (110) differs from motion calculated by the digital video stabilizer (108) by less than a motion-difference threshold, then applying (408) the stabilization- compensation value to the series of images (104).

2. The method of claim 1 wherein the personal electronics device is selected from the group consisting of: a camera, a mobile telephone, a personal digital assistant, and a tablet computer.

3. The method of claim 1 wherein the motion detector comprises an element selected from the group consisting of: a gyroscope, an accelerometer, a GPS receiver, and an image sensor.

4. The method of claim 1 wherein calculating a stabilization-compensation value comprises comparing images in the series of images and minimizing a sum of pixel-error differences between the compared images.

5. The method of claim 1 wherein the stabilization-compensation value is selected from the group consisting of: a linear offset and a rotation. The method of claim 1 wherein calculating the motion-difference threshold comprises measuring motion data produced by the motion detector while the personal electronics device is held static.

The method of claim 1 wherein applying the stabilization-compensation value comprises modifying an image in the series of images, the modifying based, at least in part, on the stabilization-compensation value, and sending the modified image to a video encoder.

A personal electronics device (100) comprising:

a camera (102) configured for producing (400) a series of images (104); a digital video stabilizer (108) configured for calculating (402) a stabilization-compensation value associated with the series of images (104);

a motion detector (110) configured for producing (404) motion data; and a processor (106) operative ly connected to the camera (102), to the digital video stabilizer (108), and to the motion detector (110), the processor (106) configured for:

analyzing (406) the motion data and the stabilization-compensation value; and

only if (408) the analyzing reveals that motion detected by the motion detector (110) differs from motion calculated by the digital video stabilizer (108) by less than a motion-difference threshold, then applying (408) the stabilization-compensation value to the series of images (104).

The personal electronics device of claim 8 wherein the personal electronics device is selected from the group consisting of: a camera, a mobile telephone, a personal digital assistant, and a tablet computer.

Description:
PREVENTING MOTION ARTIFACTS BY INTELLIGENTLY DISABLING

VIDEO STABILIZATION

TECHNICAL FIELD

[0002] The present disclosure is related generally to digital-image capture and, more particularly, to digital video stabilization.

BACKGROUND

[0003] Digital video-capture devices, such as still and video cameras, are becoming more commonplace. Once available only on high-end professional cameras, today such digital devices are found in smartphones, tablet computers, and other personal electronics devices. Digital cameras are small and relatively inexpensive to manufacture and are thus popular accessories in today's personal electronics devices.

[0004] Because these personal electronics devices are often quite small and light, they can be easily shaken when the user is trying to take a photograph or a movie, and this shaking can produce blurry images. To compensate for shaking, digital video stabilization methods compare captured images frame by frame and apply global motion compensation to remove the frame-to-frame motion and to thus make the captured images less blurry.

BRIEF DESCRIPTION OF THE SEVERAL VIEWS OF THE DRAWINGS

[0005] While the appended claims set forth the features of the present techniques with particularity, these techniques, together with their objects and advantages, may be best understood from the following detailed description taken in conjunction with the accompanying drawings of which:

[0006] Figure 1 is an schematic of a representative personal electronics device with a video camera in which the present techniques may be practiced;

[0007] Figure 2 is a flowchart of a representative method for disabling video stabilization when a camera is steady; [0008] Figures 3a through 3c are graphs of motion-data measurements made for a camera in different circumstances; and

[0009] Figures 4 and 5 are flowcharts of methods for selectively applying video stabilization when a camera may be moving.

DETAILED DESCRIPTION

[0010] Turning to the drawings, wherein like reference numerals refer to like elements, techniques of the present disclosure are illustrated as being implemented in a suitable environment. The following description is based on embodiments of the claims and should not be taken as limiting the claims with regard to alternative embodiments that are not explicitly described herein.

[0011] Digital video stabilization is selectively turned off in circumstances where it could actually decrease the quality of a captured video. A video camera includes a motion detector device for directly detecting physical motion of the camera (e.g., a gyroscope, accelero meter, a GPS receiver, or another camera). Motion data from the motion detector are analyzed to see if video stabilization is appropriate. If the motion data indicate that the video camera is stable, for example, then video stabilization is not applied to the video, thus preventing the possibility of introducing "motion artifacts" into the captured video. In another example, motion as detected by the motion detector can be compared with motion as detected by the video-stabilization engine. If the two motions disagree significantly, then the video-stabilization engine is probably responding more strongly to motion in the captured images than to motion of the camera itself, and video stabilization should probably not be applied to the video.

[0012] Various embodiments can be implemented in hardware or as executable code running on a microprocessor or a controller of an video-capture system. Where so configured, the executable code can include various modules that determine video stability and physical motion. [0013] Figure 1 shows a representative personal electronics device 100 that can embody aspects of the present disclosure. The device 100 can be just about any device with a video camera 102 including, for example, a dedicated camera, a mobile telephone, a personal digital assistant, or a tablet computer.

[0014] The video camera 102 of Figure 1 represents an entire video-capture device, as known in the art. A typical video-capture device 102 includes an image sensor and a control circuit (represented in Figure 1 by the processor 106, but see the discussion below). The image sensor, which can be any type of image sensor known in the art, such as a CMOS or a CCD sensor, receives light through a lens. The light is reflected off a subject and is then captured by the image sensor to form an image. The captured image is stored as one digital frame 104. Generally speaking, the video camera 102 creates frames of captured images as a constant rate. When displayed to a user at the same rate, the succession of frames is a video clip. As is known in the art, the video-capture device 102 may include other optical, mechanical, and electronic systems (including a variable aperture, lenses, an auto-focus engine, and the like). The personal electronics device 100 can include another video camera (not shown in Figure 1), the possible use of which is discussed below.

[0015] For ease of discussion, it is assumed that the personal electronics device 100 is completely controlled by a software-driven processor 106. In some embodiments, however, a microcontroller, embedded controller, or application-specific controller 106 controls certain aspects of the device 100 including the video stabilizer 108 (also called a video-stabilization engine) and the motion detector 1 10 as described below in reference to Figures 2, 4, and 5. In some embodiments, control functions are divided among multiple modules within the device 100 including both software-controlled processors and hardwired controllers.

[0016] The video-stabilization engine 108, as is well known in the art, reviews the captured frames 104 and attempts to detect motion of the personal electronics device 100. If, for example, a pixel-by-pixel comparison of two successive frames 104 reveals that the second frame is essentially identical to the first but displaced by a small but constant amount to the right, then it is possible that the image being captured has not moved to the right, but instead the device 100 has moved that small distance to the left. This often happens when the hands holding the device 100 shake. Continuing with the above example, in traditional operation, the video-stabilization engine 108 attempts to compensate for this small movement of the device 100 by shifting the image of the second frame back to the left. The motion of the device 100 has been compensated for by moving the image in the succession of captured frames 104, and in the resultant video, which comprises the motion-compensated output frames 1 12, there are, ideally, no lingering effects of the shaking of the device 100.

[0017] (As a side note, in order to shift the captured image to compensate for the slight motion of the personal electronics device 100, the captured frames 104 are actually somewhat larger than the video eventually displayed. The captured frames 104 include a small extra border of pixels so that if, for example, the image has shifted to the left and the leftmost pixels have thus disappeared off the edge of the normal image, these leftmost pixels are still captured in the left border and can be used when the image is moved back to the right to compensate for the motion. This is all well known in the art.)

[0018] The motion detector module 1 10 directly detects physical motion of the personal electronics device 100. Various known hardware implementations are possible here. A three-axis accelerometer can report movement, as can a gyroscope, or a GPS receiver. In some embodiments, the motion detector module 1 10 is based on an image sensor (that is, an image sensor other than the video camera 102, e.g., a second camera), and it indirectly calculates motion based on perceived motion.

[0019] Generally speaking, the personal electronics device 100 includes other components such as a screen for viewing captured images and video, an interface for receiving user commands and for displaying status information, memory for storing controller software and captured frames, and a communications module for sending and receiving information. Because these components are well known in the art and are not of particular concern for the present discussion, they need not be discussed further.

[0020] Figure 2 shows a first representative method usable by the personal electronics device 100 of Figure 1. In step 200, the video-capture engine (or camera) 102 captures and stores a succession of image frames 104.

[0021] (Note that for ease of discussion, the representative methods of Figures 2, 4, and 5 are illustrated and discussed sequentially. In many embodiments, various steps are performed concurrently, possibly by different processors and controllers working, at least to some extent, independently.)

[0022] In step 202, well known techniques of video-stabilization analysis are applied to the succession of captured frames 104. In one embodiment, successive frames are compared pixel-by-pixel by the video-stabilization engine 108. If the analysis decides that the differences between frames are best explained, at least in part, by motion of the personal electronics device 100, then one or more stabilization-compensation values are calculated. In some well known embodiments of video stabilization, a calculated stabilization-compensation value minimizes a sum of "pixel-error" differences if it were applied to the second of two successive captured frames 104. For side -to-side motion, for example, a stabilization-compensation value could be a vector whose scalar value is the number of pixels that the detected motion represents and therefore the number of pixels to shift the second image to match (at least approximately) the first image to compensate for motion of the device 100. In a general case, the analysis can detect motion in all three spatial dimensions as well as rotations. (Note that in step 202, the stabilization- compensation values are calculated but are not applied to the captured frames 104.)

[0023] In many embodiments, the motion detector 1 10 constantly produces motion data that represent the detected motions of the personal electronics device 100. In other embodiments, motion data are only produced if motion is detected (i.e., no updated motion data mean no detected motion). [0024] In any case, the current motion data from step 204 are analyzed in step 206. Specifically, the currently detected motion data are compared against a noise threshold value. Most motion detectors 1 10 known in the art produce some statistically random motion data even when the personal electronics device 100 is completely at rest. Laboratory tests can be run for a particular motion detector 1 10 by locking it in place and then reading its motion-data output. Viewing the output generally clearly reveals the noise threshold of the motion detector 1 10. (Of course, statistical techniques more sophisticated than eyeballing a graph can be used to characterize the noise threshold.)

[0025] Figure 3a shows the results of an actual test of a motion detector 1 10 that was held completely static. The graph of Figure 3a shows the motion data (in three dimensions) produced in this static test case. The graph shows very frequent motion events, all of small amplitude. This is characteristic of detector noise. For this particular motion detector 1 10, a review of the graph reveals a noise threshold of plus or minus 0.08. (The actual value of the noise threshold for a particular motion detector 1 10 is of less importance than the presence of a well defined threshold. Of course, lower threshold values are generally better, but achieving a very low threshold may involve production costs that far outweigh any added benefits.)

[0026] If the motion data produced in step 204 are below the experimentally derived noise threshold of the motion detector 1 10, then the personal electronics device 100 is most likely at rest. This is the case even if the video-stabilization engine 108 produces a non-zero stabilization-compensation value in step 202. That non-zero value is most likely to be simply incorrect. Therefore, the method of Figure 2 concludes in step 208 by only applying the stabilization-compensation value of step 202 to the captured frames 104 if the motion data produced in step 204 are above the noise threshold of the motion detector 1 10. Otherwise, the device 100 is static, and the stabilization-compensation value is simply ignored.

[0027] (The question can be asked: Why would a properly functioning video- stabilization engine 108 produce a non-zero stabilization-compensation value when the personal electronics device 100 is completely static? The answer is based on the realization that the video-stabilization engine 108 does not measure motion directly but only infers motion by comparing successive captured frames 104. That analysis is "fooled" when, to give just one example, more than half of the captured image is actually moving smoothly and steadily across the frame (e.g., when a large object near the front of the scene is moving from right to left). In this case, most embodiments of the video- stabilization engine 108 believe that it is the device 100 that is moving rather than the majority of image being captured. Thus, it produces a non-zero stabilization compensation value when it should, in an ideal world, produce a zero value. If that nonzero value were applied to the captured frames 104 to compensate for the non-existent motion of the static device 100 (that is, if the method of Figure 2 were not applied), then the resulting output video 1 12 would include annoying "motion artifacts." The method of Figure 2 prevents these artifacts.)

[0028] Note: Performing step 202 consumes power and resources within the personal electronics device 100 even when the stabilization-compensation values are eventually discarded in step 208 because the device 100 is static. Thus, in some embodiments, step 202 is only performed if the analysis of step 206 reveals that the device 100 may actually be moving. In other embodiments, step 202 is always performed, but the results of that step are only used when they are appropriate.

[0029] Compare Figure 3a with Figure 3b. (The bold horizontal bars at about plus and minus 0.1 of Figure 3b correspond to the noise threshold measured in Figure 3a.) The motion data of Figure 3b were collected while the personal electronics device 100 was held in one hand. Figure 3b shows very frequent motion events, many of which have amplitudes that far exceed the noise threshold. In this case, video stabilization would be very useful, so step 208 of Figure 2 allows the stabilization-compensation values to be applied to the captured frames 104 to create the output frames 1 12. (Techniques for applying stabilization-compensation values to video are well known in the art.) [0030] The data for Figure 3c were taken when the personal electronics device 100 was held in two hands. Comparing the amplitudes and the frequency of the motion events in this figure with those of Figure 3b, it is clear that a two-hand grip makes for a much more stable device 100. However, the motion amplitudes in Figure 3c do still sometimes exceed the noise threshold, though usually by less than twice the threshold value. A strict application of the method of Figure 2 to this situation would allow the stabilization- compensation values to be applied to the captured frames 104. However, this is a borderline case, and more data would be useful to make the best decision about using video stabilization. Figure 4, discussed below, presents one way to do this.

[0031] Figure 4 shows a second representative method usable by the personal electronics device 100 of Figure 1. The method of Figure 4 begins in a fashion similar to the method of Figure 2. Image frames 104 are captured by the camera 102 (step 400). From the captured frames 104, the video stabilization engine 108 calculates one or more stabilization-compensation values (step 402). Meanwhile, the motion detector 1 10 produces motion data (step 404).

[0032] In step 406, the method of Figure 4 diverges from that of Figure 2. Here, the motion data produced by the motion detector 1 10 are compared against the stabilization- compensation values calculated by the video stabilization engine 108. In high-level terms, this means that two independently derived values for the current motion of the personal electronics device 100 are compared. If the motion detector 1 10 agrees (within a motion-difference threshold) with the video-stabilization engine 108 as to how, and how much, the device 100 is currently moving, then their agreed upon value is most likely correct. (Note that, as mentioned above, the motion detector 1 10 may be implemented as a second video camera, such as a front-facing camera on a laptop computer. In this case, step 406 compares the stabilization-compensation values from the two cameras. If the value agree within the motion-difference threshold, then their agreed motion value is most likely to be correct.) In this case, step 408 applies the stabilization-compensation value to the captured frames 104 to create the output frames 1 12. If the two motion values disagree, then the video-stabilization engine 108 is probably being fooled, so its stabilization-compensation values cannot be relied upon and are discarded.

[0033] Laboratory tests of the personal electronics device 100 can be used to set the value of the motion-difference threshold. In some cases, the noise threshold derived for the motion detector 1 10 when the device 100 is held static (see Figure 3a and the accompanying discussion) may be used for the motion-difference threshold. It is also conceivable that laboratory testing can find, for some hardware embodiments, an optimal motion-difference threshold that is different from the noise threshold. Different hardware embodiments can lead to different results.

[0034] Finally, Figure 5 shows a third representative method usable by the personal electronics device 100 of Figure 1. This method combines aspects of the methods of Figures 2 and 4. As in those methods, image frames 104 are captured by the camera 102 (step 500). From the captured frames 104, the video stabilization engine 108 calculates one or more stabilization-compensation values (step 502). Meanwhile, the motion detector 1 10 produces motion data (step 504). As in step 406 of Figure 4, in step 506 the motion data produced by the motion detector 1 10 are compared against the stabilization- compensation values calculated by the video stabilization engine 108.

[0035] Step 508 applies both the test of step 208 of Figure 2 and the test of step 408 of Figure 4. Thus, only if the personal electronics device 100 is not static (that is, if the motion data produced in step 504 are above the noise threshold of the motion detector 1 10), and if the motion detector 1 10 agrees (within the motion-difference threshold) with the video-stabilization engine 108 as to how, and how much, the device 100 is currently moving, then the stabilization-compensation values are applied to the captured frames 104 to create the output frames 1 12. Otherwise, the video-stabilization engine 108 is probably being fooled, so its stabilization-compensation values cannot be relied upon and are discarded. [0036] In view of the many possible embodiments to which the principles of the present discussion may be applied, it should be recognized that the embodiments described herein with respect to the drawing figures are meant to be illustrative only and should not be taken as limiting the scope of the claims. Therefore, the techniques as described herein contemplate all such embodiments as may come within the scope of the following claims and equivalents thereof.