1198         FuncCallContext *funcctx;
 
 1208         if (SRF_IS_FIRSTCALL()) {
 
 1209                 MemoryContext oldcontext;
 
 1214                 int32_t bandindex = 0;
 
 1216                 bool exclude_nodata_value = 
TRUE;
 
 1218                 double *quantiles = NULL;
 
 1219                 uint32_t quantiles_count = 0;
 
 1220                 double quantile = 0;
 
 1236                 funcctx = SRF_FIRSTCALL_INIT();
 
 1239                 oldcontext = MemoryContextSwitchTo(funcctx->multi_call_memory_ctx);
 
 1242                 if (PG_ARGISNULL(0)) {
 
 1243                         MemoryContextSwitchTo(oldcontext);
 
 1244                         SRF_RETURN_DONE(funcctx);
 
 1246                 pgraster = (
rt_pgraster *) PG_DETOAST_DATUM(PG_GETARG_DATUM(0));
 
 1250                         PG_FREE_IF_COPY(pgraster, 0);
 
 1251                         MemoryContextSwitchTo(oldcontext);
 
 1252                         elog(ERROR, 
"RASTER_quantile: Cannot deserialize raster");
 
 1253                         SRF_RETURN_DONE(funcctx);
 
 1257                 bandindex = PG_GETARG_INT32(1);
 
 1259                 if (bandindex < 1 || bandindex > num_bands) {
 
 1260                         elog(NOTICE, 
"Invalid band index (must use 1-based). Returning NULL");
 
 1262                         PG_FREE_IF_COPY(pgraster, 0);
 
 1263                         MemoryContextSwitchTo(oldcontext);
 
 1264                         SRF_RETURN_DONE(funcctx);
 
 1268                 if (!PG_ARGISNULL(2))
 
 1269                         exclude_nodata_value = PG_GETARG_BOOL(2);
 
 1272                 if (!PG_ARGISNULL(3)) {
 
 1273                         sample = PG_GETARG_FLOAT8(3);
 
 1274                         if (sample < 0 || sample > 1) {
 
 1275                                 elog(NOTICE, 
"Invalid sample percentage (must be between 0 and 1). Returning NULL");
 
 1277                                 PG_FREE_IF_COPY(pgraster, 0);
 
 1278                                 MemoryContextSwitchTo(oldcontext);
 
 1279                                 SRF_RETURN_DONE(funcctx);
 
 1281                         else if (
FLT_EQ(sample, 0.0))
 
 1288                 if (!PG_ARGISNULL(4)) {
 
 1289                         array = PG_GETARG_ARRAYTYPE_P(4);
 
 1290                         etype = ARR_ELEMTYPE(array);
 
 1291                         get_typlenbyvalalign(etype, &typlen, &typbyval, &typalign);
 
 1299                                         PG_FREE_IF_COPY(pgraster, 0);
 
 1300                                         MemoryContextSwitchTo(oldcontext);
 
 1301                                         elog(ERROR, 
"RASTER_quantile: Invalid data type for quantiles");
 
 1302                                         SRF_RETURN_DONE(funcctx);
 
 1306                         deconstruct_array(array, etype, typlen, typbyval, typalign, &e,
 
 1309                         quantiles = palloc(
sizeof(
double) * n);
 
 1310                         for (i = 0, j = 0; i < n; i++) {
 
 1311                                 if (nulls[i]) 
continue;
 
 1315                                                 quantile = (double) DatumGetFloat4(e[i]);
 
 1318                                                 quantile = (double) DatumGetFloat8(e[i]);
 
 1322                                 if (quantile < 0 || quantile > 1) {
 
 1323                                         elog(NOTICE, 
"Invalid value for quantile (must be between 0 and 1). Returning NULL");
 
 1326                                         PG_FREE_IF_COPY(pgraster, 0);
 
 1327                                         MemoryContextSwitchTo(oldcontext);
 
 1328                                         SRF_RETURN_DONE(funcctx);
 
 1331                                 quantiles[j] = quantile;
 
 1335                         quantiles_count = j;
 
 1346                         elog(NOTICE, 
"Cannot find band at index %d. Returning NULL", bandindex);
 
 1348                         PG_FREE_IF_COPY(pgraster, 0);
 
 1349                         MemoryContextSwitchTo(oldcontext);
 
 1350                         SRF_RETURN_DONE(funcctx);
 
 1357                 PG_FREE_IF_COPY(pgraster, 0);
 
 1358                 if (NULL == stats || NULL == stats->
values) {
 
 1359                         elog(NOTICE, 
"Cannot retrieve summary statistics for band at index %d", bandindex);
 
 1360                         MemoryContextSwitchTo(oldcontext);
 
 1361                         SRF_RETURN_DONE(funcctx);
 
 1363                 else if (stats->
count < 1) {
 
 1364                         elog(NOTICE, 
"Cannot compute quantiles for band at index %d as the band has no values", bandindex);
 
 1365                         MemoryContextSwitchTo(oldcontext);
 
 1366                         SRF_RETURN_DONE(funcctx);
 
 1371                 if (quantiles_count) pfree(quantiles);
 
 1373                 if (NULL == quant || !
count) {
 
 1374                         elog(NOTICE, 
"Cannot compute quantiles for band at index %d", bandindex);
 
 1375                         MemoryContextSwitchTo(oldcontext);
 
 1376                         SRF_RETURN_DONE(funcctx);
 
 1382                 funcctx->user_fctx = quant;
 
 1385                 funcctx->max_calls = 
count;
 
 1388                 if (get_call_result_type(fcinfo, NULL, &tupdesc) != TYPEFUNC_COMPOSITE) {
 
 1390                                 errcode(ERRCODE_FEATURE_NOT_SUPPORTED),
 
 1392                                         "function returning record called in context " 
 1393                                         "that cannot accept type record" 
 1398                 BlessTupleDesc(tupdesc);
 
 1399                 funcctx->tuple_desc = tupdesc;
 
 1401                 MemoryContextSwitchTo(oldcontext);
 
 1405         funcctx = SRF_PERCALL_SETUP();
 
 1407         call_cntr = funcctx->call_cntr;
 
 1408         max_calls = funcctx->max_calls;
 
 1409         tupdesc = funcctx->tuple_desc;
 
 1410         quant2 = funcctx->user_fctx;
 
 1413         if (call_cntr < max_calls) {
 
 1423                 values[0] = Float8GetDatum(quant2[call_cntr].quantile);
 
 1424                 values[1] = Float8GetDatum(quant2[call_cntr].
value);
 
 1427                 tuple = heap_form_tuple(tupdesc, values, nulls);
 
 1430                 result = HeapTupleGetDatum(tuple);
 
 1432                 SRF_RETURN_NEXT(funcctx, 
result);
 
 1437                 SRF_RETURN_DONE(funcctx);
 
char result[OUT_DOUBLE_BUFFER_SIZE]
void rt_raster_destroy(rt_raster raster)
Release memory associated to a raster.
void rt_band_destroy(rt_band band)
Destroy a raster band.
uint16_t rt_raster_get_num_bands(rt_raster raster)
rt_quantile rt_band_get_quantiles(rt_bandstats stats, double *quantiles, int quantiles_count, uint32_t *rtn_count)
Compute the default set of or requested quantiles for a set of data the quantile formula used is same...
rt_bandstats rt_band_get_summary_stats(rt_band band, int exclude_nodata_value, double sample, int inc_vals, uint64_t *cK, double *cM, double *cQ)
Compute summary statistics for a band.
rt_raster rt_raster_deserialize(void *serialized, int header_only)
Return a raster from a serialized form.
rt_band rt_raster_get_band(rt_raster raster, int bandNum)
Return Nth band, or NULL if unavailable.
raster
Be careful!! Zeros function's input parameter can be a (height x width) array, not (width x height): ...
#define POSTGIS_RT_DEBUGF(level, msg,...)