commit
cc4f6a30e4
File diff suppressed because it is too large
Load Diff
@ -1,86 +0,0 @@
|
|||||||
/**
|
|
||||||
* 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_PREDICT_BATCHNORM_FOLD_FUSION_PASS_H
|
|
||||||
#define MINDSPORE_PREDICT_BATCHNORM_FOLD_FUSION_PASS_H
|
|
||||||
|
|
||||||
#include <unordered_map>
|
|
||||||
#include <memory>
|
|
||||||
#include <string>
|
|
||||||
#include "tools/converter/legacy_optimizer/fusion/fusion_pass.h"
|
|
||||||
|
|
||||||
namespace mindspore {
|
|
||||||
namespace lite {
|
|
||||||
// input = input
|
|
||||||
// weight = SimQuantPerChannel(weight * gamma / sigma)
|
|
||||||
// bias = beta - gamma * mi / sigma
|
|
||||||
// MulFold: gamma sigma
|
|
||||||
// BatchNormFold: mi sigma
|
|
||||||
// AddFold: gamma beta mi sigma
|
|
||||||
class BatchNormFoldFusionPass : public FusionPass {
|
|
||||||
public:
|
|
||||||
BatchNormFoldFusionPass() = default;
|
|
||||||
|
|
||||||
~BatchNormFoldFusionPass() override;
|
|
||||||
|
|
||||||
STATUS DefinePattern() override;
|
|
||||||
|
|
||||||
STATUS DoFusion(MetaGraphT *graph, const std::string &patternName,
|
|
||||||
std::unordered_map<std::string, std::shared_ptr<Path>> &matchedPath) override;
|
|
||||||
|
|
||||||
STATUS Run(MetaGraphT *graph) override;
|
|
||||||
|
|
||||||
protected:
|
|
||||||
STATUS FindNodes(MetaGraphT *graph, const std::unordered_map<std::string, std::shared_ptr<Path>> &matchedPath);
|
|
||||||
STATUS CheckPath(MetaGraphT *graph, const std::unordered_map<std::string, std::shared_ptr<Path>> &matchedPath);
|
|
||||||
STATUS FindTensors();
|
|
||||||
STATUS GenNewWeightTensor();
|
|
||||||
STATUS GenNewBiasTensor();
|
|
||||||
STATUS IsolateNodes(MetaGraphT *graph, const std::unordered_map<std::string, std::shared_ptr<Path>> &matchedPath);
|
|
||||||
void UpdateConvWeights();
|
|
||||||
STATUS DeleteConstTensors();
|
|
||||||
|
|
||||||
protected:
|
|
||||||
MetaGraphT *graph = nullptr;
|
|
||||||
CNodeT *preConv = nullptr;
|
|
||||||
CNodeT *bnFold = nullptr;
|
|
||||||
CNodeT *mulFold = nullptr;
|
|
||||||
CNodeT *fakeNode = nullptr;
|
|
||||||
CNodeT *convNode = nullptr;
|
|
||||||
CNodeT *addFold = nullptr;
|
|
||||||
TensorT *muTensor = nullptr;
|
|
||||||
TensorT *sigmaTensor = nullptr;
|
|
||||||
TensorT *gammaTensor = nullptr;
|
|
||||||
TensorT *betaTensor = nullptr;
|
|
||||||
TensorT *oldWeightTensor = nullptr;
|
|
||||||
int32_t channelOut = 0;
|
|
||||||
|
|
||||||
std::unique_ptr<TensorT> newWeightTensor = nullptr;
|
|
||||||
std::unique_ptr<TensorT> newBiasTensor = nullptr;
|
|
||||||
|
|
||||||
std::string inputOpName = "Input";
|
|
||||||
std::string convPatternOpName1 = "Convolution1";
|
|
||||||
std::string bnFoldOpName = "BatchNormFold";
|
|
||||||
std::string mulFoldOpName = "MulFold";
|
|
||||||
std::string fakeQuantOpName = "FakeQuant";
|
|
||||||
std::string convPatternOpName2 = "Convolution2";
|
|
||||||
std::string addFoldOpName = "AddFold";
|
|
||||||
std::string withPrePatternName = "BNFoldFusionWithPre";
|
|
||||||
std::string noPrePatternName = "BNFoldFusionNoPre";
|
|
||||||
};
|
|
||||||
} // namespace lite
|
|
||||||
} // namespace mindspore
|
|
||||||
#endif // MINDSPORE_PREDICT_BATCHNORM_FOLD_FUSION_PASS_H
|
|
@ -0,0 +1,63 @@
|
|||||||
|
/**
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
#include "tools/converter/parser/tf/tf_logical_parser.h"
|
||||||
|
#include <map>
|
||||||
|
#include <memory>
|
||||||
|
#include <string>
|
||||||
|
#include <vector>
|
||||||
|
#include "tools/converter/parser/tf/tf_node_parser_registry.h"
|
||||||
|
|
||||||
|
namespace mindspore {
|
||||||
|
namespace lite {
|
||||||
|
STATUS TFLogicalParser::Parse(const tensorflow::NodeDef &tf_op,
|
||||||
|
const std::map<string, const tensorflow::NodeDef *> &tf_node_map, PrimitiveC **primitiveC,
|
||||||
|
std::vector<std::string> *inputs, int *output_size) {
|
||||||
|
MS_LOG(INFO) << "TF LogicalParser";
|
||||||
|
if (primitiveC == nullptr || output_size == nullptr) {
|
||||||
|
MS_LOG(ERROR) << "primitiveC is nullptr";
|
||||||
|
return RET_NULL_PTR;
|
||||||
|
}
|
||||||
|
|
||||||
|
auto primitive = std::make_unique<schema::PrimitiveT>();
|
||||||
|
if (primitive == nullptr) {
|
||||||
|
MS_LOG(ERROR) << "primitive is nullptr";
|
||||||
|
return RET_NULL_PTR;
|
||||||
|
}
|
||||||
|
if (tf_op.op() == "LogicalAnd") {
|
||||||
|
auto attr = std::make_unique<schema::LogicalAndT>();
|
||||||
|
if (attr == nullptr) {
|
||||||
|
MS_LOG(ERROR) << "new op failed";
|
||||||
|
return RET_NULL_PTR;
|
||||||
|
}
|
||||||
|
primitive->value.type = schema::PrimitiveType_LogicalAnd;
|
||||||
|
primitive->value.value = attr.release();
|
||||||
|
*primitiveC = PrimitiveC::Create(primitive.release());
|
||||||
|
}
|
||||||
|
if (*primitiveC == nullptr) {
|
||||||
|
MS_LOG(ERROR) << "primitiveC is nullptr";
|
||||||
|
return RET_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
*output_size = 1;
|
||||||
|
for (int i = 0; i < tf_op.input_size(); i++) {
|
||||||
|
inputs->emplace_back(tf_op.input(i));
|
||||||
|
}
|
||||||
|
|
||||||
|
return RET_OK;
|
||||||
|
}
|
||||||
|
TFNodeRegistrar g_tfLogicalAndParser("LogicalAnd", new TFLogicalParser());
|
||||||
|
} // namespace lite
|
||||||
|
} // namespace mindspore
|
@ -0,0 +1,37 @@
|
|||||||
|
/**
|
||||||
|
* 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_LITE_TOOLS_CONVERTER_PARSER_TF_TF_LOGICAL_PARSER_H_
|
||||||
|
#define MINDSPORE_LITE_TOOLS_CONVERTER_PARSER_TF_TF_LOGICAL_PARSER_H_
|
||||||
|
|
||||||
|
#include <map>
|
||||||
|
#include <memory>
|
||||||
|
#include <string>
|
||||||
|
#include <vector>
|
||||||
|
#include "tools/converter/parser/tf/tf_node_parser.h"
|
||||||
|
|
||||||
|
namespace mindspore {
|
||||||
|
namespace lite {
|
||||||
|
class TFLogicalParser : public TFNodeParser {
|
||||||
|
public:
|
||||||
|
TFLogicalParser() = default;
|
||||||
|
~TFLogicalParser() override = default;
|
||||||
|
|
||||||
|
STATUS Parse(const tensorflow::NodeDef &tf_op, const std::map<string, const tensorflow::NodeDef *> &tf_node_map,
|
||||||
|
PrimitiveC **primitiveC, std::vector<std::string> *inputs, int *output_size) override;
|
||||||
|
};
|
||||||
|
} // namespace lite
|
||||||
|
} // namespace mindspore
|
||||||
|
#endif // MINDSPORE_LITE_TOOLS_CONVERTER_PARSER_TF_TF_LOGICAL_PARSER_H_
|
File diff suppressed because it is too large
Load Diff
@ -0,0 +1,62 @@
|
|||||||
|
/**
|
||||||
|
* 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.
|
||||||
|
*/
|
||||||
|
#include "tools/converter/parser/tf/tf_while_parser.h"
|
||||||
|
#include <string>
|
||||||
|
#include <memory>
|
||||||
|
#include <map>
|
||||||
|
#include <vector>
|
||||||
|
#include "tools/converter/parser/tf/tf_node_parser_registry.h"
|
||||||
|
|
||||||
|
namespace mindspore {
|
||||||
|
namespace lite {
|
||||||
|
STATUS TFWhileParser::Parse(const tensorflow::NodeDef &tf_op,
|
||||||
|
const std::map<string, const tensorflow::NodeDef *> &tf_node_map, PrimitiveC **primitiveC,
|
||||||
|
std::vector<std::string> *inputs, int *output_size) {
|
||||||
|
MS_LOG(INFO) << "TF WhileParser";
|
||||||
|
if (primitiveC == nullptr || output_size == nullptr) {
|
||||||
|
MS_LOG(ERROR) << "primitiveC is nullptr";
|
||||||
|
return RET_NULL_PTR;
|
||||||
|
}
|
||||||
|
|
||||||
|
auto primitive = std::make_unique<schema::PrimitiveT>();
|
||||||
|
if (primitive == nullptr) {
|
||||||
|
MS_LOG(ERROR) << "primitive is nullptr";
|
||||||
|
return RET_NULL_PTR;
|
||||||
|
}
|
||||||
|
auto attr = std::make_unique<schema::WhileT>();
|
||||||
|
if (attr == nullptr) {
|
||||||
|
MS_LOG(ERROR) << "new op failed";
|
||||||
|
return RET_NULL_PTR;
|
||||||
|
}
|
||||||
|
|
||||||
|
primitive->value.type = schema::PrimitiveType_While;
|
||||||
|
primitive->value.value = attr.release();
|
||||||
|
*primitiveC = PrimitiveC::Create(primitive.release());
|
||||||
|
if (*primitiveC == nullptr) {
|
||||||
|
MS_LOG(ERROR) << "primitiveC is nullptr";
|
||||||
|
return RET_ERROR;
|
||||||
|
}
|
||||||
|
|
||||||
|
*output_size = tf_op.input_size();
|
||||||
|
for (int i = 0; i < tf_op.input_size(); i++) {
|
||||||
|
inputs->emplace_back(tf_op.input(i));
|
||||||
|
}
|
||||||
|
return RET_OK;
|
||||||
|
}
|
||||||
|
TFNodeRegistrar g_tfStatelessWhileParser("StatelessWhile", new TFWhileParser());
|
||||||
|
TFNodeRegistrar g_tfWhileParser("While", new TFWhileParser());
|
||||||
|
} // namespace lite
|
||||||
|
} // namespace mindspore
|
@ -0,0 +1,37 @@
|
|||||||
|
/**
|
||||||
|
* 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_LITE_TOOLS_CONVERTER_PARSER_TF_TF_WHILE_PARSER_H_
|
||||||
|
#define MINDSPORE_LITE_TOOLS_CONVERTER_PARSER_TF_TF_WHILE_PARSER_H_
|
||||||
|
|
||||||
|
#include <string>
|
||||||
|
#include <memory>
|
||||||
|
#include <map>
|
||||||
|
#include <vector>
|
||||||
|
#include "tools/converter/parser/tf/tf_node_parser.h"
|
||||||
|
|
||||||
|
namespace mindspore {
|
||||||
|
namespace lite {
|
||||||
|
class TFWhileParser : public TFNodeParser {
|
||||||
|
public:
|
||||||
|
TFWhileParser() = default;
|
||||||
|
~TFWhileParser() override = default;
|
||||||
|
|
||||||
|
STATUS Parse(const tensorflow::NodeDef &tf_op, const std::map<string, const tensorflow::NodeDef *> &tf_node_map,
|
||||||
|
PrimitiveC **primitiveC, std::vector<std::string> *inputs, int *output_size) override;
|
||||||
|
};
|
||||||
|
} // namespace lite
|
||||||
|
} // namespace mindspore
|
||||||
|
#endif // MINDSPORE_LITE_TOOLS_CONVERTER_PARSER_TF_TF_WHILE_PARSER_H_
|
Loading…
Reference in new issue