diff options
author | Matt Arsenault <Matthew.Arsenault@amd.com> | 2014-10-10 05:21:32 +0000 |
---|---|---|
committer | Matt Arsenault <Matthew.Arsenault@amd.com> | 2014-10-10 05:21:32 +0000 |
commit | 5ccdb98c6846159a6cbcf3284ac3ede353ef1717 (patch) | |
tree | cdf2bf91fd574aeacc9084621e8de5a3d5fbb4f1 /llvm/unittests/ADT/APFloatTest.cpp | |
parent | ca067148b2fe604036fb4f0f9b59c539ab5802cc (diff) | |
download | bcm5719-llvm-5ccdb98c6846159a6cbcf3284ac3ede353ef1717.tar.gz bcm5719-llvm-5ccdb98c6846159a6cbcf3284ac3ede353ef1717.zip |
Add minnum / maxnum to APFloat
llvm-svn: 219475
Diffstat (limited to 'llvm/unittests/ADT/APFloatTest.cpp')
-rw-r--r-- | llvm/unittests/ADT/APFloatTest.cpp | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/llvm/unittests/ADT/APFloatTest.cpp b/llvm/unittests/ADT/APFloatTest.cpp index 8a29b86b785..880e8317084 100644 --- a/llvm/unittests/ADT/APFloatTest.cpp +++ b/llvm/unittests/ADT/APFloatTest.cpp @@ -476,6 +476,28 @@ TEST(APFloatTest, FMA) { } } +TEST(APFloatTest, MinNum) { + APFloat f1(1.0); + APFloat f2(2.0); + APFloat nan = APFloat::getNaN(APFloat::IEEEdouble); + + EXPECT_EQ(1.0, minnum(f1, f2).convertToDouble()); + EXPECT_EQ(1.0, minnum(f2, f1).convertToDouble()); + EXPECT_EQ(1.0, minnum(f1, nan).convertToDouble()); + EXPECT_EQ(1.0, minnum(nan, f1).convertToDouble()); +} + +TEST(APFloatTest, MaxNum) { + APFloat f1(1.0); + APFloat f2(2.0); + APFloat nan = APFloat::getNaN(APFloat::IEEEdouble); + + EXPECT_EQ(2.0, maxnum(f1, f2).convertToDouble()); + EXPECT_EQ(2.0, maxnum(f2, f1).convertToDouble()); + EXPECT_EQ(1.0, maxnum(f1, nan).convertToDouble()); + EXPECT_EQ(1.0, minnum(nan, f1).convertToDouble()); +} + TEST(APFloatTest, Denormal) { APFloat::roundingMode rdmd = APFloat::rmNearestTiesToEven; |