2018-05-10 16:51:45 +00:00
# Функции для работы с географическими координатами
## greatCircleDistance
Вычисляет расстояние между двумя точками на поверхности Земли по [формуле большого круга ](https://en.wikipedia.org/wiki/Great-circle_distance ).
```
greatCircleDistance(lon1Deg, lat1Deg, lon2Deg, lat2Deg)
```
**Входные параметры**
2018-11-01 13:28:45 +00:00
- `lon1Deg` — долгота первой точки в градусах. Диапазон — `[-180°, 180°]` .
- `lat1Deg` — широта первой точки в градусах. Диапазон — `[-90°, 90°]` .
- `lon2Deg` — долгота второй точки в градусах. Диапазон — `[-180°, 180°]` .
- `lat2Deg` — широта второй точки в градусах. Диапазон — `[-90°, 90°]` .
2018-05-10 16:51:45 +00:00
Положительные значения соответствуют северной широте и восточной долготе, отрицательные — южной широте и западной долготе.
**Возвращаемое значение**
Расстояние между двумя точками на поверхности Земли в метрах.
Генерирует исключение, когда значения входных параметров выходят за границы диапазонов.
**Пример**
2018-10-16 10:47:17 +00:00
``` sql
2018-05-10 16:51:45 +00:00
SELECT greatCircleDistance(55.755831, 37.617673, -55.755831, -37.617673)
```
2018-10-16 10:47:17 +00:00
```
2018-05-10 16:51:45 +00:00
┌─greatCircleDistance(55.755831, 37.617673, -55.755831, -37.617673)─┐
│ 14132374.194975413 │
└───────────────────────────────────────────────────────────────────┘
```
## pointInEllipses
Проверяет, принадлежит ли точка хотя бы одному из эллипсов.
```
pointInEllipses(x, y, x₀, y₀, a₀, b₀,...,xₙ, yₙ, aₙ, bₙ)
```
**Входные параметры**
2018-11-01 13:28:45 +00:00
- `x, y` — координаты точки на плоскости.
2018-05-10 16:51:45 +00:00
- `xᵢ, yᵢ` — координаты центра `i` -г о эллипса.
- `aᵢ, bᵢ` — полуоси `i` -г о эллипса в метрах.
Входных параметров должно быть `2+4⋅n` , где `n` — количество эллипсов.
**Возвращаемые значения**
`1` , если точка внутри хотя бы одного из эллипсов, `0` , если нет.
2018-08-13 14:51:06 +00:00
**Пример**
2018-05-10 16:51:45 +00:00
2018-10-16 10:47:17 +00:00
``` sql
2018-05-10 16:51:45 +00:00
SELECT pointInEllipses(55.755831, 37.617673, 55.755831, 37.617673, 1.0, 2.0)
```
2018-10-16 10:47:17 +00:00
```
2018-05-10 16:51:45 +00:00
┌─pointInEllipses(55.755831, 37.617673, 55.755831, 37.617673, 1., 2.)─┐
│ 1 │
└─────────────────────────────────────────────────────────────────────┘
```
2018-08-13 14:51:06 +00:00
## pointInPolygon
2018-08-14 14:52:38 +00:00
Проверяет, принадлежит ли точка многоугольнику на плоскости.
2018-08-13 14:51:06 +00:00
```
2018-08-14 14:52:38 +00:00
pointInPolygon((x, y), [(a, b), (c, d) ...], ...)
2018-08-13 14:51:06 +00:00
```
**Входные значения**
2018-08-14 14:52:38 +00:00
- `(x, y)` — координаты точки на плоскости. Тип данных — [Tuple ](../../data_types/tuple.md#data_type-tuple ) - кортеж из двух чисел.
- `[(a, b), (c, d) ...]` — вершины многоугольника. Тип данных — [Array ](../../data_types/array.md#data_type-array ). Каждая вершина представлена парой координат `(a, b)` . Вершины следует указывать в порядке обхода по или против часовой стрелки. Минимальное количество вершин — 3. Многоугольник должен быть константным.
- функция поддерживает также многоугольники с дырками (вырезанными кусками). Для этого случая, добавьте многоугольники, описывающие вырезанные куски, дополнительными аргументами функции. Функция не поддерживает неодносвязные многоугольники.
2018-08-13 14:51:06 +00:00
**Возвращаемые значения**
`1` , если точка внутри многоугольника, `0` , если нет.
2018-08-14 14:52:38 +00:00
Если точка находится на границе многоугольника, функция может возвращать как 0, так и 1.
2018-08-13 14:51:06 +00:00
**Пример**
2018-10-16 10:47:17 +00:00
``` sql
2018-08-13 14:51:06 +00:00
SELECT pointInPolygon((3., 3.), [(6, 0), (8, 4), (5, 8), (0, 2)]) AS res
```
```
┌─res─┐
│ 1 │
└─────┘
```
2018-10-16 10:47:17 +00:00
[Оригинальная статья ](https://clickhouse.yandex/docs/ru/query_language/functions/geo/ ) <!--hide-->