19#include "gmock/gmock.h"
20#include "gtest/gtest.h"
28using ::testing::ElementsAre;
30const double kInfinity = std::numeric_limits<double>::infinity();
32TEST(ShardedQuadraticProgramTest, BasicTest) {
33 const int num_threads = 2;
34 const int num_shards = 10;
37 const int primal_size = 2;
38 const int dual_size = 1;
39 EXPECT_EQ(sharded_qp.DualSize(), dual_size);
40 EXPECT_EQ(sharded_qp.PrimalSize(), primal_size);
41 EXPECT_THAT(
ToDense(sharded_qp.TransposedConstraintMatrix()),
42 EigenArrayEq<double>({{1}, {1}}));
43 EXPECT_EQ(sharded_qp.ConstraintMatrixSharder().NumElements(), primal_size);
44 EXPECT_EQ(sharded_qp.DualSharder().NumElements(), dual_size);
45 EXPECT_EQ(sharded_qp.PrimalSharder().NumElements(), primal_size);
46 EXPECT_EQ(sharded_qp.TransposedConstraintMatrixSharder().NumElements(),
50TEST(RescaleProblem, BasicTest) {
60 const int num_threads = 2;
61 const int num_shards = 10;
64 Eigen::VectorXd col_scaling_vec(2);
65 Eigen::VectorXd row_scaling_vec(1);
66 col_scaling_vec << 1, 0.5;
67 row_scaling_vec << 0.5;
68 sharded_qp.RescaleQuadraticProgram(col_scaling_vec, row_scaling_vec);
70 EXPECT_THAT(sharded_qp.Qp().constraint_lower_bounds, ElementsAre(-
kInfinity));
71 EXPECT_THAT(sharded_qp.Qp().constraint_upper_bounds, ElementsAre(0.5));
72 EXPECT_THAT(sharded_qp.Qp().variable_lower_bounds, ElementsAre(1, -4));
73 EXPECT_THAT(sharded_qp.Qp().variable_upper_bounds, ElementsAre(2, 8));
74 EXPECT_THAT(sharded_qp.Qp().objective_vector, ElementsAre(-1, -0.5));
75 EXPECT_THAT(
ToDense(sharded_qp.Qp().constraint_matrix),
76 EigenArrayEq<double>({{0.5, 0.25}}));
77 EXPECT_THAT(
ToDense(sharded_qp.TransposedConstraintMatrix()),
78 EigenArrayEq<double>({{0.5}, {0.25}}));
79 EXPECT_THAT(sharded_qp.Qp().objective_matrix->diagonal(),
80 EigenArrayEq<double>({4, 0.25}));
::Eigen::ArrayXXd ToDense(const Eigen::SparseMatrix< double, Eigen::ColMajor, int64_t > &sparse_mat)
constexpr double kInfinity
QuadraticProgram TestDiagonalQp1()
TEST(LinearAssignmentTest, NullMatrix)