-
Notifications
You must be signed in to change notification settings - Fork 300
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
computation between datasets loses geocoding information #909
Comments
This is by design in xarray and is not controlled by us in Satpy. Xarray, by default, will drop attributes when doing any operation on a DataArray. If you print There is a from satpy.dataset import combine_metadata
scene['new_band'] = scene['0a05'] / scene['0a01']
scene['new_band'].attrs = combine_metadata(scene['0a05'], scene['0a01'])
scene['new_band'].attrs['some_other_key'] = 'whatever_value_you_want' Another thing is that you may want to create a temporary variable, assign the attributes, and then assign that variable to the Scene object to avoid the Scene adding its own attributes (thinking it knows best) before you have set your own: new_band = scene['0a05'] / scene['0a01']
new_band.attrs = ...
scene['new_band'] = new_band Note: You should access DataArray metadata through |
Thank you for your very clear response. I found this PR: pydata/xarray#2482 that may be relevant. There is certainly rough corners anyway in this automatic approach... |
Exactly right, Satpy can't set that globally without making some major assumptions about who is using it and how. Glad it worked for you. I skimmed the PR and didn't see anything about more |
I have come across this lately a lot too. I totally agree with @djhoese that there are no global decisions about which attributes should be kept can be made. But it would be nice if at least information like area would be kept since that is kind of vital for Satpy functionality like resampling and I guess a user would expect this kind of behavior. In any way @djhoese comment would probably make a nice addition to the documentation maybe under https://satpy.readthedocs.io/en/latest/quickstart.html#creating-new-datasets? |
@BENR0 One thing that I want to work on is the geoxarray project (there is a repository with a pull request but no releases yet). This would be used by Satpy to standardize this logic for how and where geolocation/projection information is stored in an xarray object. If it were stored as a coordinate variable then it is less likely to get lost in various operations. But depending on how it is implemented (a CRS object stored as a coordinate, WKT stored as a coordinate, etc) you can annoyingly run in to cases where xarray says "yeah the coordinates are different so just drop them" and you have the same problem of the projection information disappearing. |
Yes I have seen geoxarray I think that is a good idea an I know it is not that easy to find a good solution. What's your opinion to adding the information to the documentation so users can be aware of this and find a solution? I can add it and do a PR if your ok with it. |
You mean add documentation to satpy about this? I am ok with that if you can think of a good place for it. If you are talking about geoxarray, then I'm not sure. |
yes Satpy documentation. |
Describe the bug
I'm computing a ratio of two bands from the same image (OLCI sensor).
scene['new_band'] = scene['Oa05'] / scene['Oa01']
and then resample and save to geotif the result. The resulting image is correct, but not its geolocation.
Inspecting scene['new_band'] shows that the area attrs is not there. In fact, even the resolution is not copied, it is None. The Oa05 and Oa01 have both an area and it is the same (same reference)
To Reproduce
Expected behavior
I'm expecting scene['new_band'] to have the combined metadata of the two bands used to compute the ratio, including area and resolution.
Actual results
raise an AttributeError because scene['new_band'] has no area attribute.
Environment Info:
The text was updated successfully, but these errors were encountered: