mirror of https://github.com/ecmwf/eccodes.git
Test program for converting between ieee and unsigned long
This commit is contained in:
parent
f8762d9191
commit
f3b8681563
|
@ -26,6 +26,7 @@ list( APPEND test_bins
|
|||
optimize_scaling_sh
|
||||
ecc-386
|
||||
bufr_get_element
|
||||
ieee
|
||||
)
|
||||
|
||||
foreach( tool ${test_bins} )
|
||||
|
|
48
tests/ieee.c
48
tests/ieee.c
|
@ -9,6 +9,7 @@
|
|||
*/
|
||||
|
||||
#include <stdio.h>
|
||||
#include <assert.h>
|
||||
|
||||
#include "grib_api_internal.h"
|
||||
|
||||
|
@ -16,11 +17,23 @@ double min = -1.0000000001;
|
|||
double max = -1.00000000001;
|
||||
double scale ;
|
||||
|
||||
typedef unsigned long (*ieee_to_long_proc) (double);
|
||||
typedef double (*long_to_ieee_proc) (unsigned long);
|
||||
|
||||
void test(unsigned long input, ieee_to_long_proc ieee_to_long, long_to_ieee_proc long_to_ieee)
|
||||
{
|
||||
double x1 = long_to_ieee(input);
|
||||
unsigned long num2 = ieee_to_long(x1);
|
||||
printf("\nconv input=%ld to double=%.10f (%g) and back => %ld\n", input, x1, x1, num2);
|
||||
if (num2!=input) printf("ERROR: input=%ld not equal!!!\n", input);
|
||||
}
|
||||
|
||||
|
||||
#if 0
|
||||
double p(double ref1,double ref2)
|
||||
{
|
||||
double scale = (max-ref1) / 65535;
|
||||
|
||||
|
||||
unsigned long pack = (unsigned long)(((max - ref1)/scale)+0.5);
|
||||
double unpack = pack*scale + ref2;
|
||||
|
||||
|
@ -33,48 +46,49 @@ double p(double ref1,double ref2)
|
|||
|
||||
return unpack;
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
int main(int argc, char *argv[])
|
||||
{
|
||||
#if 1
|
||||
unsigned long i = 0;
|
||||
|
||||
test(3242539564, grib_ieee_to_long, grib_long_to_ieee);
|
||||
assert(grib_ieee_to_long(grib_long_to_ieee(i)) == i);
|
||||
|
||||
for(i = 1; i < 0x7fffffff; i++)
|
||||
/* The minimum value for which we can convert a long to ieee and back is 0x800000 */
|
||||
/* The maximum value for which we can convert a long to ieee and back is 0x7f800000 */
|
||||
for(i = 0x800000; i < 0x7f800000; i++)
|
||||
{
|
||||
unsigned long j = i | 0x80000000;
|
||||
/*unsigned long j = i | 0x80000000;*/
|
||||
|
||||
if(grib_ieee_to_long(grib_long_to_ieee(i)) != i)
|
||||
{
|
||||
printf("i=%ld i=%lx e=%g x=%lx\n",i,i,grib_long_to_ieee(i),grib_ieee_to_long(grib_long_to_ieee(i)));
|
||||
assert(grib_ieee_to_long(grib_long_to_ieee(i)) == i);
|
||||
/*assert(grib_ieee_to_long(grib_long_to_ieee(i)) == i);*/
|
||||
}
|
||||
assert(grib_ieee_to_long(grib_long_to_ieee(j)) == j);
|
||||
if((i%100000) == 0)
|
||||
printf("i = %08lx %08lx %g %g\n",i,j,grib_long_to_ieee(i),grib_long_to_ieee(j));
|
||||
/*if(grib_ieee_to_long(grib_long_to_ieee(j)) != j)
|
||||
{
|
||||
printf("j=%ld i=%lx e=%g x=%lx\n",j,j,grib_long_to_ieee(j),grib_ieee_to_long(grib_long_to_ieee(j)));
|
||||
}
|
||||
*/
|
||||
/*if((i%10000000) == 0)
|
||||
printf("i = %08lx(%ld) %08lx(%ld) %g %g\n", i,i,j,j,grib_long_to_ieee(i),grib_long_to_ieee(j));*/
|
||||
}
|
||||
|
||||
#else
|
||||
|
||||
|
||||
double ref1 = grib_long_to_ieee(grib_ieee_to_long(min));
|
||||
double ref2 = grib_nearest_smaller_ieee_float(min);
|
||||
|
||||
|
||||
double a = p(min,ref1);
|
||||
double b = p(min,ref2);
|
||||
double c = p(ref1,ref1);
|
||||
double d = p(ref2,ref2);
|
||||
|
||||
|
||||
assert(min<max);
|
||||
|
||||
|
||||
/* */
|
||||
|
||||
assert(min<max);
|
||||
|
||||
#endif
|
||||
|
||||
printf("ALL DONE\n");
|
||||
return 0;
|
||||
}
|
||||
|
|
Loading…
Reference in New Issue