Skip to content

Latest commit

 

History

History
197 lines (123 loc) · 13.6 KB

README.md

File metadata and controls

197 lines (123 loc) · 13.6 KB

Image Segmentation using Segment Anything Model (SAM)

Meta's new prompt-based AI model allows zero-shot generalization for any segmentation tasks without the need for additional training.

    
Image Segmentation

1. Overview

Foundation Models are powerful models trained over a massive amount of unlabeled data, which can be used for different applications with minimal fine-tuning. This eliminates the need to generate and organize massive datasets and train the AI models to recognize everything for every specific use case. They are already popular in the field of NLP, and now, Meta's Segment Anything Project has developed a solid base to introduce these foundation models in computer vision as well. Segment Anything Model can extract any object from an image using a variety of prompts as input.

From here on, the discussion will focus on the two vital components of the project-

  • The largest segmentation dataset ever
  • The Segment Anything Model (SAM) - a promptable foundation model for image segmentation

2. The Segment Anything Model (SAM)

As discussed, the earlier models, while useful, take an extensive amount of resources and time. Each specific task requires a specially curated, well-organized dataset which needs a lot of time for data collection and manual annotation itself, along with long hours of intensive training. Furthermore, in making changes to the dataset, considerable hours of retraining are also necessary.

SAM is a transformer-based deep learning model which seeks to resolve these problems by allowing a very high-powered generalization of a range of downstream segmentation problems by pre-training it on an extensive dataset comprising of images and masks. This image segmentation model uses prompt engineering and, otherwise, needs very minimal human involvement.

2.1 Zero-shot generalization in SAM

Foundation models like SAM learn a general notion of what objects are, such that unfamiliar objects and images can be dealt with without requiring additional training. This is called Zero-shot generalization.

On careful assessment, it is realized that SAM has a very effective zero-shot performance – often competitive with or even superior to prior fully supervised results.

2.2 SAM as a Promptable Image Segmentation Model


Segment Anything as a promptable image segmentation model

SAM can take prompts from users about which area to segment out precisely. The following prompts can be provided to SAM as inputs:

  • By clicking on a point
  • By drawing a bounding box
  • By drawing a rough mask on an object
  • By giving text prompts (not released)

Since the text prompt for SAM has yet to be released by Meta, to read more about image segmentation with text prompts using SAM and Grounding Dino, you can refer to my article here.

    
Segmentation using single point & text prompt respectively

2.3 Model Architecture

2.3.1 Overview


The model architecture of Segment Anything when giving it an image as input

Any image given as an input first passes through an encoder which produces a one-time embedding for the input.

There is also a prompt encoder for points, boxes, or text as prompts. For points, the x & y coordinates, along with the foreground and background information, become input to the encoder. For boxes, the bounding box coordinates become the input to the encoder, and as for the text (not released at the time of writing this), the tokens become the input. In case we provide a mask as input, it directly goes through a downsampling stage. The downsampling happens using 2D convolutional layers. Then the model concatenates it with the image embedding to get the final vector.

Any vector that the model gets from the prompt vector + image embedding passes through a lightweight decoder that creates the final segmentation mask. We get possible valid masks along with a confidence score as the output.

2.3.2 Components


The Segment Anything Model can run in real-time in browser

  • SAM Image Encoder: The image encoder is one of the most powerful and essential components of SAM. It is built upon an MAE pre-trained Vision Transformer model. The image encoder runs once per image and can be applied prior to prompting the model.
  • Prompt Encoder: For the prompt encoder, points, boxes, and text act as sparse inputs, and masks act as dense inputs. The creators of SAM represent points and bounding boxes using positional encodings and sum it with learned embeddings. For text prompts, SAM uses the text encoder from CLIP. For masks as prompts, after downsampling happens through convolutional layers, the embedding is summed element-wise with the input image embedding.
  • Mask Decoder: The mask decoder efficiently maps the image embedding, prompt embeddings, and an output token to a mask.

3. The Segment Anything Dataset

The foundation of any groundbreaking deep learning model is the dataset it's trained on. And it's no different for the Segmentation Anything Model as well.

The Segment Anything Dataset contains more than 11 million images and 1.1 billion masks. The final dataset is called the SA-1B dataset.

After annotating enough masks with SAM's help, we were able to leverage SAM's sophisticated ambiguity-aware design to annotate new images fully automatically. To do this, we present SAM with a grid of points on an image and ask SAM to segment everything at each point. Our final dataset includes more than 1.1 billion segmentation masks collected on ~11 million licensed and privacy-preserving images.

Explore the dataset    Download the dataset

4. Data Engine in SAM

Meta developed a data engine to collect a dataset, SA-1B, of 1.1 billion segmentation masks, as these masks are limited on the internet.

To enhance SAM's capabilities, researchers employed a model-in-the-loop data engine, using SAM to interactively annotate images and update the model. This iterative process of using SAM for annotation and training improved both the model and the dataset.


Data Engine

The data engine has three stages:

  • Assisted-Manual Stage
  • Semi-Automatic Stage
  • Fully Automatic Stage

5. Code Implementation

Here is the code implementation of Automated Mask Generation, Generate Segmentation with Bounding Box, and Generate Segmentation with a text prompt.

6. Evaluation Metric and Quantitative Results of SAM

  • Intersection-Over-Union: IoU is the area of overlap between the predicted segmentation and the ground truth divided by the area of union between the predicted segmentation and the ground truth
  • Average Mask Rating: Metric for mask quality on image segmentation. Mask quality on a scale of 1 (nonsense) to 10 (pixel-perfect).
  • Efficiency. The overall model design is largely motivated by efficiency. Given a precomputed image embedding, the prompt encoder and mask decoder runs in a web browser, on CPU, at ∼50ms. This runtime performance enables seamless, real-time interactive prompting of our model.



Point to mask evaluation in 23 datasets

The results show that SAM outperforms the strong RITM baseline on 16 of the 23 datasets in terms of automatic evaluation using mIoU. With an oracle to resolve ambiguity, SAM outperforms RITM on all datasets.

7. Applications

  • Image editing: SAM can be used to quickly and easily remove objects from images, such as people, cars, or buildings. This can be useful for privacy reasons or to create more creative and interesting images. For example, a photographer could use SAM to remove a distracting person from the background of a portrait, or a graphic designer could use SAM to remove a logo from a product image.


Photoshop Editing

  • Data Annotation: Data annotation using the Segment Anything model offers versatile applications in the field of computer vision. This model enables precise annotation and segmentation of a wide range of objects, irrespective of their complexity or category. It can be applied in areas such as autonomous driving, where accurately annotating different road elements like lanes, traffic signs, and pedestrians is crucial for developing robust self-driving systems.


Data Annotation

  • Medical image analysis: SAM can be used to segment organs and tissues in medical images, such as MRI scans and CT scans. This can be useful for diagnosis and treatment planning. For example, a doctor could use SAM to identify a tumor in a patient's brain, or a surgeon could use SAM to plan the best way to remove a tumor.


Brain tumor segmentation

8. Limitations

  • Prior knowledge requirement: SAM often requires additional manual prompts with prior knowledge, especially for complex scenes like crop segmentation and fundus image segmentation. This can potentially result in a suboptimal user experience. Additionally, SAM's preference for foreground masks can limit its performance in shadow detection tasks, even with numerous click prompts.

  • Low-contrast applications: SAM's effectiveness is reduced when segmenting objects with similar surroundings, particularly transparent or camouflaged objects seamlessly blending into their environment. Enhancements are needed to improve SAM's robustness in handling complex scenes with low-contrast elements.

  • Limited understanding of professional data: SAM's performance with professional data, especially in box mode and everything mode, is often unsatisfactory. This highlights SAM's limitations in comprehending practical scenarios. Even with click mode, both the user and the model require domain-specific knowledge and understanding of the task.

  • Challenges with smaller and irregular objects: SAM faces difficulties in segmenting smaller and irregular objects, commonly found in remote sensing and agriculture applications. This includes irregular buildings and small-sized streets captured by aerial imaging sensors. Developing effective strategies for SAM in such cases remains an open issue.

9. References

  1. https://arxiv.org/pdf/2304.02643.pdf

  2. https://segment-anything.com/

  3. https://learnopencv.com/segment-anything/

  4. https://github.com/facebookresearch/segment-anything

  5. https://blog.roboflow.com/grounding-dino-zero-shot-object-detection/