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

[Good First Issue][TF FE]: Support complex tensors for Pack operation #22954

Closed
rkazants opened this issue Feb 20, 2024 · 18 comments · Fixed by #25193
Closed

[Good First Issue][TF FE]: Support complex tensors for Pack operation #22954

rkazants opened this issue Feb 20, 2024 · 18 comments · Fixed by #25193
Assignees
Labels
category: TF FE OpenVINO TensorFlow FrontEnd good first issue Good for newcomers no_stale Do not mark as stale
Milestone

Comments

@rkazants
Copy link
Member

Context

OpenVINO component responsible for support of TensorFlow models is called as TensorFlow Frontend (TF FE). TF FE converts a model represented in TensorFlow opset to a model in OpenVINO opset.
Some audio models use tensors of complex type. Complex type tensor is a tensor that has elements of complex type. For example, 1D tensor with three elements x = [1+2j, 2, -2j].

For supporting Pack operation on complex type tensor, you need to extend the corresponding loader for Pack.

What needs to be done?

The existing loader for Pack needs to be extended by propagating ComplexTypeMark from input to output and to represent output complex type tensor as a floating-point type tensor with auxiliary dimension that concatenates real and imaginary parts of complex tensor.
To validate the extension, the corresponding layer test needs to be updated with complex tensor cases.

Here is an example of how to extend Reshape loader to support complex type tensors:

OutputVector translate_reshape_op(const NodeContext& node) {
    default_op_checks(node, 2, {"Reshape"}, true);
    auto tensor = node.get_input(0);
    auto complex_type_mark = as_type_ptr<ComplexTypeMark>(tensor.get_node_shared_ptr());
    auto shape = node.get_input(1);
    if (complex_type_mark) {
        element::Type complex_part_type = complex_type_mark->get_complex_part_type();
        tensor = complex_type_mark->input_value(0);

        OutputVector concat_inputs;
        concat_inputs.push_back(shape);
        concat_inputs.push_back(make_shared<v0::Constant>(shape.get_element_type(), Shape{1}, 2));

        auto concat = make_shared<v0::Concat>(concat_inputs, 0);
        auto reshape = make_shared<v1::Reshape>(tensor, concat, false);
        set_node_name(node.get_name(), reshape);
        auto complex_reshape = make_shared<ComplexTypeMark>(reshape, complex_part_type);
        return {complex_reshape->output(0)};
    }

    auto reshape = make_shared<v1::Reshape>(tensor, shape, false);
    set_node_name(node.get_name(), reshape);
    return {reshape};
}

Since OpenVINO does not have native support of complex tensors, we handle complex type in intermediate layers by representing them as a floating-point type with additional dimension (specially created) to store real and imaginary parts of the original complex tensor so slicing by the last dimension will give either real or imaginary parts: x[...,0] - real and x[...,1] - imaginary parts.

On the first step, we update default_op_checks with true flag to indicate that loader for Reshape operation now handles complex tensors:

default_op_checks(node, 2, {"Reshape"}, true);

Secondly, we check if complex type mark exists by anticipated inputs. This mark indicates that input tensor of complex type:

auto complex_type_mark = as_type_ptr<ComplexTypeMark>(tensor.get_node_shared_ptr());

Thirdly, we retrieve a floating-point tensor (with additional dimension to store real and imaginary parts) simulating complex tensor:

tensor = complex_type_mark->input_value(0);

After that, we implement conversion for Reshape for this particular case. Since a floating-point tensor simulating complex tensor has additional dimension equal to 2,
we update input target shape by appending 2 value and perform reshape on a floating-point tensor simulating complex tensor.

Finally, since Reshape should produce complex tensor by output we insert a new mark ComplexTypeMark into the output.

To validate support of complex tensors for Reshape, the new layer test TestComplexReshape was added.

Example how to run the layer test:

export TEST_DEVICE=CPU
cd openvino/tests/layer_tests/tensorflow_tests
pytest test_tf_Reshape.py

Example Pull Requests

Resources

Contact points

  • @openvinotoolkit/openvino-tf-frontend-maintainers
  • rkazants in Discord

Ticket

No response

