[GRASS-SVN] r70674 - in grass/trunk: lib/calc raster/r.mapcalc/testsuite

svn_grass at osgeo.org svn_grass at osgeo.org
Sun Feb 26 01:47:14 PST 2017


Author: marisn
Date: 2017-02-26 01:47:13 -0800 (Sun, 26 Feb 2017)
New Revision: 70674

Added:
   grass/trunk/raster/r.mapcalc/testsuite/test_nmedian_bug_3296.py
Modified:
   grass/trunk/lib/calc/xnmedian.c
Log:
Do not calculate median if only one variable is provided.
Fixes #3296


Modified: grass/trunk/lib/calc/xnmedian.c
===================================================================
--- grass/trunk/lib/calc/xnmedian.c	2017-02-25 13:45:22 UTC (rev 70673)
+++ grass/trunk/lib/calc/xnmedian.c	2017-02-26 09:47:13 UTC (rev 70674)
@@ -82,6 +82,8 @@
 
 		if (!n)
 		    SET_NULL_C(&res[i]);
+                else if (n == 1)
+                    res[i] = *a1;
 		else {
 		    qsort(a, n, sizeof(CELL), icmp);
 		    res[i] = (*a1 + *a2) / 2;
@@ -109,6 +111,8 @@
 
 		if (!n)
 		    SET_NULL_F(&res[i]);
+                else if (n == 1)
+                    res[i] = *a1;
 		else {
 		    qsort(a, n, sizeof(FCELL), fcmp);
 		    res[i] = (*a1 + *a2) / 2;
@@ -136,6 +140,8 @@
 
 		if (!n)
 		    SET_NULL_D(&res[i]);
+                else if (n == 1)
+                    res[i] = *a1;
 		else {
 		    qsort(a, n, sizeof(DCELL), dcmp);
 		    res[i] = (*a1 + *a2) / 2;

Added: grass/trunk/raster/r.mapcalc/testsuite/test_nmedian_bug_3296.py
===================================================================
--- grass/trunk/raster/r.mapcalc/testsuite/test_nmedian_bug_3296.py	                        (rev 0)
+++ grass/trunk/raster/r.mapcalc/testsuite/test_nmedian_bug_3296.py	2017-02-26 09:47:13 UTC (rev 70674)
@@ -0,0 +1,104 @@
+#!/usr/bin/env python
+
+############################################################################
+#
+# MODULE:        test_nmedian_bug.py
+# AUTHOR:        Maris Nartiss, based on Vaclav Petras test_row_above_below_bug.py
+# PURPOSE:       Show bug reported in #3296
+# COPYRIGHT:     (C) 2017 by Maris Nartiss and the GRASS Development Team
+#
+#                This program is free software under the GNU General Public
+#                License (>=v2). Read the file COPYING that comes with GRASS
+#                for details.
+#
+#############################################################################
+
+# #3296
+# r.mapcalc calculates wrong median value if one of two input maps has a null value
+# Also depends on correct functioning of row() and col() mapcalc variables
+# https://trac.osgeo.org/grass/ticket/3296
+
+from grass.gunittest.case import TestCase
+from grass.gunittest.main import test
+
+
+OUTPUT = """\
+north: 3
+south: 0
+west: 0
+east: 3
+rows: 3
+cols: 3
+null: *
+1.0 1.0 1.0
+4.0 4.0 4.0
+9.0 9.0 9.0
+"""
+
+OUTPUT_CELL = """\
+north: 3
+south: 0
+west: 0
+east: 3
+rows: 3
+cols: 3
+null: *
+1 1 1
+4 4 4
+9 9 9
+"""
+
+
+class TestNmedianBug(TestCase):
+    to_remove = []
+    input = 'r_mapcalc_test_pattern'
+    output = 'r_mapcalc_test_output'
+    output_ref = 'r_mapcalc_test_output_ref'
+    output_cell = 'r_mapcalc_test_output_cell'
+
+    def setUp(self):
+        expression = "{o}=row()*col()".format(o=self.input)
+        self.use_temp_region()
+        self.runModule('g.region', n=3, s=0, e=3, w=0, res=1)
+        self.runModule('r.mapcalc', expression=expression, overwrite=True)
+        self.to_remove.append(self.input)
+        self.runModule('r.in.ascii', input='-', stdin_=OUTPUT,
+                       output=self.output_ref, overwrite=True)
+        self.to_remove.append(self.output_ref)
+        self.runModule('r.in.ascii', input='-', stdin_=OUTPUT_CELL,
+                       output=self.output_cell, overwrite=True)
+        self.to_remove.append(self.output_cell)
+
+    def tearDown(self):
+        self.del_temp_region()
+        if 0 and self.to_remove:
+            self.runModule('g.remove', flags='f', type='raster',
+                           name=','.join(self.to_remove), verbose=True)
+
+    def test_cell(self):
+        expression = "{o}=nmedian(({i}[0,-1] - {i})^2,({i}[0,1] - {i})^2)".format(o=self.output, i=self.input)
+        self.assertModule('r.mapcalc', expression=expression, overwrite=True)
+        self.assertRasterExists(self.output)
+        self.to_remove.append(self.output)
+        self.assertRastersNoDifference(actual=self.output,
+            reference=self.output_cell, precision=0)
+
+    def test_fcell(self):
+        expression = "{o}=nmedian(float(({i}[0,-1] - {i})^2), float(({i}[0,1] - {i})^2))".format(o=self.output, i=self.input)
+        self.assertModule('r.mapcalc', expression=expression, overwrite=True)
+        self.assertRasterExists(self.output)
+        self.to_remove.append(self.output)
+        self.assertRastersNoDifference(actual=self.output,
+            reference=self.output_ref, precision=0)
+    
+    def test_dcell(self):
+        expression = "{o}=nmedian(double(({i}[0,-1] - {i})^2), double(({i}[0,1] - {i})^2))".format(o=self.output, i=self.input)
+        self.assertModule('r.mapcalc', expression=expression, overwrite=True)
+        self.assertRasterExists(self.output)
+        self.to_remove.append(self.output)
+        self.assertRastersNoDifference(actual=self.output,
+            reference=self.output_ref, precision=0)
+
+
+if __name__ == '__main__':
+    test()



More information about the grass-commit mailing list