-
Notifications
You must be signed in to change notification settings - Fork 98
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
Pure 32-bit versions of 32-bit math functions #248
Comments
So, yeah, option 2 seems best. |
Don't forget that we have target attributes: |
target_pointer_width tells you nothing about whether f64 is natively supported or not. |
I would personally think that actually having both the 64-bit emulation as well as the 32-bit implementation is a viable option. I would imagine that implementing the 32-bit operation in terms of the 64-bit operation improves code-size if you use both, which might be important for some situations (?). Additionally I would expected that any 32-bit-specific version would be thoroughly tested, so the maintenance burden doesn't seem like it would be especially high to have two versions (assuming the 32-bit version is a trivial wrapper around the 64-bit version). The important bit here though I think is the 32-bit-specific CI. I think we'd need a target on CI that verifies that 64-bit things weren't used in the implementation, but I'm not sure how to write that CI myself. |
We can use 64-bit version for 64-bit systems and have cargo option like |
Has there been any movement on this? |
Currently,
libm
's 32-bit floating-point math functions (e.g.,sinf
,cosf
, etc.) are ports to Rust of musl implementations. This means that many of these 32-bit functions (e.g.,sinf
) usef64
intermediate values (presumably to avoid accumulating intermediate rounding errors). This works well on CPUs with double-precision FPUs, but makes these functions unusable on many embedded systems with only single-precision floating-point support. There have been a number of issues raised/PRs submitted for newlib implementations (see "Related issues/PRs" section at the end of this post), which use pure 32-bit implementations. But, as far as I'm aware none of these PRs have made it into thelibm
source code. It seems like a few questions need to be addressed before implementing pure 32-bit math functions:libm
want pure 32-bit implementations?libm
?As I see it, the tradeoff between using 32-bit FP or 64-bit FP intermediate values for 32-bit functions is that 64-bit implementations give better precision with equivalent performance in many non-embedded environments. The benefit of 32-bit implementations (as already stated) is that they are usable on platforms with only single-precision floating-point support. Any other important considerations?
There are a number of options here:
Although option 3 accommodates the greatest number of use cases, it would require 2 implementations of 32-bit math functions, which is confusing to users and more work to maintain. Therefore, it is probably the least desirable option. Option 2 seems to be the best in my mind. This would make
libm
applicable to a broader range of embedded devices. Additionally, many applications that benefit from the 64-bit implementations are already served bystd
, or can use thef64
implementations. Are there any major use cases that would be neglected by transitioning to pure 32-bit implementations?cc @alexcrichton @japaric
Related issues/PRs (might not be exhaustive)
The text was updated successfully, but these errors were encountered: