在浏览器上使用transformers.js运行(WebGPU)RMBG-1.4进行抠图(背景移除)

在浏览器上使用transformers.js运行(WebGPU)RMBG-1.4进行抠图(背景移除)

说明:

准备

下载onnx模型文件: https://huggingface.co/briaai/RMBG-1.4/tree/main/onnx, 有3个onnx模型文件:

  • model.onnx
  • model_fp16.onnx
  • model_quantized.onnx

Clone仓库并打开示例文件夹:

bash 复制代码
git clone https://github.com/xenova/transformers.js.git
cd transformers.js/examples/remove-background-client

创建public/models/briaai/RMBG-1.4/onnx 文件夹,并将下载的模型文件放入。

运行tree public/,可以看到:

public/
└── models
    └── briaai
        └── RMBG-1.4
            └── onnx
                ├── model.onnx
                ├── model_fp16.onnx
                └── model_quantized.onnx

安装项目依赖:

bash 复制代码
npm install

推理

修改main.js文件中的env配置,使用本地模型:

js 复制代码
env.allowLocalModels = true;

有很多可用的env配置,详见 https://huggingface.co/docs/transformers.js/api/env

以下是我测试过得配置(仅测试,不需要在main.js中修改):

js 复制代码
env.remoteHost = 'https://hf-mirror.com';
env.allowRemoteModels = false;
// 默认会读取之前的缓存,如果之前的缓存是错的,需要清空浏览器缓存,或者使用该配置不使用浏览器缓存
env.useBrowserCache = false;

使用model_quantized.onnx

默认使用的模型文件名为model_quantized.onnx,不需要做任何修改。

使用model.onnx

修改main.js,添加quantized: falseAutoModel.from_pretrained

js 复制代码
const model = await AutoModel.from_pretrained('briaai/RMBG-1.4', {
    // Do not require config.json to be present in the repository
    config: { model_type: 'custom' },
    quantized: false
    // model_file_name: 'model_fp16',
    // quantized: false
});

使用model_fp16.onnx

修改main.js,AutoModel.from_pretrained部分如下:

js 复制代码
const model = await AutoModel.from_pretrained('briaai/RMBG-1.4', {
    // Do not require config.json to be present in the repository
    config: { model_type: 'custom' },
    model_file_name: 'model_fp16',
    quantized: false
});

运行

bash 复制代码
npm run dev

然后打开浏览器,等待状态从Loading model...变为Ready后,上传图片

添加日志查看使用的模型文件

修改node_modules/@xenova/transformers/src/utils/hub.js中的getModelFile函数,添加日志打印localPath:

js 复制代码
    let requestURL = pathJoin(path_or_repo_id, filename);
    let localPath = pathJoin(env.localModelPath, requestURL);

    console.log("localPath: ", localPath);
bash 复制代码
npm run build
npm run preview

浏览器打开链接,F12显示开发者工具,可以看到日志:

localPath:  /models/briaai/RMBG-1.4/onnx/model_fp16.onnx
相关推荐
利白1 个月前
我的Qt作品(20)使用Qt+OpenCV写一个旋转/抠图/mask生成工具
qt·opencv·旋转·抠图·mask
玩电脑的辣条哥1 个月前
怎么给git动图扣除背景?
git·抠图
德林恩宝1 个月前
WebGPU、WebGL 和 OpenGL/Vulkan对比分析
web·webgl·opengl·webgpu
算家云3 个月前
BRIA-RMBG-1.4容器构建指南
人工智能·aigc·图像生成·模型训练·抠图·背景去除·内容创作
iReachers3 个月前
在浏览器里就可以运行的本地AI模型 - 一键去除图片背景AI
人工智能·webgpu·去除图片背景
runing_an_min3 个月前
ffmpeg视频滤镜:抠图-despill
ffmpeg·音视频·抠图·despill
灵魂画师向阳4 个月前
AI绘画Stable Diffusion 自制素材工具: layerdiffusion插件—你的透明背景图片生成工具
ai作画·stable diffusion·ai绘画·抠图·ai绘画教程·透明背景·sd教程
贝格前端工场5 个月前
作为web3D的核心,webGL会被webGPU取代吗?
webgl·webgpu
下饭的菜5 个月前
【sdk】- 对接阿里云抠图
java·阿里云·抠图