greatCircleDistance
lon1Deg— خط الطول النقطة الأولى بالدرجات. النطاق:[-180°, 180°].lat1Deg— خط العرض النقطة الأولى بالدرجات. النطاق:[-90°, 90°].lon2Deg— خط الطول النقطة الثانية بالدرجات. النطاق:[-180°, 180°].lat2Deg— خط العرض النقطة الثانية بالدرجات. النطاق:[-90°, 90°].
geoDistance
greatCircleDistance، لكنها تحسب المسافة على إهليلج WGS-84 بدلًا من الكرة. ويوفّر ذلك تقريبًا أدق لجيود الأرض.
الأداء مماثل لأداء greatCircleDistance (من دون أي تراجع في الأداء). ويُوصى باستخدام geoDistance لحساب المسافات على الأرض.
ملاحظة تقنية: بالنسبة للنقاط المتقاربة بما يكفي، نحسب المسافة باستخدام تقريب مستوٍ وفق المترية على المستوى المماس عند منتصف الإحداثيات.
lon1Deg— خط الطول النقطة الأولى بالدرجات. النطاق:[-180°, 180°].lat1Deg— خط العرض النقطة الأولى بالدرجات. النطاق:[-90°, 90°].lon2Deg— خط الطول النقطة الثانية بالدرجات. النطاق:[-180°, 180°].lat2Deg— خط العرض النقطة الثانية بالدرجات. النطاق:[-90°, 90°].
greatCircleAngle
lon1Deg— خط الطول للنقطة الأولى، بالدرجات.lat1Deg— خط العرض للنقطة الأولى، بالدرجات.lon2Deg— خط الطول للنقطة الثانية، بالدرجات.lat2Deg— خط العرض للنقطة الثانية، بالدرجات.
pointInEllipses
x, y— إحداثيات نقطة على المستوى.xᵢ, yᵢ— إحداثيات مركز القطع الناقص رقمi.aᵢ, bᵢ— محورا القطع الناقص رقمiبوحدات إحداثيي x وy.
2+4⋅n، حيث إن n هو عدد الأشكال البيضوية.
القيم المعادة
1 إذا كانت النقطة داخل شكل بيضوي واحد على الأقل؛ 0 إذا لم تكن كذلك.
مثال
pointInPolygon
(x, y)— إحداثيات نقطة على المستوى. نوع البيانات — Tuple — قيمة Tuple مكوّنة من رقمين.[(a, b), (c, d) ...]— رؤوس المضلع. نوع البيانات — Array. تُمثَّل كل قمة بزوج من الإحداثيات(a, b). يجب تحديد الرؤوس بترتيب مع عقارب الساعة أو عكس اتجاه عقارب الساعة. الحد الأدنى لعدد الرؤوس هو 3. يجب أن يكون المضلع ثابتًا.- تدعم الدالة أيضًا المضلع ذي الفتحات (الأجزاء المقتطعة). نوع البيانات — Polygon. مرِّر إما
Polygonبالكامل باعتباره المُدخل الثاني، أو مرِّر الحلقة الخارجية أولًا ثم كل فتحة كمدخل إضافي منفصل. - تدعم الدالة أيضًا MultiPolygon. نوع البيانات — MultiPolygon. مرِّر إما
MultiPolygonبالكامل باعتباره المُدخل الثاني، أو أدرج كل مضلع مكوّن باعتباره مُدخلًا مستقلًا.
1 إذا كانت النقطة داخل المضلع، و0 إذا لم تكن كذلك.
إذا كانت النقطة على حدود المضلع، فقد تُرجع الدالة 0 أو 1.
مثال
ملاحظة • يمكنك تعيينvalidate_polygons = 0لتجاوز التحقق من صحة الأشكال الهندسية. • تفترض الدالةpointInPolygonأن كل مضلع مُشكَّل بصورة صحيحة. إذا كان الإدخال متقاطعًا مع نفسه، أو كانت حلقاته مرتبة على نحو غير صحيح، أو كانت حوافه متداخلة، تصبح النتائج غير موثوقة—خصوصًا للنقاط الواقعة تمامًا على حافة أو رأس، أو داخل تقاطع ذاتي حيث يكون مفهوم “الداخل” مقابل “الخارج” غير معرّف. • عندما تكون وسيطة المضلع ثابتة وتُعبَّر النقطة باستخدام أعمدة المفتاح المفهرسة (على سبيل المثال،pointInPolygon((x, y), constant_polygon)على جدول تكون فيهx, yجزءًا منPRIMARY KEYأو مشمولة بفهرسminmax)، يمكن لـ ClickHouse استخدام كلٍّ من المفتاح الأساسي وفهارس تخطي البياناتminmaxلاستبعاد الحبيبات غير ذات الصلة.