QGIS API Documentation 3.99.0-Master (09f76ad7019)
Loading...
Searching...
No Matches
qgsalgorithmfuzzifyraster.h
Go to the documentation of this file.
1/***************************************************************************
2 qgsalgorithmrasterlayeruniquevalues.h
3 ---------------------
4 begin : October 2019
5 copyright : (C) 2019 by Clemens Raffler
6 email : clemens dot raffler at gmail dot com
7 ***************************************************************************/
8
9/***************************************************************************
10 * *
11 * This program is free software; you can redistribute it and/or modify *
12 * it under the terms of the GNU General Public License as published by *
13 * the Free Software Foundation; either version 2 of the License, or *
14 * (at your option) any later version. *
15 * *
16 ***************************************************************************/
17
18#ifndef QGSFUZZIFYRASTERALGORITHM_H
19#define QGSFUZZIFYRASTERALGORITHM_H
20
21#define SIP_NO_FILE
22
23#include "qgis_sip.h"
24#include "qgsapplication.h"
26
27#include <QString>
28
29using namespace Qt::StringLiterals;
30
32
36class QgsFuzzifyRasterAlgorithmBase : public QgsProcessingAlgorithm
37{
38 public:
39 QString group() const final;
40 QString groupId() const final;
41 void initAlgorithm( const QVariantMap &configuration = QVariantMap() ) final;
42
43 protected:
48 virtual void addAlgorithmParams() = 0;
49
50 bool prepareAlgorithm( const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) final;
51
55 virtual bool prepareAlgorithmFuzzificationParameters( const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) = 0;
56
60 QVariantMap processAlgorithm( const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) final;
61
65 virtual void fuzzify( QgsRasterDataProvider *destinationProvider, QgsProcessingFeedback *feedback ) = 0;
66
67 QgsRasterLayer *mInputRaster = nullptr;
68 int mBand = 1;
69 std::unique_ptr<QgsRasterInterface> mInterface;
70 QgsRectangle mExtent;
72 int mLayerWidth = 0;
73 int mLayerHeight = 0;
74 int mNbCellsXProvider = 0;
75 int mNbCellsYProvider = 0;
76
78 const double mNoDataValue = -9999;
79 double mMaxProgressDuringBlockWriting = 100;
80};
81
82
83class QgsFuzzifyRasterLinearMembershipAlgorithm : public QgsFuzzifyRasterAlgorithmBase
84{
85 public:
86 QgsFuzzifyRasterLinearMembershipAlgorithm() = default;
87 QIcon icon() const override { return QgsApplication::getThemeIcon( u"/algorithms/mAlgorithmFuzzifyLinear.svg"_s ); }
88 QString svgIconPath() const override { return QgsApplication::iconPath( u"/algorithms/mAlgorithmFuzzifyLinear.svg"_s ); }
89 QString name() const override;
90 QString displayName() const override;
91 QStringList tags() const override;
92 QString shortDescription() const override;
93 QString shortHelpString() const override;
94 QgsFuzzifyRasterLinearMembershipAlgorithm *createInstance() const override SIP_FACTORY;
95
96 protected:
97 void addAlgorithmParams() override;
98 bool prepareAlgorithmFuzzificationParameters( const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
99 void fuzzify( QgsRasterDataProvider *destinationProvider, QgsProcessingFeedback *feedback ) override;
100
101 private:
102 double mFuzzifyLowBound = 0;
103 double mFuzzifyHighBound = 0;
104};
105
106
107class QgsFuzzifyRasterPowerMembershipAlgorithm : public QgsFuzzifyRasterAlgorithmBase
108{
109 public:
110 QgsFuzzifyRasterPowerMembershipAlgorithm() = default;
111 QIcon icon() const override { return QgsApplication::getThemeIcon( u"/algorithms/mAlgorithmFuzzifyPower.svg"_s ); }
112 QString svgIconPath() const override { return QgsApplication::iconPath( u"/algorithms/mAlgorithmFuzzifyPower.svg"_s ); }
113 QString name() const override;
114 QString displayName() const override;
115 QStringList tags() const override;
116 QString shortDescription() const override;
117 QString shortHelpString() const override;
118 QgsFuzzifyRasterPowerMembershipAlgorithm *createInstance() const override SIP_FACTORY;
119
120 protected:
121 void addAlgorithmParams() override;
122 bool prepareAlgorithmFuzzificationParameters( const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
123 void fuzzify( QgsRasterDataProvider *destinationProvider, QgsProcessingFeedback *feedback ) override;
124
125 private:
126 double mFuzzifyLowBound = 0;
127 double mFuzzifyHighBound = 0;
128 double mFuzzifyExponent = 0;
129};
130
131
132class QgsFuzzifyRasterLargeMembershipAlgorithm : public QgsFuzzifyRasterAlgorithmBase
133{
134 public:
135 QgsFuzzifyRasterLargeMembershipAlgorithm() = default;
136 QIcon icon() const override { return QgsApplication::getThemeIcon( u"/algorithms/mAlgorithmFuzzifyLarge.svg"_s ); }
137 QString svgIconPath() const override { return QgsApplication::iconPath( u"/algorithms/mAlgorithmFuzzifyLarge.svg"_s ); }
138 QString name() const override;
139 QString displayName() const override;
140 QStringList tags() const override;
141 QString shortHelpString() const override;
142 QString shortDescription() const override;
143 QgsFuzzifyRasterLargeMembershipAlgorithm *createInstance() const override SIP_FACTORY;
144
145 protected:
146 void addAlgorithmParams() override;
147 bool prepareAlgorithmFuzzificationParameters( const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
148 void fuzzify( QgsRasterDataProvider *destinationProvider, QgsProcessingFeedback *feedback ) override;
149
150 private:
151 double mFuzzifyMidpoint = 0;
152 double mFuzzifySpread = 0;
153};
154
155
156class QgsFuzzifyRasterSmallMembershipAlgorithm : public QgsFuzzifyRasterAlgorithmBase
157{
158 public:
159 QgsFuzzifyRasterSmallMembershipAlgorithm() = default;
160 QIcon icon() const override { return QgsApplication::getThemeIcon( u"/algorithms/mAlgorithmFuzzifySmall.svg"_s ); }
161 QString svgIconPath() const override { return QgsApplication::iconPath( u"/algorithms/mAlgorithmFuzzifySmall.svg"_s ); }
162 QString name() const override;
163 QString displayName() const override;
164 QStringList tags() const override;
165 QString shortHelpString() const override;
166 QString shortDescription() const override;
167 QgsFuzzifyRasterSmallMembershipAlgorithm *createInstance() const override SIP_FACTORY;
168
169 protected:
170 void addAlgorithmParams() override;
171 bool prepareAlgorithmFuzzificationParameters( const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
172 void fuzzify( QgsRasterDataProvider *destinationProvider, QgsProcessingFeedback *feedback ) override;
173
174 private:
175 double mFuzzifyMidpoint = 0;
176 double mFuzzifySpread = 0;
177};
178
179
180class QgsFuzzifyRasterGaussianMembershipAlgorithm : public QgsFuzzifyRasterAlgorithmBase
181{
182 public:
183 QgsFuzzifyRasterGaussianMembershipAlgorithm() = default;
184 QIcon icon() const override { return QgsApplication::getThemeIcon( u"/algorithms/mAlgorithmFuzzifyGaussian.svg"_s ); }
185 QString svgIconPath() const override { return QgsApplication::iconPath( u"/algorithms/mAlgorithmFuzzifyGaussian.svg"_s ); }
186 QString name() const override;
187 QString displayName() const override;
188 QStringList tags() const override;
189 QString shortHelpString() const override;
190 QString shortDescription() const override;
191 QgsFuzzifyRasterGaussianMembershipAlgorithm *createInstance() const override SIP_FACTORY;
192
193 protected:
194 void addAlgorithmParams() override;
195 bool prepareAlgorithmFuzzificationParameters( const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
196 void fuzzify( QgsRasterDataProvider *destinationProvider, QgsProcessingFeedback *feedback ) override;
197
198 private:
199 double mFuzzifyMidpoint = 0;
200 double mFuzzifySpread = 0;
201};
202
203
204class QgsFuzzifyRasterNearMembershipAlgorithm : public QgsFuzzifyRasterAlgorithmBase
205{
206 public:
207 QgsFuzzifyRasterNearMembershipAlgorithm() = default;
208 QIcon icon() const override { return QgsApplication::getThemeIcon( u"/algorithms/mAlgorithmFuzzifyNear.svg"_s ); }
209 QString svgIconPath() const override { return QgsApplication::iconPath( u"/algorithms/mAlgorithmFuzzifyNear.svg"_s ); }
210 QString name() const override;
211 QString displayName() const override;
212 QStringList tags() const override;
213 QString shortHelpString() const override;
214 QString shortDescription() const override;
215 QgsFuzzifyRasterNearMembershipAlgorithm *createInstance() const override SIP_FACTORY;
216
217 protected:
218 void addAlgorithmParams() override;
219 bool prepareAlgorithmFuzzificationParameters( const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
220 void fuzzify( QgsRasterDataProvider *destinationProvider, QgsProcessingFeedback *feedback ) override;
221
222 private:
223 double mFuzzifyMidpoint = 0;
224 double mFuzzifySpread = 0;
225};
226
227
229
230#endif // QGSALGORITHMFUZZIFYRASTER_H
DataType
Raster data types.
Definition qgis.h:379
@ Float32
Thirty two bit floating point (float).
Definition qgis.h:387
static QIcon getThemeIcon(const QString &name, const QColor &fillColor=QColor(), const QColor &strokeColor=QColor())
Helper to get a theme icon.
static QString iconPath(const QString &iconFile)
Returns path to the desired icon file.
Represents a coordinate reference system (CRS).
Abstract base class for processing algorithms.
virtual QString group() const
Returns the name of the group this algorithm belongs to.
virtual bool prepareAlgorithm(const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback *feedback)
Prepares the algorithm to run using the specified parameters.
virtual QString groupId() const
Returns the unique ID of the group this algorithm belongs to.
virtual QVariantMap processAlgorithm(const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback *feedback)=0
Runs the algorithm using the specified parameters.
virtual void initAlgorithm(const QVariantMap &configuration=QVariantMap())=0
Initializes the algorithm using the specified configuration.
Contains information about the context in which a processing algorithm is executed.
Base class for providing feedback from a processing algorithm.
Base class for raster data providers.
Represents a raster layer.
A rectangle specified with double values.
#define SIP_FACTORY
Definition qgis_sip.h:84