From e373633c29e7153284945daf3fa998d8a29e40a2 Mon Sep 17 00:00:00 2001 From: Chao Chen Date: Sat, 8 Jun 2024 23:22:34 +0000 Subject: [PATCH] init commit for xla-101-advanced --- xla/service/gpu/ir_emitter_unnested.cc | 4 +- xla/tests/cholesky_test.cc | 466 +++++++++++++------------ 2 files changed, 236 insertions(+), 234 deletions(-) diff --git a/xla/service/gpu/ir_emitter_unnested.cc b/xla/service/gpu/ir_emitter_unnested.cc index 5ffdd4865cb35..deddceeeba600 100644 --- a/xla/service/gpu/ir_emitter_unnested.cc +++ b/xla/service/gpu/ir_emitter_unnested.cc @@ -2875,7 +2875,7 @@ absl::Status IrEmitterUnnested::EmitHloInstruction( if (IsCustomCallToDnnConvolution(*instr)) { return EmitConvolutionThunk(custom_call); } -#if GOOGLE_CUDA || TENSORFLOW_USE_ROCM +#if GOOGLE_CUDA if (IsCustomCallToCusolver(*instr)) { return EmitCholeskyThunk(instr); } @@ -2885,7 +2885,7 @@ absl::Status IrEmitterUnnested::EmitHloInstruction( if (IsCubDeviceRadixSort(*instr)) { return EmitCubDeviceRadixSort(custom_call); } -#endif // GOOGLE_CUDA || TENSORFLOW_USE_ROCM +#endif // GOOGLE_CUDA if (custom_call->custom_call_target() == "PadToStatic") { return EmitPadToStatic(custom_call); } diff --git a/xla/tests/cholesky_test.cc b/xla/tests/cholesky_test.cc index 5def722e43497..039424109758e 100644 --- a/xla/tests/cholesky_test.cc +++ b/xla/tests/cholesky_test.cc @@ -34,183 +34,183 @@ limitations under the License. namespace xla { namespace { -using CholeskyTest = ClientLibraryTestBase; - -XLA_TEST_F(CholeskyTest, NonPSDInput) { - XlaBuilder builder(TestName()); - - Array2D a_vals({ - {1, 1, 1}, - {1, 1, 1}, - {1, 1, 1}, - }); - - XlaOp a; - auto a_data = CreateR2Parameter(a_vals, 0, "a", &builder, &a); - Cholesky(a, /*lower=*/true); - - float nan = std::numeric_limits::quiet_NaN(); - Array2D expected({ - {nan, nan, nan}, - {nan, nan, nan}, - {nan, nan, nan}, - }); - - ComputeAndCompareR2(&builder, expected, {a_data.get()}, - ErrorSpec(1e-4, 1e-4)); -} - -XLA_TEST_F(CholeskyTest, NonPSDBatched) { - XlaBuilder builder(TestName()); - - Array3D a_vals({ - { - {10, 0, 0}, - {1, 20, 0}, - {1, 1, 30}, - }, - { - {1, 1, 1}, - {1, 1, 1}, - {1, 1, 1}, - }, - }); - - XlaOp a; - auto a_data = CreateR3Parameter(a_vals, 0, "a", &builder, &a); - Cholesky(a, /*lower=*/true); - - float nan = std::numeric_limits::quiet_NaN(); - Array3D expected({ - { - {3.16227766, 0., 0.}, - {0.31622777, 4.4609416, 0.}, - {0.31622777, 0.20175113, 5.46436606}, - }, - { - {nan, nan, nan}, - {nan, nan, nan}, - {nan, nan, nan}, - }, - }); - - ComputeAndCompareR3(&builder, expected, {a_data.get()}, - ErrorSpec(1e-4, 1e-4)); -} - -XLA_TEST_F(CholeskyTest, Lower) { - XlaBuilder builder(TestName()); - - float nan = std::numeric_limits::quiet_NaN(); - Array2D a_vals({ - {4, nan, nan, nan}, - {6, 45, nan, nan}, - {8, 54, 146, nan}, - {10, 63, 166, 310}, - }); - - XlaOp a; - auto a_data = CreateR2Parameter(a_vals, 0, "a", &builder, &a); - LowerTriangle(Cholesky(a, /*lower=*/true)); - - Array2D expected({ - {2, 0, 0, 0}, - {3, 6, 0, 0}, - {4, 7, 9, 0}, - {5, 8, 10, 11}, - }); - - ComputeAndCompareR2(&builder, expected, {a_data.get()}, - ErrorSpec(1e-4, 1e-4)); -} - -XLA_TEST_F(CholeskyTest, Upper) { - XlaBuilder builder(TestName()); - - float nan = std::numeric_limits::quiet_NaN(); - Array2D a_vals({ - {4, 6, 8, 10}, - {nan, 45, 54, 63}, - {nan, nan, 146, 166}, - {nan, nan, nan, 310}, - }); - - XlaOp a; - auto a_data = CreateR2Parameter(a_vals, 0, "a", &builder, &a); - UpperTriangle(Cholesky(a, /*lower=*/false)); - - Array2D expected({ - {2, 3, 4, 5}, - {0, 6, 7, 8}, - {0, 0, 9, 10}, - {0, 0, 0, 11}, - }); - - ComputeAndCompareR2(&builder, expected, {a_data.get()}, - ErrorSpec(1e-4, 1e-4)); -} - -XLA_TEST_F(CholeskyTest, Simple2) { - XlaBuilder builder(TestName()); - - Array2D a_vals({ - {16, 24, 8, 12}, - {24, 61, 82, 48}, - {8, 82, 456, 106}, - {12, 48, 106, 62}, - }); - - XlaOp a; - auto a_data = CreateR2Parameter(a_vals, 0, "a", &builder, &a); - LowerTriangle(Cholesky(a, /*lower=*/true)); - - Array2D expected({{4, 0, 0, 0}, // - {6, 5, 0, 0}, // - {2, 14, 16, 0}, // - {3, 6, 1, 4}}); - - ComputeAndCompareR2(&builder, expected, {a_data.get()}, - ErrorSpec(1e-4, 1e-4)); -} - -XLA_TEST_F(CholeskyTest, SimpleBatched) { - XlaBuilder builder(TestName()); - - Array3D a_vals({ - { - {4, 6, 8, 10}, - {6, 45, 54, 63}, - {8, 54, 146, 166}, - {10, 63, 166, 310}, - }, - { - {16, 24, 8, 12}, - {24, 61, 82, 48}, - {8, 82, 456, 106}, - {12, 48, 106, 62}, - }, - }); - - XlaOp a; - auto a_data = CreateR3Parameter(a_vals, 0, "a", &builder, &a); - LowerTriangle(Cholesky(a, /*lower=*/true)); - - Array3D expected({ - { - {2, 0, 0, 0}, - {3, 6, 0, 0}, - {4, 7, 9, 0}, - {5, 8, 10, 11}, - }, - {{4, 0, 0, 0}, // - {6, 5, 0, 0}, // - {2, 14, 16, 0}, // - {3, 6, 1, 4}}, - }); - - ComputeAndCompareR3(&builder, expected, {a_data.get()}, - ErrorSpec(1e-4, 1e-4)); -} +// using CholeskyTest = ClientLibraryTestBase; + +// XLA_TEST_F(CholeskyTest, NonPSDInput) { +// XlaBuilder builder(TestName()); + +// Array2D a_vals({ +// {1, 1, 1}, +// {1, 1, 1}, +// {1, 1, 1}, +// }); + +// XlaOp a; +// auto a_data = CreateR2Parameter(a_vals, 0, "a", &builder, &a); +// Cholesky(a, /*lower=*/true); + +// float nan = std::numeric_limits::quiet_NaN(); +// Array2D expected({ +// {nan, nan, nan}, +// {nan, nan, nan}, +// {nan, nan, nan}, +// }); + +// ComputeAndCompareR2(&builder, expected, {a_data.get()}, +// ErrorSpec(1e-4, 1e-4)); +// } + +// XLA_TEST_F(CholeskyTest, NonPSDBatched) { +// XlaBuilder builder(TestName()); + +// Array3D a_vals({ +// { +// {10, 0, 0}, +// {1, 20, 0}, +// {1, 1, 30}, +// }, +// { +// {1, 1, 1}, +// {1, 1, 1}, +// {1, 1, 1}, +// }, +// }); + +// XlaOp a; +// auto a_data = CreateR3Parameter(a_vals, 0, "a", &builder, &a); +// Cholesky(a, /*lower=*/true); + +// float nan = std::numeric_limits::quiet_NaN(); +// Array3D expected({ +// { +// {3.16227766, 0., 0.}, +// {0.31622777, 4.4609416, 0.}, +// {0.31622777, 0.20175113, 5.46436606}, +// }, +// { +// {nan, nan, nan}, +// {nan, nan, nan}, +// {nan, nan, nan}, +// }, +// }); + +// ComputeAndCompareR3(&builder, expected, {a_data.get()}, +// ErrorSpec(1e-4, 1e-4)); +// } + +// XLA_TEST_F(CholeskyTest, Lower) { +// XlaBuilder builder(TestName()); + +// float nan = std::numeric_limits::quiet_NaN(); +// Array2D a_vals({ +// {4, nan, nan, nan}, +// {6, 45, nan, nan}, +// {8, 54, 146, nan}, +// {10, 63, 166, 310}, +// }); + +// XlaOp a; +// auto a_data = CreateR2Parameter(a_vals, 0, "a", &builder, &a); +// LowerTriangle(Cholesky(a, /*lower=*/true)); + +// Array2D expected({ +// {2, 0, 0, 0}, +// {3, 6, 0, 0}, +// {4, 7, 9, 0}, +// {5, 8, 10, 11}, +// }); + +// ComputeAndCompareR2(&builder, expected, {a_data.get()}, +// ErrorSpec(1e-4, 1e-4)); +// } + +// XLA_TEST_F(CholeskyTest, Upper) { +// XlaBuilder builder(TestName()); + +// float nan = std::numeric_limits::quiet_NaN(); +// Array2D a_vals({ +// {4, 6, 8, 10}, +// {nan, 45, 54, 63}, +// {nan, nan, 146, 166}, +// {nan, nan, nan, 310}, +// }); + +// XlaOp a; +// auto a_data = CreateR2Parameter(a_vals, 0, "a", &builder, &a); +// UpperTriangle(Cholesky(a, /*lower=*/false)); + +// Array2D expected({ +// {2, 3, 4, 5}, +// {0, 6, 7, 8}, +// {0, 0, 9, 10}, +// {0, 0, 0, 11}, +// }); + +// ComputeAndCompareR2(&builder, expected, {a_data.get()}, +// ErrorSpec(1e-4, 1e-4)); +// } + +// XLA_TEST_F(CholeskyTest, Simple2) { +// XlaBuilder builder(TestName()); + +// Array2D a_vals({ +// {16, 24, 8, 12}, +// {24, 61, 82, 48}, +// {8, 82, 456, 106}, +// {12, 48, 106, 62}, +// }); + +// XlaOp a; +// auto a_data = CreateR2Parameter(a_vals, 0, "a", &builder, &a); +// LowerTriangle(Cholesky(a, /*lower=*/true)); + +// Array2D expected({{4, 0, 0, 0}, // +// {6, 5, 0, 0}, // +// {2, 14, 16, 0}, // +// {3, 6, 1, 4}}); + +// ComputeAndCompareR2(&builder, expected, {a_data.get()}, +// ErrorSpec(1e-4, 1e-4)); +// } + +// XLA_TEST_F(CholeskyTest, SimpleBatched) { +// XlaBuilder builder(TestName()); + +// Array3D a_vals({ +// { +// {4, 6, 8, 10}, +// {6, 45, 54, 63}, +// {8, 54, 146, 166}, +// {10, 63, 166, 310}, +// }, +// { +// {16, 24, 8, 12}, +// {24, 61, 82, 48}, +// {8, 82, 456, 106}, +// {12, 48, 106, 62}, +// }, +// }); + +// XlaOp a; +// auto a_data = CreateR3Parameter(a_vals, 0, "a", &builder, &a); +// LowerTriangle(Cholesky(a, /*lower=*/true)); + +// Array3D expected({ +// { +// {2, 0, 0, 0}, +// {3, 6, 0, 0}, +// {4, 7, 9, 0}, +// {5, 8, 10, 11}, +// }, +// {{4, 0, 0, 0}, // +// {6, 5, 0, 0}, // +// {2, 14, 16, 0}, // +// {3, 6, 1, 4}}, +// }); + +// ComputeAndCompareR3(&builder, expected, {a_data.get()}, +// ErrorSpec(1e-4, 1e-4)); +// } using CholeskyTestCase = std::tuple; @@ -255,63 +255,65 @@ XLA_TEST_P(RandomCholeskyTest, Real) { ErrorSpec(1e-4, 1e-4)); } -XLA_TEST_P(RandomCholeskyTest, Complex) { - XlaBuilder builder(TestName()); - - auto test_params = GetParam(); - std::vector dimensions = {std::get<0>(test_params), - std::get<1>(test_params), - std::get<1>(test_params)}; - bool lower = std::get<2>(test_params); - Shape shape = ShapeUtil::MakeShape(F32, dimensions); - TF_ASSERT_OK_AND_ASSIGN( - auto literal_real, - LiteralUtil::CreateRandomLiteral(shape, 0.0, 1.0)); - TF_ASSERT_OK_AND_ASSIGN( - auto literal_imag, - LiteralUtil::CreateRandomLiteral(shape, 0.0, 1.0)); - - auto input_real = Parameter(&builder, 0, shape, "input_real"); - auto input_imag = Parameter(&builder, 1, shape, "input_imag"); - auto input = Complex(input_real, input_imag); - // Form a random positive definite matrix. - auto matrix = BatchDot(input, TransposeInMinorDims(Conj(input)), - PrecisionConfig::HIGHEST); - - auto cholesky = Triangle(Cholesky(matrix, lower), lower); - - // Verify that ||matrix - cholesky * cholesky_t||_2 ~= 0 - XlaOp verification; - if (lower) { - verification = BatchDot(cholesky, TransposeInMinorDims(Conj(cholesky)), - PrecisionConfig::HIGHEST); - } else { - verification = BatchDot(TransposeInMinorDims(Conj(cholesky)), cholesky, - PrecisionConfig::HIGHEST); - } - auto delta = matrix - verification; - Reduce(Abs(delta * Conj(delta)), ConstantR0(&builder, 0.0), - CreateScalarAddComputation(F32, &builder), {0, 1, 2}); - - TF_ASSERT_OK_AND_ASSIGN(auto input_data_real, - client_->TransferToServer(literal_real)); - TF_ASSERT_OK_AND_ASSIGN(auto input_data_imag, - client_->TransferToServer(literal_imag)); - ComputeAndCompareR0(&builder, 0.0, - {input_data_real.get(), input_data_imag.get()}, - ErrorSpec(1e-4, 1e-4)); -} +// XLA_TEST_P(RandomCholeskyTest, Complex) { +// XlaBuilder builder(TestName()); + +// auto test_params = GetParam(); +// std::vector dimensions = {std::get<0>(test_params), +// std::get<1>(test_params), +// std::get<1>(test_params)}; +// bool lower = std::get<2>(test_params); +// Shape shape = ShapeUtil::MakeShape(F32, dimensions); +// TF_ASSERT_OK_AND_ASSIGN( +// auto literal_real, +// LiteralUtil::CreateRandomLiteral(shape, 0.0, 1.0)); +// TF_ASSERT_OK_AND_ASSIGN( +// auto literal_imag, +// LiteralUtil::CreateRandomLiteral(shape, 0.0, 1.0)); + +// auto input_real = Parameter(&builder, 0, shape, "input_real"); +// auto input_imag = Parameter(&builder, 1, shape, "input_imag"); +// auto input = Complex(input_real, input_imag); +// // Form a random positive definite matrix. +// auto matrix = BatchDot(input, TransposeInMinorDims(Conj(input)), +// PrecisionConfig::HIGHEST); + +// auto cholesky = Triangle(Cholesky(matrix, lower), lower); + +// // Verify that ||matrix - cholesky * cholesky_t||_2 ~= 0 +// XlaOp verification; +// if (lower) { +// verification = BatchDot(cholesky, TransposeInMinorDims(Conj(cholesky)), +// PrecisionConfig::HIGHEST); +// } else { +// verification = BatchDot(TransposeInMinorDims(Conj(cholesky)), cholesky, +// PrecisionConfig::HIGHEST); +// } +// auto delta = matrix - verification; +// Reduce(Abs(delta * Conj(delta)), ConstantR0(&builder, 0.0), +// CreateScalarAddComputation(F32, &builder), {0, 1, 2}); + +// TF_ASSERT_OK_AND_ASSIGN(auto input_data_real, +// client_->TransferToServer(literal_real)); +// TF_ASSERT_OK_AND_ASSIGN(auto input_data_imag, +// client_->TransferToServer(literal_imag)); +// ComputeAndCompareR0(&builder, 0.0, +// {input_data_real.get(), input_data_imag.get()}, +// ErrorSpec(1e-4, 1e-4)); +// } INSTANTIATE_TEST_SUITE_P(RandomCholeskyTestInstance, RandomCholeskyTest, - ::testing::Values(CholeskyTestCase{1, 1, true}, - CholeskyTestCase{1, 2, true}, - CholeskyTestCase{1, 50, true}, - CholeskyTestCase{1, 50, false}, - CholeskyTestCase{1, 255, false}, - CholeskyTestCase{10, 5, true}, - CholeskyTestCase{5, 10, false}, - CholeskyTestCase{2, 20, true}, - CholeskyTestCase{2, 129, true})); + ::testing::Values( + // CholeskyTestCase{1, 1, true}, + // CholeskyTestCase{1, 2, true}, + CholeskyTestCase{1, 50, true} + // CholeskyTestCase{1, 50, false}, + // CholeskyTestCase{1, 255, false}, + // CholeskyTestCase{10, 5, true}, + // CholeskyTestCase{5, 10, false}, + // CholeskyTestCase{2, 20, true}, + // CholeskyTestCase{2, 129, true} + )); } // namespace } // namespace xla