@rkazants rkazants added good first issue Good for newcomers no_stale Do not mark as stale labels Feb 20, 2024
@github-project-automation github-project-automation bot moved this to Contributors Needed in Good first issues Feb 20, 2024
@rkazants rkazants added category: TF FE OpenVINO TensorFlow FrontEnd good first issue Good for newcomers gsoc-prerequisite-task Prerequisite task related to Google Summer of Code projects and removed good first issue Good for newcomers labels Feb 20, 2024
@yongyizang
Copy link

.take

Copy link
Contributor

Thank you for looking into this issue! Please let us know if you have any questions or require any help.

@mlukasze mlukasze moved this from Contributors Needed to Assigned in Good first issues Feb 26, 2024
@ysrastogi
Copy link

.take

Copy link
Contributor

github-actions bot commented Mar 3, 2024

Thanks for being interested in this issue. It looks like this ticket is already assigned to a contributor. Please communicate with the assigned contributor to confirm the status of the issue.

@ysrastogi
Copy link

Hii @yongyizang can we collaborate? I have created the idea and very close to solve the issue.

@yongyizang
Copy link

Sure! Sorry, just saw your message.

@yongyizang
Copy link

@ysrastogi How do you want to proceed? If you have already created a solution, feel free to proceed without me. I'm open to discussing the issue together if you are looking for collaboration and discussion.

@rkazants
Copy link
Member Author

rkazants commented Mar 8, 2024

Hi @yongyizang, any update on this task?

Best regards,
Roman

@rkazants
Copy link
Member Author

no update for two weeks. I release this task.

Best regards,
Roman

@rkazants rkazants moved this from Assigned to Contributors Needed in Good first issues Mar 15, 2024
@Pranshu-S
Copy link
Contributor

.take

Copy link
Contributor

Thank you for looking into this issue! Please let us know if you have any questions or require any help.

@Jessielovecodings
Copy link

.take

#WLB

Copy link
Contributor

Thanks for being interested in this issue. It looks like this ticket is already assigned to a contributor. Please communicate with the assigned contributor to confirm the status of the issue.

@mlukasze mlukasze moved this from Contributors Needed to Assigned in Good first issues Mar 18, 2024
@mlukasze mlukasze moved this from Assigned to In Review in Good first issues Mar 19, 2024
@rkazants rkazants added good first issue Good for newcomers and removed gsoc-prerequisite-task Prerequisite task related to Google Summer of Code projects labels May 31, 2024
@rkazants rkazants moved this from In Review to Contributors Needed in Good first issues May 31, 2024
@hibahassan1
Copy link
Contributor

.take

Copy link
Contributor

Thank you for looking into this issue! Please let us know if you have any questions or require any help.

@rkazants rkazants moved this from Contributors Needed to Assigned in Good first issues Jun 11, 2024
@hibahassan1
Copy link
Contributor

Hello, I have some trouble running the tests. I am working in VS code and am experiencing a lot of ImportErrors. I created a virtual environment and installed all the dependencies, but I am still experiencing this.

@rkazants
Copy link
Member Author

Hello, I have some trouble running the tests. I am working in VS code and am experiencing a lot of ImportErrors. I created a virtual environment and installed all the dependencies, but I am still experiencing this.

Hi,

Please send the error log.

Best regards,
Roman

@hibahassan1
Copy link
Contributor

The issue seems to have been fixed by creating a new virtual environment. Thank you

@mlukasze mlukasze moved this from Assigned to In Review in Good first issues Jul 25, 2024
github-merge-queue bot pushed a commit that referenced this issue Sep 1, 2024
…#25193)

### Details:
- ***Addresses the issue** : [[Good First Issue][TF FE]: Support complex
tensors for Pack operation
#22954](#22954
 - *Added support for complex tensors for pack operation*
 - *Let me know if any changes are required*

---------

Co-authored-by: Michal Lukaszewski <[email protected]>
Co-authored-by: Roman Kazantsev <[email protected]>
@github-project-automation github-project-automation bot moved this from In Review to Closed in Good first issues Sep 1, 2024
@mlukasze mlukasze added this to the 2024.5 milestone Sep 2, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
category: TF FE OpenVINO TensorFlow FrontEnd good first issue Good for newcomers no_stale Do not mark as stale
Projects
Archived in project
7 participants