Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[core] Result node may uses inputs names on creation #28168

Merged
merged 5 commits into from
Jan 8, 2025

Conversation

praasz
Copy link
Contributor

@praasz praasz commented Dec 20, 2024

Details:

  • The Result node may use inputs names when created. Creation such Result assume as previous layer is model output.
  • The model when created from outputs and the outputs are note Result node, then create results and take its names as model output names.
  • The Result has option to enable/disable use inputs names as it owns. If names not used they still be visible as output names if Result has no dedicated names but if Result is connect to other input these names stay on origin input.

Tickets:

@praasz praasz requested review from a team as code owners December 20, 2024 12:41
@praasz praasz requested review from itikhono and removed request for a team December 20, 2024 12:41
@github-actions github-actions bot added category: inference OpenVINO Runtime library - Inference category: Core OpenVINO Core (aka ngraph) category: transformations OpenVINO Runtime library - Transformations category: IR FE OpenVINO IR v10 / v11 FrontEnd category: ONNX FE OpenVINO ONNX FrontEnd category: CPP API OpenVINO CPP API bindings labels Dec 20, 2024
@github-actions github-actions bot removed the category: inference OpenVINO Runtime library - Inference label Dec 20, 2024
@praasz praasz changed the title [core] Result node uses inputs names on creation [core] Result node may uses inputs names on creation Dec 21, 2024
@praasz praasz added this to the 2025.0 milestone Dec 21, 2024
@StefaniaHergane
Copy link
Contributor

Tests look good in NPU CI

@ilya-lavrenov ilya-lavrenov added this pull request to the merge queue Dec 24, 2024
@ilya-lavrenov ilya-lavrenov removed this pull request from the merge queue due to a manual request Dec 24, 2024
Copy link
Contributor

@dtrawins dtrawins left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

the following models still fail to report the output names:

import openvino as ov
det_model = YOLO(f"yolo11n.pt")
ir_model_dir = det_model.export(format="openvino", dynamic=True, half=True)```

The errors from `std::string name = output.get_any_name();` is:

OpenVINO with error:Check '!get_names().empty()' failed at src/core/src/descriptor/tensor.cpp:102:
Attempt to get a name for a Tensor without names.

@praasz
Copy link
Contributor Author

praasz commented Jan 7, 2025

the following models still fail to report the output names:

import openvino as ov
det_model = YOLO(f"yolo11n.pt")
ir_model_dir = det_model.export(format="openvino", dynamic=True, half=True)```

The errors from `std::string name = output.get_any_name();` is:

OpenVINO with error:Check '!get_names().empty()' failed at src/core/src/descriptor/tensor.cpp:102: Attempt to get a name for a Tensor without names.

I can't reproduce issues for: convert_tokenizer -o bge-m3 BAAI/bge-m3 and yolo11.
But can easily reproduce for convert_tokenizer -o bge-m3 BAAI/bge-m3 that without these changes there is no tensor names on model outputs generated by convert_tokenizer

In dummy model example there is no tensor names on model's outputs because names are not set the example has to be modified e.g.:

op0 = ov.opset1.multiply(in1, in0, name="MULTIPLY")
op1 = ov.opset1.add(in1, in0, name="ADD")
op0.output(0).set_names({"mul"})
op1.output(0).set_names({"add"})

or

model = ov.Model([op0, op1], [in0, in1], model_name)
model.output(0).set_names({"mul"})
model.output(1).set_names({"add"})

There is no general feature to auto name tensors in OV, but there are some exception like python API ov.Model where Model creation use Parameters friendly names as tensor names.

@praasz praasz requested a review from dtrawins January 7, 2025 06:22
@praasz
Copy link
Contributor Author

praasz commented Jan 7, 2025

@ilya-lavrenov Could you review PR again?

@praasz praasz added this pull request to the merge queue Jan 8, 2025
Merged via the queue into openvinotoolkit:master with commit 97a2148 Jan 8, 2025
185 checks passed
@praasz praasz deleted the bugfix/result-use-input-names branch January 8, 2025 12:34
github-merge-queue bot pushed a commit to openvinotoolkit/openvino.genai that referenced this pull request Jan 9, 2025
ilya-lavrenov added a commit to openvinotoolkit/openvino.genai that referenced this pull request Jan 10, 2025
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
category: Core OpenVINO Core (aka ngraph) category: CPP API OpenVINO CPP API bindings category: IR FE OpenVINO IR v10 / v11 FrontEnd category: ONNX FE OpenVINO ONNX FrontEnd category: transformations OpenVINO Runtime library - Transformations
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants