greatCircleDistance
lon1Deg— Longitud del primer punto en grados. Rango:[-180°, 180°].lat1Deg— Latitud del primer punto en grados. Rango:[-90°, 90°].lon2Deg— Longitud del segundo punto en grados. Rango:[-180°, 180°].lat2Deg— Latitud del segundo punto en grados. Rango:[-90°, 90°].
geoDistance
greatCircleDistance, pero calcula la distancia sobre el elipsoide WGS-84 en lugar de hacerlo sobre una esfera. Esta es una aproximación más precisa del geoide terrestre.
El rendimiento es el mismo que el de greatCircleDistance (sin pérdida de rendimiento). Se recomienda usar geoDistance para calcular distancias sobre la Tierra.
Nota técnica: para puntos suficientemente cercanos, calculamos la distancia mediante una aproximación plana con la métrica en el plano tangente en el punto medio de las coordenadas.
lon1Deg— Longitud del primer punto en grados. Rango:[-180°, 180°].lat1Deg— Latitud del primer punto en grados. Rango:[-90°, 90°].lon2Deg— Longitud del segundo punto en grados. Rango:[-180°, 180°].lat2Deg— Latitud del segundo punto en grados. Rango:[-90°, 90°].
greatCircleAngle
lon1Deg— Longitud del primer punto, en grados.lat1Deg— Latitud del primer punto, en grados.lon2Deg— Longitud del segundo punto, en grados.lat2Deg— Latitud del segundo punto, en grados.
pointInEllipses
x, y— Coordenadas de un punto en el plano.xᵢ, yᵢ— Coordenadas del centro de la elipsei.aᵢ, bᵢ— Ejes de la elipseien unidades de las coordenadasxey.
2+4⋅n, donde n es el número de elipses.
Valores devueltos
1 si el punto está dentro de al menos una de las elipses; 0 si no lo está.
Ejemplo
pointInPolygon
(x, y)— Coordenadas de un punto en el plano. Tipo de dato — Tuple — Una tupla de dos números.[(a, b), (c, d) ...]— Vértices del polígono. Tipo de dato — Array. Cada vértice se representa mediante un par de coordenadas(a, b). Los vértices deben especificarse en sentido horario o antihorario. El número mínimo de vértices es 3. El polígono debe ser constante.- La función admite polígonos con huecos (secciones recortadas). Tipo de dato — Polygon. Pase el
Polygoncompleto como segundo argumento, o bien pase primero el anillo exterior y luego cada hueco como argumento adicional independiente. - La función también admite multipolígonos. Tipo de dato — MultiPolygon. Pase el
MultiPolygoncompleto como segundo argumento, o indique cada polígono componente como un argumento independiente.
1 si el punto está dentro del polígono, 0 si no lo está.
Si el punto está en el borde del polígono, la función puede devolver 0 o 1.
Ejemplo
Nota • Puede establecervalidate_polygons = 0para omitir la validación geométrica. •pointInPolygonasume que cada polígono está bien formado. Si la entrada se interseca a sí misma, tiene anillos en un orden incorrecto o bordes superpuestos, los resultados dejan de ser fiables, especialmente para puntos que están exactamente sobre un borde, un vértice o dentro de una autointersección, donde la noción de “dentro” frente a “fuera” no está definida. • Cuando el argumento del polígono es constante y el punto se expresa mediante columnas de clave indexadas (por ejemplo,pointInPolygon((x, y), constant_polygon)en una tabla dondex, yforman parte de laPRIMARY KEYo están incluidas en un índiceminmax), ClickHouse puede usar tanto la clave primaria como los índices de omisión de datosminmaxpara descartar gránulos irrelevantes.