Megosztás a következőn keresztül:


geo_azimuth()

Kiszámítja az óramutató járásával megegyező szöget radiánban az 1. ponttól a valódi északig és a Föld 1. pontjától a 2. pontig.

Syntax

geo_azimuth(, p1_longitude, p1_latitude, p2_longitudep2_latitude)

További információ a szintaxis konvenciókról.

Paraméterek

Név Típus Kötelező Leírás
p1_longitude real ✔️ A hosszúsági érték az első térinformatikai koordináta fokában. Az érvényes érték a [-180, +180] tartományban van.
p1_latitude real ✔️ A földrajzi szélesség értéke az első térinformatikai koordináta fokában. Az érvényes érték a [-90, +90] tartományban van.
p2_longitude real ✔️ A hosszúsági érték a második térinformatikai koordináta fokában. Az érvényes érték a [-180, +180] tartományban van.
p2_latitude real ✔️ A második térinformatikai koordináta fokában megadott szélességi érték. Az érvényes érték a [-90, +90] tartományban van.

Válaszok

Radiánban kifejezett szög a p1 ponttól a valódi északig és a [p1, p2] vonalig. A szög mérése az óramutató járásával megegyező irányban történik.

Megjegyzés

  • A térinformatikai koordinátákat a WGS-84 koordináta-referenciarendszer képviseli.
  • A Föld távolságának mérésére használt geodéziai datum egy gömb. A vonalszélek geodéziaiak a gömbön.
  • Azimuth 0 pont északra. Azimuth Pi/2 pont keletre. Azimuth Pi délre. Azimuth 3Pi/2 pont nyugatra.
  • Ha a koordináták érvénytelenek, a lekérdezés null eredményt ad.
  • Ha az 1. pont egyenlő a 2. ponttal, a lekérdezés null eredményt ad.
  • Ha az 1. és a 2. pont antipodális, a lekérdezés null eredményt ad.

Példák

Az alábbi példa radiánban számítja ki az azimutot.

print azimuth_in_radians = geo_azimuth(5, 10, 10, -40)

Kimenet

azimuth_in_radians
3.05459939796449

Az alábbi példa fokban számítja ki az azimutot.

let azimuth_in_radians = geo_azimuth(5, 10, 10, -40);
print azimuth_in_degrees = degrees(azimuth_in_radians);

Kimenet

azimuth_in_degrees
175.015653606568

Az alábbi példa egy teherautót tekint, amely telemetriát bocsát ki a tartózkodási helyéről, miközben utazik, és megkeresi az útirányát.

let get_direction = (azimuth:real)
{
    let pi = pi();
    iff(azimuth < pi/2,   "North-East",
    iff(azimuth < pi,     "South-East",
    iff(azimuth < 3*pi/2, "South-West",
                          "North-West")));
};
datatable(timestamp:datetime, lng:real, lat:real)
[
    datetime(2024-01-01T00:01:53.048506Z), -115.4036607693417, 36.40551631046261,
    datetime(2024-01-01T00:02:53.048506Z), -115.3256807623232, 36.34102142760111,
    datetime(2024-01-01T00:03:53.048506Z), -115.2732290602112, 36.28458914829917,
    datetime(2024-01-01T00:04:53.048506Z), -115.2513186233914, 36.27622394664352,
    datetime(2024-01-01T00:05:53.048506Z), -115.2352055633212, 36.27545547038515,
    datetime(2024-01-01T00:06:53.048506Z), -115.1894341934856, 36.28266934431671,
    datetime(2024-01-01T00:07:53.048506Z), -115.1054318118468, 36.28957085435267,
    datetime(2024-01-01T00:08:53.048506Z), -115.0648614339413, 36.28110743285072,
    datetime(2024-01-01T00:09:53.048506Z), -114.9858032867736, 36.29780696509714,
    datetime(2024-01-01T00:10:53.048506Z), -114.9016966527561, 36.36556196813566,
]
| sort by timestamp asc 
| extend prev_lng = prev(lng), prev_lat = prev(lat)
| where isnotnull(prev_lng) and isnotnull(prev_lat)
| extend direction = get_direction(geo_azimuth(prev_lng, prev_lat, lng, lat))
| project direction, lng, lat
| render scatterchart with (kind = map)

Kimenet

Azimuth két egymást követő hely között.

Az alábbi példa azért ad true vissza, mert az első pont megegyezik a második ponttal.

print is_null = isnull(geo_azimuth(5, 10, 5, 10))

Kimenet

is_null
true