IOPaint/main.py

119 lines
3.2 KiB
Python
Raw Normal View History

2021-11-15 08:22:34 +01:00
#!/usr/bin/env python3
2021-12-16 14:29:32 +01:00
import argparse
2021-11-15 08:22:34 +01:00
import io
2021-12-16 14:29:32 +01:00
import multiprocessing
2021-11-15 08:22:34 +01:00
import os
from typing import Union
2021-12-16 14:29:32 +01:00
2021-11-15 08:22:34 +01:00
import cv2
import torch
2022-03-04 06:44:53 +01:00
from lama_cleaner.lama import LaMa
from lama_cleaner.ldm import LDM
try:
torch._C._jit_override_can_fuse_on_cpu(False)
torch._C._jit_override_can_fuse_on_gpu(False)
torch._C._jit_set_texpr_fuser_enabled(False)
torch._C._jit_set_nvfuser_enabled(False)
except:
pass
2021-11-15 08:22:34 +01:00
from flask import Flask, request, send_file
from flask_cors import CORS
2022-02-09 11:01:19 +01:00
from lama_cleaner.helper import (
load_img,
norm_img,
numpy_to_bytes,
2022-03-04 06:44:53 +01:00
resize_max_size, )
2021-11-15 20:11:46 +01:00
NUM_THREADS = str(multiprocessing.cpu_count())
2021-11-15 08:22:34 +01:00
os.environ["OMP_NUM_THREADS"] = NUM_THREADS
os.environ["OPENBLAS_NUM_THREADS"] = NUM_THREADS
os.environ["MKL_NUM_THREADS"] = NUM_THREADS
os.environ["VECLIB_MAXIMUM_THREADS"] = NUM_THREADS
os.environ["NUMEXPR_NUM_THREADS"] = NUM_THREADS
2021-11-16 14:21:41 +01:00
if os.environ.get("CACHE_DIR"):
os.environ["TORCH_HOME"] = os.environ["CACHE_DIR"]
2021-11-15 08:22:34 +01:00
BUILD_DIR = os.environ.get("LAMA_CLEANER_BUILD_DIR", "./lama_cleaner/app/build")
app = Flask(__name__, static_folder=os.path.join(BUILD_DIR, "static"))
app.config["JSON_AS_ASCII"] = False
CORS(app)
model = None
device = None
@app.route("/inpaint", methods=["POST"])
def process():
input = request.files
2022-03-04 06:44:53 +01:00
# RGB
2021-11-15 08:22:34 +01:00
image = load_img(input["image"].read())
original_shape = image.shape
interpolation = cv2.INTER_CUBIC
size_limit: Union[int, str] = request.form.get("sizeLimit", "1080")
if size_limit == "Original":
size_limit = max(image.shape)
else:
size_limit = int(size_limit)
print(f"Origin image shape: {original_shape}")
image = resize_max_size(image, size_limit=size_limit, interpolation=interpolation)
print(f"Resized image shape: {image.shape}")
image = norm_img(image)
2021-11-15 08:22:34 +01:00
mask = load_img(input["mask"].read(), gray=True)
mask = resize_max_size(mask, size_limit=size_limit, interpolation=interpolation)
mask = norm_img(mask)
2022-03-04 06:44:53 +01:00
res_np_img = model(image, mask)
2021-11-15 08:22:34 +01:00
return send_file(
io.BytesIO(numpy_to_bytes(res_np_img)),
mimetype="image/jpeg",
2021-11-15 08:22:34 +01:00
as_attachment=True,
attachment_filename="result.jpeg",
2021-11-15 08:22:34 +01:00
)
@app.route("/")
def index():
return send_file(os.path.join(BUILD_DIR, "index.html"))
def get_args_parser():
parser = argparse.ArgumentParser()
parser.add_argument("--port", default=8080, type=int)
2022-03-04 06:44:53 +01:00
parser.add_argument("--model", default="lama", choices=["lama", "ldm"])
parser.add_argument("--ldm-steps", default=50, type=int, help="Steps for DDIM sampling process."
"The larger the value, the better the result, but it will be more time-consuming")
2021-11-15 08:22:34 +01:00
parser.add_argument("--device", default="cuda", type=str)
parser.add_argument("--debug", action="store_true")
2021-11-15 08:22:34 +01:00
return parser.parse_args()
def main():
global model
global device
args = get_args_parser()
device = torch.device(args.device)
2022-03-04 06:44:53 +01:00
if args.model == "lama":
model = LaMa(device)
elif args.model == "ldm":
model = LDM(device, steps=args.ldm_steps)
else:
2022-03-04 06:44:53 +01:00
raise NotImplementedError(f"Not supported model: {args.model}")
app.run(host="0.0.0.0", port=args.port, debug=args.debug)
2021-11-15 08:22:34 +01:00
if __name__ == "__main__":
main()