| |
| |
| |
| |
| |
| |
| from .linear_head import LinearPts3d |
| from .dpt_head import create_dpt_head, create_dpt_head_mask, create_dpt_head_depth |
|
|
| def head_factory(head_type, output_mode, net, has_conf=False): |
| """" build a prediction head for the decoder |
| """ |
| if head_type == 'linear' and output_mode == 'pts3d': |
| return LinearPts3d(net, has_conf) |
| if head_type == 'linear_depth' and output_mode == 'pts3d': |
| return LinearPts3d(net, has_conf,mode='depth') |
| if head_type == 'linear_classifier' and output_mode == 'pts3d': |
| return LinearPts3d(net, has_conf,mode='classifier') |
| elif head_type == 'dpt' and output_mode == 'pts3d': |
| return create_dpt_head(net, has_conf=has_conf) |
| elif head_type == 'dpt_depth' and output_mode == 'pts3d': |
| return create_dpt_head_depth(net, has_conf=has_conf) |
| elif head_type == 'dpt_mask' and output_mode == 'pts3d': |
| return create_dpt_head_mask(net, has_conf=has_conf) |
| else: |
| raise NotImplementedError(f"unexpected {head_type=} and {output_mode=}") |