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

sqrt(x*x) not improved correctly #220

Open
DerekJuba-NIST opened this issue Nov 17, 2024 · 6 comments
Open

sqrt(x*x) not improved correctly #220

DerekJuba-NIST opened this issue Nov 17, 2024 · 6 comments
Assignees

Comments

@DerekJuba-NIST
Copy link

When using "improve" on sqrt(x*x), the returned result is x. The result should be abs(x), so the returned result has high error. The Herbie example at https://herbie.uwplse.org/ processes this correctly.

@elmisback
Copy link
Collaborator

Definitely a bug, thank you for reporting!

I confirmed that this is the result we are obtaining from the /alternatives endpoint, so it is a problem in Herbie. I will cross-file this with herbie-fp/herbie as an issue with that endpoint and close this issue once that issue is closed.

@zaneenders
Copy link
Contributor

I started looking into this.

@zaneenders zaneenders removed their assignment Dec 13, 2024
@elmisback
Copy link
Collaborator

This seems to be blocked on server changes which Zane isn't around to finish. I've added this to the Monday meeting agenda.

@ztatlock
Copy link
Contributor

FWIW, the relevant rewrites seem sound (at first glance anyway). Perhaps something is smuggled through a pow rewrite?

Next step is probably to try to repro with unsound rules disabled. Then to check the eqsat proof terms.

@elmisback
Copy link
Collaborator

There must be a difference between the alternatives considered by make-alternatives-result (https://github.com/herbie-fp/herbie/blob/d270acbc7fdb70c022858d48c7001216797499b1/src/api/server.rkt#L532) and make-improve-result (https://github.com/herbie-fp/herbie/blob/d270acbc7fdb70c022858d48c7001216797499b1/src/api/server.rkt#L435). I think Zane mentioned that it might have to do with improve running a processing step that doesn't run for alternatives?

@zaneenders
Copy link
Contributor

I started on this on this PR but didn't conclude on a solution before I got pulled away by end-of-semester items.
The demo also does not display a valid FPCore which is part of the problem.

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

No branches or pull requests

5 participants