2015-11-30 15:47:08 +00:00
|
|
|
import ecto
|
|
|
|
|
|
|
|
from opendm import io
|
|
|
|
from opendm import log
|
|
|
|
from opendm import system
|
|
|
|
from opendm import context
|
|
|
|
|
2015-12-10 11:01:41 +00:00
|
|
|
|
2016-02-26 18:50:12 +00:00
|
|
|
class ODMPmvsCell(ecto.Cell):
|
2015-12-10 11:01:41 +00:00
|
|
|
def declare_params(self, params):
|
|
|
|
params.declare("level", 'The level in the image pyramid that is used '
|
|
|
|
'for the computation', 1)
|
|
|
|
params.declare("csize", 'Cell size controls the density of reconstructions', 2)
|
|
|
|
params.declare("thresh", 'A patch reconstruction is accepted as a success '
|
2016-02-26 18:50:12 +00:00
|
|
|
'and kept, if its associcated photometric consistency '
|
|
|
|
'measure is above this threshold.', 0.7)
|
2015-12-10 11:01:41 +00:00
|
|
|
params.declare("wsize", 'pmvs samples wsize x wsize pixel colors from '
|
2016-02-26 18:50:12 +00:00
|
|
|
'each image to compute photometric consistency '
|
|
|
|
'score. For example, when wsize=7, 7x7=49 pixel '
|
|
|
|
'colors are sampled in each image. Increasing the '
|
|
|
|
'value leads to more stable reconstructions, but '
|
|
|
|
'the program becomes slower.', 7)
|
2015-12-10 11:01:41 +00:00
|
|
|
params.declare("min_imgs", 'Each 3D point must be visible in at least '
|
2016-02-26 18:50:12 +00:00
|
|
|
'minImageNum images for being reconstructed. 3 is '
|
|
|
|
'suggested in general.', 3)
|
2015-12-10 11:01:41 +00:00
|
|
|
params.declare("cores", 'The maximum number of cores to use in dense '
|
2016-02-26 18:50:12 +00:00
|
|
|
' reconstruction.', context.num_cores)
|
2015-11-30 15:47:08 +00:00
|
|
|
|
|
|
|
def declare_io(self, params, inputs, outputs):
|
2015-12-10 11:01:41 +00:00
|
|
|
inputs.declare("tree", "Struct with paths", [])
|
2015-11-30 15:47:08 +00:00
|
|
|
inputs.declare("args", "The application arguments.", {})
|
2015-12-10 11:01:41 +00:00
|
|
|
inputs.declare("reconstruction", "list of ODMReconstructions", [])
|
|
|
|
outputs.declare("reconstruction", "list of ODMReconstructions", [])
|
2015-11-30 15:47:08 +00:00
|
|
|
|
|
|
|
def process(self, inputs, outputs):
|
2016-02-26 18:50:12 +00:00
|
|
|
|
2016-02-29 14:45:00 +00:00
|
|
|
# Benchmarking
|
|
|
|
start_time = system.now_raw()
|
|
|
|
|
2015-11-30 15:47:08 +00:00
|
|
|
log.ODM_INFO('Running OMD PMVS Cell')
|
|
|
|
|
|
|
|
# get inputs
|
|
|
|
args = self.inputs.args
|
2015-12-10 11:01:41 +00:00
|
|
|
tree = self.inputs.tree
|
2015-11-30 15:47:08 +00:00
|
|
|
|
2015-12-01 16:52:18 +00:00
|
|
|
# check if we rerun cell or not
|
2016-03-08 18:26:58 +00:00
|
|
|
rerun_cell = (args.rerun is not None and
|
|
|
|
args.rerun == 'pmvs') or \
|
|
|
|
(args.rerun_all) or \
|
|
|
|
(args.rerun_from is not None and
|
|
|
|
'pmvs' in args.rerun_from)
|
2015-12-10 11:01:41 +00:00
|
|
|
|
|
|
|
if not io.file_exists(tree.pmvs_model) or rerun_cell:
|
|
|
|
log.ODM_DEBUG('Creating dense pointcloud in: %s' % tree.pmvs_model)
|
2015-12-01 16:52:18 +00:00
|
|
|
|
2015-12-10 11:01:41 +00:00
|
|
|
kwargs = {
|
|
|
|
'bin': context.cmvs_opts_path,
|
|
|
|
'prefix': tree.pmvs_rec_path,
|
|
|
|
'level': self.params.level,
|
|
|
|
'csize': self.params.csize,
|
|
|
|
'thresh': self.params.thresh,
|
|
|
|
'wsize': self.params.wsize,
|
|
|
|
'min_imgs': self.params.min_imgs,
|
|
|
|
'cores': self.params.cores
|
|
|
|
}
|
|
|
|
|
|
|
|
# generate pmvs2 options
|
2016-02-26 18:50:12 +00:00
|
|
|
system.run('{bin} {prefix}/ {level} {csize} {thresh} {wsize} '
|
2015-12-10 11:01:41 +00:00
|
|
|
'{min_imgs} {cores}'.format(**kwargs))
|
2015-11-30 15:47:08 +00:00
|
|
|
|
|
|
|
# run pmvs2
|
2016-02-26 18:50:12 +00:00
|
|
|
system.run('%s %s/ option-0000' %
|
|
|
|
(context.pmvs2_path, tree.pmvs_rec_path))
|
2015-12-10 11:01:41 +00:00
|
|
|
|
2015-11-30 15:47:08 +00:00
|
|
|
else:
|
2015-12-10 11:01:41 +00:00
|
|
|
log.ODM_WARNING('Found a valid PMVS file in %s' % tree.pmvs_model)
|
2015-11-30 15:47:08 +00:00
|
|
|
|
2016-03-08 18:26:58 +00:00
|
|
|
if args.time:
|
2016-02-29 14:45:00 +00:00
|
|
|
system.benchmark(start_time, tree.benchmarking, 'PMVS')
|
|
|
|
|
2016-03-08 18:26:58 +00:00
|
|
|
log.ODM_INFO('Running ODM PMVS Cell - Finished')
|
|
|
|
return ecto.OK if args.end_with != 'pmvs' else ecto.QUIT
|