mirror of
				https://github.com/django/django.git
				synced 2025-10-24 22:26:08 +00:00 
			
		
		
		
	Refs #26592 -- Fixed band statistics for empty bands and GDAL 2.1
This commit is contained in:
		
				
					committed by
					
						 Claude Paroz
						Claude Paroz
					
				
			
			
				
	
			
			
			
						parent
						
							aa69f36984
						
					
				
				
					commit
					078eb87626
				
			| @@ -74,12 +74,10 @@ get_band_statistics = void_output( | ||||
|         c_void_p, c_int, c_int, POINTER(c_double), POINTER(c_double), | ||||
|         POINTER(c_double), POINTER(c_double), c_void_p, c_void_p, | ||||
|     ], | ||||
|     errcheck=False | ||||
| ) | ||||
| compute_band_statistics = void_output( | ||||
|     std_call('GDALComputeRasterStatistics'), | ||||
|     [c_void_p, c_int, POINTER(c_double), POINTER(c_double), POINTER(c_double), POINTER(c_double), c_void_p, c_void_p], | ||||
|     errcheck=False | ||||
| ) | ||||
|  | ||||
| # Reprojection routine | ||||
|   | ||||
| @@ -1,4 +1,3 @@ | ||||
| import math | ||||
| from ctypes import byref, c_double, c_int, c_void_p | ||||
|  | ||||
| from django.contrib.gis.gdal.base import GDALBase | ||||
| @@ -85,18 +84,19 @@ class GDALBand(GDALBase): | ||||
|         ] | ||||
|  | ||||
|         if refresh or self._stats_refresh: | ||||
|             capi.compute_band_statistics(*stats_args) | ||||
|             func = capi.compute_band_statistics | ||||
|         else: | ||||
|             # Add additional argument to force computation if there is no | ||||
|             # existing PAM file to take the values from. | ||||
|             force = True | ||||
|             stats_args.insert(2, c_int(force)) | ||||
|             capi.get_band_statistics(*stats_args) | ||||
|             func = capi.get_band_statistics | ||||
|  | ||||
|         result = smin.value, smax.value, smean.value, sstd.value | ||||
|  | ||||
|         # Check if band is empty (in that case, set all statistics to None) | ||||
|         if any((math.isnan(val) for val in result)): | ||||
|         # Computation of statistics fails for empty bands. | ||||
|         try: | ||||
|             func(*stats_args) | ||||
|             result = smin.value, smax.value, smean.value, sstd.value | ||||
|         except GDALException: | ||||
|             result = (None, None, None, None) | ||||
|  | ||||
|         self._stats_refresh = False | ||||
|   | ||||
		Reference in New Issue
	
	Block a user