-
Notifications
You must be signed in to change notification settings - Fork 100
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
Investigate jn and jnf randomly falling on CI #170
Comments
Just to add why I believe this is some kind of random fluke. https://dev.azure.com/benjamin0103/benjamin/_build/results?buildId=9 |
You can dbg! these fns with INPUT on different targets and find difference. |
Thanks I fixed the test in |
It looks like my previous diagnosis was wrong and I can actually reproduce this locally. Tests such as: diff --git a/src/math/jn.rs b/src/math/jn.rs
index 1be167f..f70ad02 100644
--- a/src/math/jn.rs
+++ b/src/math/jn.rs
@@ -341,3 +341,24 @@ pub fn yn(n: i32, x: f64) -> f64 {
b
}
}
+
+#[cfg(test)]
+mod tests {
+ #[test]
+ fn test_from_ci() {
+ let ret = super::jn(
+ 136,
+ f64::from_bits(4602429132083530282),
+ );
+ assert_eq!(ret, f64::from_bits(15924833));
+ }
+
+ #[test]
+ fn test_from_ci2() {
+ let ret = super::jn(
+ 114,
+ f64::from_bits(4594974205335009568),
+ );
+ assert_eq!(ret, f64::from_bits(1617394868955));
+ }
+}
diff --git a/src/math/jnf.rs b/src/math/jnf.rs
index 360f62e..d19657c 100644
--- a/src/math/jnf.rs
+++ b/src/math/jnf.rs
@@ -257,3 +257,15 @@ pub fn ynf(n: i32, x: f32) -> f32 {
b
}
}
+
+#[cfg(test)]
+mod tests {
+ #[test]
+ fn test_from_ci() {
+ let ret = super::jnf(
+ 29,
+ f32::from_bits(1061546867),
+ );
+ assert_eq!(ret, f32::from_bits(86));
+ }
+} when run with
does indeed have the same failures:
would be good to investigate and see what's going on! In the meantime though we'll likely want to disable/remove these intrinsics until we can sort through the errors |
@Schultzer , Sorry for the confusion. This code was directly translated without any thought put in. Believe it or not, both musl and newlib rely on overflows in those functions, but that definitely should not affect this code. if ((ix | (lx|-lx)>>31) > 0x7ff00000) /* nan */
return x;
diff --git a/src/math/jn.rs b/src/math/jn.rs
index 1be167f..194bf41 100644
--- a/src/math/jn.rs
+++ b/src/math/jn.rs
@@ -53,8 +53,7 @@ pub fn jn(n: i32, mut x: f64) -> f64 {
sign = (ix >> 31) != 0;
ix &= 0x7fffffff;
- // -lx == !lx + 1
- if (ix | (lx | ((!lx).wrapping_add(1))) >> 31) > 0x7ff00000 {
+ if x.is_nan() {
/* nan */
return x;
}
@@ -267,8 +266,7 @@ pub fn yn(n: i32, x: f64) -> f64 {
sign = (ix >> 31) != 0;
ix &= 0x7fffffff;
- // -lx == !lx + 1
- if (ix | (lx | ((!lx).wrapping_add(1))) >> 31) > 0x7ff00000 {
+ if x.is_nan() {
/* nan */
return x;
} |
Hi @m1el, I've been researching a bit and haven't really been able to come to any conclusion. One of the things I've done was to try to make a test suite inspired from GCC libm test suite, it's on this branch add-test-suite. Right know it's only passing locally on my macbook so I'm not sure it's the right way to go. I have a hunch that is properly due some codegen in rustc. It would be cool if it's possible to evaluate the assembly of musl functions and our implementation. |
Signed-off-by: Benjamin Schultzer <[email protected]>
Signed-off-by: Benjamin Schultzer <[email protected]>
Signed-off-by: Benjamin Schultzer <[email protected]>
Signed-off-by: Benjamin Schultzer <[email protected]>
Signed-off-by: Benjamin Schultzer <[email protected]>
Signed-off-by: Benjamin Schultzer <[email protected]>
Signed-off-by: Benjamin Schultzer <[email protected]>
Signed-off-by: Benjamin Schultzer <[email protected]>
Signed-off-by: Benjamin Schultzer <[email protected]>
Signed-off-by: Benjamin Schultzer <[email protected]>
Signed-off-by: Benjamin Schultzer <[email protected]>
Signed-off-by: Benjamin Schultzer <[email protected]>
Signed-off-by: Benjamin Schultzer <[email protected]>
Signed-off-by: Benjamin Schultzer <[email protected]>
Signed-off-by: Benjamin Schultzer <[email protected]>
Signed-off-by: Benjamin Schultzer <[email protected]>
Hi guys,
jn
andjnf
are randomly failing on ARM.On master Build
On #169 Build
Questions
wrapping_add
andwrapping_sup
?The text was updated successfully, but these errors were encountered: