The invention generally relates to the field of digital photography, particularly the methods of accelerating image captures and post-capture actions on the digital camera device based on user behaviors.
User behavior for image captures on a digital camera is typically irregular and sporadic. Common behavioral patterns indicate that most camera users spent significant time to frame shots and to review the captured images in a typical image capturing session. Due to this user behavior, the load of the device's processors is unbalanced and varies drastically. The processor is under very light load between shots and during shot preparation. In contrast, the processor is under extremely heavy load during image processing, which often leads to lagging and perceived long delay between image operations.
The proposed method accelerates the process by intelligently rearranging and prioritizing tasks in the camera operation sequence.
To understand this, consider a typical image capture sequence in a digital camera session breaks down as three major procedures: ‘capture’, ‘tweak’, and ‘record’. Each of these procedures breaks down into smaller discrete tasks. During a series of image captures, a number of these tasks must be completed for each capture prior to other captures. Tasks, such as ‘initialize sensor’ and ‘readout sensor values’, must be completed immediately, while other tasks, such as ‘image manipulation’ and ‘image conversion’, can be postponed. Since the camera processor is only under heavy usage a fraction of the time, the proposed method amortizes the process load in a way to accelerate the user's image capturing and viewing experience.
Aside from intelligently queuing tasks, camera viewfinder's small resolution also contributes to the accelerate feedback in this method. Camera viewfinder resolution ranges generally ranges from one-tenth to one-hundredth of the actual image resolution. Manipulation of the image on the viewfinder for immediate feedback does not require processing of the full resolution image, hence the processing requirements for the on-screen actions are minimal in comparison to that of full size images. This resolution independent method greatly helps to reduce image processing time without any changes to the device hardware.
The method is particularly useful to alleviate the underpowered mobile processors like ones commonly found on camera-embedded phones.
This invention addresses the few key issues mentioned above. It utilizes behaviorally-based software methods to minimize the perceived long delay in digital cameras. The invention is a combination of two complimentary set of procedures, ‘process’ and ‘feedback’.
The first half of the method is the ‘process’ step. In this step, the list of tasks is divided based on whether or not the particular task must be completed prior to other captures. The list of tasks is further arranged in the order of a preset capture sequence and assigns a priority to each item.
In an accelerated software ‘capture’ sequence, the must-complete tasks executes first in the correct order. Once this completes, the method provides immediate ready signal feedback to the user to acknowledge that the camera is ready for other actions. If there are no further actions from the user, the method continues to process remaining tasks in the preset capture sequence.
In the case that there is a feedback from the user to initiate another capture, the method immediately puts remaining tasks on hold in memory and processes the must-complete tasks from the second capture. Once all must-complete tasks are completed, the method provides ready signal feedback to the user and resumes the previous work on remaining tasks.
Minimizing time between image capture and ready feedback greatly improves the capture delays between images, typically achieving a minimum of 2-3× improvement for the end user depending on the device configuration. However, the method is imperfect. Because the method relies on storing information in memory for fast access, it is limited by the memory size, which could be relatively low in mobile devices. This limitation will be less of an issue as the mobile device memory inevitably increases in the future.
Complimentary to the ‘process’ step in the invention is the ‘feedback’ step. In this step, the method acknowledges that the image has been taken and is ready for the user to either take post-capture actions on the images or capture more images. There are many post-capture actions available. Most of these actions can be categories into three main objectives detailed below.
One objective of the post-capture action is to visualize the captured images. This can be achieved in a non-intrusive way by showing a thumbnail of the latest capture. Furthermore, it would be possible to expand the thumbnail visualizations to encompass the capture history and the entire camera album. This enables the possibility to visualize all of the images in an album right on the camera viewfinder without the need to exit the camera's capture mode.
Another objective of the post-capture action is to have the ability to manipulate and enhance the captured images. This includes but is not limited to enlarging the picture for inspection, deleting/moving the picture location, and enhancing the image with simple filters such as grayscale. This enables the possibility to manipulate and enhance images right on the camera viewfinder without the need to exit the camera's capture mode.
Another objective of the post-capture action is the share captured images. This includes but is not limited to emailing, posting to forums, uploading to various services, and collaborating with others. This enables the possibility to share images right on the camera viewfinder without the need to exit the camera's capture mode.
All of the post-capture actions are available on the viewfinder inside of the camera application. This further accelerates the camera operations to the end user by providing immediate access and feedback.
A further aspect of the invention focuses on improving the method by dynamically updating the task priority by continuously tracking usage behavior. As an example, if the user's behavior is inclined to inspect each image taken, the method increases the priority on the tasks to create the fastest feedback. Alternatively, if the user's behavior takes as many images as possible without inspection, the method would decrease the feedback priority and increase priority on the capture speed. This aspect of the invention further accelerates the camera operations by customizing the processing order to the habits of the particular camera user.
The invention is further illustrated by the following drawings in which:
As used herein in the specification and claims, including as used in the examples and unless otherwise expressly specified, all numbers may be read as if prefaced by the word “about”, even if the term does not expressly appear. Also, any numerical range recited herein is intended to include all sub-ranges subsumed therein.
The present invention comprises a method and system for accelerating operations on a camera device by obfuscating the long processing time of camera operations with immediate and comprehensive user feedback.
In one aspect of the invention, the system provides a comprehensive, bidirectional, interactive on-screen feedback to the user such that the actual progress of a camera operation is irrelevant to the user. The user can view, manipulate, and perform actions to the captured image on viewfinder so the user is neither aware nor is impacted by the actual progress of the camera operation quietly processing in the background.
In another aspect of the invention, upon any camera operation request from the user, the system completes only the minimal tasks prior to immediately providing proposed feedback to the user. The remaining tasks are intelligently queued and processed at a later time when the processor becomes available.
The combination of these two aspects of the invention creates a greatly accelerated digital camera user experience. The present invention can be implemented purely using camera software, without the need to incur any additional hardware cost.
Referring now to
As assumptions, the digital camera device in the descriptions utilizes a digital sensor to capture images. It is also assumed that the digital camera utilizes a digital screen to frame, view, or manipulate digital images. The camera application refers to the underlying device software that controls the camera hardware and interacts with the camera user. Additionally, all descriptions apply to both standalone digital cameras as well as embedded digital camera in multimedia devices.
The flow starts when the camera capture application initializes and enters shooting mode. Once the initialization completes and the camera application is ready for captures, the application signals Capture Ready On 100 and indicates to user its readiness. Camera application remains in this state awaits for the capture request 101, and capture Ready 100 remains on when there is no capture request 102. Upon detecting a capture request 103, the application turns off its Ready Capture 104 signals and initiates the image capture step 105.
The image capture step 105 exposes of the on-board digital camera sensors to external light for a brief moment and records illumination data in its sensors. These raw sensor values then runs through a series of image post-process steps before the application produces the final image. These post-process steps include but are not limited to various filters, data transfers, file conversions and pixel manipulations. The application schedules these tasks in a task queue 106 and processes these tasks accordingly 107. Due to computationally-intensive nature of these computations, these post-process steps usually result in a noticeable delay in cameras.
Once the application completes tasks in the task queue, the camera application provides a feedback 108 to acknowledge to the user that the camera is ready for image management request 109. If there is no pending image management request 110, the application loops back to Capture Ready ON 100 state in preparation for more image capture request 101. If there is an image management request 111, the camera capture application exits 112 and initiates the image management application 113.
The image management application allows the user to perform a variety of image operations. These include but are not limited to manipulating the image using different filters such as “black and white” or “red-eye reduction”, sharing the image using email or online services, deleting/renaming/moving images and other operations. The user selects any of the available options 113, and the application schedules 114 and processes 115 the tasks in the task queue. Depending on the operation, this might also result in noticeable delays to the end user. Once all tasks complete, the application provides feedback 116 to acknowledge the completion of these tasks. Simultaneously, it provides options for the user to either return to the camera capture mode 117 or initiate another image management request.
If the user chooses to return to the camera capture mode 117, the image management application exits image management application and loads camera capture application 120. If the user chooses not to return to camera capture mode 118, the application returns to image management application main menu to allow the user to select other image management options 113.
Digital cameras operations vary in minor detail, but it can be generalized by the diagram in
Referring now to
The present invention addresses the issue of significant processing delay that exhibits on most digital cameras, which results in poor responsiveness to the end user. The present invention propose a method to intelligently allocate computing cycles to produce the fastest user feedback possible, and postponing the time-uncritical tasks for processor low-duty times. While the total processing time for the camera operation does not improve, the delay between user action and camera feedback is significantly reduced. By further analyzing the user's behavior, the proposed method can provide near instantaneous feedback to the user. Since camera feedback is the only way a user can judge camera's readiness and responsiveness, it is thus possible to accelerate camera operations utilizing only software methods as proposed.
The proposed method assumes that typical camera processor utilization is much than 100% during its ON state. Standard camera usage flow typically consists of image framing, capturing, reviewing, and modifying steps. In most steps, the device's processor is at virtually 0% utilization. When the device processor is under heavy utilization, it typically becomes a bottleneck in the processor which results in long delays. The proposed method reliefs the utilization bottleneck and amortize the device's processor utilization over a wider period, under which the processor is fully utilized.
The flow starts at when the camera capture application initializes and enters shooting mode. Once the initialization completes and the camera application is ready for captures, the application signals Capture Ready On 200 and indicates to the user its readiness. The application proceeds to detect any user input request 201. Upon detecting a user input 202, the application verifies if the input is an image capture request 203. When the application confirms an image capture request 204, it turns off the Ready Capture 205 signal and proceeds to capture 206 an image. The application processes only the minimal time-critical tasks 207 to capture an image 206, and immediately provides a feedback 208 to acknowledge to the user that the camera is ready for another quick image capture 209. This image remains in an unprocessed state until the application processes this image. By avoiding the time-consuming processing, the proposed method significantly reduces the long delay between camera's image captures.
Once Capture Ready ON 209 is set, the application detects for additional user inputs 201. If no user inputs are detected 210, the application then proceeds to detect any unprocessed images 211 in task queue. If unprocessed image exists 212, the application schedules the necessary post-process tasks 213 to the task queue.
If there is neither a user input 210 nor any unprocessed image waiting 214, the application then checks if any tasks exist in the task queue 215. If yes 216, the application process a task 217 and proceeds to check for new user input 201. If not 218, the application returns to check for new inputs 201.
If the user input is non-capture image request, the proposed method also utilizes the same framework to provide expedited feedback and postpone the time-uncritical tasks. The application receives a user input 201 and determines that it is not 219 a capture request 203. The application completes the minimal processing 220 and provides immediate feedback to the user 221. The application then adds the time-uncritical tasks the task queue 222 similar to that of camera capture request procedure. These non-capture image requests can be any camera software operation, such as email, upload, image manipulation and image management.
The most significant difference between the proposed method and the existing standard method is this concept of minimal processing 207 prior to providing feedback 208. Instead of completing the post-capture processing tasks in the existing methods, the proposed method processes only the mandatory time-critical tasks and postpones the time-uncritical tasks for later. Depending on the user's requests, the proposed method intelligently finds the best time to complete the remaining tasks. An example of time-critical tasks is reading of the image sensor value, which must be done as soon as possible. An example such time-uncritical tasks is compressing the raw image values into a smaller file, which can be done at anytime as long as the raw image values are available.
From the end-user perspective, camera operations under the proposed method are considerably faster. To perform same operations, the proposed method typically cutting the feedback delay time from one-half to one-fifth depending on the operation. Since the user cannot be aware that the bulk of the processing is done when the user is not actively using the camera (e.g. framing a shot), the end result is acceleration for camera operations purely done in software without any hardware assistance.
Referring now to
Continuing now with the
Since the user is neither aware nor concerned about the background, the Perceived Processing Time of the proposed method 307 is the difference between Ready1311 and Ready4312. This time is significantly shorter than that of the typical method's Perceived Process Time 300. The improvement is generally anywhere from 2× to 10× depending the camera operation, and can be further accelerated using dynamic behavioral analysis shown in
Referring now to
Continuing now with the
Upon storing IMG_N 412, the application detects insufficient memory storage and enters maximum memory utilization mode. In this mode, the application prioritizes the tasks in the task queue over new requests, essentially reverting back to a serial mode similar to that of standard method 400. In the worst case scenario, although the application must free up memory prior to taking new requests, the overall throughput rate is no less than the standard camera option method. Physically, if the user continuously performs action under software acceleration faster than the rate at which actions can be processed, at some point the proposed camera application must revert back to the non-accelerated mode. As device memory grows in future camera devices, this will become less of an issue.
In the case where camera user prematurely exits the camera application prior to completing all tasks in queue, the application initiates exit protection procedures to operate in the background until all images are processed. To prevent slowing of other application's performance, exit protection procedures operate in the background only when the processor is not under full load. Certain camera devices forbid exited applications to run in the background. In these devices, the application can either wait until all images complete processing or discard the images in memory for a prompt exit.
Referring now to
Upon receiving any user request, the application updates the corresponding cells in
The sample record of user actions in
Historically, some less frequent actions are Full Screen Preview 507 and Email 509. The user roughly previews one out of every four images and emails roughly one out of every 10 images. This indicates that the user do use these features but not on a consistent basis.
The infrequent actions on the matrix are Geolocate 510, Upload album 511 and Grayscale 512.
The historical data alone is not enough to determine each task's priority. The application keeps track of the latest actions as well. In the matrix shown, it appears that Initial Capture 505 and Format JPEG 508 remain frequently used, but the user rarely uses the Thumbnail Preview. The application also observes a dramatic increase in the Grayscale 512 requests in the recent operations.
The frequent grayscale image manipulation requests are a drastic change in the user behavior which could be a result of a new camera user operating the camera. The application can speculate this behavior and dynamically-prioritizes the task queue to generate an even more accelerated response to the end user. In effect, before processing the standard sequence of tasks for an image capture, the application pre-computes the grayscale results for the next image first from speculation that it might be the user's next request. If the speculation is correct and the user requests a grayscale action, the on-screen grayscale result preview would be instantaneous because the image has been pre-computed. If the speculation is incorrect, the pre-computation would add to the total background processing but would still not affect the user's on-screen performance in any way.
The historical data 501 shows the popular general actions from the user, while the current data 502 shows any recent trends. The application combines the two source of information to calculate the importance 503 ranking. The importance rank 503 differs from the instantaneous priority 504 where the importance rank doesn't take in consideration of any technical limitations. In some instances, one action must precede another due to technical reasons. The Instantaneous Priority 504 takes in consideration of both technical limitations and the importance ranking to suggest the most optimized task queue priority list.
In the case where behavior-tracking is not feasible, the method proposes to pre-seed priority information to still achieve great results. Experiments are used to gather behavioral information from large pool of camera users and later infer into priority ranking.
Due to the generally predictable user behavior, proposed method with these pre-seeded data produces great acceleration on the common camera operations. The trade off for not keeping up-to-date behavior information is the inability to cope with any user behavior that drastically differs from the norm.
Referring now to
Continuing with
The instantaneous feedback does not require a full resolution image, thus for speed the grayscale conversion is only pre-computed for the preview size resolution. The full resolution grayscale is a time-uncritical task that is processed at a later time if needed. The amount of added pre-computation for grayscale preview 607 is relatively small. However, the resulting instantaneous feedback greatly accelerates the perceived camera operations speed and significantly improves the user experience.
Referring now to
Continuing with the
The interactive feedback is layered on top of live updating viewfinder, but not obstructing the main view. In effect, the feedback is readily available, but does not obstruct the user from any camera operations. The interactive feedback can also hide completely if requested.
The interactive feedback generates the thumbnail to signal to the user that the device is ready for more actions 200. Although the image is not yet fully processed, the user can fully interact with the image to perform any camera operations. Thus as the user is concerned, processing in association to the camera operation is complete the moment the user can fully interact with the captured image.
One way to implement the thumbnail preview is to sub-sample a screen resolution size and a thumbnail size image from the original full resolution image in software. Another method is to utilize the existing hardware to capture a smaller screen-sized image prior to capturing the full resolution image. The two resulting images are roughly the same unless there is significant camera movement. Depending on the device capability, the hardware assist can further accelerate the camera operations using the proposed method.
A wide range of common image management options are shown in
Referring now to
Continuing with the
Continuing with the
Referring now to
Continuing with the
To maximize the operation's feedback speed, the implementation stores both the full-screen and thumbnail sized versions of the image in memory. A circular queue can be used to store these data as the user only has access to a limited number of images at a time on the viewfinder. This implementation help minimizes the memory footprint while maximizes the feedback speed.
Referring now to
Continuing with the
Continuing now with
Unknown to the user the deletion only occurs on screen while the actual computing is done at a later time. The minimal processing 220 provides immediate user feedback 221. Meanwhile, the insert deletion related tasks in the task queue 222 for processing at a later time. This implementation help maximizes the feedback speed for the deletion operation.
Referring now to
Continuing with the
Continuing with the
Continuing with the
The application submenu is customizable by design. Depending on the device and requirement, the application can show different submenu to provide options for different possible operations.
Referring now to
Continuing with
Continuing with
The camera application pre-seeds some or all of the sections on the form, which includes To 1205, Subject 1206 and Body 1207 section. The body 1208 section of the form is automatically filled in with the selected image. Once the user selects Send 1209, the form disappears and the live viewfinder is once again visible.
Emailing the image does not exit the camera application, loads up the email application, nor does the application process the email right away. The application performs the minimal processing to generate the email form, and then inserts the time-uncritical tasks in the task queue for later processing. This technique significantly accelerates the emailing operation by avoiding potential long delays in communication. The camera application is able to execute other applications in the same fashion without worries of major performance impact.
Referring now to
Continuing with the
Continuing with the
Continuing with the
Referring now to
Continuing with the
Continuing with the
Continuing with the
While various embodiment of the present invention have been shown and described, it should be understood that other modifications, substitutions and alternatives can be made without departing from the spirit and scope of the invention, which should be determined from the appended claims.
This application claims priority under 35 U.S.C. 119(e) to U.S. Provisional Patent Application No. 61/149,351 filed Feb. 3, 2009, of Gai, et. al, for BEHAVIORALLY-BASED SOFTWARE ACCELERATION FOR DIGITAL CAMERA OPERATION, which U.S. Provisional Patent Application is hereby fully incorporated herein by reference.
Number | Date | Country | |
---|---|---|---|
61149351 | Feb 2009 | US |