-
-
Notifications
You must be signed in to change notification settings - Fork 46.7k
Add doctest to trapezoidal_rule #11274
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
Conversation
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.
Recheck the tests
What do you mean? Are the doctests wrong or are you talking about the ruff check failing? |
@kyrtsouv The doctests seem to be fine since the build passes. The ruff errors are probably due to newly added ruff rules—try rebasing your code to get it up-to-date and see if that fixes things. |
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.
Aside from changes requested in my other comments, all of the functions also need type hints
@@ -9,7 +9,7 @@ | |||
""" | |||
|
|||
|
|||
def method_1(boundary, steps): | |||
def method_1(func, boundary, steps): |
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 function is entirely untested
@@ -20,29 +20,70 @@ def method_1(boundary, steps): | |||
y += (h / 2.0) * f(a) | |||
for i in x_i: | |||
# print(i) | |||
y += h * f(i) | |||
y += h * f(func, i) |
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 don't see the need for the function f
. Why not just run func
directly?
@@ -20,29 +20,70 @@ def method_1(boundary, steps): | |||
y += (h / 2.0) * f(a) | |||
for i in x_i: | |||
# print(i) | |||
y += h * f(i) | |||
y += h * f(func, i) | |||
y += (h / 2.0) * f(b) |
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.
Was this instance of f
meant to be changed to func
as well?
def f(y, x): # enter your function here | ||
""" | ||
Returns the value of a lambda functiοn y at x | ||
>>> f(lambda x: x**2,2) | ||
4 | ||
>>> f(lambda x: x**2,-1) | ||
1 | ||
>>> f(lambda x: (x+1)/2,5) | ||
3.0 | ||
>>> f(lambda x: (x+1)/2,0) | ||
0.5 | ||
""" | ||
return y(x) |
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.
See previous comment: why have a wrapper function for a function rather than just running the function directly?
>>> x_i = make_points(0, 0.4, 0.1) | ||
>>> next(x_i) | ||
0.1 | ||
>>> next(x_i) | ||
0.2 | ||
>>> next(x_i) | ||
0.3 | ||
>>> next(x_i) | ||
Traceback (most recent call last): | ||
... | ||
StopIteration |
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.
>>> x_i = make_points(0, 0.4, 0.1) | |
>>> next(x_i) | |
0.1 | |
>>> next(x_i) | |
0.2 | |
>>> next(x_i) | |
0.3 | |
>>> next(x_i) | |
Traceback (most recent call last): | |
... | |
StopIteration | |
>>> x_i = list(make_points(0, 0.4, 0.1)) | |
>>> x_i | |
[0.1, 0.2, 0.3] |
Instead of iterating through the iterator manually, it's simpler to just cast it to a list and check the list
... | ||
ValueError: h must be positive | ||
|
||
>>> x_i = make_points(1,0,0.2) |
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.
>>> x_i = make_points(1,0,0.2) | |
>>> x_i = make_points(1, 0, 0.2) |
Minor formatting stuff
Closing tests_are_failing PRs to prepare for Hacktoberfest 2024 |
Describe your change:
Contributes to #9943
Checklist: