Merge pull request #20374 from cesarpgouveia:bugfix/fix_load_onnxModel_debug
* Fix bug while loading onnx model in debug * dnn: fix other .at using Co-authored-by: Alexander Alekhin <alexander.a.alekhin@gmail.com>
This commit is contained in:
parent
6af2faebd2
commit
167a12028d
@ -788,7 +788,7 @@ void ONNXImporter::handleNode(const opencv_onnx::NodeProto& node_proto_)
|
|||||||
int blob_total = blob.total();
|
int blob_total = blob.total();
|
||||||
if (blob_total == 1) {
|
if (blob_total == 1) {
|
||||||
layerParams.type = "Power";
|
layerParams.type = "Power";
|
||||||
layerParams.set("shift", (isSub ? -1 : 1) * blob.at<float>(0));
|
layerParams.set("shift", (isSub ? -1 : 1) * blob.ptr<float>()[0]);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
MatShape inpShape = outShapes[node_proto.input(1 - const_blob_id)];
|
MatShape inpShape = outShapes[node_proto.input(1 - const_blob_id)];
|
||||||
@ -871,7 +871,7 @@ void ONNXImporter::handleNode(const opencv_onnx::NodeProto& node_proto_)
|
|||||||
|
|
||||||
blob.convertTo(blob, CV_32F);
|
blob.convertTo(blob, CV_32F);
|
||||||
layerParams.type = "Power";
|
layerParams.type = "Power";
|
||||||
layerParams.set("power", blob.at<float>(0));
|
layerParams.set("power", blob.ptr<float>()[0]);
|
||||||
}
|
}
|
||||||
else if (layer_type == "Max")
|
else if (layer_type == "Max")
|
||||||
{
|
{
|
||||||
@ -1150,7 +1150,8 @@ void ONNXImporter::handleNode(const opencv_onnx::NodeProto& node_proto_)
|
|||||||
Mat blob = getBlob(node_proto, constId);
|
Mat blob = getBlob(node_proto, constId);
|
||||||
blob = blob.reshape(1, 1);
|
blob = blob.reshape(1, 1);
|
||||||
if (blob.total() == 1) {
|
if (blob.total() == 1) {
|
||||||
float coeff = isDiv ? 1.0 / blob.at<float>(0) : blob.at<float>(0);
|
float blob_value = blob.ptr<float>()[0];
|
||||||
|
float coeff = isDiv ? 1.0 / blob_value : blob_value;
|
||||||
layerParams.set("scale", coeff);
|
layerParams.set("scale", coeff);
|
||||||
layerParams.type = "Power";
|
layerParams.type = "Power";
|
||||||
}
|
}
|
||||||
@ -1188,12 +1189,14 @@ void ONNXImporter::handleNode(const opencv_onnx::NodeProto& node_proto_)
|
|||||||
{
|
{
|
||||||
if (inp0.total() == 1)
|
if (inp0.total() == 1)
|
||||||
{
|
{
|
||||||
float coeff = isDiv ? 1.0 / inp0.at<float>(0) : inp0.at<float>(0);
|
float inp0_value = inp0.ptr<float>()[0];
|
||||||
|
float coeff = isDiv ? 1.0 / inp0_value : inp0_value;
|
||||||
multiply(inp1, coeff, out);
|
multiply(inp1, coeff, out);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
float coeff = isDiv ? 1.0 / inp1.at<float>(0) : inp1.at<float>(0);
|
float inp1_value = inp1.ptr<float>()[0];
|
||||||
|
float coeff = isDiv ? 1.0 / inp1_value : inp1_value;
|
||||||
multiply(inp0, coeff, out);
|
multiply(inp0, coeff, out);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1605,7 +1608,7 @@ void ONNXImporter::handleNode(const opencv_onnx::NodeProto& node_proto_)
|
|||||||
if (node_proto.input_size() == 3)
|
if (node_proto.input_size() == 3)
|
||||||
{
|
{
|
||||||
Mat value = getBlob(node_proto, 2);
|
Mat value = getBlob(node_proto, 2);
|
||||||
layerParams.set("value", value.at<float>(0));
|
layerParams.set("value", value.ptr<float>()[0]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user