greatCircleDistance
lon1Deg— 1 点目の経度 (度単位) 。範囲:[-180°, 180°]。lat1Deg— 1 点目の緯度 (度単位) 。範囲:[-90°, 90°]。lon2Deg— 2 点目の経度 (度単位) 。範囲:[-180°, 180°]。lat2Deg— 2 点目の緯度 (度単位) 。範囲:[-90°, 90°]。
geoDistance
greatCircleDistance と似ていますが、球面ではなく WGS-84 楕円体上での距離を計算します。これは地球のジオイドをより正確に近似するものです。
パフォーマンスは greatCircleDistance と同等で、性能上のデメリットはありません。地球上の距離を計算する場合は、geoDistance の使用を推奨します。
技術的な注記: 十分に近い点どうしについては、座標の中点における接平面上の計量を用いた平面近似によって距離を計算します。
lon1Deg— 1 番目の地点の経度 (度) 。範囲:[-180°, 180°]。lat1Deg— 1 番目の地点の緯度 (度) 。範囲:[-90°, 90°]。lon2Deg— 2 番目の地点の経度 (度) 。範囲:[-180°, 180°]。lat2Deg— 2 番目の地点の緯度 (度) 。範囲:[-90°, 90°]。
greatCircleAngle
lon1Deg— 1 番目の点の経度 (度) 。lat1Deg— 1 番目の点の緯度 (度) 。lon2Deg— 2 番目の点の経度 (度) 。lat2Deg— 2 番目の点の緯度 (度) 。
pointInEllipses
x, y— 平面上の点の座標。xᵢ, yᵢ—i番目の楕円の中心の座標。aᵢ, bᵢ—i番目の楕円の軸を x, y 座標の単位で表したもの。
2+4⋅n でなければなりません。ここで、n は楕円の数です。
戻り値
点が少なくとも 1 つの楕円の内側にある場合は 1、そうでない場合は 0。
例
pointInPolygon
(x, y)— 平面上の点の座標。データ型 — Tuple — 2 つの数値からなるタプル。[(a, b), (c, d) ...]— Polygon の頂点。データ型 — Array。各頂点は座標の組(a, b)で表されます。頂点は時計回りまたは反時計回りの順序で指定する必要があります。頂点の最小数は 3 です。Polygon は定数である必要があります。- この関数は穴 (切り抜き部分) のある Polygon もサポートします。データ型 — Polygon。
Polygon全体を第 2 引数として渡すか、外側のリングを最初に渡し、その後に各穴を個別の追加引数として渡します。 - この関数は MultiPolygon もサポートします。データ型 — MultiPolygon。
MultiPolygon全体を第 2 引数として渡すか、各構成 Polygon をそれぞれ個別の引数として列挙します。
1、そうでない場合は 0 を返します。
点が Polygon の境界上にある場合、この関数は 0 または 1 のいずれかを返すことがあります。
例
注 • ジオメトリの検証をスキップするには、validate_polygons = 0を設定できます。 •pointInPolygonは、すべてのポリゴンが正しい形式であることを前提としています。入力が自己交差している、リングの順序が誤っている、または辺同士が重なっている場合、結果は信頼できなくなります。特に、点が辺上や頂点上にちょうどある場合や、“内側” と “外側” の区別が定義できない自己交差部分の内部にある場合は、その傾向が顕著です。 • ポリゴン引数が定数で、点が索引付きのキーカラムで表されている場合 (たとえば、x, yがPRIMARY KEYの一部である、またはminmax索引でカバーされているテーブル上のpointInPolygon((x, y), constant_polygon)など) 、ClickHouse は主キーとminmaxのデータスキップ索引の両方を使って、無関係なグラニュールを刈り込むことができます。