- 
                Notifications
    You must be signed in to change notification settings 
- Fork 25.7k
[tensorexpr] support for fusing autocasting ops #72478
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
Conversation
aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused. [ghstack-poisoned]
| CI Flow Status⚛️ CI FlowRuleset - Version:  
 | 
| 🔗 Helpful links
 💊 CI failures summary and remediationsAs of commit bed4c84 (more details on the Dr. CI page): 💚 💚 Looks good so far! There are no failures yet. 💚 💚 This comment was automatically generated by Dr. CI (expand for details).Please report bugs/suggestions to the (internal) Dr. CI Users group. | 
| @davidberard98 has imported this pull request. If you are a Facebook employee, you can view this diff on Phabricator. | 
aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused. Differential Revision: [D34057522](https://our.internmc.facebook.com/intern/diff/D34057522) [ghstack-poisoned]
aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused. Differential Revision: [D34057522](https://our.internmc.facebook.com/intern/diff/D34057522) [ghstack-poisoned]
aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused. Differential Revision: [D34057522](https://our.internmc.facebook.com/intern/diff/D34057522) [ghstack-poisoned]
| @davidberard98 has imported this pull request. If you are a Facebook employee, you can view this diff on Phabricator. | 
| RUN_TORCHBENCH: ALL | 
aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused. Differential Revision: [D34057522](https://our.internmc.facebook.com/intern/diff/D34057522) [ghstack-poisoned]
| @davidberard98 has imported this pull request. If you are a Facebook employee, you can view this diff on Phabricator. | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM with one change
| return false; | ||
| } | ||
| } | ||
| // cant support non-constant pin_memory or pin_memory = True | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Let's add the autocast nodes here:
| if (n->kind() != aten::to) { | 
aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused. Differential Revision: [D34057522](https://our.internmc.facebook.com/intern/diff/D34057522) [ghstack-poisoned]
| @davidberard98 has imported this pull request. If you are a Facebook employee, you can view this diff on Phabricator. | 
aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused. Differential Revision: [D34057522](https://our.internmc.facebook.com/intern/diff/D34057522) [ghstack-poisoned]
| @davidberard98 has imported this pull request. If you are a Facebook employee, you can view this diff on Phabricator. | 
Summary: Pull Request resolved: #72478 aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused. Test Plan: Imported from OSS Reviewed By: bdhirsh Differential Revision: D34057522 Pulled By: davidberard98 fbshipit-source-id: f3b53641415702a4ac56460587801b9c76d81b3c
| Hey @davidberard98. | 
Summary: Pull Request resolved: pytorch/pytorch#72478 aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused. Test Plan: Imported from OSS Reviewed By: bdhirsh Differential Revision: D34057522 Pulled By: davidberard98 fbshipit-source-id: f3b53641415702a4ac56460587801b9c76d81b3c (cherry picked from commit 838ce5542ebd1f95be1ab57ed496f16db4fb7d68)
Summary: Pull Request resolved: pytorch/pytorch#72478 aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused. Test Plan: Imported from OSS Reviewed By: bdhirsh Differential Revision: D34057522 Pulled By: davidberard98 fbshipit-source-id: f3b53641415702a4ac56460587801b9c76d81b3c (cherry picked from commit 838ce5542ebd1f95be1ab57ed496f16db4fb7d68)
Summary: Pull Request resolved: pytorch/pytorch#72478 aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused. Test Plan: Imported from OSS Reviewed By: bdhirsh Differential Revision: D34057522 Pulled By: davidberard98 fbshipit-source-id: f3b53641415702a4ac56460587801b9c76d81b3c (cherry picked from commit 838ce5542ebd1f95be1ab57ed496f16db4fb7d68)
Summary: Pull Request resolved: pytorch/pytorch#72478 aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused. Test Plan: Imported from OSS Reviewed By: bdhirsh Differential Revision: D34057522 Pulled By: davidberard98 fbshipit-source-id: f3b53641415702a4ac56460587801b9c76d81b3c (cherry picked from commit 838ce5542ebd1f95be1ab57ed496f16db4fb7d68)
Summary: Pull Request resolved: pytorch/pytorch#72478 aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused. Test Plan: Imported from OSS Reviewed By: bdhirsh Differential Revision: D34057522 Pulled By: davidberard98 fbshipit-source-id: f3b53641415702a4ac56460587801b9c76d81b3c (cherry picked from commit 838ce5542ebd1f95be1ab57ed496f16db4fb7d68)
Summary: Pull Request resolved: pytorch/pytorch#72478 aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused. Test Plan: Imported from OSS Reviewed By: bdhirsh Differential Revision: D34057522 Pulled By: davidberard98 fbshipit-source-id: f3b53641415702a4ac56460587801b9c76d81b3c (cherry picked from commit 838ce5542ebd1f95be1ab57ed496f16db4fb7d68)
Summary: Pull Request resolved: pytorch/pytorch#72478 aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused. Test Plan: Imported from OSS Reviewed By: bdhirsh Differential Revision: D34057522 Pulled By: davidberard98 fbshipit-source-id: f3b53641415702a4ac56460587801b9c76d81b3c (cherry picked from commit 838ce5542ebd1f95be1ab57ed496f16db4fb7d68)
Summary: Pull Request resolved: pytorch/pytorch#72478 aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused. Test Plan: Imported from OSS Reviewed By: bdhirsh Differential Revision: D34057522 Pulled By: davidberard98 fbshipit-source-id: f3b53641415702a4ac56460587801b9c76d81b3c (cherry picked from commit 838ce5542ebd1f95be1ab57ed496f16db4fb7d68)
Summary: Pull Request resolved: pytorch/pytorch#72478 aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused. Test Plan: Imported from OSS Reviewed By: bdhirsh Differential Revision: D34057522 Pulled By: davidberard98 fbshipit-source-id: f3b53641415702a4ac56460587801b9c76d81b3c (cherry picked from commit 838ce5542ebd1f95be1ab57ed496f16db4fb7d68)
Summary: Pull Request resolved: pytorch/pytorch#72478 aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused. Test Plan: Imported from OSS Reviewed By: bdhirsh Differential Revision: D34057522 Pulled By: davidberard98 fbshipit-source-id: f3b53641415702a4ac56460587801b9c76d81b3c (cherry picked from commit 838ce5542ebd1f95be1ab57ed496f16db4fb7d68)
Summary: Pull Request resolved: pytorch/pytorch#72478 aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused. Test Plan: Imported from OSS Reviewed By: bdhirsh Differential Revision: D34057522 Pulled By: davidberard98 fbshipit-source-id: f3b53641415702a4ac56460587801b9c76d81b3c (cherry picked from commit 838ce5542ebd1f95be1ab57ed496f16db4fb7d68)
Summary: Pull Request resolved: pytorch/pytorch#72478 aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused. Test Plan: Imported from OSS Reviewed By: bdhirsh Differential Revision: D34057522 Pulled By: davidberard98 fbshipit-source-id: f3b53641415702a4ac56460587801b9c76d81b3c (cherry picked from commit 838ce5542ebd1f95be1ab57ed496f16db4fb7d68)
Summary: Pull Request resolved: pytorch/pytorch#72478 aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused. Test Plan: Imported from OSS Reviewed By: bdhirsh Differential Revision: D34057522 Pulled By: davidberard98 fbshipit-source-id: f3b53641415702a4ac56460587801b9c76d81b3c (cherry picked from commit 838ce5542ebd1f95be1ab57ed496f16db4fb7d68)
Summary: Pull Request resolved: pytorch/pytorch#72478 aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused. Test Plan: Imported from OSS Reviewed By: bdhirsh Differential Revision: D34057522 Pulled By: davidberard98 fbshipit-source-id: f3b53641415702a4ac56460587801b9c76d81b3c (cherry picked from commit 838ce5542ebd1f95be1ab57ed496f16db4fb7d68)
Summary: Pull Request resolved: pytorch/pytorch#72478 aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused. Test Plan: Imported from OSS Reviewed By: bdhirsh Differential Revision: D34057522 Pulled By: davidberard98 fbshipit-source-id: f3b53641415702a4ac56460587801b9c76d81b3c (cherry picked from commit 838ce5542ebd1f95be1ab57ed496f16db4fb7d68)
Summary: Pull Request resolved: pytorch/pytorch#72478 aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused. Test Plan: Imported from OSS Reviewed By: bdhirsh Differential Revision: D34057522 Pulled By: davidberard98 fbshipit-source-id: f3b53641415702a4ac56460587801b9c76d81b3c (cherry picked from commit 838ce5542ebd1f95be1ab57ed496f16db4fb7d68)
Stack from ghstack:
aten::_autocast_to_reduced_precision and `aten::_autocast_to_full_precision are essentially just aten::to operations, so they can be fused the same way aten::to is fused.
Differential Revision: D34057522