File: LidarToolsAlgorithmProvider.py

package info (click to toggle)
qgis 2.18.28%2Bdfsg-2
  • links: PTS, VCS
  • area: main
  • in suites: buster
  • size: 1,007,948 kB
  • sloc: cpp: 671,774; python: 158,539; xml: 35,690; ansic: 8,346; sh: 1,766; perl: 1,669; sql: 999; yacc: 836; lex: 461; makefile: 292
file content (250 lines) | stat: -rw-r--r-- 10,902 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
# -*- coding: utf-8 -*-

"""
***************************************************************************
    LidarToolsAlgorithmProvider.py
    ---------------------
    Date                 : August 2012
    Copyright            : (C) 2012 by Victor Olaya
    Email                : volayaf at gmail dot com
    ---------------------
    Date                 : April, October 2014 and May 2016
    Copyright            : (C) 2014 - 2016 by Martin Isenburg
    Email                : martin near rapidlasso point com
    ---------------------
    Date                 : June 2014
    Copyright            : (C) 2014 by Agresta S. Coop
    Email                : iescamochero at agresta dot org
***************************************************************************
*                                                                         *
*   This program is free software; you can redistribute it and/or modify  *
*   it under the terms of the GNU General Public License as published by  *
*   the Free Software Foundation; either version 2 of the License, or     *
*   (at your option) any later version.                                   *
*                                                                         *
***************************************************************************
"""
__author__ = 'Victor Olaya'
__date__ = 'August 2012'
__copyright__ = '(C) 2012, Victor Olaya'

# This will get replaced with a git SHA1 when you do a git archive

__revision__ = '$Format:%H$'

import os
from qgis.PyQt.QtGui import QIcon
from processing.core.AlgorithmProvider import AlgorithmProvider
from processing.core.ProcessingConfig import ProcessingConfig, Setting
from processing.tools.system import isWindows

from .lastools.LAStoolsUtils import LAStoolsUtils
from .lastools.lasground import lasground
from .lastools.lasheight import lasheight
from .lastools.lasclassify import lasclassify
from .lastools.laszip import laszip
from .lastools.lasindex import lasindex
from .lastools.lasclip import lasclip
from .lastools.lasquery import lasquery
from .lastools.lascolor import lascolor
from .lastools.lasthin import lasthin
from .lastools.lasnoise import lasnoise
from .lastools.lassort import lassort
from .lastools.lastile import lastile
from .lastools.lasgrid import lasgrid
from .lastools.lasview import lasview
from .lastools.lasboundary import lasboundary
from .lastools.lasinfo import lasinfo
from .lastools.las2dem import las2dem
from .lastools.blast2dem import blast2dem
from .lastools.las2iso import las2iso
from .lastools.las2tin import las2tin
from .lastools.las2las_filter import las2las_filter
from .lastools.las2las_project import las2las_project
from .lastools.las2las_transform import las2las_transform
from .lastools.blast2iso import blast2iso
from .lastools.lasprecision import lasprecision
from .lastools.lasvalidate import lasvalidate
from .lastools.lasduplicate import lasduplicate
from .lastools.las2txt import las2txt
from .lastools.txt2las import txt2las
from .lastools.las2shp import las2shp
from .lastools.shp2las import shp2las
from .lastools.lasmerge import lasmerge
from .lastools.lassplit import lassplit
from .lastools.lascanopy import lascanopy
from .lastools.lasoverage import lasoverage
from .lastools.lasoverlap import lasoverlap
from .lastools.laspublish import laspublish
from .lastools.lasground_new import lasground_new
from .lastools.lascontrol import lascontrol
from .lastools.lasdiff import lasdiff
from .lastools.lasheight_classify import lasheight_classify

