Image Segmentation
BiRefNet
Safetensors
Transformers
background-removal
mask-generation
Dichotomous Image Segmentation
Camouflaged Object Detection
Salient Object Detection
pytorch_model_hub_mixin
model_hub_mixin
custom_code
Instructions to use ZhengPeng7/BiRefNet with libraries, inference providers, notebooks, and local apps. Follow these links to get started.
- Libraries
- BiRefNet
How to use ZhengPeng7/BiRefNet with BiRefNet:
# Option 1: use with transformers from transformers import AutoModelForImageSegmentation birefnet = AutoModelForImageSegmentation.from_pretrained("ZhengPeng7/BiRefNet", trust_remote_code=True)# Option 2: use with BiRefNet # Install from https://github.com/ZhengPeng7/BiRefNet from models.birefnet import BiRefNet model = BiRefNet.from_pretrained("ZhengPeng7/BiRefNet") - Transformers
How to use ZhengPeng7/BiRefNet with Transformers:
# Use a pipeline as a high-level helper from transformers import pipeline pipe = pipeline("image-segmentation", model="ZhengPeng7/BiRefNet", trust_remote_code=True)# Load model directly from transformers import AutoModelForImageSegmentation model = AutoModelForImageSegmentation.from_pretrained("ZhengPeng7/BiRefNet", trust_remote_code=True, dtype="auto") - Notebooks
- Google Colab
- Kaggle
| import torch.nn as nn | |
| from models.modules.utils import build_act_layer, build_norm_layer | |
| class StemLayer(nn.Module): | |
| r""" Stem layer of InternImage | |
| Args: | |
| in_channels (int): number of input channels | |
| out_channels (int): number of output channels | |
| act_layer (str): activation layer | |
| norm_layer (str): normalization layer | |
| """ | |
| def __init__(self, | |
| in_channels=3+1, | |
| inter_channels=48, | |
| out_channels=96, | |
| act_layer='GELU', | |
| norm_layer='BN'): | |
| super().__init__() | |
| self.conv1 = nn.Conv2d(in_channels, | |
| inter_channels, | |
| kernel_size=3, | |
| stride=1, | |
| padding=1) | |
| self.norm1 = build_norm_layer( | |
| inter_channels, norm_layer, 'channels_first', 'channels_first' | |
| ) | |
| self.act = build_act_layer(act_layer) | |
| self.conv2 = nn.Conv2d(inter_channels, | |
| out_channels, | |
| kernel_size=3, | |
| stride=1, | |
| padding=1) | |
| self.norm2 = build_norm_layer( | |
| out_channels, norm_layer, 'channels_first', 'channels_first' | |
| ) | |
| def forward(self, x): | |
| x = self.conv1(x) | |
| x = self.norm1(x) | |
| x = self.act(x) | |
| x = self.conv2(x) | |
| x = self.norm2(x) | |
| return x | |