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

Update Tensorflow to 2.16.1 #805

Merged
merged 42 commits into from
Jun 20, 2024
Merged

Update Tensorflow to 2.16.1 #805

merged 42 commits into from
Jun 20, 2024

Conversation

CNugteren
Copy link
Contributor

@CNugteren CNugteren commented May 24, 2024

What do these changes do?

Very much a draft, only updated TF itself, CI, and Bazel so far. Still to be done: update the actual C++ code as needed.

The main reason for updating TF is that it will add support for Python 3.12 builds.

TODO

  • Tom updated the code by continuing to compile until there were no more compilation errors, but we should check the actual changes of the MLIR code between TF 2.13 and 2.16: its very likely that we have to add/remove/modify some MLIR passes.
  • Tom removed the addBenefit arguments from the TableGen rules. We should check if this doesn't introduce problems.
  • Use the new TF_PYTHON_VERSION environment variable in CI
  • Test release jobs
  • Fix windows builds (see this error for example). This is (very very likely) due to the 260 path length limit in MSVC.
    It tries to access C:/build_output/execroot/larq-compute-engine/bazel-out/x64_windows-opt/bin/external/org_tensorflow/tensorflow/compiler/mlir/quantization/tensorflow/calibrator/_objs/calibration_statistics_collector_average_min_max/calibration_statistics_collector_average_min_max.obj.params which is 274 characters, so we need to remove at least 14 (or 15?) characters from this.
    • We could change C:/build_output to C:/bzl
    • We could change workspace(name = "larq_compute_engine") to workspace(name = "lce")
    • With those combined the path (at least for this compiled file) would become short enough.
    • This combination is being tested here ✔️ It worked!

@CNugteren CNugteren added the dependencies Pull requests that update a dependency file label May 24, 2024
@@ -43,8 +43,7 @@ def : Pat<(TFL_Conv2DOp:$conv_output
[(HasOneUse $pad_output),
(NoBatchAndChannelPadding $paddings),
(SamePaddingHeight $paddings, $input, $conv_output, $stride_h),
(SamePaddingWidth $paddings, $input, $conv_output, $stride_w)],
(addBenefit 100)>;
Copy link
Collaborator

@Tombana Tombana Jun 15, 2024

Choose a reason for hiding this comment

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

There is now an extra argument before the benefit-argument. So we could either insert a [], here before addBenefit, or just remove the benefit thing alltogether. @lgeiger do you know if we depend on these benefit values? A lot of them seem arbitrary to me, but some seem to be chosen specifically.

Copy link
Collaborator

Choose a reason for hiding this comment

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

I looked through the patterns again, and I added back one of the addBenefits and left all the others out.

The one I added back was in order to give priority to GreaterEqual(x, 0) -> Quantize pattern over the more generic GreaterEqual(x, threshold) -> Quantize(x - threshold) pattern. This might avoid a 'subtract 0' operation.
For all other patterns, I don't think the benefit value really mattered: you could first convert a ste.sign(x) to Quantize(Dequantize(x)) or first convert a Conv to a Bconv; that order does not matter. (Besides, it only applies to patterns within one pass)

@Tombana Tombana marked this pull request as ready for review June 20, 2024 06:31
Copy link
Contributor Author

@CNugteren CNugteren left a comment

Choose a reason for hiding this comment

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

Thanks for going through all this effort @Tombana 🙏 Looks ready to merge to me (I can't approve since I'm the original author of the PR) 👍 .

@lgeiger lgeiger self-requested a review June 20, 2024 11:25
Copy link
Member

@lgeiger lgeiger left a comment

Choose a reason for hiding this comment

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

Awesome! Thank you so much for upgrading 🙏

echo -e 'build --google_default_credentials' >> .bazelrc.user
fi

bazelisk build :build_pip_pkg --copt=-fvisibility=hidden --copt=-mavx --linkopt=-dead_strip --distinct_host_configuration=false
bazel-bin/build_pip_pkg artifacts --plat-name macosx_10_14_x86_64
bazelisk build :build_pip_pkg --config=release_macos_x86 --config=release_cpu_macos --copt=-fvisibility=hidden --linkopt=-dead_strip
Copy link
Member

Choose a reason for hiding this comment

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

Should we still keep --distinct_host_configuration=false? Though happy to keep it as is if it works

Copy link
Collaborator

Choose a reason for hiding this comment

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

That flag was removed in this bazel version :)
I think it would still be nice to have the same effect to avoid a few double builds, but in order to achieve that with the new bazel I think you have to do add some complex toolchain files.

@Tombana Tombana merged commit 75e1d37 into main Jun 20, 2024
14 checks passed
@Tombana Tombana deleted the update_tensorflow branch June 20, 2024 11:57
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
dependencies Pull requests that update a dependency file
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants