1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105
|
// Copyright by Contributors
#include "../../../src/tree/param.h"
#include "../helpers.h"
#include <gtest/gtest.h>
TEST(Param, VectorIOStream) {
std::vector<int> vals = {3, 2, 1};
std::stringstream ss;
std::vector<int> vals_in;
ss << vals;
EXPECT_EQ(ss.str(), "(3,2,1)");
ss >> vals_in;
EXPECT_EQ(vals_in, vals);
vals.clear(); ss.flush(); ss.clear(); ss.str("");
vals = {1};
ss << vals;
EXPECT_EQ(ss.str(), "(1,)");
}
TEST(Param, VectorStreamRead) {
std::vector<int> vals = {3, 2, 1};
std::stringstream ss;
std::vector<int> vals_in;
vals_in.clear(); ss.flush(); ss.clear(); ss.str("");
ss << "(3, 2, 1)";
ss >> vals_in;
EXPECT_EQ(vals_in, vals);
vals_in.clear(); ss.flush(); ss.clear(); ss.str("");
ss << "(3L,2L,1L)";
ss >> vals_in;
EXPECT_EQ(vals_in, vals);
vals_in.clear(); ss.flush(); ss.clear(); ss.str("");
ss << " (3,2,1,)";
ss >> vals_in;
EXPECT_EQ(vals_in, vals);
vals_in.clear(); ss.flush(); ss.clear(); ss.str("");
ss << " ( 3, 2,1 )";
ss >> vals_in;
EXPECT_EQ(vals_in, vals);
vals_in.clear(); ss.flush(); ss.clear(); ss.str("");
ss << " ( 3, 2,1 ) ";
ss >> vals_in;
EXPECT_EQ(vals_in, vals);
vals_in.clear(); ss.flush(); ss.clear(); ss.str("");
ss << " 321 ";
ss >> vals_in;
EXPECT_EQ(vals_in[0], 321);
vals_in.clear(); ss.flush(); ss.clear(); ss.str("");
ss << "(3.0,2,1)";
ss >> vals_in;
EXPECT_NE(vals_in, vals);
vals_in.clear(); ss.flush(); ss.clear(); ss.str("");
ss << "1a";
ss >> vals_in;
EXPECT_NE(vals_in, vals);
vals_in.clear(); ss.flush(); ss.clear(); ss.str("");
ss << "abcde";
ss >> vals_in;
EXPECT_NE(vals_in, vals);
vals_in.clear(); ss.flush(); ss.clear(); ss.str("");
ss << "(3,2,1";
ss >> vals_in;
EXPECT_NE(vals_in, vals);
vals_in.clear(); ss.flush(); ss.clear(); ss.str("");
vals_in.emplace_back(3);
ss << "( )";
ss >> vals_in;
ASSERT_TRUE(ss.good());
}
TEST(Param, SplitEntry) {
xgboost::tree::SplitEntry se1;
EXPECT_FALSE(se1.NeedReplace(-1, 100));
xgboost::tree::SplitEntry se2;
EXPECT_FALSE(se1.Update(se2));
EXPECT_FALSE(se2.Update(-1, 100, 0, true, false, xgboost::tree::GradStats(),
xgboost::tree::GradStats()));
ASSERT_TRUE(se2.Update(1, 100, 0, true, false, xgboost::tree::GradStats(),
xgboost::tree::GradStats()));
ASSERT_TRUE(se1.Update(se2));
xgboost::tree::SplitEntry se3;
se3.Update(2, 101, 0, false, false, xgboost::tree::GradStats(),
xgboost::tree::GradStats());
xgboost::tree::SplitEntry::Reduce(se2, se3);
EXPECT_EQ(se2.SplitIndex(), 101);
EXPECT_FALSE(se2.DefaultLeft());
EXPECT_TRUE(se1.NeedReplace(3, 1));
}
|