blob: 0cdc9bd4653b6f8fbd54576ad59013b14d6ea7a1 [file] [log] [blame]
// Copyright 2016 The Fuchsia Authors
// Copyright (c) 2014 Travis Geiselbrecht
//
// Use of this source code is governed by a MIT-style
// license that can be found in the LICENSE file or at
// https://opensource.org/licenses/MIT
#include <stdint.h>
union double_int {
double d;
uint64_t i;
};
static const union double_int float_test_vec[] = {
{.d = -2.0},
{.d = -1.0},
{.d = -0.5},
{.d = -0.0},
{.d = 0.0},
{.d = 0.01},
{.d = 0.1},
{.d = 0.2},
{.d = 0.25},
{.d = 0.5},
{.d = 0.75},
{.d = 1.0},
{.d = 2.0},
{.d = 3.0},
{.d = 10.0},
{.d = 100.0},
{.d = 123456.0},
{.d = -123456.0},
{.d = 546.5645644531f},
{.d = -546.5645644531f},
{.d = 0.12345},
{.d = 0.0000012345},
{.d = 0.0000019999},
{.d = 0.0000015},
{.i = 0x4005bf0a8b145649ULL}, // e
{.i = 0x400921fb54442d18ULL}, // pi
{.i = 0x43f0000000000000ULL}, // 2^64
{.i = 0x7fefffffffffffffULL}, // largest normalized
{.i = 0x0010000000000000ULL}, // least positive normalized
{.i = 0x0000000000000001ULL}, // smallest possible denorm
{.i = 0x000fffffffffffffULL}, // largest possible denorm
{.i = 0x7ff0000000000001ULL}, // smallest SNAn
{.i = 0x7ff7ffffffffffffULL}, // largest SNAn
{.i = 0x7ff8000000000000ULL}, // smallest QNAn
{.i = 0x7fffffffffffffffULL}, // largest QNAn
{.i = 0xfff0000000000000ULL}, // -infinity
{.i = 0x7ff0000000000000ULL}, // +infinity
};
#define countof(a) (sizeof(a) / sizeof((a)[0]))
static const unsigned int float_test_vec_size = countof(float_test_vec);
#define PRINT_FLOAT \
printf("0x%016llx %f %F %a %A\n", \
float_test_vec[i], \
*(const double*)&float_test_vec[i], \
*(const double*)&float_test_vec[i], \
*(const double*)&float_test_vec[i], \
*(const double*)&float_test_vec[i])