geo_azimuth()
Vypočítá úhel po směru hodinových ručiček v radiánech mezi přímkou od bodu 1 k pravému severu a přímkou od bodu 1 do bodu2 na Zemi.
Syntax
geo_azimuth(
,
p1_longitude,
p1_latitude,
p2_longitudep2_latitude)
Přečtěte si další informace o konvencích syntaxe.
Parametry
Název | Typ | Vyžadováno | Popis |
---|---|---|---|
p1_longitude | real |
✔️ | Hodnota zeměpisné délky ve stupních první geoprostorové souřadnice. Platná hodnota je v rozsahu [-180, +180]. |
p1_latitude | real |
✔️ | Hodnota zeměpisné šířky ve stupních první geoprostorové souřadnice. Platná hodnota je v rozsahu [-90, +90]. |
p2_longitude | real |
✔️ | Hodnota zeměpisné délky ve stupních druhé geoprostorové souřadnice. Platná hodnota je v rozsahu [-180, +180]. |
p2_latitude | real |
✔️ | Hodnota zeměpisné šířky ve stupních druhé geoprostorové souřadnice. Platná hodnota je v rozsahu [-90, +90]. |
Návraty
Úhel v radiánech mezi přímkou od bodu p1 k pravému severu a přímkou [p1, p2]. Úhel se měří po směru hodinových ručiček.
Poznámka
- Geoprostorové souřadnice jsou interpretovány jako reprezentované systémem souřadnic WGS-84 .
- Geodetické datum používané k měření vzdálenosti na Zemi je koule. Hrany čar jsou geodézie na kouli.
- Azimut 0 bodů na sever. Azimuth Pí/2 body na východ. Azimuth Pí míří na jih. Azimuth 3Pi/2 body západ.
- Pokud jsou souřadnice neplatné, dotaz vygeneruje výsledek s hodnotou null.
- Pokud je bod 1 roven bodu 2, dotaz vytvoří výsledek s hodnotou null.
- Pokud jsou body point1 a point2 antipodal, dotaz vygeneruje výsledek null.
Příklady
Následující příklad vypočítá azimut v radiánech.
print azimuth_in_radians = geo_azimuth(5, 10, 10, -40)
Výstup
azimuth_in_radians |
---|
3.05459939796449 |
Následující příklad vypočítá azimut ve stupních.
let azimuth_in_radians = geo_azimuth(5, 10, 10, -40);
print azimuth_in_degrees = degrees(azimuth_in_radians);
Výstup
azimuth_in_degrees |
---|
175.015653606568 |
V následujícím příkladu se uvažuje o nákladním vozu, který během své cesty vysílá telemetrii o své poloze a hledá jeho směr jízdy.
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)
Výstup
Následující příklad vrátí, true
protože první bod se rovná druhému bodu.
print is_null = isnull(geo_azimuth(5, 10, 5, 10))
Výstup
is_null |
---|
true |
Váš názor
https://aka.ms/ContentUserFeedback.
Připravujeme: V průběhu roku 2024 budeme postupně vyřazovat problémy z GitHub coby mechanismus zpětné vazby pro obsah a nahrazovat ho novým systémem zpětné vazby. Další informace naleznete v tématu:Odeslat a zobrazit názory pro