2015-08-20 19:16:25 +00:00
|
|
|
#!/usr/bin/python
|
|
|
|
|
2015-12-22 12:29:13 +00:00
|
|
|
from opendm import log
|
|
|
|
from opendm import config
|
|
|
|
from opendm import system
|
2016-12-20 16:14:52 +00:00
|
|
|
from opendm import io
|
2019-05-15 21:04:09 +00:00
|
|
|
from opendm.progress import progressbc
|
2015-08-27 12:59:35 +00:00
|
|
|
|
2016-07-18 22:02:37 +00:00
|
|
|
import os
|
2019-04-22 19:14:39 +00:00
|
|
|
from pipes import quote
|
2015-08-27 12:59:35 +00:00
|
|
|
|
2019-05-06 19:42:49 +00:00
|
|
|
from stages.odm_app import ODMApp
|
2015-08-27 14:29:54 +00:00
|
|
|
|
2015-08-27 12:59:35 +00:00
|
|
|
if __name__ == '__main__':
|
2016-03-08 18:26:58 +00:00
|
|
|
args = config.config()
|
|
|
|
|
2020-03-18 19:29:43 +00:00
|
|
|
log.ODM_INFO('Initializing ODM - %s' % system.now())
|
2017-02-09 23:57:24 +00:00
|
|
|
|
2019-05-19 19:34:03 +00:00
|
|
|
# Print args
|
|
|
|
args_dict = vars(args)
|
2019-06-28 15:10:08 +00:00
|
|
|
log.ODM_INFO('==============')
|
2019-05-19 19:34:03 +00:00
|
|
|
for k in sorted(args_dict.keys()):
|
2020-03-18 19:29:43 +00:00
|
|
|
# Skip _is_set keys
|
|
|
|
if k.endswith("_is_set"):
|
|
|
|
continue
|
|
|
|
|
2019-05-19 19:34:03 +00:00
|
|
|
# Don't leak token
|
|
|
|
if k == 'sm_cluster' and args_dict[k] is not None:
|
2019-06-28 15:10:08 +00:00
|
|
|
log.ODM_INFO('%s: True' % k)
|
2019-05-19 19:34:03 +00:00
|
|
|
else:
|
2019-06-28 15:10:08 +00:00
|
|
|
log.ODM_INFO('%s: %s' % (k, args_dict[k]))
|
|
|
|
log.ODM_INFO('==============')
|
2019-05-19 19:34:03 +00:00
|
|
|
|
2019-05-15 21:04:09 +00:00
|
|
|
progressbc.set_project_name(args.name)
|
|
|
|
|
2017-03-27 19:41:51 +00:00
|
|
|
# Add project dir if doesn't exist
|
2017-03-07 19:58:40 +00:00
|
|
|
args.project_path = io.join_paths(args.project_path, args.name)
|
|
|
|
if not io.dir_exists(args.project_path):
|
2017-02-09 23:57:24 +00:00
|
|
|
log.ODM_WARNING('Directory %s does not exist. Creating it now.' % args.name)
|
2016-12-20 16:14:52 +00:00
|
|
|
system.mkdir_p(os.path.abspath(args.project_path))
|
2015-08-27 12:59:35 +00:00
|
|
|
|
2017-03-27 19:41:51 +00:00
|
|
|
# If user asks to rerun everything, delete all of the existing progress directories.
|
2016-07-18 22:02:37 +00:00
|
|
|
if args.rerun_all:
|
2019-06-28 15:10:08 +00:00
|
|
|
log.ODM_INFO("Rerun all -- Removing old data")
|
2019-04-22 19:14:39 +00:00
|
|
|
os.system("rm -rf " +
|
|
|
|
" ".join([
|
|
|
|
quote(os.path.join(args.project_path, "odm_georeferencing")),
|
2019-12-18 20:29:33 +00:00
|
|
|
quote(os.path.join(args.project_path, "odm_georeferencing_25d")),
|
2019-04-22 19:14:39 +00:00
|
|
|
quote(os.path.join(args.project_path, "odm_meshing")),
|
|
|
|
quote(os.path.join(args.project_path, "odm_orthophoto")),
|
|
|
|
quote(os.path.join(args.project_path, "odm_texturing")),
|
|
|
|
quote(os.path.join(args.project_path, "opensfm")),
|
|
|
|
quote(os.path.join(args.project_path, "odm_filterpoints")),
|
2019-12-18 20:29:33 +00:00
|
|
|
quote(os.path.join(args.project_path, "odm_texturing_25d")),
|
2019-04-22 19:14:39 +00:00
|
|
|
quote(os.path.join(args.project_path, "mve")),
|
2019-09-09 12:58:19 +00:00
|
|
|
quote(os.path.join(args.project_path, "entwine_pointcloud")),
|
2019-04-24 18:28:44 +00:00
|
|
|
quote(os.path.join(args.project_path, "submodels")),
|
|
|
|
]))
|
2019-04-22 19:14:39 +00:00
|
|
|
|
|
|
|
app = ODMApp(args)
|
|
|
|
app.execute()
|
2018-12-03 14:26:21 +00:00
|
|
|
|
2019-04-24 21:36:45 +00:00
|
|
|
# Do not show ASCII art for local submodels runs
|
2019-04-30 23:12:17 +00:00
|
|
|
if not "submodels/submodel_" in args.project_path:
|
2019-04-24 21:36:45 +00:00
|
|
|
log.ODM_INFO('MMMMMMMMMMMNNNMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMNNNMMMMMMMMMMM')
|
|
|
|
log.ODM_INFO('MMMMMMdo:..---../sNMMMMMMMMMMMMMMMMMMMMMMMMMMNs/..---..:odMMMMMM')
|
|
|
|
log.ODM_INFO('MMMMy-.odNMMMMMNy/`/mMMMMMMMMMMMMMMMMMMMMMMm/`/hNMMMMMNdo.-yMMMM')
|
|
|
|
log.ODM_INFO('MMN/`sMMMMMMMMMNNMm/`yMMMMMMMMMMMMMMMMMMMMy`/mMNNMMMMMMMMNs`/MMM')
|
|
|
|
log.ODM_INFO('MM/ hMMMMMMMMNs.+MMM/ dMMMMMMMMMMMMMMMMMMh +MMM+.sNMMMMMMMMh +MM')
|
|
|
|
log.ODM_INFO('MN /MMMMMMNo/./mMMMMN :MMMMMMMMMMMMMMMMMM: NMMMMm/./oNMMMMMM: NM')
|
|
|
|
log.ODM_INFO('Mm +MMMMMN+ `/MMMMMMM`-MMMMMMMMMMMMMMMMMM-`MMMMMMM:` oNMMMMM+ mM')
|
|
|
|
log.ODM_INFO('MM..NMMNs./mNMMMMMMMy sMMMMMMMMMMMMMMMMMMo hMMMMMMMNm/.sNMMN`-MM')
|
|
|
|
log.ODM_INFO('MMd`:mMNomMMMMMMMMMy`:MMMMMMMNmmmmNMMMMMMN:`hMMMMMMMMMdoNMm-`dMM')
|
|
|
|
log.ODM_INFO('MMMm:.omMMMMMMMMNh/ sdmmho/.`..`-``-/sddh+ /hNMMMMMMMMdo.:mMMM')
|
|
|
|
log.ODM_INFO('MMMMMd+--/osss+:-:/` ```:- .ym+ hmo``:-` `+:-:ossso/-:+dMMMMM')
|
|
|
|
log.ODM_INFO('MMMMMMMNmhysosydmNMo /ds`/NMM+ hMMd..dh. sMNmdysosyhmNMMMMMMM')
|
|
|
|
log.ODM_INFO('MMMMMMMMMMMMMMMMMMMs .:-:``hmmN+ yNmds -:.:`-NMMMMMMMMMMMMMMMMMM')
|
|
|
|
log.ODM_INFO('MMMMMMMMMMMMMMMMMMN.-mNm- //:::. -:://: +mMd`-NMMMMMMMMMMMMMMMMM')
|
|
|
|
log.ODM_INFO('MMMMMMMMMMMMMMMMMM+ dMMN -MMNNN+ yNNNMN :MMMs sMMMMMMMMMMMMMMMMM')
|
|
|
|
log.ODM_INFO('MMMMMMMMMMMMMMMMMM`.mmmy /mmmmm/ smmmmm``mmmh :MMMMMMMMMMMMMMMMM')
|
|
|
|
log.ODM_INFO('MMMMMMMMMMMMMMMMMM``:::- ./////. -:::::` :::: -MMMMMMMMMMMMMMMMM')
|
|
|
|
log.ODM_INFO('MMMMMMMMMMMMMMMMMM:`mNNd /NNNNN+ hNNNNN .NNNy +MMMMMMMMMMMMMMMMM')
|
|
|
|
log.ODM_INFO('MMMMMMMMMMMMMMMMMMd`/MMM.`ys+//. -/+oso +MMN.`mMMMMMMMMMMMMMMMMM')
|
|
|
|
log.ODM_INFO('MMMMMMMMMMMMMMMMMMMy /o:- `oyhd/ shys+ `-:s-`hMMMMMMMMMMMMMMMMMM')
|
|
|
|
log.ODM_INFO('MMMMMMMMNmdhhhdmNMMM` +d+ sMMM+ hMMN:`hh- sMMNmdhhhdmNMMMMMMMM')
|
|
|
|
log.ODM_INFO('MMMMMms:::/++//::+ho .+- /dM+ hNh- +/` -h+:://++/::/smMMMMM')
|
|
|
|
log.ODM_INFO('MMMN+./hmMMMMMMNds- ./oso:.``:. :-``.:os+- -sdNMMMMMMmy:.oNMMM')
|
|
|
|
log.ODM_INFO('MMm-.hMNhNMMMMMMMMNo`/MMMMMNdhyyyyhhdNMMMM+`oNMMMMMMMMNhNMh.-mMM')
|
|
|
|
log.ODM_INFO('MM:`mMMN/-sNNMMMMMMMo yMMMMMMMMMMMMMMMMMMy sMMMMMMMNNs-/NMMm`:MM')
|
|
|
|
log.ODM_INFO('Mm /MMMMMd/.-oMMMMMMN :MMMMMMMMMMMMMMMMMM-`MMMMMMMo-./dMMMMM/ NM')
|
|
|
|
log.ODM_INFO('Mm /MMMMMMm:-`sNMMMMN :MMMMMMMMMMMMMMMMMM-`MMMMMNs`-/NMMMMMM/ NM')
|
|
|
|
log.ODM_INFO('MM:`mMMMMMMMMd/-sMMMo yMMMMMMMMMMMMMMMMMMy sMMMs-/dMMMMMMMMd`:MM')
|
|
|
|
log.ODM_INFO('MMm-.hMMMMMMMMMdhMNo`+MMMMMMMMMMMMMMMMMMMM+`oNMhdMMMMMMMMMh.-mMM')
|
|
|
|
log.ODM_INFO('MMMNo./hmNMMMMMNms--yMMMMMMMMMMMMMMMMMMMMMMy--smNMMMMMNmy/.oNMMM')
|
|
|
|
log.ODM_INFO('MMMMMms:-:/+++/:-+hMMMMMMMMMMMMMMMMMMMMMMMMMNh+-:/+++/:-:smMMMMM')
|
|
|
|
log.ODM_INFO('MMMMMMMMNdhhyhdmMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMMmdhyhhmNMMMMMMMM')
|
|
|
|
log.ODM_INFO('MMMMMMMMMMMMMMMNNNNNMMMMMMNNNNNNMMMMMMMMNNMMMMMMMNNMMMMMMMMMMMMM')
|
|
|
|
log.ODM_INFO('MMMMMMMMMMMMMh/-...-+dMMMm......:+hMMMMs../MMMMMo..sMMMMMMMMMMMM')
|
|
|
|
log.ODM_INFO('MMMMMMMMMMMM/ /yhy- sMMm -hhy/ :NMM+ oMMMy /MMMMMMMMMMMM')
|
|
|
|
log.ODM_INFO('MMMMMMMMMMMy /MMMMN` NMm /MMMMo +MM: .` yMd``` :MMMMMMMMMMMM')
|
|
|
|
log.ODM_INFO('MMMMMMMMMMM+ sMMMMM: hMm /MMMMd -MM- /s `h.`d- -MMMMMMMMMMMM')
|
|
|
|
log.ODM_INFO('MMMMMMMMMMMs +MMMMM. mMm /MMMMy /MM. +M/ yM: `MMMMMMMMMMMM')
|
|
|
|
log.ODM_INFO('MMMMMMMMMMMN- smNm/ +MMm :NNdo` .mMM` oMM+/yMM/ MMMMMMMMMMMM')
|
|
|
|
log.ODM_INFO('MMMMMMMMMMMMNo- `:yMMMm `:sNMMM` sMMMMMMM+ NMMMMMMMMMMM')
|
|
|
|
log.ODM_INFO('MMMMMMMMMMMMMMMNmmNMMMMMMMNmmmmNMMMMMMMNNMMMMMMMMMNNMMMMMMMMMMMM')
|
2016-02-26 18:50:12 +00:00
|
|
|
log.ODM_INFO('OpenDroneMap app finished - %s' % system.now())
|