From 7aca4d084091e8574d98c0d89913721f7a55749b Mon Sep 17 00:00:00 2001
From: Paul McCarthy <pauldmccarthy@gmail.com>
Date: Thu, 22 Aug 2024 11:42:46 +0100
Subject: [PATCH] ENH: Adjust logic so that Splinterpolator can be created with
 pre-calculated coefficeints

---
 splinterpolator.h | 9 ++++++---
 1 file changed, 6 insertions(+), 3 deletions(-)

diff --git a/splinterpolator.h b/splinterpolator.h
index fbd7b4f..e7c43cf 100644
--- a/splinterpolator.h
+++ b/splinterpolator.h
@@ -1431,16 +1431,19 @@ void Splinterpolator<T>::assign(const Splinterpolator<T>& src)
 template<class T>
 bool Splinterpolator<T>::calc_coef(const T *data_or_coefs, bool copy, bool data_are_coefs)
 {
-  if (_order < 2 && !copy) { _cptr = data_or_coefs; return(false); }
+  // No copy, and nearest/interp, or pre-calculated
+  // coefficients - just take a pointer to the data
+  if (_order < 2     && !copy) { _cptr = data_or_coefs; return(false); }
+  if (data_are_coefs && !copy) { _cptr = data_or_coefs; return(false); }
 
   // Allocate memory and put the original data into _coef
-  //
   unsigned int ts=1;
   for (unsigned int i=0; i<_dim.size(); i++) ts *= _dim[i];
   _coef = new T[ts];
   memcpy(_coef,data_or_coefs,ts*sizeof(T));
 
-  if (_order < 2) return(true);  // If nearest neighbour or linear, that's all we need
+  if (_order < 2)     return(true); // If nearest neighbour or linear, that's all we need
+  if (data_are_coefs) return(true); // User has given us pre-calculated coefficients
 
   // Loop over all non-singleton dimensions and deconvolve along them
   //
-- 
GitLab