]> git.ipfire.org Git - thirdparty/Python/cpython.git/commitdiff
Minor code clean-up. Don't alter the input vector. Use variables instead. GH-8748
authorRaymond Hettinger <rhettinger@users.noreply.github.com>
Sun, 12 Aug 2018 21:18:56 +0000 (14:18 -0700)
committerGitHub <noreply@github.com>
Sun, 12 Aug 2018 21:18:56 +0000 (14:18 -0700)
Modules/mathmodule.c

index ab49dcef288417e1a46a023f6bb721b997828da9..2d483afff54d1b38cc4667e2c7511b680fc4f784 100644 (file)
@@ -2056,7 +2056,7 @@ the *vec* is a NaN.
 static inline double
 vector_norm(Py_ssize_t n, double *vec, double max, int found_nan)
 {
-    double x, csum = 0.0, oldcsum, frac = 0.0;
+    double x, csum = 0.0, oldcsum, frac = 0.0, last;
     Py_ssize_t i;
 
     if (Py_IS_INFINITY(max)) {
@@ -2069,12 +2069,13 @@ vector_norm(Py_ssize_t n, double *vec, double max, int found_nan)
         return 0.0;
     }
     assert(n > 0);
+    last = vec[n-1];
     for (i=0 ; i < n-1 ; i++) {
         x = vec[i];
         assert(Py_IS_FINITE(x) && x >= 0.0 && x <= max);
         if (x == max) {
-            x = vec[n-1];
-            vec[n-1] = max;
+            x = last;
+            last = max;
         }
         x /= max;
         x = x*x - frac;
@@ -2082,7 +2083,7 @@ vector_norm(Py_ssize_t n, double *vec, double max, int found_nan)
         csum += x;
         frac = (csum - oldcsum) - x;
     }
-    assert(vec[n-1] == max);
+    assert(last == max);
     csum += 1.0 - frac;
     return max * sqrt(csum);
 }