kopia lustrzana https://github.com/OpenDroneMap/ODM
51 wiersze
1.7 KiB
Python
51 wiersze
1.7 KiB
Python
|
import os
|
||
|
from opendm.net import download
|
||
|
from opendm import log
|
||
|
import zipfile
|
||
|
import time
|
||
|
|
||
|
def get_model(namespace, url, version, name = "model.onnx"):
|
||
|
version = version.replace(".", "_")
|
||
|
|
||
|
base_dir = os.path.join(os.path.abspath(os.path.join(os.path.dirname(__file__), "..")), "storage", "models")
|
||
|
namespace_dir = os.path.join(base_dir, namespace)
|
||
|
versioned_dir = os.path.join(namespace_dir, version)
|
||
|
|
||
|
if not os.path.isdir(versioned_dir):
|
||
|
os.makedirs(versioned_dir, exist_ok=True)
|
||
|
|
||
|
# Check if we need to download it
|
||
|
model_file = os.path.join(versioned_dir, name)
|
||
|
if not os.path.isfile(model_file):
|
||
|
log.ODM_INFO("Downloading AI model from %s ..." % url)
|
||
|
|
||
|
last_update = 0
|
||
|
|
||
|
def callback(progress):
|
||
|
nonlocal last_update
|
||
|
|
||
|
time_has_elapsed = time.time() - last_update >= 2
|
||
|
|
||
|
if time_has_elapsed or int(progress) == 100:
|
||
|
log.ODM_INFO("Downloading: %s%%" % int(progress))
|
||
|
last_update = time.time()
|
||
|
|
||
|
try:
|
||
|
downloaded_file = download(url, versioned_dir, progress_callback=callback)
|
||
|
except Exception as e:
|
||
|
log.ODM_WARNING("Cannot download %s: %s" % (url, str(e)))
|
||
|
return None
|
||
|
|
||
|
if os.path.basename(downloaded_file).lower().endswith(".zip"):
|
||
|
log.ODM_INFO("Extracting %s ..." % downloaded_file)
|
||
|
with zipfile.ZipFile(downloaded_file, 'r') as z:
|
||
|
z.extractall(versioned_dir)
|
||
|
os.remove(downloaded_file)
|
||
|
|
||
|
if not os.path.isfile(model_file):
|
||
|
log.ODM_WARNING("Cannot find %s (is the URL to the AI model correct?)" % model_file)
|
||
|
return None
|
||
|
else:
|
||
|
return model_file
|
||
|
else:
|
||
|
return model_file
|