nopperl
Disable example cache
cca31ec
from os.path import basename, splitext
import gradio as gr
from huggingface_hub import hf_hub_download
from onnx_inference import vectorize_image
MODEL_PATH = hf_hub_download("nopperl/marked-lineart-vectorizer", "model.onnx")
def predict(input_image_path, threshold, stroke_width):
output_filepath = splitext(basename(input_image_path))[0] + ".svg"
for recons_img in vectorize_image(input_image_path, model=MODEL_PATH, output=output_filepath, threshold_ratio=threshold, stroke_width=stroke_width):
yield recons_img
yield output_filepath
interface = gr.Interface(
predict,
inputs=[gr.Image(sources="upload", type="filepath"), gr.Slider(minimum=0.1, maximum=0.9, value=0.1, label="threshold"), gr.Slider(minimum=0.1, maximum=4.0, value=0.512, label="stroke_width")],
outputs=gr.Image(),
description="Demo for a model that converts raster line-art images into vector images iteratively. The model is trained on black-and-white line-art images, hence it won't work with other images. Inference time will be quite slow due to a lack of GPU resources. More information at https://github.com/nopperl/marked-lineart-vectorization.",
examples = [
["examples/01.png", 0.1, 0.512],
["examples/02.png", 0.1, 0.512]
],
analytics_enabled=False,
cache_examples=False
)
interface.launch()