All photos contain noise, especially those captured in low light or high dynamic range settings. Since this noise is random, it can be reduced by averaging a burst of images. Flagship smartphones have been doing this for years (eg Google’s Night Sight, Apple’s Night Mode) and it turns out that the same technology can be used with essentially any camera capable of capturing a burst of RAW images.

Fortunately, Google has published a paper thoroughly explaining their burst photography pipeline. Our app is a simplified implementation of that pipeline.


When you capture a burst of images handheld or if the images contain movement (people, cars, stars, etc), the images need to be aligned to each other before they can be merged. In the case of astrophotography, the alignment is relatively simple since all the stars are moving in the same direction. In the case of portraits, this is a hard problem: a person can tilt their head, squint, and alter their smile, all at the same time. For these reasons, taking a long exposure is not an option to reduce noise. The only option is to capture a burst of shorter images and merge them using a pipeline like this.

In our pipeline, we first pick a “reference” image (the middle image) and try to align all the other “comparison” images to this image.

To align one of the comparison images with the reference image, we resize both of the images to a very small resolution. Afterwards, we divide the comparison image into a grid of tiles and try to align each tile to the reference image.

Once we have aligned the downscaled images, we use this alignment as a starting point and refine it using a slightly higher resolution image. We repeat this process multiple times until we align the original full-resolution images.

Below we illustrate this process on two images of letters. The letters are shifted and resized between the two images and the goal is to align the letters.

Once the images are aligned, all that’s left to do is to merge them.


Our app has a motion robustness setting. If it is set to “low”, motion-related artifacts may appear in the output image, but noise reduction will be the strongest. Conversely, setting motion robustness to “high” will prevent artifacts at the cost of weaker noise reduction.

The following is a comparison between a raw image, output from our app using Robustness set to High, and output from our app using Robustness set to Low. The image is taken from Google’s HDR+ dataset licensed under CC BY-SA.

You can compare our results to Google’s by opening Figure 6 in their paper.