/****************************************************************************** * $Id$ * * Project: GDAL Gridding API. * Purpose: Prototypes, and definitions for of GDAL scattered data gridder. * Author: Even Rouault, * ****************************************************************************** * Copyright (c) 2013, Even Rouault * * Permission is hereby granted, free of charge, to any person obtaining a * copy of this software and associated documentation files (the "Software"), * to deal in the Software without restriction, including without limitation * the rights to use, copy, modify, merge, publish, distribute, sublicense, * and/or sell copies of the Software, and to permit persons to whom the * Software is furnished to do so, subject to the following conditions: * * The above copyright notice and this permission notice shall be included * in all copies or substantial portions of the Software. * * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER * DEALINGS IN THE SOFTWARE. ****************************************************************************/ #ifndef GDALGRID_PRIV_H #define GDALGRID_PRIV_H #include "cpl_error.h" #include "cpl_quad_tree.h" //! @cond Doxygen_Suppress typedef struct { const double* padfX; const double* padfY; } GDALGridXYArrays; typedef struct { GDALGridXYArrays* psXYArrays; int i; } GDALGridPoint; typedef struct { CPLQuadTree* hQuadTree; double dfInitialSearchRadius; float *pafX; // Aligned to be usable with AVX float *pafY; float *pafZ; GDALTriangulation* psTriangulation; int nInitialFacetIdx; /*! Weighting power divided by 2 (pre-computation). */ double dfPowerDiv2PreComp; /*! The radius of search circle squared (pre-computation). */ double dfRadiusPower2PreComp; /*! The radius of search circle to power 4 (pre-computation). */ double dfRadiusPower4PreComp; } GDALGridExtraParameters; #ifdef HAVE_SSE_AT_COMPILE_TIME CPLErr GDALGridInverseDistanceToAPower2NoSmoothingNoSearchSSE( const void *poOptions, GUInt32 nPoints, const double *unused_padfX, const double *unused_padfY, const double *unused_padfZ, double dfXPoint, double dfYPoint, double *pdfValue, void* hExtraParamsIn ); #endif #ifdef HAVE_AVX_AT_COMPILE_TIME CPLErr GDALGridInverseDistanceToAPower2NoSmoothingNoSearchAVX( const void *poOptions, GUInt32 nPoints, const double *unused_padfX, const double *unused_padfY, const double *unused_padfZ, double dfXPoint, double dfYPoint, double *pdfValue, void* hExtraParamsIn ); #endif //! @endcond #endif // GDALGRID_PRIV_H