Spaces:
Running
on
Zero
Running
on
Zero
# Copyright (C) 2024-present Naver Corporation. All rights reserved. | |
# Licensed under CC BY-NC-SA 4.0 (non-commercial use only). | |
# | |
# -------------------------------------------------------- | |
# modified from DUSt3R | |
from .linear_head import LinearPts3d, LinearPts3d_Desc, LinearPts3dPose | |
from .dpt_head import DPTPts3dPose | |
def head_factory( | |
head_type, | |
output_mode, | |
net, | |
has_conf=False, | |
has_depth=False, | |
has_rgb=False, | |
has_pose_conf=False, | |
has_pose=False, | |
): | |
""" " build a prediction head for the decoder""" | |
if head_type == "linear" and output_mode == "pts3d": | |
return LinearPts3d(net, has_conf, has_depth, has_rgb, has_pose_conf) | |
elif head_type == "linear" and output_mode == "pts3d+pose": | |
return LinearPts3dPose(net, has_conf, has_rgb, has_pose) | |
elif head_type == "linear" and output_mode.startswith("pts3d+desc"): | |
local_feat_dim = int(output_mode[10:]) | |
return LinearPts3d_Desc(net, has_conf, has_depth, local_feat_dim) | |
elif head_type == "dpt" and output_mode == "pts3d": | |
raise NotImplementedError(f"unexpected {head_type=} and {output_mode=}") | |
return create_dpt_head(net, has_conf=has_conf) | |
elif head_type == "dpt" and output_mode == "pts3d+pose": | |
return DPTPts3dPose(net, has_conf, has_rgb, has_pose) | |
else: | |
raise NotImplementedError(f"unexpected {head_type=} and {output_mode=}") | |