import torch import torch.nn.functional as F import logging import os import os.path as osp import sys CODE_SPACE=os.path.dirname(os.path.dirname(os.path.abspath(__file__))) try: from mmcv.utils import Config, DictAction except: from mmengine import Config, DictAction from mono.utils.logger import setup_logger import glob from mono.utils.comm import init_env from mono.model.monodepth_model import get_configured_monodepth_model from mono.utils.running import load_ckpt from mono.utils.do_test import transform_test_data_scalecano, get_prediction from mono.utils.custom_data import load_from_annos, load_data from mono.utils.avg_meter import MetricAverageMeter from mono.utils.visualization import save_val_imgs, create_html, save_raw_imgs, save_normal_val_imgs import cv2 from tqdm import tqdm import numpy as np from PIL import Image import matplotlib.pyplot as plt from mono.utils.unproj_pcd import reconstruct_pcd, save_point_cloud from mono.utils.transform import gray_to_colormap from mono.utils.visualization import vis_surface_normal import gradio as gr cfg = Config.fromfile('./mono/configs/HourglassDecoder/vit.raft5.large.py') torch.hub.download_url_to_file('https://images.unsplash.com/photo-1437622368342-7a3d73a34c8f', 'turtle.jpg') torch.hub.download_url_to_file('https://images.unsplash.com/photo-1519066629447-267fffa62d4b', 'lions.jpg') model = get_configured_monodepth_model(cfg, ) model, _, _, _ = load_ckpt('./weight/metric_depth_vit_large_800k.pth', model, strict_match=False) model.eval() device = "cpu" model.to(device) def depth_normal(img): cv_image = np.array(img) img = cv2.cvtColor(cv_image, cv2.COLOR_BGR2RGB) intrinsic = [1000.0, 1000.0, img.shape[1]/2, img.shape[0]/2] rgb_input, cam_models_stacks, pad, label_scale_factor = transform_test_data_scalecano(img, intrinsic, cfg.data_basic) with torch.no_grad(): pred_depth, pred_depth_scale, scale, output = get_prediction( model = model, input = rgb_input, cam_model = cam_models_stacks, pad_info = pad, scale_info = label_scale_factor, gt_depth = None, normalize_scale = cfg.data_basic.depth_range[1], ori_shape=[img.shape[0], img.shape[1]], ) pred_normal = output['normal_out_list'][0][:, :3, :, :] H, W = pred_normal.shape[2:] pred_normal[:, :, pad[0]:H-pad[1], pad[2]:W-pad[3]] pred_depth = pred_depth.squeeze().cpu().numpy() pred_depth[pred_depth<0] = 0 pred_color = gray_to_colormap(pred_depth) pred_normal = pred_normal.squeeze() if pred_normal.size(0) == 3: pred_normal = pred_normal.permute(1,2,0) pred_color_normal = vis_surface_normal(pred_normal) ##formatted = (output * 255 / np.max(output)).astype('uint8') img = Image.fromarray(pred_color) img_normal = Image.fromarray(pred_color_normal) return img, img_normal #inputs = gr.inputs.Image(type='pil', label="Original Image") #depth = gr.outputs.Image(type="pil",label="Output Depth") #normal = gr.outputs.Image(type="pil",label="Output Normal") title = "Metric3D" description = "Gradio demo for Metric3D (vit-large) running on CPU which takes in a single image for computing metric depth and surface normal. To use it, simply upload your image, or click one of the examples to load them. Read more at the links below." article = "

Metric3D: Towards Zero-shot Metric 3D Prediction from A Single Image | Github Repo

" examples = [ ["turtle.jpg"], ["lions.jpg"] ] gr.Interface( depth_normal, inputs=[gr.Image(type='pil', label="Original Image")], outputs=[gr.Image(type="pil",label="Output Depth"), gr.Image(type="pil",label="Output Normal")], title=title, description=description, article=article, examples=examples, analytics_enabled=False).launch()