Skip to content

Commit

Permalink
Remove NaN values from raster before hash calculation
Browse files Browse the repository at this point in the history
  • Loading branch information
Médéric RIBREUX committed May 29, 2016
1 parent 235f986 commit ec6b29a
Show file tree
Hide file tree
Showing 3 changed files with 26 additions and 22 deletions.
5 changes: 4 additions & 1 deletion python/plugins/processing/gui/TestTools.py
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,8 @@
from osgeo import gdal
from osgeo.gdalconst import GA_ReadOnly

from numpy import nan_to_num

from qgis.PyQt.QtCore import QCoreApplication, QMetaObject
from qgis.PyQt.QtWidgets import QDialog, QVBoxLayout, QTextEdit

Expand Down Expand Up @@ -195,7 +197,8 @@ def createTest(text):
elif isinstance(out, OutputRaster):
filename = token[1:-1]
dataset = gdal.Open(filename, GA_ReadOnly)
strhash = hashlib.sha224(dataset.ReadAsArray(0).data).hexdigest()
dataArray = nan_to_num(dataset.ReadAsArray(0))
strhash = hashlib.sha224(dataArray.data).hexdigest()

results[out.name] = {
'type': 'rasterhash',
Expand Down
7 changes: 4 additions & 3 deletions python/plugins/processing/tests/AlgorithmsTestBase.py
Original file line number Diff line number Diff line change
Expand Up @@ -34,6 +34,7 @@
import tempfile

from osgeo.gdalconst import GA_ReadOnly
from numpy import nan_to_num

import processing
from processing.modeler.ModelerAlgorithmProvider import ModelerAlgorithmProvider
Expand Down Expand Up @@ -100,7 +101,7 @@ def check_algorithm(self, name, defs):

expectFailure = False
if 'expectedFailure' in defs:
exec('\n'.join(defs['expectedFailure'][:-1])) in globals(), locals()
exec('\n'.join(defs['expectedFailure'][:-1]) in globals(), locals()
expectFailure = eval(defs['expectedFailure'][-1])

if expectFailure:
Expand All @@ -114,7 +115,6 @@ def check_algorithm(self, name, defs):
else:
alg.execute()
self.check_results(alg.getOutputValuesAsDictionary(), defs['results'])


def load_params(self, params):
"""
Expand Down Expand Up @@ -210,7 +210,8 @@ def check_results(self, results, expected):

elif 'rasterhash' == expected_result['type']:
dataset = gdal.Open(results[id], GA_ReadOnly)
strhash = hashlib.sha224(dataset.ReadAsArray(0).data).hexdigest()
dataArray = nan_to_num(dataset.ReadAsArray(0))
strhash = hashlib.sha224(dataArray.data).hexdigest()

self.assertEqual(strhash, expected_result['hash'])
elif 'file' == expected_result['type']:
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,7 @@ tests:
results:
output:
type: rasterhash
hash: 80fe9e022cff3d4cad57fbad40aa7f547b3621a4eec94629d69e16ed
hash: cef69ed56f0b0f991ae2f7f2a54b8a29319eaf8b7d65653c75cbf985

- algorithm: grass7:i.biomass
name: GRASS7 i.biomass
Expand All @@ -38,7 +38,7 @@ tests:
type: raster
results:
output:
hash: edbbf2a0866a2fdfa01996d5bef5a06862df2a54c020fc8b1e4aa51a
hash: 358c7745aaa5d7fbc56b34a21821fdfdc61f68e6ca79fb996a2241d8
type: rasterhash

- algorithm: grass7:i.eb.eta
Expand All @@ -56,7 +56,7 @@ tests:
type: raster
results:
output:
hash: 5143d76a4d32395f4cfaf22aab33c5ae47f2c219eebbb888663a4e85
hash: 23e65e4c5384b48d7151f781bab10e5caa398b36d363ff8c1049c917
type: rasterhash

- algorithm: grass7:i.eb.netrad
Expand Down Expand Up @@ -92,7 +92,7 @@ tests:
type: raster
results:
output:
hash: b38052d5d446aad62dfe46c84d0fb949b9ba0b6f43aa7c95e3de2c92
hash: 361d48c66d978d4844ae7c073c9e6d042fdc8c7739b889a1efce3c3f
type: rasterhash

- algorithm: grass7:i.eb.soilheatflux
Expand All @@ -117,7 +117,7 @@ tests:
type: raster
results:
output:
hash: aa195846f7a93d4141c01170751afad055ab6d1caa74cc888c4ad398
hash: a25c4b750dd1f2f2124a117c80ac3f0e3d9b353618a86389eca794e8
type: rasterhash

- algorithm: grass7:i.evapo.mh
Expand All @@ -139,7 +139,7 @@ tests:
type: raster
results:
output:
hash: 9bdbd441804b613f0fdb2449572b69fdc3431113810330693c45b87f
hash: b0211772fe8e2c3d8c713551137f014756eb63ccd12f95a322f63ce0
type: rasterhash

- algorithm: grass7:i.evapo.pm
Expand All @@ -166,7 +166,7 @@ tests:
type: raster
results:
output:
hash: 7d649cefbf6b0d5581c9cafb285c0598827198fd6f313909325979d7
hash: 419ae792b057d2324354ce76d971d01e36751cf1c45cf3d856634576
type: rasterhash

- algorithm: grass7:i.evapo.pt
Expand All @@ -188,7 +188,7 @@ tests:
type: raster
results:
output:
hash: 9bdbd441804b613f0fdb2449572b69fdc3431113810330693c45b87f
hash: b0211772fe8e2c3d8c713551137f014756eb63ccd12f95a322f63ce0
type: rasterhash

- algorithm: grass7:i.topo.coor.ill
Expand All @@ -202,7 +202,7 @@ tests:
zenith: 50
results:
output:
hash: d1eb7882b3d68f2bc5785dc052b1c870d84e9a232b72607ca4d7da45
hash: b08dc5b47f557ecadf0c125c99f249e49111c44e43f463c2444ab474
type: rasterhash

- algorithm: grass7:i.vi
Expand All @@ -219,7 +219,7 @@ tests:
viname: 10
results:
output:
hash: 9bdbd441804b613f0fdb2449572b69fdc3431113810330693c45b87f
hash: b0211772fe8e2c3d8c713551137f014756eb63ccd12f95a322f63ce0
type: rasterhash

- algorithm: grass7:i.zc
Expand Down Expand Up @@ -323,7 +323,7 @@ tests:
type: raster
results:
imaginary:
hash: 0a64ae8d6ba603cbedeee7706df0942f4d7221e394bc76939f33a3dc
hash: 94249384dd8b6019f0024501bc9a093cba9dd025c183d3fb46d77027
type: rasterhash
real:
hash: 09ab93c65aa2dde4da422b62a5ed3e38208e2da072cec2b0eb837a47
Expand All @@ -350,7 +350,7 @@ tests:
threshold: 0.5
results:
goodness:
hash: 597d8962276c360ef1efc0b8647c3bd773b5e98898d4e56a2d82928f
hash: 4d7728e28734d2b67427a514bcd155d254d30b3424bf4e0ad8f0f0c6
type: rasterhash
output:
hash: b65992a5d48b867d4a32a533f38e7a72cb1ba18f1e261c6be132baca
Expand Down Expand Up @@ -434,13 +434,13 @@ tests:
type: raster
results:
blueoutput:
hash: 75bac89afee968cd5d7027de1acfff3b02a7517eb136f3b73e49b2fa
hash: 906de8be89e302057ed849d00eaf49332ecca73ffaba1374994f1a17
type: rasterhash
greenoutput:
hash: e11274dddcd5f169f03957f41ece1fde7625b8ace342de258ba2873b
hash: 588ad1ef8360ce903fc2defb1a1728a1dc8335d737d5fa77797605ed
type: rasterhash
redoutput:
hash: 9fc943dcf4fcead4f2c662bb6e3f0455caed5df1d9f46ae763955001
hash: ad80c0007faa1b0dc15c0b0c21ff4e0045ff5e67b454df0f65e68899
type: rasterhash

- algorithm: grass7:i.smap
Expand Down Expand Up @@ -538,7 +538,7 @@ tests:
vapourpressureactual: 1.511
results:
output:
hash: 10a7144d393e716f721265057d1d1603baa627ceb7c6b29e30865a58
hash: cac9e91f9b5182fbad336fd46ecebcf5185327e009ae8dc4cc0367fc
type: rasterhash

- algorithm: grass7:i.modis.qc
Expand Down Expand Up @@ -597,7 +597,7 @@ tests:
vapourpressureactual: 1.511
results:
output:
hash: 77e31601b511602b998168f715756a87a3735b07131a99b27e2de241
hash: b0211772fe8e2c3d8c713551137f014756eb63ccd12f95a322f63ce0
type: rasterhash

- algorithm: grass7:i.atcorr
Expand All @@ -615,5 +615,5 @@ tests:
name: custom/grass7/i.atcorr.txt
results:
output:
hash: 46dea0dc5e5a3fed82aed98aa1cb6fe82deb8f1ac0347e930d4bbbeb
hash: e5fada2ec43658e25a34d0486e810dec1cad289b626f6d1c4bbfea18
type: rasterhash

0 comments on commit ec6b29a

Please sign in to comment.