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

Allow per-example atol, rtol; support Ellipsis in numeric values #147

Open
ev-br opened this issue Apr 5, 2024 · 1 comment
Open

Allow per-example atol, rtol; support Ellipsis in numeric values #147

ev-br opened this issue Apr 5, 2024 · 1 comment
Labels
enhancement New features w.r.t. the original refguide-check help wanted Extra attention is needed

Comments

@ev-br
Copy link
Member

ev-br commented Apr 5, 2024

Consider the following doctest example

>>> np.sqrt(2)
1.4...

Under doctest.ELLIPSIS this means that ... matches any string --- essentially this defines the tolerance for this particular example.

We do have doctest.ELLIPSIS on by default, and it works fine --- but it curiously breaks down under numpy 2.0 scalar representation:

>>> import numpy as np
>>> np.sqrt(2)
np.float64(1.4142135623730951)

Normally, 1.4142 would evaluate to np.allclose to np.float64(1.4142135) --- but the ellipsis breaks it because the vanilla doctest does not understand np.float64 and our machinery does not understand ....

The solution is to probably

  • detect the trailing ellipsis in want, i.e. if want.edswith('...')
  • chop it off
  • adjust the atol, rtol to the number of sig figs (DTChecker._do_check should get explicit atol, rtol arguments defaulting to self.atol, self.rtol).
@ev-br ev-br added the enhancement New features w.r.t. the original refguide-check label Apr 5, 2024
@ev-br ev-br added the help wanted Extra attention is needed label Aug 24, 2024
@lesteve
Copy link

lesteve commented Dec 18, 2024

I think I bumped into this in the context of scikit-learn/scikit-learn#30496 and kind of expected the ellipsis to work with dt_config.strict_check = False but at the same time, I figured "fair enough ellipsis are the old way of doing it and I should not expect floating point comparison in this case". It was straightforward enough to update the doctests to use Numpy 2 formatting in scikit-learn/scikit-learn#30495.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New features w.r.t. the original refguide-check help wanted Extra attention is needed
Projects
None yet
Development

No branches or pull requests

2 participants