Label Large Images in the Image Labeler
The Image Labeler app enables you to label images that might be too large to fit into memory. The app achieves this by converting the large image into a blocked image. A blocked image divides the large image into smaller blocks that can fit in memory.
In the Image Labeler app, you can label a blocked image as you would any other image.
Import Blocked Image into Image Labeler
When loading images into the Image Labeler app, if an image appears to be too large to fit into memory (having at least one dimension larger than 8000 pixels) or is a multiresolution image, the app displays the Importing Large Images dialog box, which offers you the option to convert the image into a blocked image. The image on the left side of the dialog box represents a blocked image, with visible grid lines to show how an image is divided into blocks. To choose to use a blocked image, select Import as Blocked Image and click OK.
Initially, the app loads blocks that form the center of the image (50% of image height
and width). For multiresolution images, the app chooses the resolution to use depending
on how much of the image is visible. As you zoom in on an image, the app switches to a
finer resolution. For more information about displaying multiresolution images, see
When using blocked images, the app also provides a view of the entire image in the Overview pane. In the Overview pane, the display overlays a box on the image that shows the portion of the image that is currently visible in the main view pane in the center of the app window. To view other parts of the image in the app, drag the view box to a different part of the image in the Overview pane. To get a more detailed view of the image, use the zoom buttons in the axes toolbar that appears when you move the mouse over the image in the main view pane. The axes toolbar also contains a button to enable a view of the block boundaries grid over the image. The current resolution level used by the app can affect the visibility of these block boundaries.
Work with Blocked Images in the Image Labeler
Once you load a blocked image into the Image Labeler app, you can
work with the blocked image as you would with nonblocked images. You can create labels,
sublabels, and attributes and, when you are finished labeling, you can export the labels
Using blocked images enables you to label images in the app that do not fit in memory. However, there are some limitations with use of blocked images in the Image Labeler app.
Pixel labeling is not supported. You can only create labels using ROI shapes, such as rectangles, lines, and projected cuboid polygons.
When working with a multiresolution image, the images at every resolution must be in registered to each other, that is, in alignment.
Thumbnails of images displayed in the app cannot be rotated.
Use Blocked Image Automation with Images
With blocked images, as with nonblocked images, you can take advantage of automated processing to help with the labeling process. For example, with medical images, you can do automatic tumor detection using blocked image automation. You can train a object detector deep learning network and use that in the app to automatically label tumors with bounding boxes.
To use blocked image automation, click Select Algorithm, select Add Blocked Image Algorithm, and choose to either create a new algorithm, by selecting Create New Blocked Image Algorithm, or import an existing algorithm, by selecting Import Blocked Image Algorithm.
When you choose to create a new blocked image algorithm, the app opens a class file
template in the editor. The class subclasses
vision.labeler.mixin.BlockedImageAutomation. The template
contains stubs for standard methods that you must implement for your algorithm,
blockedImageAutomationAlgorithm method. For more
information about implementing this method, see
blockedImageAutomationAlgorithm. Add the code you want the algorithm to
execute. For more information about creating labeler automation algorithms and where to
save this class file, see Create Automation Algorithm for Labeling.
After saving the class file and adding the location folder to the path, click Select Algorithm in the Image Labeler app, and select Refresh list. You can select your new blocked image automation algorithm by clicking Select Algorithm, and then selecting your algorithm.
Select My Algorithm and click Automate. The app opens the Automate tab. Use this tab to control execution of your blocked image automation algorithm.
Determine what parts of the image the algorithm processes: the whole image, the current region, or a region that you specify by drawing an ROI.
Specify which resolution level you want to process. Level 1 is the finest resolution level. The resolution level with the highest number is the coarsest resolution level.
Specify the size of the blocks in the blocked image. By default, blocks are 1024-by-1024.
Click Use Parallel to take advantage of parallel processing techniques
Click Settings to access other parameters made available by the algorithm
The Automate tab includes a Metadata pane that provides information about the blocked image. You can include text instructions about your algorithm in the class file, displayed in the right-most pane of the app. To try out the algorithm, click Run.
Postprocess Exported Labels to Create a Labeled Blocked Image
You can convert polygon coordinates exported as a
groundTruth object from the Image Labeler app into a labeled
blocked image using the
polyToBlockedImage function. For more information, see Convert Image Labeler Polygons to Labeled Blocked Image for Semantic Segmentation.
- Get Started with the Image Labeler
- Convert Image Labeler Polygons to Labeled Blocked Image for Semantic Segmentation