|
--- |
|
license: cc-by-nc-4.0 |
|
|
|
language: |
|
- en |
|
pipeline_tag: depth-estimation |
|
tags: |
|
- depth |
|
- relative depth |
|
--- |
|
|
|
# Depth-Anything-V2-Base (Transformers version) |
|
|
|
## Introduction |
|
Depth Anything V2 is trained from 595K synthetic labeled images & 62M+ real unlabeled images, providing the most capable monocular depth estimation (MDE) model with the following features: |
|
- more fine-grained details than Depth Anything V1 |
|
- more robust than Depth Anything V1 & SD-based models (e.g., Marigold, Geowizard) |
|
- more efficient (10x faster) & more lightweight than SD-based models |
|
- impressive fine-tuned performance with our pre-trained models |
|
|
|
## Installation |
|
|
|
```bash |
|
git clone https://github.com/MackinationsAi/Upgraded-Depth-Anything-V2.git |
|
cd Upgraded-Depth-Anything-V2 |
|
one_click_install.bat |
|
``` |
|
|
|
## Usage |
|
|
|
Please refer to the [README.md](https://github.com/MackinationsAi/Upgraded-Depth-Anything-V2/blob/main/README.md) for actual usage. |
|
|
|
## Test Code |
|
|
|
```bash |
|
cd Upgraded-Depth-Anything-V2 |
|
venv\scripts\activate |
|
python test.py /path/to/your/image.jpg (or .png) |
|
``` |
|
Create a test.py script using the code below: |
|
|
|
```python |
|
import cv2 |
|
import torch |
|
import numpy as np |
|
import os |
|
import argparse |
|
|
|
from safetensors.torch import load_file |
|
from depth_anything_v2.dpt import DepthAnythingV2 |
|
|
|
# Argument parser for input image path |
|
parser = argparse.ArgumentParser(description="Depth map inference using DepthAnythingV2 model.") |
|
parser.add_argument("input_image_path", type=str, help="Path to the input image") |
|
args = parser.parse_args() |
|
|
|
# Determine the directory of this script |
|
script_dir = os.path.dirname(os.path.abspath(__file__)) |
|
|
|
# Set output path relative to the script directory |
|
output_image_path = os.path.join(script_dir, "base_udav2_hf-code-test.png") |
|
checkpoint_path = os.path.join(script_dir, "checkpoints", "depth_anything_v2_vitb.safetensors") |
|
|
|
# Device selection: CUDA, MPS, or CPU |
|
if torch.cuda.is_available(): |
|
device = torch.device('cuda') |
|
elif torch.backends.mps.is_available(): |
|
device = torch.device('mps') |
|
else: |
|
device = torch.device('cpu') |
|
|
|
model = DepthAnythingV2(encoder='vitb', features=128, out_channels=[96, 192, 384, 768]) |
|
|
|
state_dict = load_file(checkpoint_path, device='cpu') |
|
|
|
model.load_state_dict(state_dict) |
|
model.to(device) |
|
model.eval() |
|
|
|
# Load the input image |
|
raw_img = cv2.imread(args.input_image_path) |
|
|
|
# Infer the depth map |
|
depth = model.infer_image(raw_img) # HxW raw depth map |
|
|
|
# Normalize the depth map to 0-255 for saving as an image |
|
depth_normalized = cv2.normalize(depth, None, 0, 255, cv2.NORM_MINMAX) |
|
depth_normalized = depth_normalized.astype(np.uint8) |
|
|
|
cv2.imwrite(output_image_path, depth_normalized) |
|
print(f"Depth map saved at {output_image_path}") |
|
``` |
|
|
|
## Citation |
|
|
|
If you find this project useful, please consider citing [MackinationsAi](https://github.com/MackinationsAi/) & the following: |
|
|
|
```bibtex |
|
@article{depth_anything_v2, |
|
title={Depth Anything V2}, |
|
author={Yang, Lihe & Kang, Bingyi & Huang, Zilong & Zhao, Zhen & Xu, Xiaogang & Feng, Jiashi & Zhao, Hengshuang}, |
|
journal={arXiv:2406.09414}, |
|
year={2024} |
|
} |
|
|
|
@inproceedings{depth_anything_v1, |
|
title={Depth Anything: Unleashing the Power of Large-Scale Unlabeled Data}, |
|
author={Yang, Lihe & Kang, Bingyi & Huang, Zilong & Xu, Xiaogang & Feng, Jiashi & Zhao, Hengshuang}, |
|
booktitle={CVPR}, |
|
year={2024} |
|
} |