-
Notifications
You must be signed in to change notification settings - Fork 20
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
docs for operations on diffraction objects #248
Comments
@sbillinge looks like there're already some examples for the operations in the current docs - do we need to add more? Also, do we want to test metadata of the resulting diffraction objects to ensure it includes all metadata from self and other objects)? I'm asking this because in labpdfproc we have |
We don't have to check metadata unless we modify the metadata somehow. Right now, it will just inherit the metadata from the LHS DO (I think, right)? We might want to think how we want to handle that in the future and make an issue for a future release. One idea I had was, if each DO has a uuid (which they do now) we could store the provenance of the new DO, for example, that it was lhs_do.uuid + rhs_do.uuid, for example. In principle we could unroll everything all the way back to recover all metadata this way. But this can get pretty complicated pretty quickly. Let's just leave it as it is for now. In terms of if we need more examples, just make sure that all the tests are described in the docs in words. We may want to put in the docs that the new DO inherits metadata from the LHS DO or whatever it is. |
Yeah, it inherits the metadata from the LHS. I put this in a new issue #296. Will work on the docs |
I have to hangout with my family and will be back later this evening. Just wanted to share I have added a through doc string on def __add__(self, other):
"""Add a scalar value or another DiffractionObject to the yarray of the
DiffractionObject.
Parameters
----------
other : DiffractionObject or int or float
The object to add to the current DiffractionObject. If `other` is a scalar value,
it will be added to all yarray. The length of the yarray must match if `other` is
an instance of DiffractionObject.
Returns
-------
DiffractionObject
The new and deep-copied DiffractionObject instance after adding values to the yarray.
Raises
------
ValueError
Raised when the length of the yarray of the two DiffractionObject instances do not match.
TypeError
Raised when the type of `other` is not an instance of DiffractionObject, int, or float.
Examples
--------
Add a scalar value to the yarray of the DiffractionObject instance:
>>> new_do = my_do + 10.1
>>> new_do = 10.1 + my_do
Add the yarray of two DiffractionObject instances:
>>> new_do = my_do_1 + my_do_2
""" and if operation == "add":
do_1_y_modified = do_1 + do_2
do_2_y_modified = do_2 + do_1
elif operation == "sub":
do_1_y_modified = do_1 - do_2
do_2_y_modified = do_2 - do_1
elif operation == "mul":
do_1_y_modified = do_1 * do_2
do_2_y_modified = do_2 * do_1
elif operation == "div":
do_1_y_modified = do_1 / do_2
do_2_y_modified = do_2 / do_1 |
I will be also doing an overall fix on docstrings so if you see any poorly written ones, I will most likely fix them. |
docs for functions in #187, once that issue is finished
The text was updated successfully, but these errors were encountered: