I am creating mosaic of two images based on the region matches between them using sift descriptors. The problem is when the 开发者_如何学Ccreated mosaic's size gets too large matlab runs out of memory. Is there some way of stitching the images without actually loading the complete images in memory. If not how do other gigapixel image generation techniques work or the panorama apps.
- Determine the size of the final mosaic prior to stitching (easy to compute with the size of your input images and the homography).
- Write a blank mosaic to file (not in any specific format but a sequence of bytes just as in memory)
- I'm assuming you're inverse mapping the pixels from the original images to the mosaic. So, just write to file when you're trying to store the intensity of the pixel in your mosaic.
There are a few ways you can save memory:
- You should use integer data types, such as
uint8
for your data. - If you're stitching, you can only keep the regions of interest in memory, such as the potential overlap regions.
- If none of the other works, you can spatially downsample the images using
imresample
, and work on the resulting smaller images.
You can potentially use distributed arrays in the parallel computing toolbox
精彩评论