1*e1fe3e4aSElliott Hughesfrom fontTools.misc.fixedTools import ( 2*e1fe3e4aSElliott Hughes fixedToFloat, 3*e1fe3e4aSElliott Hughes floatToFixed, 4*e1fe3e4aSElliott Hughes floatToFixedToStr, 5*e1fe3e4aSElliott Hughes fixedToStr, 6*e1fe3e4aSElliott Hughes strToFixed, 7*e1fe3e4aSElliott Hughes strToFixedToFloat, 8*e1fe3e4aSElliott Hughes) 9*e1fe3e4aSElliott Hughesimport unittest 10*e1fe3e4aSElliott Hughes 11*e1fe3e4aSElliott Hughes 12*e1fe3e4aSElliott Hughesclass FixedToolsTest(unittest.TestCase): 13*e1fe3e4aSElliott Hughes def test_roundtrip(self): 14*e1fe3e4aSElliott Hughes for bits in range(0, 15): 15*e1fe3e4aSElliott Hughes for value in range(-(2 ** (bits + 1)), 2 ** (bits + 1)): 16*e1fe3e4aSElliott Hughes self.assertEqual(value, floatToFixed(fixedToFloat(value, bits), bits)) 17*e1fe3e4aSElliott Hughes 18*e1fe3e4aSElliott Hughes def test_fixedToFloat_precision14(self): 19*e1fe3e4aSElliott Hughes self.assertAlmostEqual(0.7999878, fixedToFloat(13107, 14)) 20*e1fe3e4aSElliott Hughes self.assertEqual(0.0, fixedToFloat(0, 14)) 21*e1fe3e4aSElliott Hughes self.assertEqual(1.0, fixedToFloat(16384, 14)) 22*e1fe3e4aSElliott Hughes self.assertEqual(-1.0, fixedToFloat(-16384, 14)) 23*e1fe3e4aSElliott Hughes self.assertAlmostEqual(0.999939, fixedToFloat(16383, 14)) 24*e1fe3e4aSElliott Hughes self.assertAlmostEqual(-0.999939, fixedToFloat(-16383, 14)) 25*e1fe3e4aSElliott Hughes 26*e1fe3e4aSElliott Hughes def test_fixedToFloat_precision6(self): 27*e1fe3e4aSElliott Hughes self.assertAlmostEqual(-9.984375, fixedToFloat(-639, 6)) 28*e1fe3e4aSElliott Hughes self.assertAlmostEqual(-10.0, fixedToFloat(-640, 6)) 29*e1fe3e4aSElliott Hughes self.assertAlmostEqual(9.984375, fixedToFloat(639, 6)) 30*e1fe3e4aSElliott Hughes self.assertAlmostEqual(10.0, fixedToFloat(640, 6)) 31*e1fe3e4aSElliott Hughes 32*e1fe3e4aSElliott Hughes def test_fixedToStr_precision14(self): 33*e1fe3e4aSElliott Hughes self.assertEqual("0.8", fixedToStr(13107, 14)) 34*e1fe3e4aSElliott Hughes self.assertEqual("0.0", fixedToStr(0, 14)) 35*e1fe3e4aSElliott Hughes self.assertEqual("1.0", fixedToStr(16384, 14)) 36*e1fe3e4aSElliott Hughes self.assertEqual("-1.0", fixedToStr(-16384, 14)) 37*e1fe3e4aSElliott Hughes self.assertEqual("0.99994", fixedToStr(16383, 14)) 38*e1fe3e4aSElliott Hughes self.assertEqual("-0.99994", fixedToStr(-16383, 14)) 39*e1fe3e4aSElliott Hughes 40*e1fe3e4aSElliott Hughes def test_fixedToStr_precision6(self): 41*e1fe3e4aSElliott Hughes self.assertAlmostEqual("-9.98", fixedToStr(-639, 6)) 42*e1fe3e4aSElliott Hughes self.assertAlmostEqual("-10.0", fixedToStr(-640, 6)) 43*e1fe3e4aSElliott Hughes self.assertAlmostEqual("9.98", fixedToStr(639, 6)) 44*e1fe3e4aSElliott Hughes self.assertAlmostEqual("10.0", fixedToStr(640, 6)) 45*e1fe3e4aSElliott Hughes 46*e1fe3e4aSElliott Hughes def test_floatToFixed_precision14(self): 47*e1fe3e4aSElliott Hughes self.assertEqual(13107, floatToFixed(0.8, 14)) 48*e1fe3e4aSElliott Hughes self.assertEqual(16384, floatToFixed(1.0, 14)) 49*e1fe3e4aSElliott Hughes self.assertEqual(16384, floatToFixed(1, 14)) 50*e1fe3e4aSElliott Hughes self.assertEqual(-16384, floatToFixed(-1.0, 14)) 51*e1fe3e4aSElliott Hughes self.assertEqual(-16384, floatToFixed(-1, 14)) 52*e1fe3e4aSElliott Hughes self.assertEqual(0, floatToFixed(0, 14)) 53*e1fe3e4aSElliott Hughes 54*e1fe3e4aSElliott Hughes def test_strToFixed_precision14(self): 55*e1fe3e4aSElliott Hughes self.assertEqual(13107, strToFixed("0.8", 14)) 56*e1fe3e4aSElliott Hughes self.assertEqual(16384, strToFixed("1.0", 14)) 57*e1fe3e4aSElliott Hughes self.assertEqual(16384, strToFixed("1", 14)) 58*e1fe3e4aSElliott Hughes self.assertEqual(-16384, strToFixed("-1.0", 14)) 59*e1fe3e4aSElliott Hughes self.assertEqual(-16384, strToFixed("-1", 14)) 60*e1fe3e4aSElliott Hughes self.assertEqual(0, strToFixed("0", 14)) 61*e1fe3e4aSElliott Hughes 62*e1fe3e4aSElliott Hughes def test_strToFixedToFloat_precision14(self): 63*e1fe3e4aSElliott Hughes self.assertAlmostEqual(0.7999878, strToFixedToFloat("0.8", 14)) 64*e1fe3e4aSElliott Hughes self.assertEqual(0.0, strToFixedToFloat("0", 14)) 65*e1fe3e4aSElliott Hughes self.assertEqual(1.0, strToFixedToFloat("1.0", 14)) 66*e1fe3e4aSElliott Hughes self.assertEqual(-1.0, strToFixedToFloat("-1.0", 14)) 67*e1fe3e4aSElliott Hughes self.assertAlmostEqual(0.999939, strToFixedToFloat("0.99994", 14)) 68*e1fe3e4aSElliott Hughes self.assertAlmostEqual(-0.999939, strToFixedToFloat("-0.99994", 14)) 69*e1fe3e4aSElliott Hughes 70*e1fe3e4aSElliott Hughes def test_floatToFixedToStr_precision14(self): 71*e1fe3e4aSElliott Hughes self.assertEqual("0.8", floatToFixedToStr(0.7999878, 14)) 72*e1fe3e4aSElliott Hughes self.assertEqual("1.0", floatToFixedToStr(1.0, 14)) 73*e1fe3e4aSElliott Hughes self.assertEqual("1.0", floatToFixedToStr(1, 14)) 74*e1fe3e4aSElliott Hughes self.assertEqual("-1.0", floatToFixedToStr(-1.0, 14)) 75*e1fe3e4aSElliott Hughes self.assertEqual("-1.0", floatToFixedToStr(-1, 14)) 76*e1fe3e4aSElliott Hughes self.assertEqual("0.0", floatToFixedToStr(0, 14)) 77*e1fe3e4aSElliott Hughes 78*e1fe3e4aSElliott Hughes def test_fixedToFloat_return_float(self): 79*e1fe3e4aSElliott Hughes value = fixedToFloat(16384, 14) 80*e1fe3e4aSElliott Hughes self.assertIsInstance(value, float) 81*e1fe3e4aSElliott Hughes 82*e1fe3e4aSElliott Hughes 83*e1fe3e4aSElliott Hughesif __name__ == "__main__": 84*e1fe3e4aSElliott Hughes import sys 85*e1fe3e4aSElliott Hughes 86*e1fe3e4aSElliott Hughes sys.exit(unittest.main()) 87