30 #ifndef GDALPANSHARPEN_H_INCLUDED
31 #define GDALPANSHARPEN_H_INCLUDED
121 int nXOff,
int nYOff,
int nXSize,
122 int nYSize,
void *pDataBuf,
134 #include <sys/time.h>
145 const void *pPanBuffer;
146 const void *pUpsampledSpectralBuffer;
181 } GDALPansharpenResampleJob;
194 std::vector<int> anInputBands{};
195 std::vector<GDALDataset *> aVDS{};
196 std::vector<GDALRasterBand *> aMSBands{};
198 int bPositiveWeights = TRUE;
200 int nKernelRadius = 0;
201 std::array<double, 6> m_adfPanToMSGT = {{0.0, 1.0, 0, 0.0, 0.0, 1.0}};
203 static void PansharpenJobThreadFunc(
void *pUserData);
204 static void PansharpenResampleJobThreadFunc(
void *pUserData);
206 template <
class WorkDataType,
class OutDataType>
207 void WeightedBroveyWithNoData(
const WorkDataType *pPanBuffer,
208 const WorkDataType *pUpsampledSpectralBuffer,
209 OutDataType *pDataBuf,
size_t nValues,
211 WorkDataType nMaxValue)
const;
212 template <
class WorkDataType,
class OutDataType,
int bHasBitDepth>
213 void WeightedBrovey3(
const WorkDataType *pPanBuffer,
214 const WorkDataType *pUpsampledSpectralBuffer,
215 OutDataType *pDataBuf,
size_t nValues,
216 size_t nBandValues, WorkDataType nMaxValue)
const;
219 template <
class WorkDataType,
class OutDataType>
220 void WeightedBrovey(
const WorkDataType *pPanBuffer,
221 const WorkDataType *pUpsampledSpectralBuffer,
222 OutDataType *pDataBuf,
size_t nValues,
223 size_t nBandValues, WorkDataType nMaxValue)
const;
224 template <
class WorkDataType>
225 CPLErr WeightedBrovey(
const WorkDataType *pPanBuffer,
226 const WorkDataType *pUpsampledSpectralBuffer,
228 size_t nValues,
size_t nBandValues,
229 WorkDataType nMaxValue)
const;
232 template <
class WorkDataType>
233 CPLErr WeightedBrovey(
const WorkDataType *pPanBuffer,
234 const WorkDataType *pUpsampledSpectralBuffer,
236 size_t nValues,
size_t nBandValues)
const;
238 void WeightedBroveyPositiveWeights(
const T *pPanBuffer,
239 const T *pUpsampledSpectralBuffer,
240 T *pDataBuf,
size_t nValues,
241 size_t nBandValues, T nMaxValue)
const;
243 template <
class T,
int NINPUT,
int NOUTPUT>
244 size_t WeightedBroveyPositiveWeightsInternal(
245 const T *pPanBuffer,
const T *pUpsampledSpectralBuffer, T *pDataBuf,
246 size_t nValues,
size_t nBandValues, T nMaxValue)
const;
250 void WeightedBroveyGByteOrUInt16(
const T *pPanBuffer,
251 const T *pUpsampledSpectralBuffer,
252 T *pDataBuf,
size_t nValues,
253 size_t nBandValues, T nMaxValue)
const;
258 const void *pUpsampledSpectralBuffer,
void *pDataBuf,
259 size_t nValues,
size_t nBandValues,
Pool of worker threads.
Definition: cpl_worker_thread_pool.h:79
A set of associated raster bands, usually from one file.
Definition: gdal_priv.h:503
Pansharpening operation class.
Definition: gdalpansharpen.h:190
CPLErr ProcessRegion(int nXOff, int nYOff, int nXSize, int nYSize, void *pDataBuf, GDALDataType eBufDataType)
Executes a pansharpening operation on a rectangular region of the resulting dataset.
Definition: gdalpansharpen.cpp:1173
GDALPansharpenOperation()
Pansharpening operation constructor.
~GDALPansharpenOperation()
Pansharpening operation destructor.
Definition: gdalpansharpen.cpp:171
GDALPansharpenOptions * GetOptions()
Return options.
Definition: gdalpansharpen.cpp:1814
CPLErr Initialize(const GDALPansharpenOptions *psOptions)
Initialize the pansharpening operation.
Definition: gdalpansharpen.cpp:190
CPLErr
Error category.
Definition: cpl_error.h:53
#define CPL_C_END
Macro to end a block of C symbols.
Definition: cpl_port.h:299
#define CPL_C_START
Macro to start a block of C symbols.
Definition: cpl_port.h:295
unsigned int GUInt32
Unsigned int32 type.
Definition: cpl_port.h:177
#define CPL_DISALLOW_COPY_ASSIGN(ClassName)
Helper to remove the copy and assignment constructors so that the compiler will not generate the defa...
Definition: cpl_port.h:1042
Public (C callable) GDAL entry points.
GIntBig GSpacing
Type to express pixel, line or band spacing.
Definition: gdal.h:315
GDALDataType
Definition: gdal.h:64
GDALRIOResampleAlg
RasterIO() resampling method.
Definition: gdal.h:143
void * GDALRasterBandH
Opaque type used for the C bindings of the C++ GDALRasterBand class.
Definition: gdal.h:294
CPLErr GDALPansharpenProcessRegion(GDALPansharpenOperationH hOperation, int nXOff, int nYOff, int nXSize, int nYSize, void *pDataBuf, GDALDataType eBufDataType)
Executes a pansharpening operation on a rectangular region of the resulting dataset.
Definition: gdalpansharpen.cpp:1889
GDALPansharpenOperationH GDALCreatePansharpenOperation(const GDALPansharpenOptions *)
Instantiate a pansharpening operation.
Definition: gdalpansharpen.cpp:1835
GDALPansharpenAlg
Pansharpening algorithms.
Definition: gdalpansharpen.h:48
@ GDAL_PSH_WEIGHTED_BROVEY
Definition: gdalpansharpen.h:50
void GDALDestroyPansharpenOptions(GDALPansharpenOptions *)
Destroy pansharpening options.
Definition: gdalpansharpen.cpp:89
GDALPansharpenOptions * GDALClonePansharpenOptions(const GDALPansharpenOptions *psOptions)
Clone pansharpening options.
Definition: gdalpansharpen.cpp:114
GDALPansharpenOptions * GDALCreatePansharpenOptions(void)
Create pansharpening options.
Definition: gdalpansharpen.cpp:68
void * GDALPansharpenOperationH
Definition: gdalpansharpen.h:115
void GDALDestroyPansharpenOperation(GDALPansharpenOperationH)
Destroy a pansharpening operation.
Definition: gdalpansharpen.cpp:1855
Pansharpening options.
Definition: gdalpansharpen.h:56
GDALPansharpenAlg ePansharpenAlg
Definition: gdalpansharpen.h:58
int bHasNoData
Definition: gdalpansharpen.h:96
int nBitDepth
Definition: gdalpansharpen.h:66
double * padfWeights
Definition: gdalpansharpen.h:72
int nThreads
Number of threads or -1 to mean ALL_CPUS.
Definition: gdalpansharpen.h:106
int nWeightCount
Definition: gdalpansharpen.h:69
GDALRasterBandH * pahInputSpectralBands
Array of nInputSpectralBands input spectral bands.
Definition: gdalpansharpen.h:86
int * panOutPansharpenedBands
Definition: gdalpansharpen.h:93
GDALRIOResampleAlg eResampleAlg
Definition: gdalpansharpen.h:62
GDALRasterBandH hPanchroBand
Definition: gdalpansharpen.h:75
int nInputSpectralBands
Definition: gdalpansharpen.h:78
int nOutPansharpenedBands
Definition: gdalpansharpen.h:89
double dfNoData
NoData value of the panchromatic and spectral bands (only taken into account if bHasNoData = TRUE).
Definition: gdalpansharpen.h:101