/** * Copyright 2020 Huawei Technologies Co., Ltd * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ #ifndef MINDSPORE_CCSRC_KERNEL_CPU_SLICE_CPU_KERNEL_H_ #define MINDSPORE_CCSRC_KERNEL_CPU_SLICE_CPU_KERNEL_H_ #include #include #include "kernel/cpu/cpu_kernel.h" #include "kernel/cpu/cpu_kernel_factory.h" namespace mindspore { namespace kernel { class SliceCPUKernel : public CPUKernel { public: SliceCPUKernel() = default; ~SliceCPUKernel() override = default; void InitKernel(const CNodePtr &kernel_node) override; bool Launch(const std::vector &inputs, const std::vector &workspace, const std::vector &outputs) override; private: void ExpandAllMemberDims(); bool CanCopyMemoryOnAxis(size_t dim) const; void CopyDataToOutput(const std::vector &inputs, size_t in_offset, const std::vector &outputs, size_t out_offset, size_t copy_num) const; void CheckParam(const CNodePtr &kernel_node) const; std::vector begin_; std::vector end_; std::vector strides_; std::vector input_shape_; std::vector input_element_num_; std::vector output_shape_; std::vector output_element_num_; }; MS_REG_CPU_KERNEL(Slice, KernelAttr().AddInputAttr(kNumberTypeFloat32).AddOutputAttr(kNumberTypeFloat32), SliceCPUKernel); MS_REG_CPU_KERNEL(StridedSlice, KernelAttr().AddInputAttr(kNumberTypeFloat32).AddOutputAttr(kNumberTypeFloat32), SliceCPUKernel); } // namespace kernel } // namespace mindspore #endif // MINDSPORE_CCSRC_KERNEL_CPU_SLICE_CPU_KERNEL_H_