18#ifndef QGSFUZZIFYRASTERALGORITHM_H
19#define QGSFUZZIFYRASTERALGORITHM_H
29using namespace Qt::StringLiterals;
39 QString
group()
const final;
41 void initAlgorithm(
const QVariantMap &configuration = QVariantMap() )
final;
48 virtual void addAlgorithmParams() = 0;
69 std::unique_ptr<QgsRasterInterface> mInterface;
74 int mNbCellsXProvider = 0;
75 int mNbCellsYProvider = 0;
78 const double mNoDataValue = -9999;
79 double mMaxProgressDuringBlockWriting = 100;
83class QgsFuzzifyRasterLinearMembershipAlgorithm :
public QgsFuzzifyRasterAlgorithmBase
86 QgsFuzzifyRasterLinearMembershipAlgorithm() =
default;
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;
97 void addAlgorithmParams() override;
98 bool prepareAlgorithmFuzzificationParameters( const QVariantMap ¶meters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
99 void fuzzify( QgsRasterDataProvider *destinationProvider, QgsProcessingFeedback *feedback ) override;
102 double mFuzzifyLowBound = 0;
103 double mFuzzifyHighBound = 0;
107class QgsFuzzifyRasterPowerMembershipAlgorithm : public QgsFuzzifyRasterAlgorithmBase
110 QgsFuzzifyRasterPowerMembershipAlgorithm() =
default;
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;
121 void addAlgorithmParams() override;
122 bool prepareAlgorithmFuzzificationParameters( const QVariantMap ¶meters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
123 void fuzzify( QgsRasterDataProvider *destinationProvider, QgsProcessingFeedback *feedback ) override;
126 double mFuzzifyLowBound = 0;
127 double mFuzzifyHighBound = 0;
128 double mFuzzifyExponent = 0;
132class QgsFuzzifyRasterLargeMembershipAlgorithm : public QgsFuzzifyRasterAlgorithmBase
135 QgsFuzzifyRasterLargeMembershipAlgorithm() =
default;
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;
146 void addAlgorithmParams() override;
147 bool prepareAlgorithmFuzzificationParameters( const QVariantMap ¶meters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
148 void fuzzify( QgsRasterDataProvider *destinationProvider, QgsProcessingFeedback *feedback ) override;
151 double mFuzzifyMidpoint = 0;
152 double mFuzzifySpread = 0;
156class QgsFuzzifyRasterSmallMembershipAlgorithm : public QgsFuzzifyRasterAlgorithmBase
159 QgsFuzzifyRasterSmallMembershipAlgorithm() =
default;
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;
170 void addAlgorithmParams() override;
171 bool prepareAlgorithmFuzzificationParameters( const QVariantMap ¶meters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
172 void fuzzify( QgsRasterDataProvider *destinationProvider, QgsProcessingFeedback *feedback ) override;
175 double mFuzzifyMidpoint = 0;
176 double mFuzzifySpread = 0;
180class QgsFuzzifyRasterGaussianMembershipAlgorithm : public QgsFuzzifyRasterAlgorithmBase
183 QgsFuzzifyRasterGaussianMembershipAlgorithm() =
default;
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;
194 void addAlgorithmParams() override;
195 bool prepareAlgorithmFuzzificationParameters( const QVariantMap ¶meters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
196 void fuzzify( QgsRasterDataProvider *destinationProvider, QgsProcessingFeedback *feedback ) override;
199 double mFuzzifyMidpoint = 0;
200 double mFuzzifySpread = 0;
204class QgsFuzzifyRasterNearMembershipAlgorithm : public QgsFuzzifyRasterAlgorithmBase
207 QgsFuzzifyRasterNearMembershipAlgorithm() =
default;
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;
218 void addAlgorithmParams() override;
219 bool prepareAlgorithmFuzzificationParameters( const QVariantMap ¶meters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
220 void fuzzify( QgsRasterDataProvider *destinationProvider, QgsProcessingFeedback *feedback ) override;
223 double mFuzzifyMidpoint = 0;
224 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.