project screenshot 1
project screenshot 2
project screenshot 3

Remove-bg

a tiny portrait background removal model, locally in the browser using Transformers.js, WebGPU-acceleration, and Basin to store and retrieve processed images on-chain.

Remove-bg

Created At

ETHOnline 2024

Winner of

Tableland - Best use of Basin (object storage) Runner ups

Project Description

A simple React + Vite application designed for running MODNet, a lightweight portrait background removal model, entirely in the browser. This solution leverages Transformers.js for seamless integration of machine learning models, while utilizing WebGPU acceleration to ensure smooth performance. Additionally, Basin is integrated to securely store and retrieve processed images on-chain, providing a decentralized solution for managing image data. This combination allows for a highly efficient, privacy-focused, and scalable application, fully powered by modern web technologies.

How it's Made

Getting Started

Follow the steps below to set up and run the application (both frontend and backend).

Prerequisites

  • Node.js: Make sure you have Node.js installed on your machine. You can download it from here.
  • ADM (Basin): Follow the Basin setup guide to ensure Basin is running and configured on your machine.

0. Setup Basin

Ensure that you have Basin properly set up by following this guide. Once Basin is running, verify that ADM commands can be executed on your machine.

1. Clone the Repository

Clone the repository from GitHub:

git clone https://github.com/0xgoldenlion/basin-remove-bg.git

2. Navigate to the Project Directory

Change your working directory to the basin-remove-bg folder:

cd basin-remove-bg

3. Install Dependencies

Install the necessary dependencies for the frontend using npm:

npm install

4. Setup Backend (Node.js) for ADM Integration

We need a backend to handle file uploads and interact with ADM.

4.1. Create a .env file

rename the template.env file in the project root to store your environment variables (Network and Private Key for ADM):

In your .env file, add the following:

NETWORK=localnet
PRIVATE_KEY=your_private_key_here
ADMADDRESS=adress_here 
ADMKEY= key_here 

Replace your_private_key_here with your actual private key for ADM transactions.

4.2. Install Backend Dependencies

Navigate to the backend directory and install the necessary backend dependencies:

cd backend
npm install

4.3. Run the Backend Server

Start the backend server, which will handle file uploads and interactions with ADM:

node server.js

The backend server will be running on http://localhost:5555.

5. Run the Frontend Development Server

Now that the backend is running, return to the main project directory (frontend) and start the development server:

npm run dev

The application should now be running locally. Open your browser and go to http://localhost:3511 to see it in action.

6. Test the Workflow

  • Upload Images: Drag and drop images into the interface.
  • Process: Click "Process" to remove the background and upload the image to ADM using the backend.
  • Download: After processing, you can download the images back from ADM through the backend.

7. Additional Notes

  • Basin Integration: Make sure ADM is set up and running before processing and uploading images. All files are stored on-chain using ADM via Basin.
  • GPU Acceleration: The application leverages WebGPU for faster processing, but make sure your browser supports WebGPU.
background image mobile

Join the mailing list

Get the latest news and updates