2016-07-31 17:20:56 +00:00
|
|
|
"""Distance util functions."""
|
|
|
|
|
|
|
|
import logging
|
|
|
|
from numbers import Number
|
|
|
|
|
2016-07-31 20:24:49 +00:00
|
|
|
from homeassistant.const import (
|
|
|
|
LENGTH_KILOMETERS,
|
|
|
|
LENGTH_MILES,
|
|
|
|
LENGTH_FEET,
|
|
|
|
LENGTH_METERS,
|
|
|
|
UNIT_NOT_RECOGNIZED_TEMPLATE,
|
|
|
|
LENGTH,
|
|
|
|
)
|
2016-07-31 17:20:56 +00:00
|
|
|
|
2016-07-31 20:24:49 +00:00
|
|
|
_LOGGER = logging.getLogger(__name__)
|
2016-07-31 17:20:56 +00:00
|
|
|
|
|
|
|
VALID_UNITS = [
|
2016-07-31 20:24:49 +00:00
|
|
|
LENGTH_KILOMETERS,
|
|
|
|
LENGTH_MILES,
|
|
|
|
LENGTH_FEET,
|
|
|
|
LENGTH_METERS,
|
2016-07-31 17:20:56 +00:00
|
|
|
]
|
|
|
|
|
|
|
|
|
2016-07-31 20:24:49 +00:00
|
|
|
def convert(value: float, unit_1: str, unit_2: str) -> float:
|
2016-07-31 17:20:56 +00:00
|
|
|
"""Convert one unit of measurement to another."""
|
2016-07-31 20:24:49 +00:00
|
|
|
if unit_1 not in VALID_UNITS:
|
|
|
|
raise ValueError(
|
|
|
|
UNIT_NOT_RECOGNIZED_TEMPLATE.format(unit_1, LENGTH))
|
|
|
|
if unit_2 not in VALID_UNITS:
|
|
|
|
raise ValueError(
|
|
|
|
UNIT_NOT_RECOGNIZED_TEMPLATE.format(unit_2, LENGTH))
|
|
|
|
|
2016-07-31 17:20:56 +00:00
|
|
|
if not isinstance(value, Number):
|
2016-07-31 20:24:49 +00:00
|
|
|
raise TypeError('{} is not of numeric type'.format(value))
|
2016-07-31 17:20:56 +00:00
|
|
|
|
2019-07-16 22:11:38 +00:00
|
|
|
# type ignore: https://github.com/python/mypy/issues/7207
|
|
|
|
if unit_1 == unit_2 or unit_1 not in VALID_UNITS: # type: ignore
|
2016-07-31 17:20:56 +00:00
|
|
|
return value
|
|
|
|
|
|
|
|
meters = value
|
|
|
|
|
2016-07-31 20:24:49 +00:00
|
|
|
if unit_1 == LENGTH_MILES:
|
2016-07-31 17:20:56 +00:00
|
|
|
meters = __miles_to_meters(value)
|
2016-07-31 20:24:49 +00:00
|
|
|
elif unit_1 == LENGTH_FEET:
|
2016-07-31 17:20:56 +00:00
|
|
|
meters = __feet_to_meters(value)
|
2016-07-31 20:24:49 +00:00
|
|
|
elif unit_1 == LENGTH_KILOMETERS:
|
2016-07-31 17:20:56 +00:00
|
|
|
meters = __kilometers_to_meters(value)
|
|
|
|
|
|
|
|
result = meters
|
|
|
|
|
2016-07-31 20:24:49 +00:00
|
|
|
if unit_2 == LENGTH_MILES:
|
2016-07-31 17:20:56 +00:00
|
|
|
result = __meters_to_miles(meters)
|
2016-07-31 20:24:49 +00:00
|
|
|
elif unit_2 == LENGTH_FEET:
|
2016-07-31 17:20:56 +00:00
|
|
|
result = __meters_to_feet(meters)
|
2016-07-31 20:24:49 +00:00
|
|
|
elif unit_2 == LENGTH_KILOMETERS:
|
2016-07-31 17:20:56 +00:00
|
|
|
result = __meters_to_kilometers(meters)
|
|
|
|
|
|
|
|
return result
|
|
|
|
|
|
|
|
|
2016-07-31 20:24:49 +00:00
|
|
|
def __miles_to_meters(miles: float) -> float:
|
2016-07-31 17:20:56 +00:00
|
|
|
"""Convert miles to meters."""
|
|
|
|
return miles * 1609.344
|
|
|
|
|
|
|
|
|
2016-07-31 20:24:49 +00:00
|
|
|
def __feet_to_meters(feet: float) -> float:
|
2016-07-31 17:20:56 +00:00
|
|
|
"""Convert feet to meters."""
|
|
|
|
return feet * 0.3048
|
|
|
|
|
|
|
|
|
2016-07-31 20:24:49 +00:00
|
|
|
def __kilometers_to_meters(kilometers: float) -> float:
|
2016-07-31 17:20:56 +00:00
|
|
|
"""Convert kilometers to meters."""
|
|
|
|
return kilometers * 1000
|
|
|
|
|
|
|
|
|
2016-07-31 20:24:49 +00:00
|
|
|
def __meters_to_miles(meters: float) -> float:
|
2016-07-31 17:20:56 +00:00
|
|
|
"""Convert meters to miles."""
|
|
|
|
return meters * 0.000621371
|
|
|
|
|
|
|
|
|
2016-07-31 20:24:49 +00:00
|
|
|
def __meters_to_feet(meters: float) -> float:
|
2016-07-31 17:20:56 +00:00
|
|
|
"""Convert meters to feet."""
|
|
|
|
return meters * 3.28084
|
|
|
|
|
|
|
|
|
2016-07-31 20:24:49 +00:00
|
|
|
def __meters_to_kilometers(meters: float) -> float:
|
2016-07-31 17:20:56 +00:00
|
|
|
"""Convert meters to kilometers."""
|
|
|
|
return meters * 0.001
|