|
14 | 14 | #include "llvm/Support/Alignment.h"
|
15 | 15 | #include "gtest/gtest.h"
|
16 | 16 | #include <array>
|
| 17 | +#include <climits> |
17 | 18 | #include <optional>
|
18 | 19 |
|
19 | 20 | using namespace llvm;
|
@@ -2877,6 +2878,91 @@ TEST(APIntTest, RoundingSDiv) {
|
2877 | 2878 | }
|
2878 | 2879 | }
|
2879 | 2880 |
|
| 2881 | +TEST(APIntTest, Average) { |
| 2882 | + APInt A0(32, 0); |
| 2883 | + APInt A2(32, 2); |
| 2884 | + APInt A100(32, 100); |
| 2885 | + APInt A101(32, 101); |
| 2886 | + APInt A200(32, 200, false); |
| 2887 | + APInt ApUMax(32, UINT_MAX, false); |
| 2888 | + |
| 2889 | + EXPECT_EQ(APInt(32, 150), APIntOps::avgFloorU(A100, A200)); |
| 2890 | + EXPECT_EQ(APIntOps::RoundingUDiv(A100 + A200, A2, APInt::Rounding::DOWN), |
| 2891 | + APIntOps::avgFloorU(A100, A200)); |
| 2892 | + EXPECT_EQ(APIntOps::RoundingUDiv(A100 + A200, A2, APInt::Rounding::UP), |
| 2893 | + APIntOps::avgCeilU(A100, A200)); |
| 2894 | + EXPECT_EQ(APIntOps::RoundingUDiv(A100 + A101, A2, APInt::Rounding::DOWN), |
| 2895 | + APIntOps::avgFloorU(A100, A101)); |
| 2896 | + EXPECT_EQ(APIntOps::RoundingUDiv(A100 + A101, A2, APInt::Rounding::UP), |
| 2897 | + APIntOps::avgCeilU(A100, A101)); |
| 2898 | + EXPECT_EQ(A0, APIntOps::avgFloorU(A0, A0)); |
| 2899 | + EXPECT_EQ(A0, APIntOps::avgCeilU(A0, A0)); |
| 2900 | + EXPECT_EQ(ApUMax, APIntOps::avgFloorU(ApUMax, ApUMax)); |
| 2901 | + EXPECT_EQ(ApUMax, APIntOps::avgCeilU(ApUMax, ApUMax)); |
| 2902 | + EXPECT_EQ(APIntOps::RoundingUDiv(ApUMax, A2, APInt::Rounding::DOWN), |
| 2903 | + APIntOps::avgFloorU(A0, ApUMax)); |
| 2904 | + EXPECT_EQ(APIntOps::RoundingUDiv(ApUMax, A2, APInt::Rounding::UP), |
| 2905 | + APIntOps::avgCeilU(A0, ApUMax)); |
| 2906 | + |
| 2907 | + APInt Ap100(32, +100); |
| 2908 | + APInt Ap101(32, +101); |
| 2909 | + APInt Ap200(32, +200); |
| 2910 | + APInt Am1(32, -1); |
| 2911 | + APInt Am100(32, -100); |
| 2912 | + APInt Am101(32, -101); |
| 2913 | + APInt Am200(32, -200); |
| 2914 | + APInt AmSMin(32, INT_MIN); |
| 2915 | + APInt ApSMax(32, INT_MAX); |
| 2916 | + |
| 2917 | + EXPECT_EQ(APInt(32, +150), APIntOps::avgFloorS(Ap100, Ap200)); |
| 2918 | + EXPECT_EQ(APIntOps::RoundingSDiv(Ap100 + Ap200, A2, APInt::Rounding::DOWN), |
| 2919 | + APIntOps::avgFloorS(Ap100, Ap200)); |
| 2920 | + EXPECT_EQ(APIntOps::RoundingSDiv(Ap100 + Ap200, A2, APInt::Rounding::UP), |
| 2921 | + APIntOps::avgCeilS(Ap100, Ap200)); |
| 2922 | + |
| 2923 | + EXPECT_EQ(APInt(32, -150), APIntOps::avgFloorS(Am100, Am200)); |
| 2924 | + EXPECT_EQ(APIntOps::RoundingSDiv(Am100 + Am200, A2, APInt::Rounding::DOWN), |
| 2925 | + APIntOps::avgFloorS(Am100, Am200)); |
| 2926 | + EXPECT_EQ(APIntOps::RoundingSDiv(Am100 + Am200, A2, APInt::Rounding::UP), |
| 2927 | + APIntOps::avgCeilS(Am100, Am200)); |
| 2928 | + |
| 2929 | + EXPECT_EQ(APInt(32, +100), APIntOps::avgFloorS(Ap100, Ap101)); |
| 2930 | + EXPECT_EQ(APIntOps::RoundingSDiv(Ap100 + Ap101, A2, APInt::Rounding::DOWN), |
| 2931 | + APIntOps::avgFloorS(Ap100, Ap101)); |
| 2932 | + EXPECT_EQ(APInt(32, +101), APIntOps::avgCeilS(Ap100, Ap101)); |
| 2933 | + EXPECT_EQ(APIntOps::RoundingSDiv(Ap100 + Ap101, A2, APInt::Rounding::UP), |
| 2934 | + APIntOps::avgCeilS(Ap100, Ap101)); |
| 2935 | + |
| 2936 | + EXPECT_EQ(APInt(32, -101), APIntOps::avgFloorS(Am100, Am101)); |
| 2937 | + EXPECT_EQ(APIntOps::RoundingSDiv(Am100 + Am101, A2, APInt::Rounding::DOWN), |
| 2938 | + APIntOps::avgFloorS(Am100, Am101)); |
| 2939 | + EXPECT_EQ(APInt(32, -100), APIntOps::avgCeilS(Am100, Am101)); |
| 2940 | + EXPECT_EQ(APIntOps::RoundingSDiv(Am100 + Am101, A2, APInt::Rounding::UP), |
| 2941 | + APIntOps::avgCeilS(Am100, Am101)); |
| 2942 | + |
| 2943 | + EXPECT_EQ(AmSMin, APIntOps::avgFloorS(AmSMin, AmSMin)); |
| 2944 | + EXPECT_EQ(AmSMin, APIntOps::avgCeilS(AmSMin, AmSMin)); |
| 2945 | + |
| 2946 | + EXPECT_EQ(APIntOps::RoundingSDiv(AmSMin, A2, APInt::Rounding::DOWN), |
| 2947 | + APIntOps::avgFloorS(A0, AmSMin)); |
| 2948 | + EXPECT_EQ(APIntOps::RoundingSDiv(AmSMin, A2, APInt::Rounding::UP), |
| 2949 | + APIntOps::avgCeilS(A0, AmSMin)); |
| 2950 | + |
| 2951 | + EXPECT_EQ(A0, APIntOps::avgFloorS(A0, A0)); |
| 2952 | + EXPECT_EQ(A0, APIntOps::avgCeilS(A0, A0)); |
| 2953 | + |
| 2954 | + EXPECT_EQ(Am1, APIntOps::avgFloorS(AmSMin, ApSMax)); |
| 2955 | + EXPECT_EQ(A0, APIntOps::avgCeilS(AmSMin, ApSMax)); |
| 2956 | + |
| 2957 | + EXPECT_EQ(APIntOps::RoundingSDiv(ApSMax, A2, APInt::Rounding::DOWN), |
| 2958 | + APIntOps::avgFloorS(A0, ApSMax)); |
| 2959 | + EXPECT_EQ(APIntOps::RoundingSDiv(ApSMax, A2, APInt::Rounding::UP), |
| 2960 | + APIntOps::avgCeilS(A0, ApSMax)); |
| 2961 | + |
| 2962 | + EXPECT_EQ(ApSMax, APIntOps::avgFloorS(ApSMax, ApSMax)); |
| 2963 | + EXPECT_EQ(ApSMax, APIntOps::avgCeilS(ApSMax, ApSMax)); |
| 2964 | +} |
| 2965 | + |
2880 | 2966 | TEST(APIntTest, umul_ov) {
|
2881 | 2967 | const std::pair<uint64_t, uint64_t> Overflows[] = {
|
2882 | 2968 | {0x8000000000000000, 2},
|
|
0 commit comments