Skip to main content

Remove image background

Reason this release was yanked:

*.onnx files are not included

Project description

Rembg (AWS Lambda)

Downloads Downloads Downloads License Hugging Face Spaces Streamlit App

This is a stripped-down fork of danielgatis/rembg designed for AWS Lambda environments.

rembg-aws-lambda is a tool to remove images background.

Requirements

python: >3.7, <3.11

Installation

CPU support:

pip install rembg-aws-lambda

GPU support:

First of all, you need to check if your system supports the onnxruntime-gpu.

Go to https://onnxruntime.ai and check the installation matrix.

If yes, just run:

pip install rembg-aws-lambda[gpu]

Usage as a library

Input and output as bytes

from rembg import remove

input_path = 'input.png'
output_path = 'output.png'

with open(input_path, 'rb') as i:
    with open(output_path, 'wb') as o:
        input = i.read()
        output = remove(input)
        o.write(output)

Input and output as a PIL image

from rembg import remove
from PIL import Image

input_path = 'input.png'
output_path = 'output.png'

input = Image.open(input_path)
output = remove(input)
output.save(output_path)

Input and output as a numpy array

from rembg import remove
import cv2

input_path = 'input.png'
output_path = 'output.png'

input = cv2.imread(input_path)
output = remove(input)
cv2.imwrite(output_path, output)

How to iterate over files in a performatic way

from pathlib import Path
from rembg import remove, new_session

session = new_session()

for file in Path('path/to/folder').glob('*.png'):
    input_path = str(file)
    output_path = str(file.parent / (file.stem + ".out.png"))

    with open(input_path, 'rb') as i:
        with open(output_path, 'wb') as o:
            input = i.read()
            output = remove(input, session=session)
            o.write(output)

Usage as a docker

Just replace the rembg command for docker run danielgatis/rembg.

Try this:

docker run danielgatis/rembg i path/to/input.png path/to/output.png

Models

All models are downloaded and saved in the user home folder in the .u2net directory.

The available models are:

  • u2net (download, source): A pre-trained model for general use cases.
  • u2netp (download, source): A lightweight version of u2net model.
  • u2net_human_seg (download, source): A pre-trained model for human segmentation.
  • u2net_cloth_seg (download, source): A pre-trained model for Cloths Parsing from human portrait. Here clothes are parsed into 3 category: Upper body, Lower body and Full body.
  • silueta (download, source): Same as u2net but the size is reduced to 43Mb.

How to train your own model

If You need more fine tunned models try this: https://github.com/danielgatis/rembg/issues/193#issuecomment-1055534289

Some video tutorials

References

License

Copyright (c) 2020-present Daniel Gatis

Licensed under MIT License

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

rembg-aws-lambda-0.0.1.tar.gz (31.3 kB view details)

Uploaded Source

Built Distribution

rembg_aws_lambda-0.0.1-py3-none-any.whl (12.7 kB view details)

Uploaded Python 3

File details

Details for the file rembg-aws-lambda-0.0.1.tar.gz.

File metadata

  • Download URL: rembg-aws-lambda-0.0.1.tar.gz
  • Upload date:
  • Size: 31.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.9.16

File hashes

Hashes for rembg-aws-lambda-0.0.1.tar.gz
Algorithm Hash digest
SHA256 21aee84035e009d5565ff9f4547abd998f11e63b0525bae4fd23180a5f3fa07f
MD5 65fb1ae50314df168f6a22cf343e7c62
BLAKE2b-256 e93bbd8834648f2989fbd072de85df0a14fb39f54a1781a09a92c8c4cffe183a

See more details on using hashes here.

File details

Details for the file rembg_aws_lambda-0.0.1-py3-none-any.whl.

File metadata

File hashes

Hashes for rembg_aws_lambda-0.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 3375e78893d11e4c8500a89b0861c5c8ae1a8480781369caf125daac0321e0e6
MD5 06d8e1d820b3a91f73c78bc6550b504c
BLAKE2b-256 f38ebb88e3363ba72f451cfc70afc4b8641c08f7a026aeaa25a292ddba6cdba8

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page