18#ifndef QGSFUZZIFYRASTERALGORITHM_H
19#define QGSFUZZIFYRASTERALGORITHM_H
30using namespace Qt::StringLiterals;
40 QString
group()
const final;
42 void initAlgorithm(
const QVariantMap &configuration = QVariantMap() )
final;
49 virtual void addAlgorithmParams() = 0;
70 std::unique_ptr<QgsRasterInterface> mInterface;
75 int mNbCellsXProvider = 0;
76 int mNbCellsYProvider = 0;
79 const double mNoDataValue = -9999;
80 double mMaxProgressDuringBlockWriting = 100;
84class QgsFuzzifyRasterLinearMembershipAlgorithm :
public QgsFuzzifyRasterAlgorithmBase
87 QgsFuzzifyRasterLinearMembershipAlgorithm() =
default;
89 QString svgIconPath()
const override {
return QgsApplication::iconPath( u
"/algorithms/mAlgorithmFuzzifyLinear.svg"_s ); }
90 QString name()
const override;
91 QString displayName()
const override;
92 QStringList tags()
const override;
93 QString shortDescription()
const override;
94 QString shortHelpString()
const override;
95 QgsFuzzifyRasterLinearMembershipAlgorithm *createInstance() const override
SIP_FACTORY;
98 void addAlgorithmParams() override;
99 bool prepareAlgorithmFuzzificationParameters( const QVariantMap ¶meters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
100 void fuzzify( QgsRasterDataProvider *destinationProvider, QgsProcessingFeedback *feedback ) override;
103 double mFuzzifyLowBound = 0;
104 double mFuzzifyHighBound = 0;
108class QgsFuzzifyRasterPowerMembershipAlgorithm : public QgsFuzzifyRasterAlgorithmBase
111 QgsFuzzifyRasterPowerMembershipAlgorithm() =
default;
113 QString svgIconPath()
const override {
return QgsApplication::iconPath( u
"/algorithms/mAlgorithmFuzzifyPower.svg"_s ); }
114 QString name()
const override;
115 QString displayName()
const override;
116 QStringList tags()
const override;
117 QString shortDescription()
const override;
118 QString shortHelpString()
const override;
119 QgsFuzzifyRasterPowerMembershipAlgorithm *createInstance() const override
SIP_FACTORY;
122 void addAlgorithmParams() override;
123 bool prepareAlgorithmFuzzificationParameters( const QVariantMap ¶meters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
124 void fuzzify( QgsRasterDataProvider *destinationProvider, QgsProcessingFeedback *feedback ) override;
127 double mFuzzifyLowBound = 0;
128 double mFuzzifyHighBound = 0;
129 double mFuzzifyExponent = 0;
133class QgsFuzzifyRasterLargeMembershipAlgorithm : public QgsFuzzifyRasterAlgorithmBase
136 QgsFuzzifyRasterLargeMembershipAlgorithm() =
default;
138 QString svgIconPath()
const override {
return QgsApplication::iconPath( u
"/algorithms/mAlgorithmFuzzifyLarge.svg"_s ); }
139 QString name()
const override;
140 QString displayName()
const override;
141 QStringList tags()
const override;
142 QString shortHelpString()
const override;
143 QString shortDescription()
const override;
144 QgsFuzzifyRasterLargeMembershipAlgorithm *createInstance() const override
SIP_FACTORY;
147 void addAlgorithmParams() override;
148 bool prepareAlgorithmFuzzificationParameters( const QVariantMap ¶meters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
149 void fuzzify( QgsRasterDataProvider *destinationProvider, QgsProcessingFeedback *feedback ) override;
152 double mFuzzifyMidpoint = 0;
153 double mFuzzifySpread = 0;
157class QgsFuzzifyRasterSmallMembershipAlgorithm : public QgsFuzzifyRasterAlgorithmBase
160 QgsFuzzifyRasterSmallMembershipAlgorithm() =
default;
162 QString svgIconPath()
const override {
return QgsApplication::iconPath( u
"/algorithms/mAlgorithmFuzzifySmall.svg"_s ); }
163 QString name()
const override;
164 QString displayName()
const override;
165 QStringList tags()
const override;
166 QString shortHelpString()
const override;
167 QString shortDescription()
const override;
168 QgsFuzzifyRasterSmallMembershipAlgorithm *createInstance() const override
SIP_FACTORY;
171 void addAlgorithmParams() override;
172 bool prepareAlgorithmFuzzificationParameters( const QVariantMap ¶meters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
173 void fuzzify( QgsRasterDataProvider *destinationProvider, QgsProcessingFeedback *feedback ) override;
176 double mFuzzifyMidpoint = 0;
177 double mFuzzifySpread = 0;
181class QgsFuzzifyRasterGaussianMembershipAlgorithm : public QgsFuzzifyRasterAlgorithmBase
184 QgsFuzzifyRasterGaussianMembershipAlgorithm() =
default;
186 QString svgIconPath()
const override {
return QgsApplication::iconPath( u
"/algorithms/mAlgorithmFuzzifyGaussian.svg"_s ); }
187 QString name()
const override;
188 QString displayName()
const override;
189 QStringList tags()
const override;
190 QString shortHelpString()
const override;
191 QString shortDescription()
const override;
192 QgsFuzzifyRasterGaussianMembershipAlgorithm *createInstance() const override
SIP_FACTORY;
195 void addAlgorithmParams() override;
196 bool prepareAlgorithmFuzzificationParameters( const QVariantMap ¶meters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
197 void fuzzify( QgsRasterDataProvider *destinationProvider, QgsProcessingFeedback *feedback ) override;
200 double mFuzzifyMidpoint = 0;
201 double mFuzzifySpread = 0;
205class QgsFuzzifyRasterNearMembershipAlgorithm : public QgsFuzzifyRasterAlgorithmBase
208 QgsFuzzifyRasterNearMembershipAlgorithm() =
default;
210 QString svgIconPath()
const override {
return QgsApplication::iconPath( u
"/algorithms/mAlgorithmFuzzifyNear.svg"_s ); }
211 QString name()
const override;
212 QString displayName()
const override;
213 QStringList tags()
const override;
214 QString shortHelpString()
const override;
215 QString shortDescription()
const override;
216 QgsFuzzifyRasterNearMembershipAlgorithm *createInstance() const override
SIP_FACTORY;
219 void addAlgorithmParams() override;
220 bool prepareAlgorithmFuzzificationParameters( const QVariantMap ¶meters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
221 void fuzzify( QgsRasterDataProvider *destinationProvider, QgsProcessingFeedback *feedback ) override;
224 double mFuzzifyMidpoint = 0;
225 double mFuzzifySpread = 0;
DataType
Raster data types.
@ Float32
Thirty two bit floating point (float).
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 ¶meters, 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 ¶meters, 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.