-
Notifications
You must be signed in to change notification settings - Fork 90
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
Updating constants to the CODATA2018 values. #140
Conversation
So, this should be ready to go. Please double check the physical constants in the The reference tapes were created by just running the tests and copying the output tapes over. Note that's how the original reference tapes were created anyway. |
@@ -45,8 +46,9 @@ def lineEquivalence(ref, trial, n, relativeError=1E-9, absoluteError=1E-10): | |||
else: | |||
# Look at all the floats on the lines | |||
for rF, tF in zip(refFloats, trialFloats): | |||
equal = fuzzyDiff(makeFloat(rF), makeFloat(tF), | |||
relativeError, absoluteError) | |||
equal = isclose( makeFloat(rF), makeFloat(tF), |
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.
I much prefer using a built-in function than home-grown.
Yeah, but it fails in actions. Probably because of the python version - I'm updating that.
________________________________
From: Jeremy Lloyd Conlin <[email protected]>
Sent: Wednesday, January 6, 2021 10:06:24 AM
To: njoy/NJOY2016
Cc: Haeck, Wim; Review requested
Subject: [EXTERNAL] Re: [njoy/NJOY2016] Updating constants to the CODATA2018 values. (#140)
@jlconlin commented on this pull request.
________________________________
In tests/execute.py<#140 (comment)>:
@@ -45,8 +46,9 @@ def lineEquivalence(ref, trial, n, relativeError=1E-9, absoluteError=1E-10):
else:
# Look at all the floats on the lines
for rF, tF in zip(refFloats, trialFloats):
- equal = fuzzyDiff(makeFloat(rF), makeFloat(tF),
- relativeError, absoluteError)
+ equal = isclose( makeFloat(rF), makeFloat(tF),
I much prefer using a built-in function than home-grown.
—
You are receiving this because your review was requested.
Reply to this email directly, view it on GitHub<#140 (review)>, or unsubscribe<https://github.com/notifications/unsubscribe-auth/AENOHQB665ALGPUWTYXNOMDSYSKBBANCNFSM4JINVWRQ>.
|
Non-regression tests should be verified prior to updating the test results to assess the impact of changing physical constants - which are expected to be small - but it needs to be done for proper QA. To perform these tests, I updated the execute.py for these tests, now using Python's own isclose function to compare two numbers. By default, the relative difference must be greater than 1e-9 for two numbers to be flagged as different, as long as one of those is not zero. In that case, the absolute difference may be up to 1e-10 for these numbers to be considered equal. At those settings, 47 out of 58 tests are flagged as failed. At a relative difference of 1e-9, ENDF formatted numbers (with 6 digits after the decimal point) that differ even in their last digit get flagged as different. Setting the relative difference to 1e-5 and 5e-5 will allow us to filter out the cases where the difference is in the last significant digit in standard ENDF notation. At 1e-5 relative difference, only 14 out of 58 tests still continue to be flagged as "failed". These tests are: 1, 2, 11, 12, 14, 16, 19, 21, 22, 25, 32, 37, 39 and 49. In what follows, I will detail these remaining differences to show why these do not constitute major blocking issues. |
Test 12 and 14: only differences in VIEWR produced post-script files - acceptable The comparison of all reference tapes, except for the post script files, comes out correctly. In the postscript files themselves only a few numbers get flagged as different. For example, for test 12:
|
Test 1: fixed versus scientific notation - acceptable A single reference tape has ~500 different lines due to a difference in fixed and scientific notation (the numbers are actually the same). For example:
|
Test 2, 11 and 16: small differences in scattering matrices - acceptable The differences are detected in GENDF files, and more specifically in the matrices (stored under MF6). These constitute differences in the 4th or 5th digit, and only if the number are already quite low (below 1). It only happens for 5 to 15 values for each of the quoted tests. For example:
|
Test 19, 37 and 39: probability tables are slightly different - acceptable The differences are detected in NJOY PENDF files for MF2 MT153, the internal storage section for probability tables.Changing the constants has an influence on cross section values, so some changes are to be expected. Only three of the ptable tests in the test suite (there's at least 10 tests related to ptables as far as I know) exhibit these differences, which indicates that this is not a consistent problem. For example:
|
Test 21 and 32: output files appear to have different number of lines - might require further investigation In this case, the test fails because the reference file and new file do not have the same number of lines. Most likely some tolerance may have lead to the addition of an additional point or something. |
Test 22, 25 and 49: thermal scattering related Test 22 is a LEAPR test. The diferences are detected in the ENDF file produced by LEAPR, in MF7 MT4 for about 25 lines in a file of over 4500 lines. These are mainly in the 4th and 5th digit after the decimal point. This is acceptable. Test 25 is a test for producing ACE files for H in H2O for 3 temperatures. The differences occur only in the ACE file for 300 K. There's about 1000 lines with differences for a file containing of the order of 12500 lines. These are mainly in the 4th and 5th digit after the decimal point. Test 49 is a test for Zr in Zrh. The resulting ACE files appear to have a different number of lines. |
I was hoping that the relative diff would catch these kinds of differences. Perhaps not? |
Since the comparison tool does not distinguish between ENDF and ACE, etc., the MAT number gets taken as part of the value in the comaprison. The comparison that gets flagged here are these two pieces:
0.276 is indeed different from 2.76e-11306 |
Oh yes, of course. I forgot about that mess. |
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.
This is good to go. The constants are verified against their source and the changed test files have been verified and show little change - as expected.
Thanks @whaeck for your detailed review on this. |
Not all tests are passing. Need to have a conversation about how best to proceed here.
Also, don't merge until CSEWG approves my proposal to the ENDF manual.