blob: 0bbdd4a1e69064233ee9f9bb4778f9f59a6b47aa [file] [log] [blame]
/*
* Copyright 2014 Google Inc.
*
* Use of this source code is governed by a BSD-style license that can be
* found in the LICENSE file.
*/
#ifndef SkHalf_DEFINED
#define SkHalf_DEFINED
#include <cstdint>
// 16-bit floating point value
// format is 1 bit sign, 5 bits exponent, 10 bits mantissa
// only used for storage
using SkHalf = uint16_t;
static constexpr uint16_t SK_HalfNaN = 0x7c01; // a NaN value, not all possible NaN values
static constexpr uint16_t SK_HalfInfinity = 0x7c00;
static constexpr uint16_t SK_HalfMin = 0x0400; // 2^-14 (minimum positive normal value)
static constexpr uint16_t SK_HalfMax = 0x7bff; // 65504 (maximum positive normal value)
static constexpr uint16_t SK_HalfEpsilon = 0x1400; // 2^-10
static constexpr uint16_t SK_Half1 = 0x3C00; // 1
// Convert between half and single precision floating point. Vectorized functions
// skvx::from_half and skvx::to_half are also available. Unlike skvx::to_half, this will
// correctly handle float NaN -> half NaN.
float SkHalfToFloat(SkHalf h);
SkHalf SkFloatToHalf(float f);
#endif