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

TypeTransformer for Keras #1242

Closed

Conversation

ryankarlos
Copy link
Contributor

@ryankarlos ryankarlos commented Oct 18, 2022

Signed-off-by: Ryan Nazareth [email protected]

TL;DR

Adds a typetransformer to support keras.Model and keras.Sequential as native types

Type

  • Bug Fix
  • Feature
  • Plugin

Are all requirements met?

  • Code completed
  • Smoke tested
  • Unit tests added
  • Code documentation added
  • Any pending items have an associated Issue

Complete description

Tracking Issue

flyteorg/flyte#2759

Follow-up issue

N/A

@ryankarlos ryankarlos changed the title TypeTransformer for Keras Sequential Model TypeTransformer for Keras Oct 19, 2022
@ryankarlos ryankarlos force-pushed the keras-model-typetransformer branch from 9bb6a88 to 1a99a2f Compare October 19, 2022 00:41
@ryankarlos ryankarlos force-pushed the keras-model-typetransformer branch from 1a99a2f to 3216e8b Compare October 20, 2022 17:59
@@ -13,3 +13,4 @@ google-cloud-bigquery
google-cloud-bigquery-storage
IPython
torch
tensorflow<=2.8.1
Copy link
Contributor Author

Choose a reason for hiding this comment

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

see my comment in #1240 (comment) for reasons for pinning tf versions.

Copy link
Contributor Author

@ryankarlos ryankarlos Oct 20, 2022

Choose a reason for hiding this comment

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

Ignore this - ive pinned grpcio-status<1.49.0 instead based on suggestion from @pingsutw in another PR, which fixed it !

Copy link
Member

@pingsutw pingsutw left a comment

Choose a reason for hiding this comment

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

There is an error in test_to_python_value_and_literal

    def test_to_python_value_and_literal(transformer, python_type, format, python_val):
        ctx = context_manager.FlyteContext.current_context()
        tf = transformer
        lt = tf.get_literal_type(python_type)
        lv = tf.to_literal(ctx, python_val, type(python_val), lt)  # type: ignore
        assert lv.scalar.blob.metadata == BlobMetadata(
            type=BlobType(
                format=format,
                dimensionality=BlobType.BlobDimensionality.SINGLE,
            )
        )
        assert lv.scalar.blob.uri is not None
    
        output = tf.to_python_value(ctx, lv, python_type)
        if isinstance(python_val, keras.Sequential):
            for p1, p2 in zip(output.weights, python_val.weights):
                np.testing.assert_array_equal(p1.numpy(), p2.numpy())
            assert True
        else:
>           assert isinstance(output, dict)
E           assert False
E            +  where False = isinstance(<keras.engine.functional.Functional object at 0x000001AE37320108>, dict)

Signed-off-by: Ryan Nazareth <[email protected]>
@ryankarlos
Copy link
Contributor Author

ryankarlos commented Oct 21, 2022

There is an error in test_to_python_value_and_literal

    def test_to_python_value_and_literal(transformer, python_type, format, python_val):
        ctx = context_manager.FlyteContext.current_context()
        tf = transformer
        lt = tf.get_literal_type(python_type)
        lv = tf.to_literal(ctx, python_val, type(python_val), lt)  # type: ignore
        assert lv.scalar.blob.metadata == BlobMetadata(
            type=BlobType(
                format=format,
                dimensionality=BlobType.BlobDimensionality.SINGLE,
            )
        )
        assert lv.scalar.blob.uri is not None
    
        output = tf.to_python_value(ctx, lv, python_type)
        if isinstance(python_val, keras.Sequential):
            for p1, p2 in zip(output.weights, python_val.weights):
                np.testing.assert_array_equal(p1.numpy(), p2.numpy())
            assert True
        else:
>           assert isinstance(output, dict)
E           assert False
E            +  where False = isinstance(<keras.engine.functional.Functional object at 0x000001AE37320108>, dict)

Ahh yes, forgot to account for keras.Model in the check, after the refactor ....... just pushed fix now

@codecov
Copy link

codecov bot commented Oct 24, 2022

Codecov Report

Merging #1242 (4fe5a31) into master (1fa73a0) will increase coverage by 0.02%.
The diff coverage is 72.78%.

@@            Coverage Diff             @@
##           master    #1242      +/-   ##
==========================================
+ Coverage   68.68%   68.71%   +0.02%     
==========================================
  Files         288      292       +4     
  Lines       26333    26482     +149     
  Branches     2486     2494       +8     
==========================================
+ Hits        18087    18196     +109     
- Misses       7768     7805      +37     
- Partials      478      481       +3     
Impacted Files Coverage Δ
flytekit/extras/keras/__init__.py 0.00% <0.00%> (ø)
flytekit/extras/keras/native.py 38.09% <38.09%> (ø)
...flytekit/unit/extras/keras/test_transformations.py 93.22% <93.22%> (ø)
tests/flytekit/unit/extras/keras/test_native.py 97.29% <97.29%> (ø)
tests/flytekit/unit/cli/pyflyte/test_run.py 99.20% <0.00%> (ø)
tests/flytekit/unit/cli/pyflyte/workflow.py 100.00% <0.00%> (ø)
flytekit/clis/sdk_in_container/run.py 84.15% <0.00%> (+0.10%) ⬆️

Help us with your feedback. Take ten seconds to tell us how you rate us. Have a feature suggestion? Share it here.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants