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

Sanitization of degree variables #6216

Closed
znichollscr opened this issue Nov 4, 2024 · 5 comments
Closed

Sanitization of degree variables #6216

znichollscr opened this issue Nov 4, 2024 · 5 comments

Comments

@znichollscr
Copy link

📚 Documentation

I read a file with iris that had units of "degrees_north". After the file was read, the units were simply "degrees". I believe the line that does this is

if attr_units in UD_UNITS_LAT or attr_units in UD_UNITS_LON:
. I tried to find a reference/explanation of this in the docs but couldn't, would it be possible to add such an explanation? I assume it is something like, "Irrespective of the exact degrees unit used, we convert to the much simpler 'degrees' as this simplifies plotting and unit handling."

@trexfeathers
Copy link
Contributor

Thanks for getting in touch @znichollscr. The level of detail here is beyond what we would want in the documentation, so contacting us on GitHub is exactly what we would like people to do 👍

It would be good for us to make this clearer in the documentation: #6218

@stephenworsley
Copy link
Contributor

From @SciTools/peloton - I'm afraid can't say for certain what the motivation for this logic is since it was implemented 12 years ago, before most of us were in the team (@bjlittle, @pp-mo are you aware of how this decision was made?). I believe the idea here is due to the fact that UDUNITS has multiple names for degrees (degrees_n, degrees_north) which would complicate code too much if they were conserved throughout, at various points in the code, iris would check if units are degrees and behave accordingly. There may well be an argument for conserving this information, though that may be a bit bit of a breaking change at this point. I could see an argument for sanitising both "degrees_north" and "degrees_n" to both be something like "degrees_north" as that simplifies while conserving relevant information. At any rate, a better code comment would be nice to have so we don't lose this information to future generations.

@bjlittle
Copy link
Member

bjlittle commented Nov 6, 2024

Jeez, that's an old decision going back some ...

If I recall, we'd seen a whole spectrum of permutations for this unit from degrees, degrees_n, degrees_north, degree_n, degree_north et al.

Essentially we wanted to rationalise this and opted for degrees for both latitude and longitude. There may have been the caveat that udunits2 didn't parse the south permutations out the box e.g.,

> udunits2 -H degrees_north -W degrees
    1 degrees_north = 1 degrees
    x/degrees = (x/degrees_north)

> udunits2 -H degrees_east -W degrees
    1 degrees_east = 1 degrees
    x/degrees = (x/degrees_east)

> udunits2 -H degrees_west -W degrees
    1 degrees_west = -1 degrees
    x/degrees = -1*(x/degrees_west)

> udunits2 -H degrees_south -W degrees
udunits2: Don't recognize "degrees_south"

That still seems to oddly be the case, I guess.

So, yes, it was a pragmatic decsion from what I recall.

@pp-mo Anything to add here?

@znichollscr
Copy link
Author

Hi all, thanks for the insights, super helpful. The decision to sanitise does make lots of sense. It does break the round-tripping I'm doing, but my use case is a super edge case in my opinion and the fix on my side is four lines so I'd suggest that there isn't anything to be done on the iris side. I'll just link to this issue in the fix and we can all move on with life. Cheers!

(Feel free to close this issue, but also fine if you want to keep it open for future tracking)

@pp-mo
Copy link
Member

pp-mo commented Nov 12, 2024

@bjlittle @ pp-mo Anything to add here?

No, done before my time too, I think !
You got it all AFAICT

@trexfeathers trexfeathers closed this as not planned Won't fix, can't repro, duplicate, stale Nov 12, 2024
@scitools-ci scitools-ci bot removed this from 🚴 Peloton Dec 11, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

5 participants