|
import argparse |
|
from pathlib import Path |
|
|
|
from ... import extract_features, match_features, pairs_from_poses, triangulation |
|
from .utils import build_empty_colmap_model, delete_unused_images, get_timestamps |
|
|
|
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"] |
|
|
|
|
|
|
|
delete_unused_images(ref_images, get_timestamps(ref_dir / "poses.txt", 0)) |
|
|
|
|
|
|
|
build_empty_colmap_model(ref_dir, ref_sfm_empty) |
|
|
|
|
|
pairs_from_poses.main(ref_sfm_empty, ref_pairs, num_ref_pairs) |
|
|
|
|
|
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) |
|
|