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

gtest-tree-ntuple-v7-ntuple-types fails, likely to due fast math. #16929

Open
pcanal opened this issue Nov 13, 2024 · 2 comments
Open

gtest-tree-ntuple-v7-ntuple-types fails, likely to due fast math. #16929

pcanal opened this issue Nov 13, 2024 · 2 comments

Comments

@pcanal
Copy link
Member

pcanal commented Nov 13, 2024

When building ROOT with an LZMA library with with fast-math (the infectious kind), master and v6-34 gtest-tree-ntuple-v7-ntuple-types fails with:

/uscms/home/pcanal/root_working/code/v6-34-00-patches/tree/ntuple/v7/test/ntuple_types.cxx:1826: Failure
Expected equality of these values:
  std::numeric_limits<float>::denorm_min()  
    Which is: 1.4012984643248171e-45
  *d1
    Which is: 0
/uscms/home/pcanal/root_working/code/v6-34-00-patches/tree/ntuple/v7/test/ntuple_types.cxx:1843: Failure
Expected equality of these values:
  std::numeric_limits<float>::denorm_min()  
    Which is: 1.4012984643248171e-45
  *d2Float
    Which is: 0

This “light numerical instability detected by the test in RNTuple (near zero stored as strict zero).” turned out to be due to linking with (not even using) the LZMA library built as part of CMSSW. That libraries is built with fast math which sets the floating point unit to have the flat “FZ - Flush to zero” and “DAZ - Denormals are zeros” for (or course :() the whole process. However the flag affects only operations (conversion, arithmetic operations) but not direct usage, hence the apparent numerical instability (which changes with or without optimization). In particular directly printing or comparing to std::numeric_limits<float>::denorm_min() works but any other operations (including returning it through a not-inlined function) will zero out it.

@dpiparo
Copy link
Member

dpiparo commented Nov 26, 2024

This is an odd and unfortunately not unknown behaviour. What is the bug in ROOT? What is the action that should be taken here? We need a concrete goal to achieve it and monitor progress along the way.

@pcanal
Copy link
Member Author

pcanal commented Nov 26, 2024

Ideally the test will be fixed to succeed even if "fast math" is enabled. If the behavior being tested and failing with "fast math" is essential to work as it is currently being checked in that test (and thus the test can not be changed) then we either need to find a way to make the feature work with "fast math" ... or we need to declare that RNTuple (or part thereof) does not work with "fast math" and add the proper documentation and/or checks in the 'right' places.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

3 participants