Spaces:
Running
Running
from pathlib import Path | |
import argparse | |
from ... import extract_features, match_features | |
from ... import pairs_from_poses, triangulation | |
from .utils import get_timestamps, delete_unused_images | |
from .utils import build_empty_colmap_model | |
parser = argparse.ArgumentParser() | |
parser.add_argument( | |
"--dataset", | |
type=Path, | |
default="datasets/4Seasons", | |
help="Path to the dataset, default: %(default)s", | |
) | |
parser.add_argument( | |
"--outputs", | |
type=Path, | |
default="outputs/4Seasons", | |
help="Path to the output directory, default: %(default)s", | |
) | |
args = parser.parse_args() | |
ref_dir = args.dataset / "reference" | |
assert ref_dir.exists(), f"{ref_dir} does not exist" | |
ref_images = ref_dir / "undistorted_images" | |
output_dir = args.outputs | |
output_dir.mkdir(exist_ok=True, parents=True) | |
ref_sfm_empty = output_dir / "sfm_reference_empty" | |
ref_sfm = output_dir / "sfm_superpoint+superglue" | |
num_ref_pairs = 20 | |
ref_pairs = output_dir / f"pairs-db-dist{num_ref_pairs}.txt" | |
fconf = extract_features.confs["superpoint_max"] | |
mconf = match_features.confs["superglue"] | |
# Only reference images that have a pose are used in the pipeline. | |
# To save time in feature extraction, we delete unsused images. | |
delete_unused_images(ref_images, get_timestamps(ref_dir / "poses.txt", 0)) | |
# Build an empty COLMAP model containing only camera and images | |
# from the provided poses and intrinsics. | |
build_empty_colmap_model(ref_dir, ref_sfm_empty) | |
# Match reference images that are spatially close. | |
pairs_from_poses.main(ref_sfm_empty, ref_pairs, num_ref_pairs) | |
# Extract, match, and triangulate the reference SfM model. | |
ffile = extract_features.main(fconf, ref_images, output_dir) | |
mfile = match_features.main(mconf, ref_pairs, fconf["output"], output_dir) | |
triangulation.main(ref_sfm, ref_sfm_empty, ref_images, ref_pairs, ffile, mfile) | |