forked from mindspore-Ecosystem/mindspore
add rts label op
This commit is contained in:
parent
298a784878
commit
06bac6f120
|
@ -0,0 +1,63 @@
|
|||
/**
|
||||
* Copyright 2019 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.
|
||||
*/
|
||||
|
||||
#include "kernel/mng/label_goto.h"
|
||||
#include <asm-generic/param.h>
|
||||
#include <memory>
|
||||
#include "runtime/stream.h"
|
||||
#include "framework/ge_runtime/task_info.h"
|
||||
#include "session/anf_runtime_algorithm.h"
|
||||
#include "common/utils.h"
|
||||
|
||||
using ge::model_runner::LabelGotoTaskInfo;
|
||||
using LabelGotoTaskInfoPtr = std::shared_ptr<LabelGotoTaskInfo>;
|
||||
|
||||
namespace mindspore {
|
||||
namespace kernel {
|
||||
LabelGotoKernel::LabelGotoKernel() { label_ = 0; }
|
||||
|
||||
LabelGotoKernel::~LabelGotoKernel() {}
|
||||
|
||||
bool LabelGotoKernel::Init(const AnfNodePtr &anf_node) {
|
||||
MS_EXCEPTION_IF_NULL(anf_node);
|
||||
MS_LOG(INFO) << "LabelGotoKernel init";
|
||||
if (!AnfAlgo::HasNodeAttr(kAttrLabelIndex, anf_node)) {
|
||||
MS_LOG(EXCEPTION) << "LabelGotoKernel has no attr label_index";
|
||||
}
|
||||
auto primitive = AnfAlgo::GetCNodePrimitive(anf_node);
|
||||
MS_EXCEPTION_IF_NULL(primitive);
|
||||
label_ = GetValue<uint32_t>(primitive->GetAttr(kAttrLabelIndex));
|
||||
MS_LOG(INFO) << "LabelGotoKernel get attr label:" << label_;
|
||||
return true;
|
||||
}
|
||||
|
||||
bool LabelGotoKernel::Launch(const std::vector<AddressPtr> &inputs, const std::vector<AddressPtr> &workspace,
|
||||
const std::vector<AddressPtr> &outputs, uintptr_t stream_ptr) {
|
||||
MS_LOG(INFO) << "LabelGotoKernel launch";
|
||||
return true;
|
||||
}
|
||||
|
||||
std::vector<TaskInfoPtr> LabelGotoKernel::GenTask(const std::vector<AddressPtr> &, const std::vector<AddressPtr> &,
|
||||
const std::vector<AddressPtr> &, uint32_t stream_id) {
|
||||
MS_LOG(INFO) << "LabelGotoKernel GenTask label:" << label_ << ", stream id:" << stream_id;
|
||||
std::vector<TaskInfoPtr> task_info_list;
|
||||
std::shared_ptr<LabelGotoTaskInfo> task_info_ptr = std::make_shared<LabelGotoTaskInfo>(stream_id, label_);
|
||||
MS_EXCEPTION_IF_NULL(task_info_ptr);
|
||||
task_info_list.emplace_back(task_info_ptr);
|
||||
return task_info_list;
|
||||
}
|
||||
} // namespace kernel
|
||||
} // namespace mindspore
|
|
@ -0,0 +1,47 @@
|
|||
/**
|
||||
* Copyright 2019 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_MNG_LABEL_GOTO_H
|
||||
#define MINDSPORE_CCSRC_KERNEL_MNG_LABEL_GOTO_H
|
||||
|
||||
#include <memory>
|
||||
#include <vector>
|
||||
#include "kernel/mng/rt_kernel.h"
|
||||
#include "kernel/mng/rt_kernel_info.h"
|
||||
|
||||
namespace mindspore {
|
||||
namespace kernel {
|
||||
class LabelGotoKernel : public RtKernel {
|
||||
public:
|
||||
LabelGotoKernel();
|
||||
~LabelGotoKernel() override;
|
||||
|
||||
bool Init(const AnfNodePtr &anf_node) override;
|
||||
|
||||
bool Launch(const std::vector<AddressPtr> &inputs, const std::vector<AddressPtr> &workspace,
|
||||
const std::vector<AddressPtr> &outputs, uintptr_t stream_ptr) override;
|
||||
std::vector<TaskInfoPtr> GenTask(const std::vector<AddressPtr> &inputs, const std::vector<AddressPtr> &workspace,
|
||||
const std::vector<AddressPtr> &outputs, uint32_t stream_id) override;
|
||||
|
||||
private:
|
||||
uint32_t label_;
|
||||
};
|
||||
|
||||
MS_REG_RTKERNEL(labelgoto, LabelGotoKernel);
|
||||
} // namespace kernel
|
||||
} // namespace mindspore
|
||||
|
||||
#endif // MINDSPORE_CCSRC_KERNEL_MNG_LABEL_GOTO_H
|
|
@ -0,0 +1,63 @@
|
|||
/**
|
||||
* Copyright 2019 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.
|
||||
*/
|
||||
|
||||
#include "kernel/mng/label_set.h"
|
||||
#include <asm-generic/param.h>
|
||||
#include <memory>
|
||||
#include "runtime/stream.h"
|
||||
#include "framework/ge_runtime/task_info.h"
|
||||
#include "session/anf_runtime_algorithm.h"
|
||||
#include "common/utils.h"
|
||||
|
||||
using ge::model_runner::LabelSetTaskInfo;
|
||||
using LabelSetTaskInfoPtr = std::shared_ptr<LabelSetTaskInfo>;
|
||||
|
||||
namespace mindspore {
|
||||
namespace kernel {
|
||||
LabelSetKernel::LabelSetKernel() { label_ = 0; }
|
||||
|
||||
LabelSetKernel::~LabelSetKernel() {}
|
||||
|
||||
bool LabelSetKernel::Init(const AnfNodePtr &anf_node) {
|
||||
MS_EXCEPTION_IF_NULL(anf_node);
|
||||
MS_LOG(INFO) << "LabelSetKernel init";
|
||||
if (!AnfAlgo::HasNodeAttr(kAttrLabelIndex, anf_node)) {
|
||||
MS_LOG(EXCEPTION) << "LabelSetKernel has no attr label_index";
|
||||
}
|
||||
auto primitive = AnfAlgo::GetCNodePrimitive(anf_node);
|
||||
MS_EXCEPTION_IF_NULL(primitive);
|
||||
label_ = GetValue<uint32_t>(primitive->GetAttr(kAttrLabelIndex));
|
||||
MS_LOG(INFO) << "LabelSetKernel get attr label:" << label_;
|
||||
return true;
|
||||
}
|
||||
|
||||
bool LabelSetKernel::Launch(const std::vector<AddressPtr> &inputs, const std::vector<AddressPtr> &workspace,
|
||||
const std::vector<AddressPtr> &outputs, uintptr_t stream_ptr) {
|
||||
MS_LOG(INFO) << "LabelSetKernel launch";
|
||||
return true;
|
||||
}
|
||||
|
||||
std::vector<TaskInfoPtr> LabelSetKernel::GenTask(const std::vector<AddressPtr> &, const std::vector<AddressPtr> &,
|
||||
const std::vector<AddressPtr> &, uint32_t stream_id) {
|
||||
MS_LOG(INFO) << "LabelSetKernel GenTask label:" << label_ << ", stream id:" << stream_id;
|
||||
std::vector<TaskInfoPtr> task_info_list;
|
||||
std::shared_ptr<LabelSetTaskInfo> task_info_ptr = std::make_shared<LabelSetTaskInfo>(stream_id, label_);
|
||||
MS_EXCEPTION_IF_NULL(task_info_ptr);
|
||||
task_info_list.emplace_back(task_info_ptr);
|
||||
return task_info_list;
|
||||
}
|
||||
} // namespace kernel
|
||||
} // namespace mindspore
|
|
@ -0,0 +1,47 @@
|
|||
/**
|
||||
* Copyright 2019 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_MNG_LABEL_SET_H
|
||||
#define MINDSPORE_CCSRC_KERNEL_MNG_LABEL_SET_H
|
||||
|
||||
#include <memory>
|
||||
#include <vector>
|
||||
#include "kernel/mng/rt_kernel.h"
|
||||
#include "kernel/mng/rt_kernel_info.h"
|
||||
|
||||
namespace mindspore {
|
||||
namespace kernel {
|
||||
class LabelSetKernel : public RtKernel {
|
||||
public:
|
||||
LabelSetKernel();
|
||||
~LabelSetKernel() override;
|
||||
|
||||
bool Init(const AnfNodePtr &anf_node) override;
|
||||
|
||||
bool Launch(const std::vector<AddressPtr> &inputs, const std::vector<AddressPtr> &workspace,
|
||||
const std::vector<AddressPtr> &outputs, uintptr_t stream_ptr) override;
|
||||
std::vector<TaskInfoPtr> GenTask(const std::vector<AddressPtr> &inputs, const std::vector<AddressPtr> &workspace,
|
||||
const std::vector<AddressPtr> &outputs, uint32_t stream_id) override;
|
||||
|
||||
private:
|
||||
uint32_t label_;
|
||||
};
|
||||
|
||||
MS_REG_RTKERNEL(labelset, LabelSetKernel);
|
||||
} // namespace kernel
|
||||
} // namespace mindspore
|
||||
|
||||
#endif // MINDSPORE_CCSRC_KERNEL_MNG_LABEL_SET_H
|
|
@ -0,0 +1,76 @@
|
|||
/**
|
||||
* Copyright 2019 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.
|
||||
*/
|
||||
|
||||
#include "kernel/mng/label_switch.h"
|
||||
#include <asm-generic/param.h>
|
||||
#include <memory>
|
||||
#include "runtime/stream.h"
|
||||
#include "framework/ge_runtime/task_info.h"
|
||||
#include "session/anf_runtime_algorithm.h"
|
||||
#include "common/utils.h"
|
||||
|
||||
using ge::model_runner::LabelSwitchTaskInfo;
|
||||
using LabelSwitchTaskInfoPtr = std::shared_ptr<LabelSwitchTaskInfo>;
|
||||
|
||||
namespace mindspore {
|
||||
namespace kernel {
|
||||
LabelSwitchKernel::LabelSwitchKernel() {
|
||||
label_list_ = {};
|
||||
cond_ = nullptr;
|
||||
label_size_ = 0;
|
||||
}
|
||||
|
||||
LabelSwitchKernel::~LabelSwitchKernel() {}
|
||||
|
||||
bool LabelSwitchKernel::Init(const AnfNodePtr &anf_node) {
|
||||
MS_EXCEPTION_IF_NULL(anf_node);
|
||||
MS_LOG(INFO) << "LabelSwitchKernel init";
|
||||
if (!AnfAlgo::HasNodeAttr(kAttrLabelSwitchList, anf_node)) {
|
||||
MS_LOG(EXCEPTION) << "LabelSwitchKernel has no attr label_switch_list";
|
||||
}
|
||||
auto primitive = AnfAlgo::GetCNodePrimitive(anf_node);
|
||||
MS_EXCEPTION_IF_NULL(primitive);
|
||||
label_list_ = GetValue<std::vector<uint32_t>>(primitive->GetAttr(kAttrLabelSwitchList));
|
||||
label_size_ = label_list_.size();
|
||||
MS_LOG(INFO) << "LabelSwitchKernel get attr label size:" << label_size_;
|
||||
for (auto label : label_list_) {
|
||||
MS_LOG(INFO) << "label: " << label;
|
||||
}
|
||||
return true;
|
||||
}
|
||||
|
||||
bool LabelSwitchKernel::Launch(const std::vector<AddressPtr> &inputs, const std::vector<AddressPtr> &workspace,
|
||||
const std::vector<AddressPtr> &outputs, uintptr_t stream_ptr) {
|
||||
MS_LOG(INFO) << "LabelSwitchKernel launch";
|
||||
return true;
|
||||
}
|
||||
|
||||
std::vector<TaskInfoPtr> LabelSwitchKernel::GenTask(const std::vector<AddressPtr> &inputs,
|
||||
const std::vector<AddressPtr> &workspace,
|
||||
const std::vector<AddressPtr> &outputs, uint32_t stream_id) {
|
||||
MS_LOG(INFO) << "LabelSwitchKernel GenTask label size:" << label_size_ << ", stream id:" << stream_id;
|
||||
std::vector<TaskInfoPtr> task_info_list;
|
||||
cond_ = inputs[0]->addr;
|
||||
// std::shared_ptr<LabelSwitchTaskInfo> task_info_ptr =
|
||||
// std::make_shared<LabelSwitchTaskInfo>(stream_id, label_size_, &label_list_, cond_);
|
||||
// need updata ge task info define
|
||||
std::shared_ptr<LabelSwitchTaskInfo> task_info_ptr = std::make_shared<LabelSwitchTaskInfo>(stream_id, label_size_);
|
||||
MS_EXCEPTION_IF_NULL(task_info_ptr);
|
||||
task_info_list.emplace_back(task_info_ptr);
|
||||
return task_info_list;
|
||||
}
|
||||
} // namespace kernel
|
||||
} // namespace mindspore
|
|
@ -0,0 +1,49 @@
|
|||
/**
|
||||
* Copyright 2019 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_MNG_LABEL_SWITCH_H
|
||||
#define MINDSPORE_CCSRC_KERNEL_MNG_LABEL_SWITCH_H
|
||||
|
||||
#include <memory>
|
||||
#include <vector>
|
||||
#include "kernel/mng/rt_kernel.h"
|
||||
#include "kernel/mng/rt_kernel_info.h"
|
||||
|
||||
namespace mindspore {
|
||||
namespace kernel {
|
||||
class LabelSwitchKernel : public RtKernel {
|
||||
public:
|
||||
LabelSwitchKernel();
|
||||
~LabelSwitchKernel() override;
|
||||
|
||||
bool Init(const AnfNodePtr &anf_node) override;
|
||||
|
||||
bool Launch(const std::vector<AddressPtr> &inputs, const std::vector<AddressPtr> &workspace,
|
||||
const std::vector<AddressPtr> &outputs, uintptr_t stream_ptr) override;
|
||||
std::vector<TaskInfoPtr> GenTask(const std::vector<AddressPtr> &inputs, const std::vector<AddressPtr> &workspace,
|
||||
const std::vector<AddressPtr> &outputs, uint32_t stream_id) override;
|
||||
|
||||
private:
|
||||
std::vector<uint32_t> label_list_;
|
||||
uint32_t label_size_;
|
||||
void *cond_;
|
||||
};
|
||||
|
||||
MS_REG_RTKERNEL(labelswitch, LabelSwitchKernel);
|
||||
} // namespace kernel
|
||||
} // namespace mindspore
|
||||
|
||||
#endif // MINDSPORE_CCSRC_KERNEL_MNG_LABEL_SWITCH_H
|
|
@ -136,6 +136,9 @@ constexpr auto kPadOpName = "Pad";
|
|||
constexpr auto kConv2DBackpropInputOpName = "Conv2DBackpropInput";
|
||||
constexpr auto kFusionOpConv2DBackpropInputReluGradV2Name = "FusionOp_Conv2DBackpropInput_ReluGradV2";
|
||||
constexpr auto kFusionOpConv2DBackpropInputAddNReluGradV2Name = "FusionOp_Conv2DBackpropInput_AddN_ReluGradV2";
|
||||
constexpr auto kLabelSetOpName = "LabelSet";
|
||||
constexpr auto kLabelSwitchOpName = "LabelSwitch";
|
||||
constexpr auto kLabelGotoOpName = "LabelGoto";
|
||||
|
||||
// attr key name
|
||||
constexpr auto kAttrInputNames = "input_names";
|
||||
|
@ -174,6 +177,8 @@ constexpr auto kAttrGroup = "group";
|
|||
constexpr auto kAttrOp = "op";
|
||||
constexpr auto kAttrIsTraining = "is_training";
|
||||
constexpr auto kAttrFusionId = "fusion_id";
|
||||
constexpr auto kAttrLabelIndex = "label_index";
|
||||
constexpr auto kAttrLabelSwitchList = "label_switch_list";
|
||||
|
||||
// attr value
|
||||
constexpr auto kValueTargetSwitch = "target_switch";
|
||||
|
|
Loading…
Reference in New Issue