1*35238bceSAndroid Build Coastguard Worker #ifndef _TCUFLOATFORMAT_HPP 2*35238bceSAndroid Build Coastguard Worker #define _TCUFLOATFORMAT_HPP 3*35238bceSAndroid Build Coastguard Worker /*------------------------------------------------------------------------- 4*35238bceSAndroid Build Coastguard Worker * drawElements Quality Program Tester Core 5*35238bceSAndroid Build Coastguard Worker * ---------------------------------------- 6*35238bceSAndroid Build Coastguard Worker * 7*35238bceSAndroid Build Coastguard Worker * Copyright 2014 The Android Open Source Project 8*35238bceSAndroid Build Coastguard Worker * 9*35238bceSAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 10*35238bceSAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 11*35238bceSAndroid Build Coastguard Worker * You may obtain a copy of the License at 12*35238bceSAndroid Build Coastguard Worker * 13*35238bceSAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 14*35238bceSAndroid Build Coastguard Worker * 15*35238bceSAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 16*35238bceSAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 17*35238bceSAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 18*35238bceSAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 19*35238bceSAndroid Build Coastguard Worker * limitations under the License. 20*35238bceSAndroid Build Coastguard Worker * 21*35238bceSAndroid Build Coastguard Worker *//*! 22*35238bceSAndroid Build Coastguard Worker * \file 23*35238bceSAndroid Build Coastguard Worker * \brief Adjustable-precision floating point operations. 24*35238bceSAndroid Build Coastguard Worker *//*--------------------------------------------------------------------*/ 25*35238bceSAndroid Build Coastguard Worker 26*35238bceSAndroid Build Coastguard Worker #include "tcuDefs.hpp" 27*35238bceSAndroid Build Coastguard Worker #include "tcuInterval.hpp" 28*35238bceSAndroid Build Coastguard Worker 29*35238bceSAndroid Build Coastguard Worker #include <string> 30*35238bceSAndroid Build Coastguard Worker 31*35238bceSAndroid Build Coastguard Worker namespace tcu 32*35238bceSAndroid Build Coastguard Worker { 33*35238bceSAndroid Build Coastguard Worker 34*35238bceSAndroid Build Coastguard Worker enum YesNoMaybe 35*35238bceSAndroid Build Coastguard Worker { 36*35238bceSAndroid Build Coastguard Worker NO, 37*35238bceSAndroid Build Coastguard Worker MAYBE, 38*35238bceSAndroid Build Coastguard Worker YES 39*35238bceSAndroid Build Coastguard Worker }; 40*35238bceSAndroid Build Coastguard Worker 41*35238bceSAndroid Build Coastguard Worker class FloatFormat 42*35238bceSAndroid Build Coastguard Worker { 43*35238bceSAndroid Build Coastguard Worker public: 44*35238bceSAndroid Build Coastguard Worker FloatFormat(int minExp, int maxExp, int fractionBits, bool exactPrecision, YesNoMaybe hasSubnormal = MAYBE, 45*35238bceSAndroid Build Coastguard Worker YesNoMaybe hasInf = MAYBE, YesNoMaybe hasNaN = MAYBE); ~FloatFormat()46*35238bceSAndroid Build Coastguard Worker virtual ~FloatFormat() 47*35238bceSAndroid Build Coastguard Worker { 48*35238bceSAndroid Build Coastguard Worker } 49*35238bceSAndroid Build Coastguard Worker getMinExp(void) const50*35238bceSAndroid Build Coastguard Worker int getMinExp(void) const 51*35238bceSAndroid Build Coastguard Worker { 52*35238bceSAndroid Build Coastguard Worker return m_minExp; 53*35238bceSAndroid Build Coastguard Worker } getMaxExp(void) const54*35238bceSAndroid Build Coastguard Worker int getMaxExp(void) const 55*35238bceSAndroid Build Coastguard Worker { 56*35238bceSAndroid Build Coastguard Worker return m_maxExp; 57*35238bceSAndroid Build Coastguard Worker } getMaxValue(void) const58*35238bceSAndroid Build Coastguard Worker double getMaxValue(void) const 59*35238bceSAndroid Build Coastguard Worker { 60*35238bceSAndroid Build Coastguard Worker return m_maxValue; 61*35238bceSAndroid Build Coastguard Worker } getFractionBits(void) const62*35238bceSAndroid Build Coastguard Worker int getFractionBits(void) const 63*35238bceSAndroid Build Coastguard Worker { 64*35238bceSAndroid Build Coastguard Worker return m_fractionBits; 65*35238bceSAndroid Build Coastguard Worker } hasInf(void) const66*35238bceSAndroid Build Coastguard Worker YesNoMaybe hasInf(void) const 67*35238bceSAndroid Build Coastguard Worker { 68*35238bceSAndroid Build Coastguard Worker return m_hasInf; 69*35238bceSAndroid Build Coastguard Worker } hasSubnormal(void) const70*35238bceSAndroid Build Coastguard Worker YesNoMaybe hasSubnormal(void) const 71*35238bceSAndroid Build Coastguard Worker { 72*35238bceSAndroid Build Coastguard Worker return m_hasSubnormal; 73*35238bceSAndroid Build Coastguard Worker } 74*35238bceSAndroid Build Coastguard Worker 75*35238bceSAndroid Build Coastguard Worker virtual double ulp(double x, double count = 1.0) const; 76*35238bceSAndroid Build Coastguard Worker Interval roundOut(const Interval &x, bool roundUnderOverflow) const; 77*35238bceSAndroid Build Coastguard Worker virtual double round(double d, bool upward) const; 78*35238bceSAndroid Build Coastguard Worker virtual double roundOut(double d, bool upward, bool roundUnderOverflow) const; 79*35238bceSAndroid Build Coastguard Worker Interval convert(const Interval &x) const; 80*35238bceSAndroid Build Coastguard Worker 81*35238bceSAndroid Build Coastguard Worker std::string floatToHex(double x) const; 82*35238bceSAndroid Build Coastguard Worker std::string intervalToHex(const Interval &interval) const; 83*35238bceSAndroid Build Coastguard Worker 84*35238bceSAndroid Build Coastguard Worker static FloatFormat nativeFloat(void); 85*35238bceSAndroid Build Coastguard Worker static FloatFormat nativeDouble(void); 86*35238bceSAndroid Build Coastguard Worker 87*35238bceSAndroid Build Coastguard Worker private: 88*35238bceSAndroid Build Coastguard Worker int exponentShift(int exp) const; 89*35238bceSAndroid Build Coastguard Worker Interval clampValue(double d) const; 90*35238bceSAndroid Build Coastguard Worker 91*35238bceSAndroid Build Coastguard Worker int m_minExp; // Minimum exponent, inclusive 92*35238bceSAndroid Build Coastguard Worker int m_maxExp; // Maximum exponent, inclusive 93*35238bceSAndroid Build Coastguard Worker int m_fractionBits; // Number of fractional bits in significand 94*35238bceSAndroid Build Coastguard Worker YesNoMaybe m_hasSubnormal; // Does the format support denormalized numbers? 95*35238bceSAndroid Build Coastguard Worker YesNoMaybe m_hasInf; // Does the format support infinities? 96*35238bceSAndroid Build Coastguard Worker YesNoMaybe m_hasNaN; // Does the format support NaNs? 97*35238bceSAndroid Build Coastguard Worker bool m_exactPrecision; // Are larger precisions disallowed? 98*35238bceSAndroid Build Coastguard Worker double m_maxValue; // Largest representable finite value. 99*35238bceSAndroid Build Coastguard Worker } DE_WARN_UNUSED_TYPE; 100*35238bceSAndroid Build Coastguard Worker 101*35238bceSAndroid Build Coastguard Worker class NormalizedFormat : public FloatFormat 102*35238bceSAndroid Build Coastguard Worker { 103*35238bceSAndroid Build Coastguard Worker public: 104*35238bceSAndroid Build Coastguard Worker NormalizedFormat(int fractionBits); ~NormalizedFormat()105*35238bceSAndroid Build Coastguard Worker ~NormalizedFormat() 106*35238bceSAndroid Build Coastguard Worker { 107*35238bceSAndroid Build Coastguard Worker } 108*35238bceSAndroid Build Coastguard Worker 109*35238bceSAndroid Build Coastguard Worker double ulp(double x, double count = 1.0) const override; 110*35238bceSAndroid Build Coastguard Worker double round(double d, bool upward) const override; 111*35238bceSAndroid Build Coastguard Worker double roundOut(double d, bool upward, bool roundUnderOverflow) const override; 112*35238bceSAndroid Build Coastguard Worker 113*35238bceSAndroid Build Coastguard Worker } DE_WARN_UNUSED_TYPE; 114*35238bceSAndroid Build Coastguard Worker 115*35238bceSAndroid Build Coastguard Worker void FloatFormat_selfTest(void); 116*35238bceSAndroid Build Coastguard Worker 117*35238bceSAndroid Build Coastguard Worker } // namespace tcu 118*35238bceSAndroid Build Coastguard Worker 119*35238bceSAndroid Build Coastguard Worker #endif // _TCUFLOATFORMAT_HPP 120