mirror of
https://github.com/ClickHouse/ClickHouse.git
synced 2024-10-16 05:20:51 +00:00
0a4a5b36cc
* Additional .gitignore entries * Merge a bunch of small articles about system tables into single one * Merge a bunch of small articles about formats into single one * Adapt table with formats to English docs too * Add SPb meetup link to main page * Move Utilities out of top level of docs (the location is probably not yet final) + translate couple articles * Merge MacOS.md into build_osx.md * Move Data types higher in ToC * Publish changelog on website alongside documentation * Few fixes for en/table_engines/file.md * Use smaller header sizes in changelogs * Group up table engines inside ToC * Move table engines out of top level too * Specificy in ToC that query language is SQL based. Thats a bit excessive, but catches eye. * Move stuff that is part of query language into respective folder * Move table functions lower in ToC * Lost redirects.txt update * Do not rely on comments in yaml + fix few ru titles * Extract major parts of queries.md into separate articles * queries.md has been supposed to be removed * Fix weird translation * Fix a bunch of links * There is only table of contents left * "Query language" is actually part of SQL abbreviation * Change filename in README.md too * fix mistype
71 lines
3.1 KiB
Markdown
71 lines
3.1 KiB
Markdown
# Функции для работы с географическими координатами
|
||
|
||
## greatCircleDistance
|
||
|
||
Вычисляет расстояние между двумя точками на поверхности Земли по [формуле большого круга](https://en.wikipedia.org/wiki/Great-circle_distance).
|
||
|
||
```
|
||
greatCircleDistance(lon1Deg, lat1Deg, lon2Deg, lat2Deg)
|
||
```
|
||
|
||
**Входные параметры**
|
||
|
||
- `lon1Deg` — широта первой точки в градусах. Диапазон — `[-90°, 90°]`.
|
||
- `lat1Deg` — долгота первой точки в градусах. Диапазон — `[-180°, 180°]`.
|
||
- `lon2Deg` — широта второй точки в градусах. Диапазон — `[-90°, 90°]`.
|
||
- `lat2Deg` — долгота второй точки в градусах. Диапазон — `[-180°, 180°]`.
|
||
|
||
Положительные значения соответствуют северной широте и восточной долготе, отрицательные — южной широте и западной долготе.
|
||
|
||
**Возвращаемое значение**
|
||
|
||
Расстояние между двумя точками на поверхности Земли в метрах.
|
||
|
||
Генерирует исключение, когда значения входных параметров выходят за границы диапазонов.
|
||
|
||
**Пример**
|
||
|
||
```sql
|
||
SELECT greatCircleDistance(55.755831, 37.617673, -55.755831, -37.617673)
|
||
```
|
||
|
||
```text
|
||
┌─greatCircleDistance(55.755831, 37.617673, -55.755831, -37.617673)─┐
|
||
│ 14132374.194975413 │
|
||
└───────────────────────────────────────────────────────────────────┘
|
||
```
|
||
|
||
## pointInEllipses
|
||
|
||
Проверяет, принадлежит ли точка хотя бы одному из эллипсов.
|
||
|
||
```
|
||
pointInEllipses(x, y, x₀, y₀, a₀, b₀,...,xₙ, yₙ, aₙ, bₙ)
|
||
```
|
||
|
||
**Входные параметры**
|
||
|
||
- `x` — широта точки.
|
||
- `y` — долгота точки.
|
||
- `xᵢ, yᵢ` — координаты центра `i`-го эллипса.
|
||
- `aᵢ, bᵢ` — полуоси `i`-го эллипса в метрах.
|
||
|
||
Входных параметров должно быть `2+4⋅n`, где `n` — количество эллипсов.
|
||
|
||
**Возвращаемые значения**
|
||
|
||
`1`, если точка внутри хотя бы одного из эллипсов, `0`, если нет.
|
||
|
||
|
||
**Примеры**
|
||
|
||
```sql
|
||
SELECT pointInEllipses(55.755831, 37.617673, 55.755831, 37.617673, 1.0, 2.0)
|
||
```
|
||
|
||
```text
|
||
┌─pointInEllipses(55.755831, 37.617673, 55.755831, 37.617673, 1., 2.)─┐
|
||
│ 1 │
|
||
└─────────────────────────────────────────────────────────────────────┘
|
||
```
|