from .lastools.lastilePro import lastilePro
from .lastools.lasgroundPro import lasgroundPro
from .lastools.las2demPro import las2demPro
from .lastools.lasheightPro import lasheightPro
from .lastools.laszipPro import laszipPro
from .lastools.lasgridPro import lasgridPro
from .lastools.lasduplicatePro import lasduplicatePro
from .lastools.lassortPro import lassortPro
from .lastools.lasclassifyPro import lasclassifyPro
from .lastools.lasthinPro import lasthinPro
from .lastools.lasnoisePro import lasnoisePro
from .lastools.lasindexPro import lasindexPro
from .lastools.lascanopyPro import lascanopyPro
from .lastools.blast2demPro import blast2demPro
from .lastools.lasboundaryPro import lasboundaryPro
from .lastools.lasinfoPro import lasinfoPro
from .lastools.las2lasPro_filter import las2lasPro_filter
from .lastools.las2lasPro_project import las2lasPro_project
from .lastools.las2lasPro_transform import las2lasPro_transform
from .lastools.lasoveragePro import lasoveragePro
from .lastools.txt2lasPro import txt2lasPro
from .lastools.las2txtPro import las2txtPro
from .lastools.blast2isoPro import blast2isoPro
from .lastools.lasvalidatePro import lasvalidatePro
from .lastools.lasmergePro import lasmergePro
from .lastools.lasviewPro import lasviewPro
from .lastools.lasoverlapPro import lasoverlapPro
from .lastools.laspublishPro import laspublishPro
from .lastools.lasgroundPro_new import lasgroundPro_new
from .lastools.lasheightPro_classify import lasheightPro_classify

from .lastools.flightlinesToDTMandDSM import flightlinesToDTMandDSM
from .lastools.flightlinesToCHM import flightlinesToCHM
from .lastools.flightlinesToSingleCHMpitFree import flightlinesToSingleCHMpitFree
from .lastools.hugeFileClassify import hugeFileClassify
from .lastools.hugeFileGroundClassify import hugeFileGroundClassify
from .lastools.hugeFileNormalize import hugeFileNormalize

from .fusion.OpenViewerAction import OpenViewerAction
from .fusion.ASCII2DTM import ASCII2DTM
from .fusion.CanopyMaxima import CanopyMaxima
from .fusion.CanopyModel import CanopyModel
from .fusion.Catalog import Catalog
from .fusion.ClipData import ClipData
from .fusion.CloudMetrics import CloudMetrics
from .fusion.Cover import Cover
from .fusion.DTM2TIF import DTM2TIF
from .fusion.DTM2ASCII import DTM2ASCII
from .fusion.FirstLastReturn import FirstLastReturn
from .fusion.GridMetrics import GridMetrics
from .fusion.GridSurfaceCreate import GridSurfaceCreate
from .fusion.TinSurfaceCreate import TinSurfaceCreate
from .fusion.Csv2Grid import Csv2Grid
from .fusion.GroundFilter import GroundFilter
from .fusion.MergeData import MergeData
from .fusion.FilterData import FilterData
from .fusion.PolyClipData import PolyClipData
from .fusion.ImageCreate import ImageCreate
from .fusion.IntensityImage import IntensityImage
from .fusion.FusionUtils import FusionUtils


