kopia lustrzana https://github.com/OpenDroneMap/ODM
Update prematching args and other args
rodzic
aeb2b243b1
commit
07a6270bcc
|
@ -50,56 +50,49 @@ parser.add_argument('--min-num-features',
|
||||||
type=int,
|
type=int,
|
||||||
help=('Minimum number of features to extract per image. '
|
help=('Minimum number of features to extract per image. '
|
||||||
'More features leads to better results but slower '
|
'More features leads to better results but slower '
|
||||||
'execution.'))
|
'execution. Default: %(default)s'))
|
||||||
|
|
||||||
parser.add_argument('--matcher-threshold',
|
parser.add_argument('--matcher-threshold',
|
||||||
metavar='<percent>',
|
metavar='<percent>',
|
||||||
default=2.0,
|
default=2.0,
|
||||||
type=float,
|
type=float,
|
||||||
help=('Ignore matched keypoints if the two images share '
|
help=('Ignore matched keypoints if the two images share '
|
||||||
'less than <float> percent of keypoints'))
|
'less than <float> percent of keypoints. Default:'
|
||||||
|
' $(default)s'))
|
||||||
|
|
||||||
parser.add_argument('--matcher-ratio',
|
parser.add_argument('--matcher-ratio',
|
||||||
metavar='<float>',
|
metavar='<float>',
|
||||||
default=0.6,
|
default=0.6,
|
||||||
type=float,
|
type=float,
|
||||||
help=('Ratio of the distance to the next best matched '
|
help=('Ratio of the distance to the next best matched '
|
||||||
'keypoint'))
|
'keypoint. Default: %(default)s'))
|
||||||
|
|
||||||
parser.add_argument('--matcher-preselect',
|
parser.add_argument('--matcher-neighbors',
|
||||||
type=bool,
|
|
||||||
metavar='',
|
|
||||||
default=False,
|
|
||||||
help=('use GPS exif data, if available, to match each '
|
|
||||||
'image only with its k-nearest neighbors, or all '
|
|
||||||
'images within a certain distance threshold'))
|
|
||||||
|
|
||||||
parser.add_argument('--matcher-useKnn',
|
|
||||||
type=bool,
|
|
||||||
metavar='',
|
|
||||||
default=True,
|
|
||||||
help=('use GPS exif data, if available, to match each '
|
|
||||||
'image only with its k-nearest neighbors, or all '
|
|
||||||
'images within a certain distance threshold'))
|
|
||||||
|
|
||||||
parser.add_argument('--matcher-kDistance',
|
|
||||||
metavar='<integer>',
|
|
||||||
default=20,
|
|
||||||
type=int,
|
type=int,
|
||||||
help='')
|
|
||||||
|
|
||||||
parser.add_argument('--matcher-k',
|
|
||||||
metavar='<integer>',
|
metavar='<integer>',
|
||||||
default=8,
|
default=8,
|
||||||
|
help='Number of nearest images to pre-match based on GPS '
|
||||||
|
'exif data. Set to 0 to skip pre-matching. '
|
||||||
|
'Neighbors works together with Distance parameter, '
|
||||||
|
'set both to 0 to not use pre-matching. OpenSFM '
|
||||||
|
'uses both parameters at the same time, Bundler '
|
||||||
|
'uses only one which has value, prefering the '
|
||||||
|
'Neighbors parameter. Default: %(default)s')
|
||||||
|
|
||||||
|
parser.add_argument('--matcher-distance',
|
||||||
|
metavar='<integer>',
|
||||||
|
default=0,
|
||||||
type=int,
|
type=int,
|
||||||
help='Number of k-nearest images to match '
|
help='Distance threshold in meters to find pre-matching '
|
||||||
'when using OpenSfM')
|
'images based on GPS exif data. Set to 0 to skip '
|
||||||
|
'pre-matching. Default: %(default)s')
|
||||||
|
|
||||||
parser.add_argument('--cmvs-maxImages',
|
parser.add_argument('--cmvs-maxImages',
|
||||||
metavar='<integer>',
|
metavar='<integer>',
|
||||||
default=500,
|
default=500,
|
||||||
type=int,
|
type=int,
|
||||||
help='The maximum number of images per cluster')
|
help='The maximum number of images per cluster. '
|
||||||
|
'Default: %(default)s')
|
||||||
|
|
||||||
parser.add_argument('--pmvs-level',
|
parser.add_argument('--pmvs-level',
|
||||||
metavar='<positive integer>',
|
metavar='<positive integer>',
|
||||||
|
@ -108,32 +101,33 @@ parser.add_argument('--pmvs-level',
|
||||||
help=('The level in the image pyramid that is used '
|
help=('The level in the image pyramid that is used '
|
||||||
'for the computation. see '
|
'for the computation. see '
|
||||||
'http://www.di.ens.fr/pmvs/documentation.html for '
|
'http://www.di.ens.fr/pmvs/documentation.html for '
|
||||||
'more pmvs documentation'))
|
'more pmvs documentation. Default: %(default)s'))
|
||||||
|
|
||||||
parser.add_argument('--pmvs-csize',
|
parser.add_argument('--pmvs-csize',
|
||||||
metavar='< positive integer>',
|
metavar='< positive integer>',
|
||||||
default=2,
|
default=2,
|
||||||
type=int,
|
type=int,
|
||||||
help='Cell size controls the density of reconstructions')
|
help='Cell size controls the density of reconstructions'
|
||||||
|
'Default: %(default)s')
|
||||||
|
|
||||||
parser.add_argument('--pmvs-threshold',
|
parser.add_argument('--pmvs-threshold',
|
||||||
metavar='<float: -1.0 <= x <= 1.0>',
|
metavar='<float: -1.0 <= x <= 1.0>',
|
||||||
default=0.7,
|
default=0.7,
|
||||||
type=float,
|
type=float,
|
||||||
help=('A patch reconstruction is accepted as a success '
|
help=('A patch reconstruction is accepted as a success '
|
||||||
'and kept, if its associcated photometric consistency '
|
'and kept if its associated photometric consistency '
|
||||||
'measure is above this threshold.'))
|
'measure is above this threshold. Default: %(default)s'))
|
||||||
|
|
||||||
parser.add_argument('--pmvs-wsize',
|
parser.add_argument('--pmvs-wsize',
|
||||||
metavar='<positive integer>',
|
metavar='<positive integer>',
|
||||||
default=7,
|
default=7,
|
||||||
type=int,
|
type=int,
|
||||||
help=('pmvs samples wsize x wsize pixel colors from '
|
help='pmvs samples wsize x wsize pixel colors from '
|
||||||
'each image to compute photometric consistency '
|
'each image to compute photometric consistency '
|
||||||
'score. For example, when wsize=7, 7x7=49 pixel '
|
'score. For example, when wsize=7, 7x7=49 pixel '
|
||||||
'colors are sampled in each image. Increasing the '
|
'colors are sampled in each image. Increasing the '
|
||||||
'value leads to more stable reconstructions, but '
|
'value leads to more stable reconstructions, but '
|
||||||
'the program becomes slower.'))
|
'the program becomes slower. Default: %(default)s')
|
||||||
|
|
||||||
parser.add_argument('--pmvs-minImageNum',
|
parser.add_argument('--pmvs-minImageNum',
|
||||||
metavar='<positive integer>',
|
metavar='<positive integer>',
|
||||||
|
@ -141,20 +135,21 @@ parser.add_argument('--pmvs-minImageNum',
|
||||||
type=int,
|
type=int,
|
||||||
help=('Each 3D point must be visible in at least '
|
help=('Each 3D point must be visible in at least '
|
||||||
'minImageNum images for being reconstructed. 3 is '
|
'minImageNum images for being reconstructed. 3 is '
|
||||||
'suggested in general.'))
|
'suggested in general. Default: %(default)s'))
|
||||||
|
|
||||||
parser.add_argument('--pmvs-num-cores',
|
parser.add_argument('--pmvs-num-cores',
|
||||||
metavar='<positive integer>',
|
metavar='<positive integer>',
|
||||||
default=1,
|
default=1,
|
||||||
type=int,
|
type=int,
|
||||||
help=('The maximum number of cores to use in dense '
|
help=('The maximum number of cores to use in dense '
|
||||||
'reconstruction.'))
|
'reconstruction. Default: %(default)s'))
|
||||||
|
|
||||||
parser.add_argument('--odm_meshing-maxVertexCount',
|
parser.add_argument('--odm_meshing-maxVertexCount',
|
||||||
metavar='<positive integer>',
|
metavar='<positive integer>',
|
||||||
default=100000,
|
default=100000,
|
||||||
type=int,
|
type=int,
|
||||||
help='The maximum vertex count of the output mesh')
|
help=('The maximum vertex count of the output mesh '
|
||||||
|
'Default: %(default)s'))
|
||||||
|
|
||||||
parser.add_argument('--odm_meshing-octreeDepth',
|
parser.add_argument('--odm_meshing-octreeDepth',
|
||||||
metavar='<positive integer>',
|
metavar='<positive integer>',
|
||||||
|
@ -162,14 +157,14 @@ parser.add_argument('--odm_meshing-octreeDepth',
|
||||||
type=int,
|
type=int,
|
||||||
help=('Oct-tree depth used in the mesh reconstruction, '
|
help=('Oct-tree depth used in the mesh reconstruction, '
|
||||||
'increase to get more vertices, recommended '
|
'increase to get more vertices, recommended '
|
||||||
'values are 8-12'))
|
'values are 8-12. Default: %(default)s'))
|
||||||
|
|
||||||
parser.add_argument('--odm_meshing-samplesPerNode',
|
parser.add_argument('--odm_meshing-samplesPerNode',
|
||||||
metavar='<float >= 1.0>',
|
metavar='<float >= 1.0>',
|
||||||
default=1,
|
default=1.0,
|
||||||
type=float,
|
type=float,
|
||||||
help=('Number of points per octree node, recommended '
|
help=('Number of points per octree node, recommended '
|
||||||
'value: 1.0'))
|
'and default value: %(default)s'))
|
||||||
|
|
||||||
parser.add_argument('--odm_meshing-solverDivide',
|
parser.add_argument('--odm_meshing-solverDivide',
|
||||||
metavar='<positive integer>',
|
metavar='<positive integer>',
|
||||||
|
@ -178,40 +173,44 @@ parser.add_argument('--odm_meshing-solverDivide',
|
||||||
help=('Oct-tree depth at which the Laplacian equation '
|
help=('Oct-tree depth at which the Laplacian equation '
|
||||||
'is solved in the surface reconstruction step. '
|
'is solved in the surface reconstruction step. '
|
||||||
'Increasing this value increases computation '
|
'Increasing this value increases computation '
|
||||||
'times slightly but helps reduce memory usage.'))
|
'times slightly but helps reduce memory usage. '
|
||||||
|
'Default: %(default)s'))
|
||||||
|
|
||||||
parser.add_argument('--odm_texturing-textureResolution',
|
parser.add_argument('--odm_texturing-textureResolution',
|
||||||
metavar='<positive integer>',
|
metavar='<positive integer>',
|
||||||
default=4096,
|
default=4096,
|
||||||
type=int,
|
type=int,
|
||||||
help=('The resolution of the output textures. Must be '
|
help=('The resolution of the output textures. Must be '
|
||||||
'greater than textureWithSize.'))
|
'greater than textureWithSize. Default: %(default)s'))
|
||||||
|
|
||||||
parser.add_argument('--odm_texturing-textureWithSize',
|
parser.add_argument('--odm_texturing-textureWithSize',
|
||||||
metavar='<positive integer>',
|
metavar='<positive integer>',
|
||||||
default=3600,
|
default=3600,
|
||||||
type=int,
|
type=int,
|
||||||
help=('The resolution to rescale the images performing '
|
help=('The resolution to rescale the images performing '
|
||||||
'the texturing.'))
|
'the texturing. Default: %(default)s'))
|
||||||
|
|
||||||
parser.add_argument('--odm_georeferencing-gcpFile',
|
parser.add_argument('--odm_georeferencing-gcpFile',
|
||||||
metavar='<path string>',
|
metavar='<path string>',
|
||||||
default='gcp_list.txt',
|
default='gcp_list.txt',
|
||||||
help=('path to the file containing the ground control '
|
help=('path to the file containing the ground control '
|
||||||
'points used for georeferencing.The file needs to '
|
'points used for georeferencing. Default: '
|
||||||
|
'%(default)s. The file needs to '
|
||||||
'be on the following line format: \neasting '
|
'be on the following line format: \neasting '
|
||||||
'northing height pixelrow pixelcol imagename'))
|
'northing height pixelrow pixelcol imagename'))
|
||||||
|
|
||||||
parser.add_argument('--odm_georeferencing-useGcp',
|
parser.add_argument('--odm_georeferencing-useGcp',
|
||||||
type = bool,
|
action = 'store_true',
|
||||||
default = False,
|
default = False,
|
||||||
help = 'set to true for enabling GCPs from the file above')
|
help = 'Enabling GCPs from the file above. The GCP file '
|
||||||
|
'is not used by default.')
|
||||||
|
|
||||||
parser.add_argument('--odm_orthophoto-resolution',
|
parser.add_argument('--odm_orthophoto-resolution',
|
||||||
metavar='<float > 0.0>',
|
metavar='<float > 0.0>',
|
||||||
default=20.0,
|
default=20.0,
|
||||||
type=float,
|
type=float,
|
||||||
help=('Orthophoto ground resolution in pixels/meter'))
|
help=('Orthophoto ground resolution in pixels/meter'
|
||||||
|
'Default: %(default)s'))
|
||||||
|
|
||||||
parser.add_argument('--zip-results',
|
parser.add_argument('--zip-results',
|
||||||
action='store_true',
|
action='store_true',
|
||||||
|
|
|
@ -38,7 +38,8 @@ class ODMApp(ecto.BlackBox):
|
||||||
feature_process_size=p.args['resize_to'],
|
feature_process_size=p.args['resize_to'],
|
||||||
feature_min_frames=p.args['min_num_features'],
|
feature_min_frames=p.args['min_num_features'],
|
||||||
processes=context.num_cores,
|
processes=context.num_cores,
|
||||||
matching_gps_neighbors=p.args['matcher_k']),
|
matching_gps_neighbors=p.args['matcher_neighbors'],
|
||||||
|
matching_gps_distance=p.args['matcher_distance']),
|
||||||
'cmvs': ODMCmvsCell(max_images=p.args['cmvs_maxImages']),
|
'cmvs': ODMCmvsCell(max_images=p.args['cmvs_maxImages']),
|
||||||
'pmvs': ODMPmvsCell(level=p.args['pmvs_level'],
|
'pmvs': ODMPmvsCell(level=p.args['pmvs_level'],
|
||||||
csize=p.args['pmvs_csize'],
|
csize=p.args['pmvs_csize'],
|
||||||
|
|
|
@ -8,10 +8,11 @@ from opendm import context
|
||||||
class ODMOpenSfMCell(ecto.Cell):
|
class ODMOpenSfMCell(ecto.Cell):
|
||||||
def declare_params(self, params):
|
def declare_params(self, params):
|
||||||
params.declare("use_exif_size", "The application arguments.", False)
|
params.declare("use_exif_size", "The application arguments.", False)
|
||||||
params.declare("feature_process_size", "The application arguments.", False)
|
params.declare("feature_process_size", "The application arguments.", 2400)
|
||||||
params.declare("feature_min_frames", "The application arguments.", 0)
|
params.declare("feature_min_frames", "The application arguments.", 4000)
|
||||||
params.declare("processes", "The application arguments.", 0)
|
params.declare("processes", "The application arguments.", context.num_cores)
|
||||||
params.declare("matching_gps_neighbors", "The application arguments.", 0)
|
params.declare("matching_gps_neighbors", "The application arguments.", 8)
|
||||||
|
params.declare("matching_gps_distance", "The application arguments.", 0)
|
||||||
|
|
||||||
def declare_io(self, params, inputs, outputs):
|
def declare_io(self, params, inputs, outputs):
|
||||||
inputs.declare("tree", "Struct with paths", [])
|
inputs.declare("tree", "Struct with paths", [])
|
||||||
|
@ -59,6 +60,9 @@ class ODMOpenSfMCell(ecto.Cell):
|
||||||
"matching_gps_neighbors: %s" % self.params.matching_gps_neighbors
|
"matching_gps_neighbors: %s" % self.params.matching_gps_neighbors
|
||||||
]
|
]
|
||||||
|
|
||||||
|
if args['matcher_distance']>0:
|
||||||
|
config.append("matching_gps_distance: %s" % self.params.matching_gps_distance)
|
||||||
|
|
||||||
# write config file
|
# write config file
|
||||||
config_filename = io.join_paths(tree.opensfm, 'config.yaml')
|
config_filename = io.join_paths(tree.opensfm, 'config.yaml')
|
||||||
with open(config_filename, 'w') as fout:
|
with open(config_filename, 'w') as fout:
|
||||||
|
|
Ładowanie…
Reference in New Issue