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

[TOSA] : Fix float to integer cast for torch.ops.aten.to lowering. #3946

Merged
merged 6 commits into from
Jan 22, 2025

Conversation

sahas3
Copy link
Contributor

@sahas3 sahas3 commented Jan 8, 2025

The behavior of float -> integer cast in PyTorch (though I haven't found the actual code implementing the cast) appears to be (based on the results produced in PyTorch):

  1. round the float nearest to zero (similar to arith.fptosi/ui)
  2. then perform the conversion

Currently we only emit tosa.cast for this operation but as per the spec https://www.mlplatform.org/tosa/tosa_spec.html#_cast the rounding performed for float -> integer is round to nearest integer (not zero). Hence, the current TOSA lowering for torch.ops.aten.to produces incorrect answer.

@sahas3 sahas3 requested a review from sjarus January 8, 2025 15:10
@justin-ngo-arm
Copy link
Contributor

Hi @sahas3, for the Torch float to integer cast behavior, did you observe it to be the same for all Torch casting, or just torch.aten.to? This is because I plan to make tosaCastTensorToType the universal tosa.cast call within TorchToTosa (plan described in #3948), and if the behavior you observed is specific to aten.to then I might need to re-evaluate my approach to unifying these calls.

@sahas3
Copy link
Contributor Author

sahas3 commented Jan 10, 2025

Hi @sahas3, for the Torch float to integer cast behavior, did you observe it to be the same for all Torch casting, or just torch.aten.to? This is because I plan to make tosaCastTensorToType the universal tosa.cast call within TorchToTosa (plan described in #3948), and if the behavior you observed is specific to aten.to then I might need to re-evaluate my approach to unifying these calls.

I think torch.aten.to or torch.tensor.to ops are the basis of all casts in PyTorch. I haven't seen different behavior in my experiments yet. Some additional tests also started passing with this PR indicating that the cast behavior is same for other cast like ops too. So I think using tosaCastTensorToType universally for all tosa.cast calls is the correct approach.

Copy link
Collaborator

@sjarus sjarus left a comment

Choose a reason for hiding this comment

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

If Torch mandates round towards zero, can that not be synthetically expressed here @sahas3 ?

@sahas3
Copy link
Contributor Author

sahas3 commented Jan 14, 2025

If Torch mandates round towards zero, can that not be synthetically expressed here @sahas3 ?

Hi @sjarus , can you elaborate more on what you mean by synthetically expressing rounding towards zero?

@sjarus
Copy link
Collaborator

sjarus commented Jan 22, 2025

Looks like we had a misunderstanding earlier @sahas3 . Approving.

@sahas3 sahas3 merged commit 481da8d into llvm:main Jan 22, 2025
3 checks passed
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