You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

test_ops_pooling_grad.cc 3.1 kB

5 years ago
1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. /**
  2. * Copyright 2020 Huawei Technologies Co., Ltd
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. #include <vector>
  17. #include <memory>
  18. #include "common/common_test.h"
  19. #include "ops/grad/pooling_grad.h"
  20. #include "ir/dtype/type.h"
  21. #include "ir/value.h"
  22. #include "abstract/dshape.h"
  23. #include "utils/tensor_construct_utils.h"
  24. namespace mindspore {
  25. namespace ops {
  26. class TestPoolingGrad : public UT::Common {
  27. public:
  28. TestPoolingGrad() {}
  29. void SetUp() {}
  30. void TearDown() {}
  31. };
  32. TEST_F(TestPoolingGrad, test_ops_pooling_grad1) {
  33. auto pooling_grad = std::make_shared<PoolingGrad>();
  34. pooling_grad->Init(MAX_POOLING, std::vector<int64_t>{1, 1}, std::vector<int64_t>{1, 1}, VALID,
  35. std::vector<int64_t>{1, 1, 1, 1}, FLOOR, NCHW, false);
  36. EXPECT_EQ(pooling_grad->get_pool_mode(), MAX_POOLING);
  37. // EXPECT_EQ(pooling_grad->get_window(), std::vector<int64_t>{1, 1});
  38. EXPECT_EQ(pooling_grad->get_pad_mode(), VALID);
  39. // EXPECT_EQ(pooling_grad->get_stride(), std::vector<int64_t>{1, 1});
  40. // EXPECT_EQ(pooling_grad->get_pad_list(), std::vector<int64_t>{1, 1, 1, 1});
  41. EXPECT_EQ(pooling_grad->get_round_mode(), FLOOR);
  42. EXPECT_EQ(pooling_grad->get_format(), NCHW);
  43. EXPECT_EQ(pooling_grad->get_global(), false);
  44. auto input0 = TensorConstructUtils::CreateOnesTensor(kNumberTypeFloat32, std::vector<int64_t>{1});
  45. auto input1 = TensorConstructUtils::CreateOnesTensor(kNumberTypeFloat32, std::vector<int64_t>{1});
  46. auto input2 = TensorConstructUtils::CreateOnesTensor(kNumberTypeFloat32, std::vector<int64_t>{3, 3});
  47. MS_EXCEPTION_IF_NULL(input0);
  48. MS_EXCEPTION_IF_NULL(input1);
  49. MS_EXCEPTION_IF_NULL(input2);
  50. auto abstract = pooling_grad->Infer({input0->ToAbstract(), input1->ToAbstract(), input2->ToAbstract()});
  51. MS_EXCEPTION_IF_NULL(abstract);
  52. EXPECT_EQ(abstract->isa<abstract::AbstractTensor>(), true);
  53. auto shape_ptr = abstract->BuildShape();
  54. MS_EXCEPTION_IF_NULL(shape_ptr);
  55. EXPECT_EQ(shape_ptr->isa<abstract::Shape>(), true);
  56. auto shape = shape_ptr->cast<abstract::ShapePtr>();
  57. MS_EXCEPTION_IF_NULL(shape);
  58. auto shape_vec = shape->shape();
  59. EXPECT_EQ(shape_vec.size(), 2);
  60. EXPECT_EQ(shape_vec[0], 3);
  61. EXPECT_EQ(shape_vec[1], 3);
  62. auto type = abstract->BuildType();
  63. MS_EXCEPTION_IF_NULL(type);
  64. EXPECT_EQ(type->isa<TensorType>(), true);
  65. auto tensor_type = type->cast<TensorTypePtr>();
  66. MS_EXCEPTION_IF_NULL(tensor_type);
  67. auto data_type = tensor_type->element();
  68. MS_EXCEPTION_IF_NULL(data_type);
  69. EXPECT_EQ(data_type->type_id(), kNumberTypeFloat32);
  70. }
  71. } // namespace ops
  72. } // namespace mindspore