Skip to content

Commit

Permalink
Vertical grid shift: do not interpolate node values at nodata value (f…
Browse files Browse the repository at this point in the history
…ixes #1002)
  • Loading branch information
rouault committed May 19, 2018
1 parent 39581f3 commit 4f987df
Show file tree
Hide file tree
Showing 3 changed files with 62 additions and 15 deletions.
Binary file added nad/tests/test_nodata.gtx
Binary file not shown.
65 changes: 50 additions & 15 deletions src/pj_apply_vgridshift.c
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,15 @@
#include "proj_internal.h"
#include "projects.h"

static int is_nodata(float value)
{
/* nodata? */
/* GTX official nodata value if -88.88880f, but some grids also */
/* use other big values for nodata (e.g naptrans2008.gtx has */
/* nodata values like -2147479936), so test them too */
return value > 1000 || value < -1000 || value == -88.88880f;
}

static double read_vgrid_value( PJ *defn, LP input, int *gridlist_count_p, PJ_GRIDINFO **tables, struct CTABLE *ct) {
int itable = 0;
double value = HUGE_VAL;
Expand Down Expand Up @@ -112,23 +121,49 @@ static double read_vgrid_value( PJ *defn, LP input, int *gridlist_count_p, PJ_GR
grid_iy2 = ct->lim.phi - 1;

cvs = (float *) ct->cvs;
value = cvs[grid_ix + grid_iy * ct->lim.lam]
* (1.0-grid_x) * (1.0-grid_y)
+ cvs[grid_ix2 + grid_iy * ct->lim.lam]
* (grid_x) * (1.0-grid_y)
+ cvs[grid_ix + grid_iy2 * ct->lim.lam]
* (1.0-grid_x) * (grid_y)
+ cvs[grid_ix2 + grid_iy2 * ct->lim.lam]
* (grid_x) * (grid_y);
{
float value_a = cvs[grid_ix + grid_iy * ct->lim.lam];
float value_b = cvs[grid_ix2 + grid_iy * ct->lim.lam];
float value_c = cvs[grid_ix + grid_iy2 * ct->lim.lam];
float value_d = cvs[grid_ix2 + grid_iy2 * ct->lim.lam];
double total_weight = 0.0;
int n_weights = 0;
value = 0.0f;
if( !is_nodata(value_a) )
{
double weight = (1.0-grid_x) * (1.0-grid_y);
value += value_a * weight;
total_weight += weight;
n_weights ++;
}
if( !is_nodata(value_b) )
{
double weight = (grid_x) * (1.0-grid_y);
value += value_b * weight;
total_weight += weight;
n_weights ++;
}
if( !is_nodata(value_c) )
{
double weight = (1.0-grid_x) * (grid_y);
value += value_c * weight;
total_weight += weight;
n_weights ++;
}
if( !is_nodata(value_d) )
{
double weight = (grid_x) * (grid_y);
value += value_d * weight;
total_weight += weight;
n_weights ++;
}
if( n_weights == 0 )
value = HUGE_VAL;
else if( n_weights != 4 )
value /= total_weight;
}

}
/* nodata? */
/* GTX official nodata value if -88.88880f, but some grids also */
/* use other big values for nodata (e.g naptrans2008.gtx has */
/* nodata values like -2147479936), so test them too */
if( value > 1000 || value < -1000 || value == -88.88880f )
value = HUGE_VAL;


return value;
}
Expand Down
12 changes: 12 additions & 0 deletions test/gie/4D-API_cs2cs-style.gie
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@

-------------------------------------------------------------------------------
===============================================================================

Test the 4D API handling of cs2cs style transformation options.
Expand Down Expand Up @@ -278,4 +280,14 @@ expect 1335.8339 7522.963
-------------------------------------------------------------------------------


-------------------------------------------------------------------------------
Test bugfix of /~https://github.com/OSGeo/proj.4/issues/1002
(do not interpolate nodata values)
-------------------------------------------------------------------------------
operation +proj=latlong +ellps=WGS84 +geoidgrids=tests/test_nodata.gtx
-------------------------------------------------------------------------------
accept 4.05 52.1 0
expect 4.05 52.1 -10
-------------------------------------------------------------------------------

</gie>

0 comments on commit 4f987df

Please sign in to comment.