250 int ndims_a, ndims_b;
252 POSTGIS_DEBUG(5,
"entered function");
256 elog(ERROR,
"gidx_union_volume received two null arguments");
272 ndims_a = GIDX_NDIMS(a);
273 ndims_b = GIDX_NDIMS(b);
276 result = Max(GIDX_GET_MAX(a, 0), GIDX_GET_MAX(b, 0)) - Min(GIDX_GET_MIN(a, 0), GIDX_GET_MIN(b, 0));
279 for (i = 1; i < ndims_b; i++)
280 result *= (Max(GIDX_GET_MAX(a, i), GIDX_GET_MAX(b, i)) - Min(GIDX_GET_MIN(a, i), GIDX_GET_MIN(b, i)));
283 for (i = ndims_b; i < ndims_a; i++)
284 result *= (GIDX_GET_MAX(a, i) - GIDX_GET_MIN(a, i));
286 POSTGIS_DEBUGF(5,
"volume( %s union %s ) = %.12g", gidx_to_string(a), gidx_to_string(b), result);
bool gidx_is_unknown(const GIDX *a)
static float gidx_volume(GIDX *a)
static void gidx_dimensionality_check(GIDX **a, GIDX **b)