From 691ef807df10ce26131e64a8eaaeb1d95438a6e2 Mon Sep 17 00:00:00 2001 From: LSchueler Date: Mon, 8 Jul 2024 13:30:35 +0200 Subject: [PATCH] Fix cython's buf. mismatch with numpy's 8bit bools --- src/gstools/variogram/estimator.pyx | 8 ++++++-- 1 file changed, 6 insertions(+), 2 deletions(-) diff --git a/src/gstools/variogram/estimator.pyx b/src/gstools/variogram/estimator.pyx index f1e9bd39..100536bb 100644 --- a/src/gstools/variogram/estimator.pyx +++ b/src/gstools/variogram/estimator.pyx @@ -14,6 +14,10 @@ cimport numpy as np from libc.math cimport M_PI, acos, atan2, cos, fabs, isnan, pow, sin, sqrt +# numpy's "bool" +ctypedef unsigned char uint8 + + def set_num_threads(num_threads): cdef int num_threads_c = 1 if num_threads is None: @@ -342,7 +346,7 @@ def structured( def ma_structured( const double[:, :] f, - const bint[:, :] mask, + uint8[:, :] mask, # numpy's bools are 8bit vars str estimator_type='m', num_threads=None, ): @@ -365,7 +369,7 @@ def ma_structured( for i in range(i_max): for j in range(j_max): for k in prange(1, k_max-i): - if not mask[i, j] and not mask[i+k, j]: + if mask[i, j] == 0 and mask[i+k, j] == 0: counts[k] += 1 variogram[k] += estimator_func(f[i, j] - f[i+k, j])