42 lines
1.0 KiB
Python
42 lines
1.0 KiB
Python
#!/usr/bin/python
|
|
# -*- coding: utf-8 -*-
|
|
# \file dfc_daps.py
|
|
# \brief TODO
|
|
# \author Florent Guiotte <florent.guiotte@gmail.com>
|
|
# \version 0.1
|
|
# \date 27 août 2018
|
|
#
|
|
# TODO details
|
|
|
|
import numpy as np
|
|
|
|
import sys
|
|
sys.path.append('..')
|
|
import ld2dap
|
|
|
|
def run(rasters, treshold=1e4, areas=None, sd=None, moi=None):
|
|
# Parse parameters type
|
|
treshold = float(treshold)
|
|
areas = None if areas is None else np.array(areas).astype(np.float).astype(np.int)
|
|
sd = None if sd is None else np.array(sd).astype(np.float)
|
|
moi = None if moi is None else np.array(moi).astype(np.float)
|
|
|
|
# Pipelines
|
|
loader = ld2dap.LoadTIFF(rasters)
|
|
dfc_filter = ld2dap.Treshold(treshold)
|
|
dfc_filter.input = loader
|
|
aps = ld2dap.AttributeProfiles(area=areas, sd=sd, moi=moi)
|
|
aps.input = dfc_filter
|
|
differential = ld2dap.Differential()
|
|
differential.input = aps
|
|
out_vectors = ld2dap.RawOutput()
|
|
out_vectors.input = differential
|
|
|
|
# Compute vectors
|
|
out_vectors.run()
|
|
|
|
return out_vectors.data
|
|
|
|
def version():
|
|
return 'v0.0'
|