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

Add unit-awareness to azimuth_range_to_lat_lon function #1977

Merged
merged 1 commit into from
Jul 22, 2021

Conversation

kgoebber
Copy link
Collaborator

Description Of Changes

This PR resolves #1970 by adding some unit handling and issue a warning if ranges and/or azimuths are supplied without units to alert the user to the assumed behavior. Test slightly updated to account for different use cases of units or no units attached to arrays.

Checklist

Copy link
Member

@dopplershift dopplershift left a comment

Choose a reason for hiding this comment

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

Can you add a with pytest.warns(UserWarning, match='not a Pint-Quantity'): to the call in test_azimuth_range_to_lat_lon? That way we check that the warning is actually issued and we silence the warning when running tests.

@@ -887,6 +888,16 @@ def azimuth_range_to_lat_lon(azimuths, ranges, center_lon, center_lat, geod=None
else:
g = geod

try: # convert range units to meters
ranges = ranges.to('meters').m
Copy link
Member

Choose a reason for hiding this comment

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

Been trying to use this more:

Suggested change
ranges = ranges.to('meters').m
ranges = ranges.m_as('meters')

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Got it.

except AttributeError: # no units associated
warnings.warn('Range values are not a Pint-Quantity, assuming values are in meters.')
try: # convert azimuth units to degrees
azimuths = azimuths.to('degrees').m
Copy link
Member

Choose a reason for hiding this comment

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

Suggested change
azimuths = azimuths.to('degrees').m
azimuths = azimuths.m_as('degrees')

Copy link
Collaborator Author

Choose a reason for hiding this comment

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

Got it.

@dopplershift dopplershift added this to the 1.1.0 milestone Jul 22, 2021
@dopplershift dopplershift added Area: Calc Pertains to calculations Type: Enhancement Enhancement to existing functionality labels Jul 22, 2021
@dopplershift dopplershift enabled auto-merge July 22, 2021 20:47
@dopplershift dopplershift merged commit e37664c into Unidata:main Jul 22, 2021
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Area: Calc Pertains to calculations Type: Enhancement Enhancement to existing functionality
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Fix unit-handling in azimuth_range_to_lat_lon
2 participants