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

Rational Numbers: Add error test case to expreal property #2213

Open
wants to merge 5 commits into
base: main
Choose a base branch
from

Conversation

natanaelsirqueira
Copy link
Sponsor Contributor

As suggested by @jiegillet in gleam!248, we would like to add a failure edge case when doing the exponentiation of a real number to a rational number.

@github-actions
Copy link
Contributor

github-actions bot commented Mar 1, 2023

Hello. Thanks for opening a PR on Exercism. We are currently in a phase of our journey where we have paused community contributions to allow us to take a breather and redesign our community model. You can learn more in this blog post. As such, all issues and PRs in this repository are being automatically closed.

That doesn't mean we're not interested in your ideas, or that if you're stuck on something we don't want to help. The best place to discuss things is with our community on the Exercism Community Forum. You can use this link to copy this into a new topic there.


Note: If this PR has been pre-approved, please link back to this PR on the forum thread and a maintainer or staff member will reopen it.

Copy link
Contributor

@jiegillet jiegillet left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

(sorry I meant to send this days ago, but I forgot to click send, so it stayed pending)

"property": "expreal",
"input": {
"x": -1,
"r": [1, 1]
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

This is kind of an edge case because a [1, 1] exponent is the same as doing nothing, and also the power -1 is not so interesting. If we want to test an actual case, maybe -8 ^ [1, 3] == -2 might be a better choice.
Same for the non-reduded case, it could be [2, 6] instead.

Copy link
Sponsor Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hey! I tried using that example in my Gleam implementation but stumbled on this. This behaviour is the same in Elixir/Erlang. Any thoughts?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yeah, that's a sensible choice. What I would do is check if the base is negative and the denominator odd, then take the power of the absolute value and negate it.

There is also the option of backing out of these strange cases altogether, although I kid of like them :)

Copy link
Sponsor Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yeah... I'm up for dropping all of this tbh. It's starting to feel like we are overcomplicating the exercise and not adding much value. Plus, the initial motivation was to add an error case to our Gleam implementation because the function returns a result. Maybe we could just make that same check that float.power/2 does and have that be our error case?

@lpil
Copy link
Sponsor Member

lpil commented May 8, 2023

Is this good to go? :)

@natanaelsirqueira
Copy link
Sponsor Contributor Author

@lpil Thank you for the reminder. In the interest of time, I believe it's reasonable to back out of this change to unblock the PR in the Gleam track. In hindsight, adding an error case to the problem spec solely because the Gleam function returns a Result may not be necessary. I'm open to being challenged on this, but if you agree with this approach, please feel free to leave your review/approval on that PR, and I'll proceed with closing this one.

@lpil
Copy link
Sponsor Member

lpil commented May 13, 2023

Thank you. What do you think @jiegillet ?

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

Successfully merging this pull request may close these issues.

None yet

3 participants