class LidarToolsAlgorithmProvider(AlgorithmProvider):

    def __init__(self):
        AlgorithmProvider.__init__(self)
        self.activate = False

    def _loadAlgorithms(self):
        self.algs = []

        # LAStools for processing single files

        if (isWindows() or LAStoolsUtils.hasWine()):
            lastools = [
                lasground(), lasheight(), lasclassify(), lasclip(), lastile(),
                lascolor(), lasgrid(), las2dem(), blast2dem(), las2iso(), blast2iso(),
                lasview(), lasboundary(), lasinfo(), lasprecision(), las2tin(),
                lasvalidate(), lasduplicate(), las2txt(), txt2las(), laszip(),
                lasindex(), lasthin(), lassort(), lascanopy(), lasmerge(),
                las2shp(), shp2las(), lasnoise(), lassplit(), las2las_filter(),
                las2las_project(), las2las_transform(), lasoverage(), lasoverlap(),
                lasquery(), laspublish(), lasground_new(), lascontrol(), lasdiff(),
                lasheight_classify()
            ]
        else:
            lastools = [
                lasinfo(), lasprecision(), lasvalidate(), las2txt(), txt2las(),
                laszip(), lasindex(), lasmerge(), las2las_filter(), las2las_project(),
                las2las_transform(), lasquery(), lasdiff()
            ]
        self.algs.extend(lastools)

        # LAStools Production for processing folders of files

        if (isWindows() or LAStoolsUtils.hasWine()):
            lastoolsPro = [
                lastilePro(), lasgroundPro(), las2demPro(), lasheightPro(), laszipPro(),
                lasduplicatePro(), lasgridPro(), lassortPro(), lasclassifyPro(), lasthinPro(),
                lasnoisePro(), lasindexPro(), lascanopyPro(), blast2demPro(), lasboundaryPro(),
                lasinfoPro(), las2lasPro_filter(), las2lasPro_project(), las2lasPro_transform(),
                lasoveragePro(), txt2lasPro(), las2txtPro(), blast2isoPro(), lasvalidatePro(),
                lasmergePro(), lasviewPro(), lasoverlapPro(), laspublishPro(), lasgroundPro_new(),
                lasheightPro_classify()
            ]
        else:
            lastoolsPro = [
                laszipPro(), lasindexPro(), lasinfoPro(), las2lasPro_filter(), las2lasPro_project(),
                las2lasPro_transform(), txt2lasPro(), las2txtPro(), lasvalidatePro(), lasmergePro()
            ]
        self.algs.extend(lastoolsPro)

        # some examples for LAStools Pipelines

        if (isWindows() or LAStoolsUtils.hasWine()):
            lastoolsPipe = [
                flightlinesToDTMandDSM(), flightlinesToCHM(), flightlinesToSingleCHMpitFree(), hugeFileClassify(),
                hugeFileGroundClassify(), hugeFileNormalize()
            ]
        else:
            lastoolsPipe = []
        self.algs.extend(lastoolsPipe)

        # FUSION

        if isWindows():
            self.actions.append(OpenViewerAction())
            fusiontools = [
                Catalog(), CloudMetrics(), CanopyMaxima(), CanopyModel(), ClipData(),
                Csv2Grid(), Cover(), FilterData(), GridMetrics(), GroundFilter(),
                GridSurfaceCreate(), MergeData(), TinSurfaceCreate(), PolyClipData(),
                DTM2TIF(), DTM2ASCII(), FirstLastReturn(), ASCII2DTM(), ImageCreate(),
                IntensityImage()
            ]
            for alg in fusiontools:
                alg.group, alg.i18n_group = alg.trAlgorithm('Fusion')
            self.algs.extend(fusiontools)

    def initializeSettings(self):
        AlgorithmProvider.initializeSettings(self)
        ProcessingConfig.addSetting(Setting(
            self.getDescription(),
            LAStoolsUtils.LASTOOLS_FOLDER,
            self.tr('LAStools folder'), LAStoolsUtils.LAStoolsPath(),
            valuetype=Setting.FOLDER))
        ProcessingConfig.addSetting(Setting(
            self.getDescription(),
            FusionUtils.FUSION_FOLDER,
            self.tr('Fusion folder'), FusionUtils.FusionPath(),
            valuetype=Setting.FOLDER))
        if not isWindows():
            ProcessingConfig.addSetting(Setting(
                self.getDescription(),
                LAStoolsUtils.WINE_FOLDER,
                self.tr('Wine folder'), '', valuetype=Setting.FOLDER))

    def getName(self):
        return 'lidartools'

    def getDescription(self):
        return self.tr('Tools for LiDAR data')

    def getIcon(self):
        return QIcon(os.path.dirname(__file__) + '/../../images/tool.png')

    def getSupportedOutputTableExtensions(self):
        return ['csv']