QGIS API Documentation 3.99.0-Master (c22de0620c0)
Loading...
Searching...
No Matches
qgsalgorithmrasterfrequencybycomparisonoperator.h
Go to the documentation of this file.
1/***************************************************************************
2 qgsalgorithmrasterfrequencybycomparisonoperator.h
3 ---------------------
4 begin : June 2020
5 copyright : (C) 2020 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 QGSALGORITHMRASTERFREQUENCYBYCOMPARISON_H
19#define QGSALGORITHMRASTERFREQUENCYBYCOMPARISON_H
20
21
22#include "qgis_sip.h"
23#include "qgsapplication.h"
26#include "qgsrasterprojector.h"
27
28#define SIP_NO_FILE
29
31
32class QgsRasterFrequencyByComparisonOperatorBase : public QgsProcessingAlgorithm
33{
34 public:
35 QgsRasterFrequencyByComparisonOperatorBase() = default;
36 void initAlgorithm( const QVariantMap &configuration = QVariantMap() ) override;
37 QString group() const override;
38 QString groupId() const override;
39
40 protected:
41 bool prepareAlgorithm( const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
42 QVariantMap processAlgorithm( const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback *feedback ) override;
43 virtual int applyComparisonOperator( double value, std::vector<double> cellValueStack ) = 0;
44
45 private:
46 std::unique_ptr<QgsRasterInterface> mInputValueRasterInterface;
47 int mInputValueRasterBand = 1;
48 std::vector<QgsRasterAnalysisUtils::RasterLogicInput> mInputs;
49 bool mIgnoreNoData = false;
50 double mNoDataValue = -9999;
51 int mLayerWidth = 0;
52 int mLayerHeight = 0;
53 QgsRectangle mExtent;
55 double mRasterUnitsPerPixelX = 0;
56 double mRasterUnitsPerPixelY = 0;
57};
58
59class QgsRasterFrequencyByEqualOperatorAlgorithm : public QgsRasterFrequencyByComparisonOperatorBase
60{
61 public:
62 QgsRasterFrequencyByEqualOperatorAlgorithm() = default;
63 QString name() const override;
64 QString displayName() const override;
65 QStringList tags() const override;
66 QString shortHelpString() const override;
67 QString shortDescription() const override;
68 QgsRasterFrequencyByEqualOperatorAlgorithm *createInstance() const override SIP_FACTORY;
69
70 protected:
71 int applyComparisonOperator( double searchValue, std::vector<double> cellValueStack ) override;
72};
73
74class QgsRasterFrequencyByGreaterThanOperatorAlgorithm : public QgsRasterFrequencyByComparisonOperatorBase
75{
76 public:
77 QgsRasterFrequencyByGreaterThanOperatorAlgorithm() = default;
78 QString name() const override;
79 QString displayName() const override;
80 QStringList tags() const override;
81 QString shortHelpString() const override;
82 QString shortDescription() const override;
83 QgsRasterFrequencyByGreaterThanOperatorAlgorithm *createInstance() const override SIP_FACTORY;
84
85 protected:
86 int applyComparisonOperator( double value, std::vector<double> cellValueStack ) override;
87};
88
89class QgsRasterFrequencyByLessThanOperatorAlgorithm : public QgsRasterFrequencyByComparisonOperatorBase
90{
91 public:
92 QgsRasterFrequencyByLessThanOperatorAlgorithm() = default;
93 QString name() const override;
94 QString displayName() const override;
95 QStringList tags() const override;
96 QString shortHelpString() const override;
97 QString shortDescription() const override;
98 QgsRasterFrequencyByLessThanOperatorAlgorithm *createInstance() const override SIP_FACTORY;
99
100 protected:
101 int applyComparisonOperator( double value, std::vector<double> cellValueStack ) override;
102};
103
105
106#endif // QGSALGORITHMRASTERFREQUENCYBYCOMPARISON_H
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.
A rectangle specified with double values.
#define SIP_FACTORY
Definition qgis_sip.h:83